SCORING TRUSTWORTHINESS, COMPETENCE, AND/OR COMPATIBILITY OF ANY ENTITY FOR ACTIVITIES INCLUDING RECRUITING OR HIRING DECISIONS, COMPOSING A TEAM, INSURANCE UNDERWRITING, CREDIT DECISIONS, OR SHORTENING OR IMPROVING SALES CYCLES
20230116362 · 2023-04-13
Inventors
Cpc classification
G06F16/958
PHYSICS
H04L45/306
ELECTRICITY
H04L67/34
ELECTRICITY
G06Q20/4016
PHYSICS
G06Q20/42
PHYSICS
International classification
G06F16/28
PHYSICS
G06F16/958
PHYSICS
G06Q50/00
PHYSICS
H04L67/00
ELECTRICITY
Abstract
Systems and methods for recruiting, counter-terrorism/security, insurance underwriting, sales and marketing improvement, decisioning financial transactions and collections, and social scoring are provided. Machine learning can assign connectivity values to other community members, including individuals, companies, products, brands, cities or neighborhoods, etc. Connectivity values may be automatically harvested from or assigned by third parties or based on the frequency and/or type of interactions between community members. Connectivity values may represent such factors as alignment, reputation within the community, degree of trust, competence at one or more skills, or compatibility with others. The degree and type of connectivity between two entities may be assessed by computing a connectivity value based upon connections between entities and relative or absolute trust, competence and/or compatibility features of the connections. Connectivity values identify best prospects (customers, hires, dates), find off-grid people, underwrite insurance, ‘decision’ loans & collections, shorten sales cycles, etc.
Claims
1. A method for facilitating financial transactions comprising: transmitting, to a first user and potential members of a publication group, software for communications relating to trust-based transactions; receiving with a server, a request from the first user's software to initiate a first trust-based transaction; automatically determining a publication group to publish at least some information relating to the transaction, wherein determining the publication group comprises: accessing, with at least one server, information in a datastore relating to a network community; identifying, with the at least one server, paths in the network community from the first user to at least one potential member of the publication group; and identifying sub-processes required to calculate a connectivity value between the first user and the at least one potential member, wherein identifying the sub-processes comprises: identifying a plurality of links in the identified paths; for one or more identified links, accessing a data structure to identify nodes connected to the identified link; and for each identified node, creating an indication of a sub-process, wherein the sub-process comprises calculating an out-link weight for one or more out-links of the identified node; distributing the indications of the sub-processes to a plurality of processors arranged in a parallel computational framework; receiving, from the plurality of processors, calculated out-link weights for the identified nodes; calculating the connectivity value based on the calculated out-link weights; and adding the at least one potential member to the publication group based on the calculated connectivity value; publishing the information relating to the transaction to the publication group; and transmitting, to the publication group's software, information related to the transaction with which information a member of the publication group may initiate a second trust-based transaction.
2. The method of claim 1 further comprising determining whether the first transaction is public, and performing the steps of automatically determining a publication group and publishing the information, only if the first transaction is public.
3. The method of claim 1 wherein publishing the information comprises publishing a link to an application related to the first transaction.
4. The method of claim 3, wherein the published link allows the member of the publication group to access the application by activating the link.
5. The method of claim 1, further comprising pre-populating at least some information in the second transaction with information from the first transaction.
6. The method of claim 1 wherein determining the publication group comprises comparing the determined connectivity value to a threshold connectivity value.
7. The method of claim 1 wherein determining the publication group comprises determining a threshold path weight value.
8. The method of claim 1 wherein determining the publication group comprises accessing attribute flag information associated with the first transaction, wherein the attribute flag information is indicative of at least other users who may be interested in the first transaction.
9. The method of claim 8 wherein the attribute flag information identifies at least one affinity group whose members may be interested in the first transaction.
10. A system for facilitating financial transactions comprising processing circuitry configured to: receive with a server, a request from the first user's software to initiate a first trust-based transaction; automatically determine a publication group to publish at least some information relating to the transaction, wherein determining the publication group comprises: accessing, with at least one server, information in a datastore relating to a network community; identifying, with the at least one server, paths in the network community from the first user to at least one potential member of the publication group; and identifying sub-processes required to calculate a connectivity value between the first user and the at least one potential member, wherein identifying the sub-processes comprises: identifying a plurality of links in the identified paths; for one or more identified links, accessing a data structure to identify nodes connected to the identified link; and for each identified node, creating an indication of a sub-process, wherein the sub-process comprises calculating an out-link weight for one or more out-links of the identified node; distributing the indications of the sub-processes to a plurality of processors arranged in a parallel computational framework; receiving, from the plurality of processors, calculated out-link weights for the identified nodes; calculating the connectivity value based on the calculated out-link weights; and adding the at least one potential member to the publication group based on the calculated connectivity value; publish the information relating to the transaction to the publication group; and transmit, to the publication group's software, information related to the transaction with which information a member of the publication group may initiate a second trust-based transaction.
11. The system of claim 10 wherein the processing circuitry is further configured to determine if the first transaction is public, wherein the processing circuitry is configured to at least determine the publication group and publish the information relating to the first transaction to the publication group in response to determining that the first transaction is public.
12. The system of claim 10 wherein the processing circuitry is configured to publish the information by publishing a link to an application related to the first transaction.
13. The system of claim 12, wherein the published link allows the member of the publication group to access the application directly from activating the link.
14. The system of claim 10, wherein the processing circuitry is further configured to pre-populate at least some information in the second transaction with information from the first transaction.
15. The system of claim 14, wherein the processing circuitry is configured to pre-populate at least some information by pre-populating at least a principal amount.
16. The system of claim 10 wherein the processing circuitry is configured to determine the publication group by comparing the determined connectivity value to a threshold connectivity value.
17. The system of claim 10 wherein the processing circuitry is configured to determine the publication group by determining a threshold path weight value.
18. The system of claim 10 wherein the processing circuitry is configured to determine the publication group by accessing attribute flag information associated with an application related to the first transaction, wherein the attribute flag information is indicative of other users who may be interested in the application.
19. A method for facilitating financial transactions comprising: transmitting, to a first user and potential members of a publication group, software for communications relating to trust-based transactions; receiving with a server, a request from the first user's software to initiate a first trust-based transaction; determining whether the first transaction is public; if the first transaction is public, automatically determining a publication group to publish at least some information relating to the transaction, wherein determining the publication group comprises: accessing, with at least one server, information in a datastore relating to a network community; identifying, with the at least one server, paths in the network community from the first user to at least one potential member of the publication group; and identifying sub-processes required to calculate a connectivity value between the first user and the at least one potential member, wherein identifying the sub-processes comprises: identifying a plurality of links in the identified paths; for one or more identified links, accessing a data structure to identify nodes connected to the identified link; and for each identified node, creating an indication of a sub-process, wherein the sub-process comprises calculating an out-link weight for one or more out-links of the identified node; distributing the indications of the sub-processes to a plurality of processors arranged in a parallel computational framework; receiving, from the plurality of processors, calculated out-link weights for the identified nodes; calculating the connectivity value based on the calculated out-link weights; and adding the at least one potential member to the publication group based on the calculated connectivity value.
20. The method of claim 19 further comprising: if the first transaction is public: publishing the information relating to the transaction to the publication group; and transmitting, to the publication group's software, information related to the transaction with which information a member of the publication group may initiate a second trust-based transaction.
Description
BRIEF DESCRIPTION OF THE DRAWINGS
[0023] The above and other features of the present invention, its nature and various advantages will be more apparent upon consideration of the following detailed description, taken in conjunction with the accompanying drawings, and in which:
[0024]
[0025]
[0026]
[0027]
[0028]
[0029]
[0030]
DETAILED DESCRIPTION
[0031] Systems and methods for determining the connectivity between nodes in a network community are provided. As defined herein, a “node” may include any user terminal, network device, computer, mobile device, access point, robot, or any other electronic device capable of being uniquely identified within a network community. For example, nodes may include robots (or other machines) assigned unique serial numbers or network devices assigned unique network addresses. In some embodiments, a node may also represent an individual human being, entity (e.g., a legal entity, such as a public or private company, corporation, limited liability company (LLC), partnership, sole proprietorship, or charitable organization), concept (e.g., a social networking group, brand, advertising campaign, subgroup within a larger group), animal, city/town/village, parcel of land (which may be identified by land descriptions), or inanimate object (e.g., a car, aircraft, tool, other product, webpage, website, document, etc.). As also defined herein, a “network community” may include a collection of nodes and may represent any group of devices, individuals, or entities.
[0032] For example, all or some subset of the users of a social networking website or social networking service (or any other type of website or service, such as an online gaming community) may make up a single network community. Each user may be represented by a node in the network community. As another example, all the subscribers to a particular newsgroup or distribution list may make up a single network community, where each individual subscriber may be represented by a node in the network community. Any particular node may belong in zero, one, or more than one network community, or a node may be banned from all, or a subset of, the community. To facilitate network community additions, deletions, and link changes, in some embodiments a network community may be represented by a directed graph, or digraph, weighted digraph, tree, or any other suitable data structure.
[0033]
[0034] Communication network 104 may include any wired or wireless network, such as the Internet, WiMax, wide area cellular, or local area wireless network. Communication network 104 may also include personal area networks, such as Bluetooth and infrared networks. Communications on communications network 104 may be encrypted or otherwise secured using any suitable security or encryption protocol.
[0035] Application server 106, which may include any network server or virtual server, such as a file or web server, may access data sources 108 locally or over any suitable network connection. Application server 106 may also include processing circuitry (e.g., one or more microprocessors), memory (e.g., RAM, ROM, and hybrid types of memory), storage devices (e.g., hard drives, optical drives, and tape drives). The processing circuitry included in application server 106 may execute a server process for supporting the network connectivity determinations of the present invention, while access application 102 executes a corresponding client process. The processing circuitry included in application server 106 may also perform any of the calculations and computations described herein in connection with determining network connectivity. In some embodiments, a computer-readable medium with computer program logic recorded thereon is included within application server 106. The computer program logic may determine the connectivity between two or more nodes in a network community and it may or may not output such connectivity to a display screen or data store.
[0036] For example, application server 106 may access data sources 108 over the Internet, a secured private LAN, or any other communications network. Data sources 108 may include one or more third-party data sources, such as data from third-party social networking services, third-party ratings bureaus, document issuers (e.g., driver's license and license plate issuers, such as the Department of Motor Vehicles), government records, privately compiled records, insurance databases, etc. For example, data sources 108 may include user and relationship data (e.g., “friend” or “follower” data) from one or more of Facebook, MySpace, openSocial, Friendster, Bebo, hi5, Orkut, PerfSpot, Yahoo! 360, Gmail, Yahoo! Mail, Hotmail, other email-based services and accounts, LinkedIn, Twitter, Snapchat, Instagram, Flickr, Monster, Upwork, Freelancer, Google Buzz, Really Simply Syndication readers, or any other social networking website or information service. Data sources 108 may also include data stores and databases local to application server 106 containing relationship information about users accessing application server 106 via access application 102 (e.g., databases of addresses, legal records, transportation passenger lists, gambling patterns, political affiliations, vehicle license plate or identification numbers, universal product codes, news articles, business listings, hospital affiliations, university affiliations, purchase histories, employer affiliations, insurance claims, credit requests, professional organization affiliations, or other organizational affiliations).
[0037] Application server 106 may be in communication with one or more of data store 110, key-value store 112, and parallel computational framework 114. Data store 110, which may include any relational database management system (RDBMS), file server, or storage system, may store information relating to one or more network communities. For example, one or more of data tables 300 (
[0038] Parallel computational framework 114, which may include any parallel or distributed computational framework or cluster, may be configured to divide computational jobs into smaller jobs to be performed simultaneously, in a distributed fashion, or both. For example, parallel computational framework 114 may support data-intensive distributed applications by implementing a map/reduce computational paradigm where the applications may be divided into a plurality of small fragments of work, each of which may be executed or re-executed on any core processor in a cluster of cores. A suitable example of parallel computational framework 114 includes an Apache Hadoop cluster.
[0039] Parallel computational framework 114 may interface with key-value store 112, which also may take the form of a cluster of cores. Key-value store 112 may hold sets of key-value pairs for use with the map/reduce computational paradigm implemented by parallel computational framework 114. For example, parallel computational framework 114 may express a large distributed computation as a sequence of distributed operations on data sets of key-value pairs. User-defined map/reduce jobs may be executed across a plurality of nodes in the cluster. The processing and computations described herein may be performed, at least in part, by any type of processor or combination of processors. For example, various types of quantum processors (e.g., solid-state quantum processors and light-based quantum processors), artificial neural networks, and the like may be used to perform massively parallel computing and processing.
[0040] In some embodiments, parallel computational framework 114 may support two distinct phases, a “map” phase and a “reduce” phase. The input to the computation may include a data set of key-value pairs stored at key-value store 112. In the map phase, parallel computational framework 114 may split, or divide, the input data set into a large number of fragments and assign each fragment to a map task. Parallel computational framework 114 may also distribute the map tasks across the cluster of nodes on which it operates. Each map task may consume key-value pairs from its assigned fragment and produce a set of intermediate key-value pairs. For each input key-value pair, the map task may invoke a user defined map function that transmutes the input into a different key-value pair. Following the map phase, parallel computational framework 114 may sort the intermediate data set by key and produce a collection of tuples so that all the values associated with a particular key appear together. Parallel computational framework 114 may also partition the collection of tuples into a number of fragments equal to the number of reduce tasks.
[0041] In the reduce phase, each reduce task may consume the fragment of tuples assigned to it. For each such tuple, the reduce task may invoke a user-defined reduce function that transmutes the tuple into an output key-value pair. Parallel computational framework 114 may then distribute the many reduce tasks across the cluster of nodes and provide the appropriate fragment of intermediate data to each reduce task.
[0042] Tasks in each phase may be executed in a fault-tolerant manner, so that if one or more nodes fail during a computation the tasks assigned to such failed nodes may be redistributed across the remaining nodes. This behavior may allow for load balancing and for failed tasks to be re-executed with low runtime overhead.
[0043] Key-value store 112 may implement any distributed file system capable of storing large files reliably. For example key-value store 112 may implement Hadoop's own distributed file system (DFS) or a more scalable column-oriented distributed database, such as HBase. Such file systems or databases may include BigTable-like capabilities, such as support for an arbitrary number of table columns.
[0044] Although
[0045] Cluster of mobile devices 202 may include one or more mobile devices, such as PDAs, cellular telephones, mobile computers, or any other mobile computing device. Cluster of mobile devices 202 may also include any appliance (e.g., audio/video systems, microwaves, refrigerators, food processors) containing a microprocessor (e.g., with spare processing time), storage, or both. Application server 106 may instruct devices within cluster of mobile devices 202 to perform computation, storage, or both in a similar fashion as would have been distributed to multiple fixed cores by parallel computational framework 114 and the map/reduce computational paradigm. Each device in cluster of mobile devices 202 may perform a discrete computational job, storage job, or both. Application server 106 may combine the results of each distributed job and return a final result of the computation.
[0046]
[0047] Table 304 may store user connectivity values. User connectivity values may be positive, indicating some degree of trust between two or more parties, or may be negative, indicating some degree of distrust between two or more parties. In some embodiments, user connectivity values may be assigned automatically by the system (e.g., by application server 106 (
[0048] More complicated interactions (e.g., product or service sales or inquires) between two nodes may increase or decrease the user connectivity values connecting those two nodes by some larger fixed amount. In some embodiments, user connectivity values between two nodes may always be increased unless a user or node indicates that the interaction was unfavorable, not successfully completed, or otherwise adverse. For example, a transaction may not have been timely executed or an email exchange may have been particularly displeasing. Adverse interactions may automatically decrease user connectivity values while all other interactions may increase user connectivity values (or have no effect). In some embodiments, the magnitude of the user connectivity value change may be based on the content of the interactions. For example, a failed transaction involving a small monetary value may cause the user connectivity value to decrease less than a failed transaction involving a larger monetary value. In addition, user connectivity values may be automatically harvested using outside sources. For example, third-party data sources (such as ratings agencies and credit bureaus) may be automatically queried for connectivity information. This connectivity information may include completely objective information, completely subjective information, composite information that is partially objective and partially subjective, any other suitable connectivity information, or any combination of the foregoing.
[0049] In some embodiments, user connectivity values may be manually assigned by members of the network community. These values may represent, for example, the degree or level of trust, competence, or compatibility between two users or nodes or one node's assessment of another node's competence in some endeavor. As described above, user connectivity values may include a subjective component and an objective component in some embodiments. The subjective component may include a trustworthiness (or competence or compatibility) “score” indicative of how trustworthy (or competent or compatible) a first user or node finds a second user, node, community, or subcommunity. This score or value may be entirely subjective and based on interactions between the two users, nodes, or communities. A composite user connectivity value including subjective and objective components may also be used. For example, third-party information may be consulted to form an objective component based on, for example, the number of consumer complaints, credit score, insurance claims, job applications, employment complaints or reprimands, defaults, product returns, awards or honors, socio-economic factors (e.g., age, income, political, religious or other affiliations, and criminal history), or number of citations/hits in the media or in search engine searches. Third-party information may be accessed using communications network 104 (
[0050] Table 304 may store an identification of a link head, link tail, and user connectivity value for the link. Links may or may not be bidirectional. For example, a user connectivity value from node n.sub.1 to node n.sub.2 may be different (and completely separate) than a link from node n.sub.2 to node n.sub.1. Especially in the trust context described above, each user can assign his or her own user connectivity value to a link (i.e., two users need not trust each other an equal amount in some embodiments).
[0051] Table 306 may store an audit log of table 304. Table 306 may be analyzed to determine which nodes or links have changed in the network community. In some embodiments, a database trigger is used to automatically insert an audit record into table 306 whenever a change of the data in table 304 is detected. For example, a new link may be created, a link may be removed, and/or a user connectivity value may be changed. This audit log may allow for decisions related to connectivity values to be made prospectively (i.e., before an anticipated event). Such decisions may be made at the request of a user, or as part of an automated process, such as the processes described below with respect to
[0052]
[0053] Data structure 310 may include node table 312. In the example shown in
[0054]
[0055] For example, a user may wish to log into the connectivity system (or some loan, insurance application, credit transaction, sales evaluation, or financial transaction system that uses the connectivity system) using access application 102 (
[0056] Table 334 may include an indication of a person or node in the network community. For example, the person associated with table 334 may be an officer in a financial institution, a lender, a borrower, a donor, an insured, an underwriter, a buyer, or a seller. Officer table 336 may include a unique identifier representing the financial institution associated with the officer and identified in organization table 338. Donation table 340 and loan table 342 may include any suitable information related to donations or loans, respectively, available on the network. Donation table 340 may include such information as a unique identifier associated with a donation, a unique identifier associated with the donor, a unique identifier associated with the financial application, whether or not a tax receipt is needed, whether or not a tax receipt has been issued, the tax receipt number, the tax receipt date, and a status indicator. The status indicator may include “0” if the donation is still waiting for a check as a source of funding for the donation, a “1” if the donation is still waiting for an external payment system as a source of funding for the donation, “2” if the donation has been canceled by the user, the financial application, the officer, or financial institution, “3” if the donation is currently active, “4” is the donation has been completed, “5” if the donor has defaulted, “6” is the donation is associated with a refund amount.
[0057] Similarly, loan table 342 may include a unique identifier associated with a loan, a unique identifier associated with the financial application, a unique identifier associated with the lender, the principal of the loan, the balance of the loan (e.g., the remaining principal on the loan), and a status indication. The status indicator may be the same as the status indicators described above with respect to the donation table. Financial application table 344 may identify the loans, donations, or other types of financial applications available in the network. Financial application table 344 may include a unique identifier for the application, a string description associated with the application (which may also include attribute flags and other metadata associated with the financial application and used in determining publication groups, as described in more detail with regard to
[0058] In some embodiments, the description field in financial application table 344 may include “LIKE” and “DISLIKE” flags identifying affinity groups, blogs, newsgroups, and other information used to determine what nodes or users may be interested or not interested in a particular financial application. These flags may be used in determining publication groups, as described in more detail below. For example, a mortgage type financial application may include a “LIKE” flag for users or nodes interested in securing real property (e.g., users or nodes belonging to a real estate affinity group or real estate blog or newsgroup). As another example, a donation type financial application to support same-sex marriage may include a “LIKE” flag for users or nodes subscribed to the Human Rights Campaign or American Civil Liberties Union affinity group and a “DISLIKE” flag for users or nodes belonging to “Yes on Prop 8” or defense of marriage affinity group. Other attribute flags may also be defined in financial application table 344. These flags may be created by the sponsor or creator of the financial application and may be customized by users initiating financial transactions, in some embodiments.
[0059] Repayment schedule table 346 may be associated with each loan in loan table 342. Repayment schedule table 346 may include a unique identifier associated with the loan to which the repayment schedule relates, the current payment number, the due date for the net payment, the total amount due, and the total amount paid. Repayment schedule table 346 may be automatically generated, in some embodiments, whenever a new loan is created or initiated by a user and approved.
[0060] In a typical usage scenario, a user may be notified when certain users in the user's network have initiated a new financial transaction using a financial application identified in financial application table 344. For example, in some embodiments, users are notified whenever any other user initiates a financial transaction. In other embodiments, users are only notified about financial transactions made by other users meeting some threshold path weight or threshold user connectivity value with the to-be-notified user. For example, a message may be sent to second user that a first user has loaned $10,000 to “Save the Pandas” and that the specific financial application is the “Wildlife Sanctuary Project.” This message may appear in email, as a pop-up message, or displayed as a link on the user's homepage, profile page, or initial log-in page.
[0061] The notified user may also decide to initiate a financial transaction using the same financial application. The user may then decide whether to fund the transaction using a check or using an external payment system (such as PayPal). Before the funding is received, the transaction may be marked as “waiting” for either a check or external payment system. For example, the status indicators in donation table 340 or loan table 342 may be set to “0” or “1”. A repayment schedule may then be generated. For example, repayment schedule table 346 may be populated.
[0062] After funding has been received, the transaction may be marked as “active” and repayments may begin (depending on the transaction type). Repayments may be made, in some embodiments, by mailing a check, direct deposit, using an external payment system, or using any other suitable mechanism.
[0063] Although
[0064]
[0065] In some embodiments, the processes described with respect to
[0066] In some embodiments, the processes described with respect to
[0067] At step 402, a determination is made whether at least one node has changed in the network community. As described above, an audit record may be inserted into table 306 (
[0068] As described above, step 418 may be executed one or more times. This step may be operative to grow paths by a single link. Each iteration of step 418 may take as input the results of a previous iteration of step 418 so that paths may grow by more than one link, if desired. In the example of
[0069] If a node change is not detected at step 404, then process 400 enters a sleep mode at step 406. For example, in some embodiments, an application thread or process may continuously check to determine if at least one node or link has changed in the network community. In other embodiments, the application thread or process may periodically check for changed links and nodes every n seconds, where n is any positive number. After the paths are calculated that go through a changed node at step 416 or after a period of sleep at step 406, process 400 may determine whether or not to loop at step 408. For example, if all changed nodes have been updated, then process 400 may stop at step 418. If, however, there are more changed nodes or links to process, then process 400 may loop at step 408 and return to step 404.
[0070] In practice, one or more steps shown in process 400 may be combined with other steps, performed in any suitable order, performed in parallel (e.g., simultaneously or substantially simultaneously), or removed.
[0071]
[0072] If there are no more link changes at step 428, then, in reduce phase 436, a determination may be made at step 438 that there are more nodes with mapped link changes to process. If so, then the next node and its link changes may be retrieved at step 440. The most recent link changes may be preserved at step 442 while any intermediate link changes are replaced by more recent changes. For example, the timestamp stored in table 306 (
[0073] As shown in
[0074] If there are no more changed nodes at step 454, then, in reduce phase 460, a determination may be made at step 462 that there are more nodes to process. If so, then the next node may be retrieved at step 464. At step 466, the in-links and out-links associated with the node may be written to a key-value store (e.g., key-value store 112 of
[0075] As shown in
[0076] If there are no more changed records at step 472, then, in reduce phase 480, a determination may be made at step 482 that there are more node to process. If so, then the next node may be retrieved at step 484. At step 486, new records may be written to the output file. In some embodiments, the records written at step 486 may include records of the form (node identifier, empty path set for the node identifier). If there are no more nodes to process at step 482, the process may stop at step 488.
[0077] As shown in
[0078] If there are no more records at step 492, then, in reduce phase 502, a determination may be made at step 504 that there are more node identifiers with their mapped (bucket type, changed node identifier, bucket identifiers) records to process. If so, then at step 506, if the bucket type is “out”, out-buckets with the given bucket identifiers may be searched and paths with the changed node identifier may be removed. At step 508, if the bucket type is “in”, in-buckets with the given bucket identifiers may be searched and paths with the changed node identifier may be removed. If there are no more records to process at step 504, the process may stop at step 510.
[0079] As shown in
[0080] If there are no more records at step 514, then, in reduce phase 520, a determination may be made at step 522 that there are more node identifiers with mapped paths to process. If so, then at step 524, new records of the form (node identifier, mapped paths) (or any other suitable form) may be written to the output file. If there are no more records to process at step 522, the process may stop at step 526.
[0081] The process shown in
[0082] As shown in
[0083] If there are no more records at step 530, then, in reduce phase 536, a determination may be made at step 538 that there are more node identifiers with mapped paths to process. If so, then at step 540, if the path tail identifier equals the node identifier, then that path may be added to the node's “out” bucket for the path head identifier. At step 542, if the path head identifier equals the node identifier, then that path may be added to the node's “in” bucket for the path tail identifier. At step 544, the node may be saved. If there are no more records to process at step 538, the process may stop at step 546.
[0084] As shown in
[0085] If there are no more records at step 550, then, in reduce phase 556, a determination may be made at step 558 that there are more node identifiers with mapped paths to process. If so, then at step 560, if the path tail identifier equals the node identifier, then that path may be added to the node's “out” bucket for the path head identifier. At step 562, if the path head identifier equals the node identifier, then that path may be added to the node's “in” bucket for the path tail identifier. At step 564, the node may be saved. If there are no more records to process at step 558, the process may stop at step 566.
[0086]
[0087] At step 582, for each source node “out” bucket, the corresponding “in” bucket of target nodes may be located. For example, column 320 of node table 312 (both of
[0088] Having returned all paths between the source and target node (of length less than or equal to three, or any other suitable value depending on the number of iterations of the process shown in
t.sub.network=Σt.sub.path×w.sub.path (7)
where t.sub.path is the user connectivity value for a path (given in accordance with equation (5)) and w.sub.path is the normalized weight for that path. The network connectivity value may then be held, output by processing circuitry of application server 106, and/or stored on data store 110 (
[0089] As another example, credit-granting decisions may be made by third parties based, at least in part, on network connectivity values. One or more queries for a network connectivity value may be automatically executed by the credit-granting institution (e.g., a bank, private financial institution, department store) as part of the credit application process. For example, a query for a network connectivity value between the applicant and the credit-granting institution itself (or its directors, board members, etc.) and between the applicant and one or more trusted nodes may be automatically executed as part of the credit application process. The one or more network connectivity values returned to the credit-granting institution may then be used as an input to a proprietary credit-granting decision algorithm. In this way, a credit-granting decision may be based on a more traditional component (e.g., occupation, income, repayment delinquencies, and credit score) and a network connectivity component. Each component may be assigned a weight and a weighted sum or weighted average may be computed. The weighted sum or average may then be used directly to make an automatic credit-granting decision for the applicant. The weights assigned to each component of the weighted sum or average may be based on such factors as the applicant's credit history with the financial institution, the amount of credit requested, the degree of confidence in the trusted nodes, any other suitable factor, or any combination of the foregoing factors. In some embodiments, the credit-granting or other decisions made by third parties may be made based entirely on network connectivity values.
[0090] In practice, one or more steps shown in process 580 may be combined with other steps, performed in any suitable order, performed in parallel (e.g., simultaneously or substantially simultaneously), or removed. In addition, as described above, various threshold functions may be used in order to reduce computational complexity. For example, one or more threshold functions defining the maximum and/or minimum number of links to traverse may be defined. Paths containing more than the maximum number of links or less than the minimum number of links specified by the threshold function(s) may not be considered in the network connectivity determination. In addition, various maximum and/or minimum threshold functions relating to link and path weights may be defined. Links or paths above a maximum threshold weight or below a minimum threshold weight specified by the threshold function(s) may not be considered in the network connectivity determination.
[0091] Although process 580 describes a single user query for all paths from a first node to a target node, in actual implementations groups of nodes may initiate a single query for all the paths from each node in the group to a particular target node. For example, multiple members of a network community may all initiate a group query to a target node. Process 580 may return an individual network connectivity value for each querying node in the group or a single composite network connectivity value taking into account all the nodes in the querying group. For example, the individual network connectivity values may be averaged to form a composite value or some weighted average may be used. The weights assigned to each individual network connectivity value may be based on seniority in the community (e.g., how long each node has been a member in the community or other indicators of stability or seniority), rank, or social stature. In addition, in some embodiments, a user may initiate a request for network connectivity values for multiple target nodes in a single query. For example, node n.sub.1 may wish to determine network connectivity values between it and multiple other nodes. For example, the multiple other nodes may represent several candidates for initiating a particular transaction with node n.sub.1. By querying for all the network connectivity values in a single query, the computations may be distributed in a parallel fashion to multiple cores so that some or all of the results are computed substantially simultaneously.
[0092] In addition, queries may be initiated in a number of ways. For example, a user (represented by a source node) may identify another user (represented by a target node) in order to automatically initiate process 580. A user may identify the target node in any suitable way, for example, by selecting the target node from a visual display, graph, or tree, by inputting or selecting a username, handle, network address, email address, telephone number, geographic coordinates, or unique identifier associated with the target node, or by speaking a predetermined command (e.g., “query node 1” or “query node group 1, 5, 9” where 1, 5, and 9 represent unique node identifiers). After an identification of the target node or nodes is received, process 520 may be automatically executed. The results of the process (e.g., the individual or composite network connectivity values) may then be automatically sent to one or more third-party services or processes as described above.
[0093] In an embodiment, a user may utilize access application 102 to generate a user query that is sent to access application server 106 over communications network 104 (see also,
[0094] In some embodiments, a user may utilize access application 102 to provide manual assignments of at least partially subjective indications of how trustworthy the target node is. For example, the user may specify that he or she trusts a selected target node (e.g., a selected “friend” or “follower”) to a particular degree. The particular degree may be in the form of a percentage that represents the user's perception of how trustworthy the target node is. The user may provide this indication before, after, or during process 580 described above. The indication provided by the user (e.g., the at least partially subjective indications of trustworthiness) may then be automatically sent to one or more third-party services or processes as described above. In some embodiments, the indications provided by the user may cause a node and/or link to change in a network community. This change may cause a determination to be made that at least one node and/or link has changed in the network community, which in turn triggers various processes as described with respect to
[0095] In some embodiments, a user may utilize access application 102 to interact with or explore a network community. For example, a user may be presented with an interactive visualization that includes one or more implicit or explicit representations of connectivity values between the user and other individuals and/or entities within the network community. This interactive visualization may allow the user to better understand what other individuals and/or entities they may trust within a network community, and/or may encourage and/or discourage particular interactions within a user's associated network community or communities.
[0096] In some embodiments, a path counting approach may be used in addition to or in place of the weighted link approach described above. Processing circuitry (e.g., of application server 106 (
[0097]
[0098] In practice, one or more steps shown in process 600 may be combined with other steps, performed in any suitable order, performed in parallel (e.g., simultaneously or substantially simultaneously), or removed.
[0099]
[0100] At step 706, a publication group is determined. For example, all users or nodes meeting or exceeding a minimum threshold connectivity value and/or not exceeding a maximum threshold connectivity value with the first user may be added to the publication group. As another example, all nodes or users meeting or exceeding some minimum threshold path weight and/or not exceeding a maximum threshold path weight to the first user may be added to the publication group. In some embodiments, the first user is given an opportunity to select the publication group or groups to which the user wants transaction information to be published. For example, the user may specify custom connectivity value maximum/minimum thresholds, custom path weight maximum/minimum thresholds, or both. This threshold value (or values) may then be used to determine the appropriate publication group. The user may also be given an opportunity to view a listing of publication group members, add additional members, and remove existing members, if desired.
[0101] In some embodiments, publication groups may be further refined using additional information known about other nodes or users in the network. For example, a first user may initiate a donation transaction for a wildlife refuge. In determining the appropriate publication group, nodes with high connectivity values with a known wildlife affinity or support group may be automatically added to the publication group, whether or not they meet the path weight or connectivity threshold values. Application server 106 (
[0102] At step 708, transaction information may be published to the selected publication group or groups. Publication may take a variety of forms, including email messages, text messages, voicemails, listings on a homepage, listings on a profile page, listings on a shared-access or community page, postings to a discussion forum, notification messages, other suitable notifications, or any combination of the foregoing. The type of notifications may be dependent on the active sign-in profile, in some embodiments. For example, if the active sign-in profile is for an email account provider, at least some of the notifications may take the form of email messages. If the active sign-in profile is for a social networking service provider, at least some of the notifications may take the form of provider notifications, wall postings, profile page postings, or the like.
[0103] At step 710, a determination is made whether a second user (e.g., a member of the publication group) has accessed the same financial application. In some embodiments, the second user may access the same financial application directly from the publication. For example, a published notification may include a link (e.g., hyperlink) to the financial application. The second user may directly access the financial application by activating the link (e.g., by clicking or selecting the link). In some embodiments, at least some of the information from the first user's financial transaction is automatically carried over to the second user's transaction, allowing the second user to efficiently execute a partly or wholly-identical transaction as the first user. For example, if the transaction is a donation, the donation amount (or more generically the principal) from the first user's transaction may be pre-populated in the electronic forms associated with the second user's transaction. In that way, users may be encouraged to donate (or borrow) the same amount as the first user. In some embodiments, users are not allowed to change pre-populated information (e.g., so as to encourage a minimum level of charitable giving). In other embodiments, pre-populated information may be changed by the user. If at step 710 the second user does access the same financial application, a new financial transaction may be processed on behalf of the second user at step 712. If applicable, a repayment schedule may also be automatically generated at step 714. For example table 346 may be automatically populated, if the financial transaction is a loan.
[0104] In processing financial transactions, connectivity values may be used to determine eligibility of the lender, borrower, or both (in the case of a loan transaction). For example, eligible borrowers may need to meet a threshold connectivity value with the lender, the lending institution, one or more officers or directors of the lending institution, or any combination of the foregoing. In addition, as described above, third-party processes may make automatic transaction decisions based, at least in part, the connectivity values. For example, in some embodiments, at least three threshold network connectivity values may be defined, N.sub.1, N.sub.2, and N.sub.3, where N.sub.1>N.sub.2>N.sub.3. Potential borrowers may be automatically approved for the financial transaction if they meet the threshold network connectivity value N.sub.1. If borrowers fail to meet the threshold network connectivity value N.sub.1, but meet threshold network connectivity value N.sub.2, then a composite score based on the actual network connectivity value and a third-party ratings agency (such as a credit ratings bureau score) may be used to determine the approval status for the financial transaction. If potential borrowers do not meet threshold network connectivity value N.sub.2, but meet threshold network connectivity value N.sub.3, these potential borrowers may be referred for manual processing. If potential borrowers do not meet threshold network connectivity value N.sub.3, these potential borrowers may be automatically denied participation in the financial transaction. The values of N.sub.1, N.sub.2, and N.sub.3 may be specified by the lending institution, an officer of the lending institution, or the financial application.
[0105] In practice, one or more steps shown in process 700 may be combined with other steps, performed in any suitable order, performed in parallel (e.g., simultaneously or substantially simultaneously), or removed. In some embodiments, process 700 may be used to facilitate other transactions, such as identity assessments, security risk assessments, or any other transaction that can take advantage of user connectivity values.
[0106] Each equation presented above should be construed as a class of equations of a similar kind, with the actual equation presented being one representative example of the class. For example, the equations presented above include all mathematically equivalent versions of those equations, reductions, simplifications, normalizations, and other equations of the same degree.
[0107] The above described embodiments of the invention are presented for purposes of illustration and not of limitation. The following claims give additional embodiments of the present invention.