Mass robocalls affect millions of people on a daily basis. A robocall is a phone call that employs computerized or electronic autodialers to deliver a pre-recorded message as if from a robot. The call can be for political and telemarketing purposes or can be or public service and/or emergency announcements. Telemarketing calls are generally undesired and can be benign (e.g., in soliciting a business service or product) or even malicious (e.g., theft phishing and the like). Organizations such as schools, medical service providers, and businesses may employ computerized or electronic autodialers to provide notifications, e.g., of emergencies, statuses, and appointments. There is interest in being able to discern calls that will provide information of interest and reject calls that are undesired.
To address undesired robocall issues, cellphone manufactures, and telephony or VOIP service providers may provide phone blocklists and caller identification services. More sophisticated robocall telemarketers have employed identification spoofing technology as well as different calling numbers to avoid such detection.
There is a benefit to improving the screening of undesired telephone calls.
An exemplary system and method are disclosed that is configured to evaluate by interrogation and analysis whether an incoming call from an unknown caller is a robocall, e.g., a mass-market, spoofed, targeted, and/or evasive robocall. The exemplary system is configured with a voice interaction model and analytical operation that can first pick up each incoming phone call on behalf of the recipient callee. The exemplary system then simulates natural conversation with the initiating caller by asking/interrogating the caller with a set of pre-stored questions that naturally occur in human conversations. The exemplary system employs the caller's responses to determine whether the call is a robocall or a natural person by assessing via pre-defined analysis for the context and/or expected natural human response. The pre-stored questions are designed to be easy and natural for humans to respond to but difficult for an automated robocaller or telemarketer with a pre-defined script. In some embodiments, the analysis is performed on natural language processing (NLP)-based machine learning operations to evaluate the context or appropriateness of the caller's response.
In some embodiments, the exemplary system is characterized as a smart virtual assistant (SmartVA) system (referred to herein as “RobocallGuardPlus”).
Based on the evaluation, the exemplary system can (i) forward a call to the recipient callee it has determined that the caller is a person or based on a user-defined preference or (ii) reject the call, or forward it to voicemail, it has determined to be a robocaller or a non-desired call based on the user-defined preference. A study was conducted that evaluated an example implementation of the exemplary system and concluded that the example implementation (e.g., of a Smart Virtual Assistant system) fulfilled the intended benefit while preserving the user experience of an incoming phone call. The study also performed security analyses and demonstrated that the Smart Virtual Assistant system could stop existing and fairly sophisticated robocaller.
In as aspect, a system is disclosed comprising a processor; and a memory having instructions stored thereon, wherein execution of the instructions by the processor causes the processor to: initiate, a telephony or VOIP session with a caller telephony or VOIP device; generate a first audio output over the telephony or VOIP session associated with a first caller detector analysis; following the generating of the first audio output and in response to a first audio input being received, generate a first transcription or natural language processing data of the first audio input (e.g., using a speech recognition operation or natural language processing operation); determine via the first caller detector analysis whether the first audio input is an appropriate response for a first context evaluated by the first caller detector analysis; generate a second audio output over the telephony or VOIP session associated with a second caller detector analysis; following the generating of the second audio output and in response to a second audio input being received, generate a second transcription or natural language processing data of the first audio input (e.g., using a speech recognition operation or natural language processing operation); determine via the second caller detector analysis whether the second audio input is an appropriate response for a second context evaluated by the second caller detector analysis; determine a score for the telephony or VOIP device; and initiate a second telephony or VOIP session with a user's telephony or VOIP device based on the determination, or direct the telephony or VOIP session with the caller telephony or VOIP device to end call or to a voicemail.
In some embodiments, the instructions further cause the processor to generate a notification of the telephony or VOIP session with the caller telephony or VOIP device.
In some embodiments, the instructions further cause the processor to generate a third audio output over the telephony or VOIP session associated with a third caller detector analysis; following the generating of the third audio output and in response to a third audio input being received, generate a third transcription or natural language processing data of the third audio input (e.g., using a speech recognition operation or natural language processing operation); and determine, via the third caller detector analysis, whether the third audio input is an appropriate response for a third context evaluated by the third caller detector analysis.
In some embodiments, any one of the first, second, or third caller detector analyses (or the first or second caller detector analysis) includes a context analysis employing a semantic clustering-based classifier.
In some embodiments, any one of the first, second, or third caller detector analyses (or the first or second caller detector analysis) includes a relevance analysis employing a semantic binary classifier trained using a (question, response) pair.
In some embodiments, any one of the first, second, or third caller detector analyses (or the first or second caller detector analysis) includes an elaboration analysis employing a keyword spotting algorithm.
In some embodiments, any one of the first, second, or third caller detector analyses (or the first or second caller detector analysis) includes an elaboration detector employing a current word count of a current response compared to a determined word count of a prior response as one of the first, second, or third transcription or natural language processing data.
In some embodiments, anyone of the first, second, or third caller detector analyses (or the first or second caller detector analysis) include an amplitude detector employing an average amplitude evaluation of any one of the first, second, or third audio inputs.
In some embodiments, any one of the first, second, or third caller detector analyses (or the first or second caller detector analysis) includes a repetition detector employing one or more features selected from the group consisting of a cosine similarity determining, a word overlap determination, and named entity overlap determination.
In some embodiments, any one of the first, second, or third caller detector analyses (or the first or second caller detector analysis) includes an intent detector employing a comparison of the first, second, or third transcription or natural language processing data to a pre-defined list of pre-defined affirmative response or a pre-defined list of negative responses.
In some embodiments, the system is configured as a cloud infrastructure.
In some embodiments, the system is configured as a smart phone.
In some embodiments, the system is configured as an infrastructure of a cell phone service provider.
In some embodiments, any one of the first, second, and third audio output are selected from a library of stored audio outputs, wherein each of the stored audio outputs has a corresponding caller detector analysis.
In some embodiments, the first audio output, the second audio output, and the third audio output are randomly selected.
In some embodiments, the first transcription or natural language processing data is generated via a speech recognition or natural language processing operation.
In some embodiments, the semantic binary classifier or the semantic clustering-based classifier employs a neural network model.
In another aspect, a computer-executed method is disclosed comprising picking up a call and greeting a caller of the call; waiting for a first response and then asking a first randomly selected question from a list of available questions; waiting for a second response and then asking a second randomly selected question from a list of available questions; determine based on at least the first response and/or second response whether the call is a person or a robot caller; and asking a third question based on the determination.
In another aspect, a method is disclosed comprising steps to operate the systems of any one of the above-discussed claims.
In another aspect, a computer-readable medium is disclosed, having instructions stored thereon, wherein execution of the instructions operates any one of the above-discussed systems.
The skilled person in the art will understand that the drawings described below are for illustration purposes only.
Some references, which may include various patents, patent applications, and publications, are cited in a reference list and discussed in the disclosure provided herein. The citation and/or discussion of such references is provided merely to clarify the description of the disclosed technology and is not an admission that any such reference is “prior art” to any aspects of the disclosed technology described herein. In terms of notation, “[n]” corresponds to the nth reference in the reference list. For example, Ref. [1] refers to the 1st reference in the list. All references cited and discussed in this specification are incorporated herein by reference in their entirety and to the same extent as if each reference was individually incorporated by reference. The exemplary system and method (also referred to herein as
“RobocallGuardPlus”) is configured to receive incoming calls on behalf of a user without user interruption and intervention. If the incoming call is from a safelisted caller, it can pick up the call and can immediately notify the user by ringing the phone. The operation may be tailored by the user per user's preferences. A safelist is define-able by the user and can include the user's contact list and other allowed caller IDs (such as a global safelist which consists of public schools, hospitals etc.). On the other hand, if the call is from a blocklisted caller, the exemplary system and method can block the call, e.g., without even letting the phone ring and/or forward the call to the voicemail. And, if the caller, per the caller identification, belongs to neither the safelist nor the blocklist, the exemplary system and method can pick up the call without ringing the phone (and disturbing the recipient callee) and initiate a conversation with the recipient caller (also referred to herein as the “user”) to decide whether this call should be brought to the attention of the recipient caller.
The exemplary system and method can use a combination of analysis operations of responses of the caller to estimate whether the caller is a robocaller or natural person as well as their purpose, in some embodiments. In some embodiments, upon picking up the call, it can greet the caller and let the caller know that he/she is talking to a virtual assistant. During the conversation, the exemplary system and method can then execute a list of pre-defined questions or randomly choose a question from a predefined pool of questions to present to the caller. The questions are those that are preferably naturally occurring in human conversations. The exemplary system and method can then determine if the response provided by the caller is appropriate for the question asked.
It is difficult for a robocaller without natural language comprehending capabilities to provide an appropriate response but easy and natural for a human to answer these questions.
In some embodiments, the exemplary system can dynamically vary the number of questions asked to the caller before making this decision depending on the responses provided by the caller and the confidence score for the labeling generated from the analysis. For example, if the exemplary system and method are highly confident that the caller is a human or a robocaller after asking two questions, it can skip asking additional questions and notifying the callee/user of the call. The exemplary system and method can ask additional questions if it is not able to make a decision at any current given time. The number of questions may be pre-defined, e.g., the number may be set as a balance between usability and security, for example, five.
Based on the above-operation, the exemplary system and method can label a caller as a human or robocaller. If the caller is deemed to be a human, the call is passed to the callee along with the transcript of the purpose of the call. On the other hand, if the caller is determined to be a robocaller, the exemplary system and method can block the call and notifies the user of the blocked call through a notification. The exemplary system and method can also store the transcript of the call for the user's convenience. Because the exemplary system and method do not solely depend on the availability of a blacklist of known robocallers, it can be effective even in the presence of caller ID spoofing.
In the example shown in
Referring to
Phone/VOIP service provider 108 can be a fixed line operator (e.g., public switched telephone network (PSTN) operator), mobile-device network operator, broadband communication operators, specific-application communication operator (e.g., VOIP service provider), and network 106 can be the appropriate communication channels for that service provider. The phone or VOIP device 102 may be a PSTN telephone that operates with an external device (see
In the example in
In the example shown in
The non-person caller detector (e.g., 110, 110′ and 110″), e.g., shown implemented as 110a, is configured to perform (i) the interrogation of the unidentified caller with pre-stored natural language questions and (ii) analysis of the response from the unidentified caller. In the example shown in
The controller 128, in the example of
Audio recorder module 130 is configured to record an audio snippet or audio file in the telephony or VOIP session. The recordation operation can be directed by the controller 128. Because the telephony or VOIP session only includes a single caller on a caller device (e.g., 104) as the phone/VOIP device (e.g., 102) is being handled by the non-person caller detector 110, the audio recorder module 130 would only record the voice or audio message of only the caller. The audio recorder module 130 is configured, in some embodiments, to record an audio while the acoustic power of the audio is above a certain threshold or until a maximum record time is reached, e.g., 20 seconds. The audio recorder module 130 then provides the recorded audio file or audio snippet/data to the audio transcription service module 132.
Transcriber. Audio transcription service module 132 is configured to receive the recorded audio file or audio snippet/data and generate, via a natural language processing (NPL) operation or other speech recognition operation, a textual data of the recording. Examples of NPL operators include TensorFlow and PyTorch, AllenNLP, HuggingFace, Spark NLP, SpaCy NLP, among others.
This component is configured to transcribe the responses provided by the caller. The transcriptions of the responses are then used by the other modules to determine if the responses are appropriate or not. Moreover, the transcript or summary of the conversation between the caller and non-person caller detector (e.g., 110) can be outputted, e.g., via display 105, to the user to provide additional context for an incoming call. The recipient callee/user can use the information to assess the content of the call without picking up and having to engage with the caller.
For calls that are not passed to the user and/or hung up/rejected by the non-person caller detector (e.g., 110), the non-person caller application can store the call context that can be later reviewed, e.g., by the user. The non-person caller detector (e.g., 110) does not need to engage in a conversation with callers that are safelisted and can pass the calls directly to the user. Therefore, transcripts may not be provided for such calls. All other callers can be greeted by a non-person caller detector (e.g., 110), and hence a transcript can be generated and made available to the user to understand the content of the calls.
In some embodiments, the non-person caller detector (e.g., 110) can interrogate safelisted callers based on a user-defined preference. In some embodiments, the system can notify the user of an incoming call from a safelisted number and present the user with an option to select the non-person caller application to interrogate the caller for information to present to the user in the non-person caller application.
Any number of transcription or speech recognition operations may be employed. There are many software libraries and APIs available for transcription, e.g., the Google Cloud Speech API [51], Kaldi [52], and Mozilla deep speech [53]. The audio transcription service module 132 can send the audio recording of the caller's response to an external service (e.g., Google Cloud) and a corresponding transcript is returned.
Audio synthesizer module 133 is configured to generate, e.g., using a media player or audio generator, an audio output in the telephony or VOIP session of an interaction file selected from the caller interaction library 138. The audio output may be outputted to a driver circuit or electronic circuit to drive the speaker (e.g., 107). The controller 128 may select or indicate an interaction file in the caller interaction library 138 to be processed and may direct the audio synthesizer module 133 to retrieve the interaction file to generate the audio output in the telephony or VOIP session. The audio output may be generated from static pre-stored voice/audio files. In some embodiments, the audio output is stored as text which can be employed by a voice synthesizer to dynamically generate the audio output.
The analysis modules (e.g., 134a-134h) are configured, in some embodiments, to operate with the controller 128 and audio transcription service module 132 to analyze the textual or NPL data from a recorded response of the caller. The controller 128 can direct the audio synthesizer module 133 to play an interaction file in the telephony or VOIP session; the indication or selection command for the selected interaction file can also be employed to select or invoke the appropriate analysis modules (e.g., 134a-134h).
Table 1 provides a summary of example analysis modules (e.g., 134a-134h) that may be employed by the non-person caller detector (e.g., 110).
As discussed above, the non-person caller detector (e.g., 110, 110′, and 110″) can intercept all incoming calls, so the phone or VOIP session does not immediately ring and notify the callee of an incoming call. The non-person caller detector (e.g., 110), in some embodiments, can perform a preliminary decision via a preliminary amendment 202, e.g., based on the caller ID of the incoming call. There can be, e.g., three scenarios: (i) the caller ID belongs to a predefined safelist (ii) the caller ID belongs to a predefined blocklist, or (iii) the caller ID does not belong to these predefined lists and thus is labeled as an unknown caller. In some embodiments, the preliminary amendment 202 may include a user-definable action (e.g., alert user of incoming safelist call and select action). If the caller ID is safelisted, the exemplary system and method can immediately pass the call to the callee. The non-person caller detector (e.g., 110) can (i) block calls from blocklisted caller IDs or forward the call to voicemail and (ii) does not ring the phone. The non-person caller detector (e.g., 110) can perform additional interrogative analysis 204 (shown as “Interrogative Assessment” 204) for the calls from unknown callers to understand the nature of the calls. In some embodiments, the non-person caller detector (e.g., 110) can be invoked by the user, e.g., a user selecting for the non-person caller detector to pick up the incoming call from on a safelisted number.
To perform the interrogative assessment, and as shown in
The non-person caller detector (e.g., 110) may then can ask (210) another question or make a decision. Based on the provided score or label, the non-person caller detector (e.g., 110) can make an estimation or detection of whether the caller is a human or robo-caller. The number of questions the non-person caller detector (e.g., 110) may ask the caller before making this decision can be static or it can be dynamically established depending on the responses provided by the caller. In some embodiments, the number of questions or the decision to ask additional question may employ a determined confidence score of the classifier label generated by the non-person caller detector (e.g., 110). For example, if the non-person caller detector (e.g., 110) determines a high confidence value indicating, based on the caller's response, that the caller is a human or a robocaller after asking two questions, it can skip asking a third question and direct the caller to the user according to its pre-defined workflow operation.
The non-person caller detector (e.g., 110) can be configured to ask the next question if it is not able to make a decision at any current given time. The minimum and the maximum number of questions asked by the non-person caller detector (e.g., 110) can be set by the user. In some embodiments, the user of minimum and maximum numbers of questions can have a default of two and five, respectively, which is typical for most phone calls. The default can be varied, e.g., by a system administrator for the non-person caller detector (e.g., 110).
In
In some embodiments, the non-person caller detector (e.g., 110) can be configured to at least ask for the caller to provide a context or purpose of the call before completing the conversation with the caller if it has not already been asked. This question ensures that the non-person caller detector (e.g., 110) can provide a context notification/output to the recipient callee/user about the nature of the incoming call.
Referring back to
A study was conducted that developed an example non-person caller detector (also referred to as a smart virtual assistant or “SmartVA”).
The study implemented several transcription services, including Kaldi, Mozilla Deep Speech, and Google Cloud Speech API, and selected the Google Cloud Speech API for the evaluation system.
During the conversation with the caller, the system used in the study picked questions to ask. These questions are asked to determine if the caller can provide relevant answers to natural questions occurring in a typical phone conversation between two humans. The responses to these questions were used to determine if the caller is a robocaller or a human. The study designed questions that are easy and natural for a human caller to respond to during a phone call. However, the responses to these questions are specific enough that they do not typically appear in robocall messages. The study considered the balance between usability and security. Table 2 shows example criteria for the questions.
The study evaluated the use of different variations of each question. For example, the question “How are you?” can have multiple variations with the same meaning, such as “How are you doing?”, “How's it going?” etc. This enables the study to ruggedize the system to defend against robo-callers that can use the audio length of a question to determine what question was asked. With multiple variations of the same question, a robocaller would need to comprehend what the system is saying in order to provide an appropriate response.
The study employed rules for the system. First, after the announcement and initial greeting by the system, the system would randomly choose to ask the caller to hold or not. The study then can randomly choose to ask the context detector or name recognizer type question with equal probability. Subsequently, the system was configured to continue the conversation or block/forward the call based on the previous responses. If the system decided to continue the conversation at this point, it randomly chooses one of the “Follow up,” “Relevance,” “Repetition,” “Name Recognizer,” “Hold” questions with high probability or “Speak up” with low probability.
If the system decides to ask a fourth or fifth question, it randomly chooses one context question, repetition question, name recognizer question, hold request, relevance question, and speak up request. The system could ask a specific question only once during the interaction with the caller. The rules were designed to keep the conversation similar to a typical phone call in addition to increasing the entropy for the attacker so that there is no specific pattern that the attacker can exploit.
The study addressed both targeted robocalls and evasive robocalls. Targeted robocalls are when the robo-callers know the name and phone number association of a particular recipient. An evasive robocaller is defined to circumvent screening, e.g., using voice activity.
Referring to
In the example of
The controller (e.g., 136) then invoked (308) one or more analyses via individual modules (e.g., 134a-134h, etc.) to analyze the transcribed audio (as a file or snippet or other measurements as described herein) and label the transcription of the caller's responses to determine if it is an appropriate response. For example, the relevance detector module (e.g., 134b) can be invoked to determine if the caller's response is an appropriate verbal response semantically to a relevance question being interrogated to the caller; the repetition detector module (e.g., 134f) may be invoked to determine if the response is an appropriate one in response to a repetition question being interrogated to the caller, among others, as shown in
Each of the analysis modules (e.g., relevance detector module 134b, repetition detector module 134f, or other described herein) analyzed the input audio (or measurement) to determine a label (e.g., label=appropriate/not appropriate) for a given classifier and a corresponding confidence score. After every analysis, the non-person caller detector (e.g., 110) assessed (310) the likelihood that the response is from a caller that is a person or a machine via a hypothesis testing operation. For the assessment (310), the state machine 302 may direct the calculation of a sequential probability ratio test (SPRT) score, Si (where 1≤i≤5), according to the Equations 1 and 2.
In Eq. 2, Ci is the confidence value generated by a given analysis module (e.g., 134a-134h), and λ is a tunable parameter that determines the weight of the ith prediction. In an implementation, the λ can be set, e.g., to 3. Additional examples of the sequential probability ratio test may be found in [50].
To perform the hypothesis testing operation (e.g., using classical hypothesis testing as an example), the state machine 302 established hypothesis testing for a pair of hypotheses H0 and H1 based on the SPRT value in which H0 and H1 are defined as:
The study used the output of the hypothesis testing operation output as a stopping rule. The stopping rule 312 to stop (312a) or to continue with additional interrogation (312b) was established using a threshold operation per Equation set 3.
a<S
i
<b: continue interrogation
S
i
≥b: accept H1
S
i
≤a: accept H0 (Eq. Set 3)
In Equation Set #3, the values of a and b can depend on the desired type I and type II errors, α and β per Equation Set #4 in which a and B are chosen, e.g., to be 5%.
In the study, λ was set to 3, and α and β were set to 5%.
The state machine 302 defined at least two predictions and, at most, five evaluations/interrogations to make a decision on whether a caller is a robocaller or not. The state machine 302 determined the number of questions to ask the caller before making a decision. At any given point, if a majority does not exist in the prediction labels, the state machine 302 directs the system to ask the next question. The state machine 302 also evaluated (314) the majority label using a majority voting ensemble. The majority voting ensemble is a meta-classifier that can combine a plurality of machine learning classifiers for classification via majority voting. In other words, the majority voting ensemble's final prediction (e.g., class label) is the one predicted most frequently by the member classification models. The majority voting ensembles are known in the art and are therefore not described in further detail herein.
If a majority exists (314a) and the Si score is between values a and b (per 312b), the state machine 302 directed the continuation of the caller assessment to ask the next question (304). Otherwise, the state machine 302 checked (316) if the majority labels and the label supported by SPRT (according to the stopping rule specified above) are in agreement. If yes (316a), the state machine 302 finalized the label and made (318) a decision to forward the call if the caller is labeled human and block the call if the caller is labeled robocaller. If not (316b), the state machine 302 directed the continuation of the caller assessment to ask the next question. The state machine 302 may also make (320a) a decision after a pre-defined number of interrogative assessments was made (320).
The study developed an example of the context detector module (e.g., 134a) that can be invoked after the non-person caller detector says, e.g., “How can I help you?” to the caller. The context detector module (e.g., 134a) was configured to label the audio response of the caller as an inappropriate response or an appropriate response using a classifier, e.g., a semantic clustering-based classifier.
To filter out misdialed calls, the study extracted important topics (e.g., per [3]) from the transcripts of calls employing the LSI topic modeling (324). Thirty (30) topics were extracted from the corpus of transcripts in which each topic represented a spam campaign. The study constructed a similarity matrix (326) by computing the cosine similarity between each transcript. The study then converted (328) the similarity matrix into a distance matrix by inverting the elements of the similarity matrix. The study then performed DBSCAN clustering (330) on the distance matrix. DBSCAN is a clustering algorithm that can group, for given a set of points, points that are closely packed together and mark, as outliers, points that lie alone in low-density regions. Seventy-two (72) clusters were created in which each cluster represented groups of highly similar transcripts of robocalls. It was observed that the clustering operation filtered non-spam calls as outliers.
To establish the threshold for the appropriate and/or inappropriate response (332), the study then took one representative robocall from each cluster and calculated the vector representations by projecting the robocall messages onto the pre-computed LSI topic model. To classify a response from a user, the context detector module (e.g., 134a) used in the study, after preprocessing the text, calculated the vector representation by projecting the response onto the pre-computed LSI topic model. It then computed the cosine similarity of the user response with pre-computed 79 robocall messages. If the cosine similarity was greater than a threshold, C's, the context detector module labeled the response as an inappropriate response and vice-versa. That is, if the content of the caller's response matches with any previously known robocall message, it is labeled as a “not appropriate” response; otherwise, it is labeled as an “appropriate” response. In one implementation, the threshold was determined to be 0.85 after offline data analysis of known robocall messages.
The study developed an example of the relevance detector module (e.g., 134b) that can determine whether the response from the caller is an appropriate response for a relevance question. The study employed a binary classifier for the relevance detector module (e.g., 134b). The classifier, for a given (question, response) pair, could label the response as appropriate if the response is a reasonable answer to the question selected by the controller and not appropriate if not. Human callers were expected to provide appropriate responses and robocallers were expected to provide not appropriate responses.
The study further tailored the dataset 335 to build a Relevance Detector model by taking the conversation between each speaker pair (e.g., speaker A and B) and converting (336) them into (comment, response) pairs. The study labeled each of these (comment, response) pairs as “appropriate.” To generate the irrelevant examples, for each comment by speaker A, the study randomly picked a response that was not the response provided by speaker B from the Fisher dataset and labeled that pair as “not-appropriate.” In all, the study generated 300,000 “appropriate” (comment, response) pairs and 300,000 “not-appropriate” (comment, response) pairs as a training dataset. The study then performed sentence embedding (338) on each data point to convert the text into a vector. Similar to word embeddings (like Word2Vec [57], GloVE [58], Elmo or Fasttext [60]), sentence embeddings embed a full sentence into a vector space. The study used Infersent to perform sentence embedding on our data points. InferSent is a sentence embedding method that provides semantic sentence representations. It was trained on natural language inference data and generalized well to many different tasks. The study then converted the data points (comment, response) pairs to (comment embedding, response embedding) pairs (where comment embedding denotes the sentence embedding of the comment and response embedding denotes the sentence embedding of the response). The (comment embedding, and response embedding) pairs were then passed to the binary classification model (340).
The study used a Multilayer Perceptron (MLP) as a base model. The study empirically set the architecture of the model as (1024, 512, 256, 1). The study used 384,000 data points to train the base model. The training, validation, and test accuracy of the base model were observed to be 83%, 70%, and 70% respectively. To test with robocalls, the study treated the questions asked by the non-person caller detector (e.g., 110) as a “comment” (in the noted pairing) and the transcripts from robocall recordings as a “response” in the pairing.
The study then finetuned the base model to specifically recognize robocalls and legitimate (human) calls. The study assumed that human callers would be able to provide appropriate responses to the questions whereas the robo-callers would not. Therefore the study labeled (question, robocall response) pairs as “not appropriate” and (question, human response) pairs as “appropriate” to finetune the base model.
The study employed a neural network model. The parameters for the finetuned model is shown in Table 3.
To generate the “not appropriate” responses, the study used the dataset of robocalls. The study took the first 30 words (as the system let each response to be of at most 20 seconds) from each robocall transcript and paired it with both relevance questions to form our “not appropriate” responses. In this way, the study generated 67 unique (question, robocall response) pairs.
Since this dataset was too small to finetune a model and the number of unique robocall messages was limited, the study performed data augmentation on the 67 unique robocall responses. For each robocall response, the study generated two more augmented texts using the techniques in to yield 201 (question, response) “not appropriate” pairs for each question from the “Relevance” question pool. To generate the appropriate pairs, for each question from the “Relevance” question pool, the study used quora to collect appropriate human responses to these questions. The study augmented the (question, human response) pairs in the same way. Upon generating the appropriate and not appropriate pairs, the study generated the sentence embedding pairs in the similar fashion described above. The (question embedding, and response embedding) pairs were then passed to finetune our base model. Table 4 shows the test accuracy of the finetuned model.
The study developed an example of the elaboration detector module (e.g., 134c) that can determine if the response provided by the caller for a follow up question is appropriate or not. Examples of follow up questions include “How can I help you?” or “Tell me more about it.”
While text summarization via natural language processing (e.g., described in [54]-[56]) could be used, the study employed a less complex implementation (that could avoid having to rely on a large number of data and complex architecture) based on the length of the caller's response. The study developed a detector that can count (344) the number of words in the caller's response. If detector determine (346) that the number of words in the current response is higher than the number of words in the previous response, then it labels the caller response as “appropriate,” otherwise “inappropriate.” While a naive approach may not consider the semantic meaning of the responses, the study understood that the detector (e.g., 134c) developed in this manner would operate in combination with other detectors to make a final decision. To this end, individual components can compensate for their individual performance with operations from other components. Indeed, in other embodiments, more complex classifiers, including those described herein, can alternatively be employed.
The study developed an example of the name recognition detector module (e.g., 134d) that can determine whether a correct name in provided in response to the inquiry of the recipient of interest.
Amplitude Detector. The study developed an example of the amplitude detector module (e.g., 134e) that can request the caller to speak up. The amplitude detector module (e.g., 134e) is configured to measure (354) the current loudness or the average amplitude of the audio of the caller's response. The amplitude detector module (e.g., 134e) then determines (356) if the caller has spoken louder in response to the request. If the average amplitude is higher by defined offset (e.g., error margin=0.028) than the caller's previous response, the amplitude detector module labels the response as an appropriate response, otherwise, the response is inappropriate.
The study developed an example of the repetition detector module (e.g., 134f) that can ask the caller to repeat what just said. The repetition detector module (e.g., 134f) can be invoked by the controller after the non-person caller detector (e.g., 110) asks the caller to repeat what he/she just said. Once the caller was done responding to the repetition request, the repetition detector module (e.g., 134f) could compare (i) the caller's current response to (ii) the immediate last response to determine if the current response is a repetition of the immediate last response.
Dataset: To build such a classifier, the study collected (current response, last response) pairs from Lenny recordings as the training data set 359. Lenny is a bot (a computer program) configured to play a set of pre-recorded voice messages to interact with spammers. The dataset included more than 600 publicly available call recordings where Lenny interacts with human spammers (telemarketers, debt collectors, etc.). During the conversation in the dataset, Lenny asked the callers to repeat themselves multiple times. Among 600+ publicly available call recordings, the study randomly selected 160 call recordings and manually transcribed the parts where the callers repeated themselves. Specifically, the study created 160 (current response, last response) pairs and assigned them the “appropriate” label. Since the telemarketers talking to Lenny are human callers, when asked to repeat themselves, they provide a semantic, if not the exact, repetition of their last statement. It is expected most legitimate human callers behave in the same way.
The study considered a second classifier to assess whether the response was inappropriate. The study additionally generated “not appropriate” (current response, last response) pairs for each last response. The study randomly selected a current response from the Lenny transcripts, which is not an appropriate repetition to generate 160 not appropriate pairs.
The study extracted three features (356) from the data points generated: Cosine similarity, word overlap, and named entity overlap.
The evaluated system was configured to calculate the cosine similarity between the current response and the last response. The cosine similarity feature is a measure of similarity between two non-zero vectors of an inner product space that measures the cosine of the angle between them. Upon removing stop words and punctuation, the evaluated system was configured to calculate the number of words overlapped (i.e., word overlap feature) between the current response and the last response. Upon removing stop words and punctuation, the evaluated system was configured to calculate the number of named entities in the current response and last response. During the information extraction, a named entity is a real-world object, such as persons, locations, organizations, products, etc., that can be denoted with a proper
name. The study used Spacy to extract the named entities and then calculated the number of named entities overlapped (i.e., named entity overlap feature) between the current response and the last response.
It was observed that the evaluated system could determine if a statement1 is a semantic repetition of statement2 without using resource-intensive machine learning models. Five different classifiers were trained (362) using the cosine similarity, word overlap, and named entity overlap three features.
The study evaluated a number of different classifiers, including SVM, Logistic Regression, Random Forest, XG Boost, and neural works, and employed Random Forest for the detector in the study. The hyperparameters for Random Forest model included minsamples_leaf=20 and nestimators=100. To generate the robocall test set, the study took 79 representative robocalls messages and generated (current response, last response) pairs by setting the first sentence and second sentence from the robocall messages as current response and last response respectively. Since, in this dataset, none of the current responses are semantic repetitions of the last responses, these pairs were labeled as a “not appropriate” response.
Table 5 shows the test accuracies and false positive rates for each classifier. Table 5 also shows how the classifier performs on the robocall test set.
Affirmative Negative Intent Recognizer. The study developed an example of the intent detector module (e.g., 134g) that can evaluate the appropriateness of a reply for affirmation of the caller's intent, e.g., in reply to a follow-up question of “Who are you trying to reach?” to confirm the name. The intent detector module (e.g., 134g) can ask the caller to confirm by saying the correct name or evaluate whether the incorrect name was spoken. For example, if the first response was “Taylor,” the intent detector module (e.g., 134g) may inquire, “Did you mean Taylor?” as an expected affirmative answer from a human caller. Another question is asking the caller to confirm the name by intentionally saying an incorrect name, such as, “Did you mean Tiffany?” In the second scenario and associated evaluation, the intent detector module (e.g., 134g) would expect a negative answer from a human caller. Based on the question and the expected response from the caller, the intent detector module (e.g., 134g) can label a response from the caller as inappropriate and appropriate.
The study developed an example of the silence detector module (e.g., 134h) that can be invoked by the controller to request the caller to hold/pause speaking. In the study, the silence detector module (e.g., 134h) was configured to randomly select a hold time, ts, e.g., ranging between five to ten seconds, to ask the caller to hold and comes back to the caller to continue the conversation after ts seconds. Human callers are expected to eventually stop talking when asked to hold and keep silent until the callee returns during a phone call. To this end, the study configured the module to detect if the caller has become silent during the ts seconds they were asked to hold.
To determine whether the caller responded appropriately when put on hold, the study configured the silence detector module (e.g., 134h) to determine if the caller was silent during at least half of the holding time, ts. The study evaluated a Voice Activity Detection (VAD) to detect silence. It was observed the implementation generated several instances of false positives.
The study further developed another implementation of the silence detector module (e.g., 134h) that is configured to transcribe all utterances stated by the caller during the ts second period and to calculate the average number of words said per second, wps. If the average number of words wps was less than a pre-defined threshold θs, the study per the silence detector module labeled the response as appropriate. The study established the threshold θs by calculating the average number of words spoken per second awps from a collection of pre-recorded robocall recordings and set θs=(ts×awpos)/2.
The study measured the accuracy of decisions made by the prototyped system.
The results show that the developed system was effectiveness against robocalls in the defined threat model. The study also evaluated the usability of the system.
The study was designed to evaluate a system that could (i) provide the convenience of a human assistant while detecting robocalls and (ii) provide context for calls to assist the callee in deciding if a call needs his/her attention and preserve user experience. In the study, 20 study participants were evaluated.
The study performed two experiments, one where the callers knew the name of the callee and one where the caller didn't know the name of the callee. During the first experiment, the study preset the correct name instead of having each user set a name. The study recruited 15 out of our 20 users for this experiment and provided four topics to make the four simulated phone calls. The topics were selected such that it is natural for a phone call setting and common in real-life scenarios. The study chose the last two topics to be in overlap with robocall topics (free cruise and car warranty). Since human callers were interacting with the system, it was expected that the calls would be forwarded even when the call topics overlapped with the robocall topics. This provided evidence that the system does not conservatively block calls containing words that might be present in robocall messages.
During the second experiment, the caller was either given an incorrect name or no name at all. The study collected information about phone usage and previous experience regarding robocalls from our users.
It was observed that most of the users (81.3%) were able to answer the questions asked by the system in the study without difficulty. Only 10% of users reported that they had difficulty answering the questions. It was also observed that while certain users initially mentioned that they felt unfamiliar with the system, the response changed after 1-2 tries. The study asked users if the number of questions they had to answer was acceptable; 5% of users reported that it was not acceptable. The study evaluated the number of questions the system asked during its interaction with the users in the study and observed that in 67% of the cases, the system made a decision by asking up to three questions. 83% of the users reported that 3 questions were acceptable. The study observed that 8.8% of user indicated the time they spent interacting with the virtual assistant before their call was forwarded/blocked was unacceptable.
The study measured false positives, defined as the percentage of calls from human callers that were mistakenly blocked, e.g., calls from human callers that were deemed as robo-callers. The study used the data collected during the user study. Twenty (20) users made 80 calls in total, and only 7 calls were blocked, yielding an overall false positive rate of 8.75%, mainly due to the silence detection and the name recognition detection.
The exemplary system and method can be thought of as a conversational agent that makes a quick conversation with the callers and makes a decision based on their responses. There has been a considerable amount of research conducted on conversational agents in the field of natural language processing [45]-[47]. Over the past few years, conversational assistants, such as Apple's Siri, Microsoft's Cortana, Amazon's Echo, Google's Now, and a growing number of new services, have become a part of people's lives. However, due to the lack of fully automated methods for handling the complexity of natural language and user intent, these services are largely limited to answering a small set of common queries involving topics like weather forecasts, driving directions, finding restaurants, and similar requests. Conversational agents such as Apple's Siri demonstrated their capability of understanding speech queries and helping with users' requests. However, all of these intelligent agents are limited in their ability to understand their users, and they fall short of the reflexive and adaptive interactivity that occurs in most human-human conversation [48]. Huang et. al. discusses the challenges (such as identifying user intent, and having clear interaction boundaries) associated with such agents. RobocallGuardPlus consists of multiple modules that examine the caller's responses. These modules determine if a response is, in fact, an appropriate response to the question asked. Building natural language models present numerous challenges. First, a large annotated dataset is required to build highly accurate NLP models. However, the dataset consisting of robocall messages is limited and small in size. Moreover, human responses to secretary-like questions is also limited. Hence, building an effective virtual assistant from a limited dataset becomes challenging.
Second, models that have the capability of fully understanding natural language and user intent tend to be very complex and is still an area of ongoing research in the field of natural language processing. Also, the system can intend RobocallGuardPlus to be used in real-time in a phone.
Therefore the models should be lightweight, which adds another challenge for us. Finally, most of the work on conversational agents has focused on usability and how the conversation can be made more human-like. However, the system can need to strike a balance between usability and security since RobocallGuardPlus is designed to face both human callers and robocallers. Having the conversational agent succeed in an adversarial environment while at the same time being user-friendly to human callers is even more challenging.
It has been shown that phone blacklisting methods provided by smartphone apps (e.g., Truecaller, Nomorobo, Youmail, Hiya, etc.) or telephone carriers (e.g., call protect services offered by AT&T, Verizon, etc.) can be helpful. However, these services typically rely on historical data such as user complaints or honeypot-generated information, and their overall effectiveness tends to be low due to caller ID spoofing. A number of research studies, and reported in publications, have explored caller ID authentication. The Federal Communications Commission (FCC) has mandated US telecom companies to start using a suite of protocols and procedures (referred to as SHAKEN/STIR) intended to combat caller ID spoofing on public telephone networks. The protocols and procedures enable the callee to verify the correctness of the caller ID. However, such protocols and procedures may be limited when the calls originate outside of the United States or if the recipient of the call does not have caller ID spoofing services.
Another call screening operation is made available on the Google Pixel phone app that allows users to screen their incoming calls prior to picking them up. When an incoming call arrives, the user is prompted with three options: answer, decline, and screen. If the screen option is selected, Google Assistant then engages with the caller to collect an audio sample and generates a transcript of the ongoing call. Hence users are notified (i.e., the phone rings) of all incoming calls (including robocalls), and user intervention is needed to screen such calls. In the latest version of the Phone app, Google allows an automatic call screen feature, thus enabling the elimination of user intervention if the user chooses to do so. This feature claims to block robocalls on behalf of the user. Upon picking up the call, Google Assistant screens the call and asks who's calling and why. Call Screen can detect robocalls and spam calls from numbers in Google's spam database. A detected spam call is then declined without alerting the user.
Call distribution techniques (Robokiller) include an Answer Bot that detects spam calls by forwarding all incoming calls to a server, which accepts each call and analyzes its audio to determine if the audio source is a recording. Once the call is determined to come from a human, it is forwarded back to the user. Robokiller performs audio analysis techniques to detect robocalls. However, these techniques can be evaded by a sophisticated robocaller.
To address the increasing number of unwanted or fraudulent phone calls, a number of call-blocking applications are available commercially, some of which are used by hundreds of millions of users (Hiya, Truecaller, Youmail etc.). Although such call-blocking apps are the only solutions for users that block or warn users about spam calls, their performance suffers with an increased amount of caller ID spoofing. Such spoofing is easy to achieve, and robo-callers have resorted to tricks like neighbor spoofing (caller ID is similar to the targeted phone number) to overcome call blocking and to increase the likelihood that the targeted user will pick up the call.
A majority of robocallers now rely on neighbor spoofing that helps them to effectively evade such blacklists. Since RobocallGuard does not solely rely on blacklists, it can block robocalls from spoofed callers.
The Call Screen feature available on the Google Pixel phone app provides call context to the user via a real-time transcript of the call audio. In the latest version of the Phone app, Google allows an automatic call screen feature, thus enabling the elimination of user intervention if the user chooses to do so. This feature also claims to block robocalls on behalf of the user. However, from the conducted experiments, it was observed that Google's call screening mostly relies on caller IDs, thus blocking calls from known robo-callers. It thus fails to block robocalls from spoofed caller IDs even when the call content is spam. Moreover, once adopted by a large number of users, Call Screen appears to be evade-able by future robo-callers that can bypass Google Assistant and reach their targets. Conducted experiments showed that instead of initially providing the spam content, robo-callers can simply provide a benign message when asked about the purpose of the call, thus evading detention by Google Assistant.
In contrast, the exemplary system disclosed herein can be addressed meaningfully by current mass robo-callers even in the presence of caller ID spoofing. Since the system does not mainly rely on blacklists, though blacklist operations may be a part of the system, in some embodiments, it can effectively block spam content from spoofed robo-callers. Moreover, a study was conducted that the security analysis showed the exemplary system to be effective against future robocallers who might try to evade RobocallGuardPlus once deployed.
As noted above, Robokiller, a smartphone application, employs an Answer Bot that detects spam calls by forwarding all incoming calls to a server, which accepts each call and analyzes its audio to determine if the audio source is a recording. Once the call is determined to come from a human, it is forwarded back to the user. In Robokiller, a caller continues to hear rings while the call is picked up, analyzed, and forwarded back to the user, which could negatively impact legitimate callers. Also, the audio analysis techniques used by Robokiller are countered by more sophisticated robo-callers that use voice activity detection. In an attempt to fool their victims, current robo-callers employ evasive techniques like mimicking human voice, not speaking until spoken to, etc. Hence, the defense mechanisms used by Robokiller are not enough to detect such evasive attackers.
In contrast, the exemplary system can preserve the user experience and can be effective against robocallers that employ audio evasion techniques. Experiments conducted in the study showed that the current implementations of both Robokiller and Google's call screens rely on caller IDs to block robo-callers. Therefore such systems are easily evaded by spoofed robo-callers. Currently, there is no such system that makes an involved conversation with the caller through multiple interactions and blocks robocalls based on the call content and the interaction pattern.
It should be appreciated that the logical operations described above and in the appendix can be implemented (1) as a sequence of computer-implemented acts or program modules running on a computing system and/or (2) as interconnected machine logic circuits or circuit modules within the computing system. The implementation is a matter of choice dependent on the performance and other requirements of the computing system. Accordingly, the logical operations described herein are referred to variously as state operations, acts, or modules. These operations, acts and/or modules can be implemented in software, in firmware, in special purpose digital logic, in hardware, and any combination thereof. It should also be appreciated that more or fewer operations can be performed than shown in the figures and described herein. These operations can also be performed in a different order than those described herein.
Machine Learning. In addition to the machine learning features described above, the various analysis system can be implemented using one or more artificial intelligence and machine learning operations. The term “artificial intelligence” can include any technique that enables one or more computing devices or comping systems (i.e., a machine) to mimic human intelligence. Artificial intelligence (AI) includes but is not limited to knowledge bases, machine learning, representation learning, and deep learning. The term “machine learning” is defined herein to be a subset of AI that enables a machine to acquire knowledge by extracting patterns from raw data. Machine learning techniques include, but are not limited to, logistic regression, support vector machines (SVMs), decision trees, Naïve Bayes classifiers, and artificial neural networks. The term “representation learning” is defined herein to be a subset of machine learning that enables a machine to automatically discover representations needed for feature detection, prediction, or classification from raw data. Representation learning techniques include, but are not limited to, autoencoders and embeddings. The term “deep learning” is defined herein to be a subset of machine learning that enables a machine to automatically discover representations needed for feature detection, prediction, classification, etc., using layers of processing. Deep learning techniques include but are not limited to artificial neural networks or multilayer perceptron (MLP).
Machine learning models include supervised, semi-supervised, and unsupervised learning models. In a supervised learning model, the model learns a function that maps an input (also known as feature or features) to an output (also known as target) during training with a labeled data set (or dataset). In an unsupervised learning model, the algorithm discovers patterns among data. In a semi-supervised model, the model learns a function that maps an input (also known as a feature or features) to an output (also known as a target) during training with both labeled and unlabeled data.
An artificial neural network (ANN) is a computing system including a plurality of interconnected neurons (e.g., also referred to as “nodes”). This disclosure contemplates that the nodes can be implemented using a computing device (e.g., a processing unit and memory as described herein). The nodes can be arranged in a plurality of layers such as an input layer, an output layer, and optionally one or more hidden layers with different activation functions. An ANN having hidden layers can be referred to as a deep neural network or multilayer perceptron (MLP). Each node is connected to one or more other nodes in the ANN. For example, each layer is made of a plurality of nodes, where each node is connected to all nodes in the previous layer. The nodes in a given layer are not interconnected with one another, i.e., the nodes in a given layer function independently of one another. As used herein, nodes in the input layer receive data from outside of the ANN, nodes in the hidden layer(s) modify the data between the input and output layers, and nodes in the output layer provide the results. Each node is configured to receive an input, implement an activation function (e.g., binary step, linear, sigmoid, tan h, or rectified linear unit (ReLU), and provide an output in accordance with the activation function. Additionally, each node is associated with a respective weight. ANNs are trained with a dataset to maximize or minimize an objective function. In some implementations, the objective function is a cost function, which is a measure of the ANN's performance (e.g., error such as L1 or L2 loss) during training, and the training algorithm tunes the node weights and/or bias to minimize the cost function. This disclosure contemplates that any algorithm that finds the maximum or minimum of the objective function can be used for training the ANN. Training algorithms for ANNs include but are not limited to backpropagation. It should be understood that an ANN is provided only as an example machine learning model. This disclosure contemplates that the machine learning model can be any supervised learning model, semi-supervised learning model, or unsupervised learning model. Optionally, the machine learning model is a deep learning model. Machine learning models are known in the art and are therefore not described in further detail herein.
A convolutional neural network (CNN) is a type of deep neural network that has been applied, for example, to image analysis applications. Unlike traditional neural networks, each layer in a CNN has a plurality of nodes arranged in three dimensions (width, height, depth). CNNs can include different types of layers, e.g., convolutional, pooling, and fully-connected (also referred to herein as “dense”) layers. A convolutional layer includes a set of filters and performs the bulk of the computations. A pooling layer is optionally inserted between convolutional layers to reduce the computational power and/or control overfitting (e.g., by downsampling). A fully-connected layer includes neurons, where each neuron is connected to all of the neurons in the previous layer. The layers are stacked similar to traditional neural networks. GCNNs are CNNs that have been adapted to work on structured datasets such as graphs.
A logistic regression (LR) classifier is a supervised classification model that uses the logistic function to predict the probability of a target, which can be used for classification. LR classifiers are trained with a data set (also referred to herein as a “dataset”) to maximize or minimize an objective function, for example, a measure of the LR classifier's performance (e.g., error such as L1 or L2 loss), during training. This disclosure contemplates that any algorithm that finds the minimum of the cost function can be used. LR classifiers are known in the art and are therefore not described in further detail herein.
An Naïve Bayes' (NB) classifier is a supervised classification model that is based on Bayes' Theorem, which assumes independence among features (i.e., the presence of one feature in a class is unrelated to the presence of any other features). NB classifiers are trained with a data set by computing the conditional probability distribution of each feature given a label and applying Bayes' Theorem to compute the conditional probability distribution of a label given an observation. NB classifiers are known in the art and are therefore not described in further detail herein.
A k-NN classifier is an unsupervised classification model that classifies new data points based on similarity measures (e.g., distance functions). The k-NN classifiers are trained with a data set (also referred to herein as a “dataset”) to maximize or minimize a measure of the k-NN classifier's performance during training. This disclosure contemplates any algorithm that finds the maximum or minimum. The k-NN classifiers are known in the art and are therefore not described in further detail herein.
Although example embodiments of the present disclosure are explained in some instances in detail herein, it is to be understood that other embodiments are contemplated. Accordingly, it is not intended that the present disclosure be limited in its scope to the details of construction and arrangement of components set forth in the following description or illustrated in the drawings. The present disclosure is capable of other embodiments and of being practiced or carried out in various ways.
It must also be noted that, as used in the specification and the appended claims, the singular forms “a,” “an,” and “the” include plural referents unless the context clearly dictates otherwise. Ranges may be expressed herein as from “about” or “5 approximately” one particular value and/or to “about” or “approximately” another particular value. When such a range is expressed, other exemplary embodiments include from the one particular value and/or to the other particular value.
By “comprising” or “containing” or “including” is meant that at least the name compound, element, particle, or method step is present in the composition or article or method, but does not exclude the presence of other compounds, materials, particles, method steps, even if the other such compounds, material, particles, method steps have the same function as what is named.
In describing example embodiments, terminology will be resorted to for the sake of clarity. It is intended that each term contemplates its broadest meaning as understood by those skilled in the art and includes all technical equivalents that operate in a similar manner to accomplish a similar purpose. It is also to be understood that the mention of one or more steps of a method does not preclude the presence of additional method steps or intervening method steps between those steps expressly identified. Steps of a method may be performed in a different order than those described herein without departing from the scope of the present disclosure. Similarly, it is also to be understood that the mention of one or more components in a device or system does not preclude the presence of additional components or intervening components between those components expressly identified.
As discussed herein, a “subject” may be any applicable human, animal, or another organism, living or dead, or other biological or molecular structure or chemical environment, and may relate to particular components of the subject, for instance, specific tissues or fluids of a subject (e.g., human tissue in a particular area of the body of a living subject), which may be in a particular location of the subject, referred to herein as an “area of interest” or a “region of interest.”
It should be appreciated that, as discussed herein, a subject may be a human or any animal. It should be appreciated that an animal may be a variety of any applicable type, including, but not limited thereto, mammal, veterinarian animal, livestock animal or pet type animal, etc. As an example, the animal may be a laboratory animal specifically selected to have certain characteristics similar to humans (e.g., rat, dog, pig, monkey), etc. It should be appreciated that the subject may be any applicable human patient, for example.
The term “about,” as used herein, means approximately, in the region of, roughly, or around. When the term “about” is used in conjunction with a numerical range, it modifies that range by extending the boundaries above and below the numerical values set forth. In general, the term “about” is used herein to modify a numerical value above and below the stated value by a variance of 10%. In one aspect, the term “about” means plus or minus 10% of the numerical value of the number with which it is being used. Therefore, about 50% means in the range of 45%-55%. Numerical ranges recited herein by endpoints include all numbers and fractions subsumed within that range (e.g., 1 to 5 includes 1, 1.5, 2, 2.75, 3, 3.90, 4, 4.24, and 5).
Similarly, numerical ranges recited herein by endpoints include subranges subsumed within that range (e.g., 1 to 5 includes 1-1.5, 1.5-2, 2-2.75, 2.75-3, 3-3.90, 3.90-4, 4-4.24, 4.24-5, 2-5, 3-5, 1-4, and 2-4). It is also to be understood that all numbers and fractions thereof are presumed to be modified by the term “about.”
Some references, which may include various patents, patent applications, and publications, are cited in a reference list and discussed in the disclosure provided herein. The citation and/or discussion of such references is provided merely to clarify the description of the present disclosure and is not an admission that any such reference is “prior art” to any aspects of the present disclosure described herein. In terms of notation, “[n]” corresponds to the nth 10 references in the list. All references cited and discussed in this specification are incorporated herein by reference in their entireties and to the same extent as if each reference was individually incorporated by reference.
This PCT application claims priority to, and the benefit of, U.S. Patent Provisional Application No. 63/254,377, filed Oct. 11, 2021, entitled “Robocall Blocking Method and System,” which is incorporated by reference herein in its entirety.
This invention was made with government support under Grant No. 1514035 awarded by the National Science Foundation. The government has certain rights in the invention.
Filing Document | Filing Date | Country | Kind |
---|---|---|---|
PCT/US2022/046278 | 10/11/2022 | WO |
Number | Date | Country | |
---|---|---|---|
63254377 | Oct 2021 | US |