1. Technical Field
The subject matter discussed herein relates generally to data processing and, more particularly, to systems and methods for detecting real names in different languages.
2. Background Information
Online products and services often require users to provide their real names. While some users provide their real names correctly, other users do not provide their real names correctly. The reason may be unintentional (e.g., typographical error) or intentional (e.g., to hide their identities). Some users may provide names that are not real names. Accordingly, there is no indication whether the names provided by the users are real or not.
Further, the provided names may be in different languages, which are associated with different cultures, traditions, and customs. Names in some languages may include a surname. For example, the surname may be provided as the first word, the last word, or a word in between the first and last words. In some languages, there is no notion of a surname.
Real names in different languages as used in online products and services are hard to detect. A solution is needed.
Systems and methods for detecting real names in different languages are described. The subject matter includes at least a computing device, at least a computer product, and at least a method for receiving a candidate name; determining a human language of the candidate name; disassembling a structure of the candidate name by applying a rule base for at least one of a character set, a meaning, and a format of the candidate name, wherein the rule base is unique to the determined human language; verifying at least a part of the disassembled structure of the candidate name with respect to actual real name information to generate a degree of confidence that the candidate name is the an actual real name; and performing an action based on the generated degree of confidence that the candidate name is the actual real name.
The subject matter described herein is taught by way of example embodiments. Various details have been omitted for the sake of clarity and to avoid obscuring the subject matter. Examples shown below are directed to structures and functions of systems and methods for detecting real names in different languages.
As used herein, a “real name” is a publicly known or legal identifier of a person. The publicly known or legal identifiers of some people may be the same. For other people (e.g., artists), their publicly know identifiers may not be the same as their legal identifiers. For example, a singer may be publicly known by a stage name, which may be different from a legal name (e.g., name on passport).
Example Processing Environment
An example of one or more devices 102-118 may be computing device 405 (
User interface (UI) 130 illustrates a mechanism for a user to provide his or her name. The user may be providing the name for any reason (e.g., registering for a product or service, opening an account, responding to a survey, etc.). For simplicity, other information (not shown, e.g., contact information) may be included, as would be understood by one skilled in the art. The user may enter their name, for example, using widget 132 (e.g., a text box, auto-fill feature, voice input widget, etc.), and activate control 134 to submit or provide their name.
UI 140 illustrates a mechanism a user may use to provide evidence or proof to support that his or her name is real. For example, the user may input evidence 142 and submit it using control 144. Further details of UI 140 are discussed in greater detail below.
UI 150 illustrates a mechanism an administrator or third-party user may use to verify whether a name is real. For example, if the name is real, the name may be confirmed or verified using control 154. If the name is not real, the name may be so indicated or rejected using control 156. Optionally, evidence 152 may be provided with either control 154 or 156. Further details of UI 150 are discussed in greater detail below.
Example Real Name Detection Process
To illustrate some example embodiments, elements of
The language may be evaluated in any manner. In some example embodiments, language evaluation may be performed using Unicode scripts (accessible on the Internet at www dot unicode dot org). Unicode has defined ranges of codes for different languages or sets of languages. For example, one range (e.g., 4E00-9FCF, in hexadecimal) has been defined for Chinese ideographs in version 6.1 of The Unicode Standard. This range of codes can be used to represent the Chinese ideographs used in the Chinese language, Japanese language, and Korean language (CJK). There are other CJK ranges of codes (e.g., CJK Extension A to CJK Extension D, etc.), Japanese ranges of codes (e.g., Hiragana and Katakana), Korean ranges of codes (e.g., Hangul ranges), and numerous other ranges of codes.
To evaluate the language of a provided name, for example, the range or ranges of codes are identified. Using the name “” as an example, some characters (e.g., “”) are identified to be in a CJK range and some characters (e.g., “”) are identified to be in a Hiragana range. Collectively, since the Japanese language uses Kanji (or Chinese characters) and the Chinese language does not use any Japanese character, the name “” can be concluded with a high degree of confidence that it is a Japanese name.
A Korean name can be evaluated (e.g., detected) by identifying that the name is represented by codes in a Korean range or in a combination of a Korean range and a CJK range. A Chinese name can be detected based on the name being represented by one or more CJK ranges. As used herein, the term “language” or “human language” refers to a collection of symbols used by human in communication.
Example of List of Names
The service provider may have access to one or more databases of name information for each language. For example, for the Japanese language, there may one or more databases of name information that can be characterized with a degree of confidence as not being components of the real name (e.g., “blacklist” of Japanese non-real names or components thereof). The blacklist may be a repository of non-real names or components thereof previously determined or detected to be non-real. The blacklist may include non-real names or components thereof collected from one or more sources (e.g., the Internet).
The blacklist may be built or expanded by any methods, using any mechanisms, using information from any sources, or any combination thereof. For example, the blacklist may be created, built, added to, expanded with known fake names or fake name components located on the Internet, derived by a spam filter, imported from a government database (e.g., a fraud information database), detected by the service provider (e.g., in a confirmation or verification process), or gained from another source or method.
If it is determined that the language of the provided name is detected based on the above-described evaluation (block 220), the service provider may identify the “blacklist” of non-real names and components thereof based on the detected language (block 225). Once the language has been detected or determined, one or more language specific rules and/or databases may be used to determine whether the provided name is a real name. For example, the language of the provided name detected may be Japanese (e.g., the provided name is encoded in a Japanese script or Unicode). Then, one or more databases or blacklists of candidate names and/or components thereof in the Japanese language are identified (e.g., identifying the databases of names and/or components thereof in Japanese, as opposed to the databases of those in English, Korean, Chinese, or another language). The provided name or part thereof (e.g., the part that represents a surname or given name in Japanese) may be compared against the non-real names and/or components thereof in the Japanese blacklist databases. If, at block 230, it is determined to not be true that at least a part of the provided name is in the blacklist database, process 200A flows to block 235 as explained below.
The one or more databases of name information for each language service provider may have access to may include, for example, one or more databases of name information that are certain to a degree or known for being components of a real name or real names (e.g., “whitelist”). The whitelist may be a repository of names or name components previously detected or determined to be real names or components thereof. The whitelists may be names or name components collected from one or more sources (e.g., the Internet) known to be used in real names (e.g., most common surnames in a given language, popular baby names in a given language, most common first names in a given language, etc.). The whitelists may be built or expanded by any methods, mechanisms, or any combination thereof.
The whitelist may be built or expanded by any methods, using any mechanisms, using information from any sources, or any combination thereof. For example, the whitelist may be created, built, added to, expanded with known real names or real name components located on the Internet (e.g., common Japanese names and common Japanese surnames, etc.), imported from one or more directories (e.g., telephone directories), imported from a government database (e.g., a driver license or identification card database), imported from a third party provider (e.g., purchased form a credit card issuer), detected by the service provider (e.g., in a confirmation or verification process), or gained from another source or method.
The service provider may identify the “whitelist” of real names and components thereof based on the detected language (block 235). For example, the language of the provided name is detected to be Japanese. Then, one or more databases or whitelists of candidate real names and/or components thereof in the Japanese language are identified (e.g., identifying the databases of names and/or names components in Japanese, as opposed to the databases of those in another language, such as English, Korean, Chinese, etc.). The provided name or part thereof (e.g., the part that represents a surname or given name in Japanese) may be compared against the names and/or name components in the Japanese whitelist databases.
Example of Name Acceptance Process
As shown in
Accepting a provided name as a real name may be based on a degree of certainty or confidence that the provided name or a component thereof is real and/or not real (e.g., accepting or rejecting a name if the degree of certainty that the name or one of its component is 70% certain real and/or 55% certain not real, respectively). In some example embodiments, the degree of certainty (e.g., probability) that a name or name component is real or not real may increase after comparing the name or name component to the content of a successive whitelist or blacklist, respectively. The degrees of confidence for any language may be set or changed to any thresholds or levels, and the degrees for different languages may be different.
Example Implementation
The service provider may implement methods, objects, or application programming interface (API) for use in identifying real names. Below is one of many possible implementation examples, as would be understood by one skilled in the art, for detecting real names in different languages.
The example MarkUpAllNames method can be implemented to best match the set of names provided in the “candidate” variable and returned all potential names and name components in the “result” variable. For example, a call is made as: MarkUpAllNames(“Nicolas Sarkozy”, “en”). The MarkUpAllNames method parses “Nicolas Sarkozy” into “Nicolas” and “Sarkozy”. The language indicator “en” signifies that the language of “Nicolas Sarkozy” has been evaluated and detected to be English. MarkUpAllNames then identifies and uses one or more blacklists and/or whitelists pertaining to the English language.
The MarkUpAllNames method may not locate “Nicolas” and/or “Sarkozy” in any blacklist. The MarkUpAllNames method may locate “Nicolas” and/or “Sarkozy” in one or more whitelists, and return in the “result” variable the following:
As an example of the returned NameOccurrence may be:
In the above example, the provide name “Nicolas Sarkozy” is determined to be a real name with a degree of certainty of 6.9 (in a 10.0 scale). If the threshold is set at 6.8 and below, “Nicolas Sarkozy” may be accepted as a real name in the English language. Real names in other languages (e.g., Japanese) may be determined similarly (e.g., using the same or similar API) or in another fashion.
If the language of the provided name is determined as not detected, at block 220, or if it is determined that no part of the provided name is in any whitelist, at block 240, process 200A may flow to sub-process “B”, as shown in
Verification of Name Acceptability
If a language is determined to have not been detected at block 220, one or more mechanisms to evaluate acceptability of the provided name may be employed (block 265). One example mechanism may be an internal review process. For example, an administrator may use a tool or user interface similar to UI 150 to review a provided name (e.g., “Awesome Dude 420”) and accept or “Certify” it (e.g., using control 154) or reject or “NOT Certify” it (e.g., using control 156). In some example embodiments, the administrator may provide evidence 152 to support his or her decision (e.g., a copy of the name owner's driver license). For example, the administrator may be reviewing a name after the owner of the name have provided a copy of his or her driver license as supporting evidence (see sub-process “C”, described below). The name verification, either “Certify” or “NOT Certify”, may be received by the service provider (block 273). The administrator is a label for a person authorized to review names in an internal review process.
Another example mechanism may be an external review process (block 276). For example, another person (e.g., a friend or family member) acquainted with the person provided the name may be given an opportunity to verify the provided name. The external review process may employ a tool or user interface similar to UI 150, described above. The result of the name verification using the external review process may be received by the service provider (block 276).
Yet another mechanism may be a review process involving a third-party provider and/or database. For example, an agreement may be established to use a third-party provider and/or database (e.g., driver license database) for name verification purposes. The result of name verification (e.g., success, failure, or another status) using a third-party provider and/or database may be received by the service provider (block 280).
Any combination of verification mechanisms may be used, including some or all of the described mechanisms and/or those not described. If the provided name is acceptable (e.g., based on a degree of certainty of the name), at block 270, the provided name may be accepted (block 295, sub-process “A”). If the provided name is deemed not acceptable at block 270 (e.g., an indication of “NOT Certify” 156 is received) or if at least a part of the name is in a blacklist at block 230, process 200A flows to sub-process “C”, as shown in
Sub-process “C” as shown in
For example, the owner may provide a copy of the utility bill, driver license, or credit card information, as evidence 142, and activate control 144 to submit the evidence. The evidence or proof may be received (block 290), for example, by the service provider. The provided name may be accepted (block 295, sub-process “A”). The evidence may verify or prove that the provided name is a real name. In some situations, a user may provide an evidence of a real name that is different from the provided name. In some example embodiments, the received evidence or proof may be reviewed before accepting the provided name as a real name.
The example embodiment is not limited to the foregoing sequence of blocks, and any other sequence may be implemented. For example but not by way of limitation, instead of flowing to sub-process “C” of
Example Process for Disassembling Name Structure
The structure of the name “” may be disassembled (block 250) into a surname “” and a given name “”. Then, the disassembled structure of the name components “” and/or “” may be verified with respect to actual real name information to generate a degree of confidence that the name is an actual real name (block 255). For example, the surname “” may be compared with one or more lists or databases (e.g., blacklists or whitelists) of common or in-use Japanese surnames. In some example embodiments, the given name “” may be compared with one or more lists or databases of common or in-use Japanese given names. A degree of confidence may be generated based on one or both comparisons. At block 260, if the degree of confidence is above a certain threshold (e.g., 51% or higher), the name “” may be accepted (block 295, sub-process “A”). If not, process 200B may flow to sub-process “B”, as shown in
Alternate Example Process
For example, the surname of the received name may be one of the commonly used surnames in a list; alternatively, the surname may be on a list of names that are not real names (e.g., blacklist). At block 330, action is taken based on whether the list includes at least part of the name. For example, in the case of a whitelist, if the name is on the whitelist, the name may then be accepted as real name or potential real name. Alternatively, in the case of a blacklist, if the name is on the list, then the name may be rejected as a non-real name or potential non-real name. The name may be recorded or saved, for example, in a database.
If the name is not in any lists (e.g., no component or part of the name is in any whitelist or blacklist), an action taken based on the determining may be to reject the name, with or without advancing to alternative mechanisms (e.g., as shown in
In some examples, processes 200A, 200B, and 300 may be implemented with different, fewer, or more blocks. One or more of processes 200A, 200B, and 300 may be implemented as computer executable instructions, which can be stored on a medium, loaded onto one or processors of one or more computing devices, and executed as a computer-implemented method.
Example Computing Devices And Environments
Computing device 405 can be communicatively coupled to input/user interface 435 and output device/interface 440. Either one or both of input/user interface 435 and output device/interface 440 can be a wired or wireless interface and can be detachable. Input/user interface 435 may include any device, component, sensor, or interface, physical or virtual, that can be used to provide input (e.g., buttons, touch-screen interface, keyboard, a pointing/cursor control, microphone, camera, braille, motion sensor, optical reader, and/or the like). Output device/interface 440 may include a display, television, monitor, printer, speaker, braille, or the like. In some example embodiments, input/user interface 435 and output device/interface 440 can be embedded with or physically coupled to the computing device 405. In other example embodiments, other computing devices may function as or provide the functions of input/user interface 435 and output device/interface 440 for a computing device 405.
Examples of computing device 405 may include, but are not limited to, highly mobile devices (e.g., smartphones, devices in vehicles and other machines, devices carried by humans and animals, and the like), mobile devices (e.g., tablets, notebooks, laptops, personal computers, portable televisions, radios, and the like), and devices not designed for mobility (e.g., desktop computers, other computers, information kiosks, televisions with one or more processors embedded therein and/or coupled thereto, radios, and the like).
Computing device 405 can be communicatively coupled (e.g., via I/O interface 425) to external storage 445 and network 450 for communicating with any number of networked components, devices, and systems, including one or more computing devices of same or different configuration. Computing device 405 or any connected computing device can be functioning as, providing services of, or referred to as a server, client, thin server, general machine, special-purpose machine, or another label.
I/O interface 425 can include, but is not limited to, wired and/or wireless interfaces using any communication or I/O protocols or standards (e.g., Ethernet, 802.11x, Universal System Bus, WiMax, modem, a cellular network protocol, and the like) for communicating information to and/or from at least all the connected components, devices, and network in computing environment 400. Network 450 can be any network or combination of networks (e.g., the Internet, local area network, wide area network, a telephonic network, a cellular network, satellite network, and the like).
Computing device 405 can use and/or communicate using computer-usable or computer-readable media, including transitory media and non-transitory media. Transitory media include transmission media (e.g., metal cables, fiber optics), signals, carrier waves, and the like. Non-transitory media include magnetic media (e.g., disks and tapes), optical media (e.g., CD ROM, digital video disks, Blu-ray disks), solid state media (e.g., RAM, ROM, flash memory, solid-state storage), and other non-volatile storage or memory.
Computing device 405 can be used to implement techniques, methods, applications, processes, or computer-executable instructions to implement at least one embodiment (e.g., a described embodiment). Computer-executable instructions can be retrieved from transitory media, and stored on and retrieved from non-transitory media. The executable instructions can be originated from one or more of any programming, scripting, and machine languages (e.g., C, C++, C#, Java, Visual Basic, Python, Perl, JavaScript, and others).
Processor(s) 410 can execute under any operating system (OS) (not shown), in a native or virtual environment. To implement a described embodiment, one or more applications can be deployed that include logic unit 460, application programming interface (API) unit 465, input unit 470, output unit 475, language detection unit 480, verification unit 485, name determination unit 490, and inter-unit communication mechanism 495 for the different units to communicate with each other, with the OS, and with other applications (not shown). For example, language detection unit 480, verification unit 485, name determination unit 490 may implement one or more processes shown in
In some example embodiments, when information or an execution instruction is received by API unit 465, it may be communicated to one or more other units (e.g., logic unit 460, input unit 470, output unit 475, language detection unit 480, verification unit 485, name determination unit 490). For example, after input unit 470 has received a name, input unit 470 may use API unit 465 to communicate the name to language detection unit 480. Language detection unit 480 may, via API unit 465, interact with the verification unit 485 to verify whether the name is real. Using API unit 465, verification unit 485 may interact with name determination unit 490, which may use one or more blacklists and/or whitelists to determine whether the name is real. In some example embodiments, verification unit 485 may use one or more mechanisms as described in sub-process “B”,
In some examples, logic unit 460 may be configured to control the information flow among the units and direct the services provided by API unit 465, input unit 470, output unit 475, language detection unit 480, verification unit 485, name determination unit 490 in order to implement an embodiment described above. For example, the flow of one or more processes or implementations may be controlled by logic unit 460 alone or in conjunction with API unit 465.
Although a few example embodiments have been shown and described, these example embodiments are provided to convey the subject matter described herein to people who are familiar with this field. It should be understood that the subject matter described herein may be embodied in various forms without being limited to the described example embodiments. The subject matter described herein can be practiced without those specifically defined or described matters or with other or different elements or matters not described. It will be appreciated by those familiar with this field that changes may be made in these example embodiments without departing from the subject matter described herein as defined in the appended claims and their equivalents.