The present technology pertains to identity management, and more specifically pertains to the authentication and authorization associated with users within or across platforms and devices.
The field of identity management has grown in response to the proliferation of digital devices, platforms, and applications in the 21st century. For many years using third-party tracking cookies, also known as web cookies, was the method of choice for developers wanting to track and authenticate users. Web cookies are small pieces of data that are stored on a user's web browser when a user accesses content such as a website. Every time a user loads the website, the browser sends a cookie back to a server where the cookie is used to identify a user and notify the website of the user's previous activities. Websites can then use the information they gather to provide insight into consumers' patterns of behavior, interests, etc., which advertisers may use to reach consumers as efficiently and cost-effectively as possible.
As targeted advertising in the digital space continues to advance, many companies are moving away from the collection of third-party cookies to reach consumers. Many mobile applications do not support cookies. Moreover, companies are increasingly using their own proprietary user identifiers (user IDs) to identify unique users across devices and platforms as diverse as desktop computers running Linux to mobile phones or wearable computers running Android. For example, a company such as Apple Inc. of Cupertino, Calif., or Google Inc. of Mountain View, Calif., can monitor a user's behavior using an identifierForAdvertisers (IDFA) or an Android ID, respectively. These IDs allow companies to gain insight into user behavior regardless of whether a user is at their desktop computer, their smart TV, or using any number of mobile devices.
Companies that track user activity work with multiple parties to monetize the information they collect about users. Advertisement exchanges, supply-side platforms (SSPs), and demand-side platforms (DSPs), for example, receive identification information from companies. However, in some cases an identifier such as an IDFA or an Android ID is not passed along to a receiving party. In some cases a hashed version of an ID is provided. Still in other cases an arbitrary user ID is provided. Often times, this leaves companies that receive customer information with disparate and fragmented information. The company can have some information about a customer that comes from Apple, some information about a customer that comes from Google, and some information from companies such as Facebook Inc. of Menlo Park, Calif., Twitter Inc. of San Francisco, Calif., etc., while not knowing that a portion of the received information all corresponds to a single unique user. Thus, companies that receive multiple alias IDs are faced with the difficult task of identifying unique users based on disparate and fragmented information derived from a variety of platforms and devices.
Additional features and advantages of the disclosure will be set forth in the description which follows, and in part will be obvious from the description, or can be learned by practice of the herein disclosed principles. The features and advantages of the disclosure can be realized and obtained by means of the instruments and combinations particularly pointed out in the appended claims. These and other features of the disclosure will become more fully apparent from the following description and appended claims, or can be learned by the practice of the principles set forth herein.
Disclosed are systems, methods, and non-transitory computer-readable storage media for managing information associated with users. In particular, systems and methods for determining co-occurrences of items of inclusion data corresponding to the same user (also referred to as a “unique user,” or “same unique user”) are disclosed. In various, non-limiting embodiments discussed herein, methods are disclosed wherein a system receives data corresponding to a history of multiple network transactions and attributes related to those transactions (collectively referred to herein as “network transaction attributes” or “attributes”), identifies co-occurrences of data that can correspond to the same user, and determines a probability that the various sets of data correspond to the same unique user.
In various embodiments discussed herein, a system may receive a user ID from a provider. The user ID can come in various types. For example, a user ID can be an IDFA, an Android ID, a web cookie, a hashed version of a user ID, etc. Each user ID is associated with numerous attributes. For example, a user ID can be associated with one or more electronic devices, media access control (MAC) addresses, internet protocol (IP) addresses, geographic locations, operating systems, browser histories, application usage histories, etc. These attributes can be items of inclusion data (e.g., data that can identify a unique user), or these attributes can be items of exclusion data (e.g., data that indicates that two user IDs do not correspond to a unique user). Of course, some attributes can be inclusion data and/or exclusion data based on the embodiment in which they are used.
When attempting to determine whether two user IDs correspond to the same user, various techniques may be applied. For example, the user IDs can be compared to one another to determine if an exact match exists. User IDs can be hashed, or reverse hashed, and compared in a similar fashion. Further, attributes corresponding to user IDs can be compared in an attempt to determine whether the user IDs correspond to the same user.
In order to describe the manner in which the above-recited and other advantages and features of the disclosure can be obtained, a more particular description of the principles briefly described above will be rendered by reference to specific embodiments thereof which are illustrated in the appended drawings. Understanding that these drawings depict only exemplary embodiments of the disclosure and are not therefore to be considered to be limiting of its scope, the principles herein are described and explained with additional specificity and detail through the use of the accompanying drawings in which:
Various embodiments of the disclosure are discussed in detail below. While specific implementations are discussed, it should be understood that this is done for illustration purposes only. A person skilled in the relevant art will recognize that other components and configurations may be used without parting from the spirit and scope of the disclosure. The disclosed technology addresses the need in the art for effective and efficient user identity management.
As used herein the term “configured” shall be considered to interchangeably be used to refer to configured and configurable, unless the term “configurable” is explicitly used to distinguish from “configured”. The proper understanding of the term will be apparent to persons of ordinary skill in the art in the context in which the term is used.
As used herein, the term “user” shall be considered to mean a user of an electronic device(s). Actions performed by a user in the context of computer software shall be considered to be actions taken by a user to provide an input to the electronic device(s) to cause the electronic device to perform the steps embodied in computer software.
An exemplary system configuration 100 is illustrated in
In system 100, user information suppliers 1101, 1102, . . . , 110n (collectively “110”) can deliver network transaction and attributes related to the network transactions via network 104 by direct and/or indirect communications with a user identification system 120. Information suppliers and user identification systems can be any network enabled client devices, such as servers or desktop computers. User identification systems can concurrently accept connections from and interact with multiple user information suppliers, and vice-versa.
The user information supplier can receive a request for electronic content, such as a dataset 200 (of
A user identification system can include one or more databases 1601, 1602, . . . , 160n (collectively “160”) to store content. This content can include a dataset comprising user IDs and related attributes. These related attributes can include inclusion data and/or exclusion data. User IDs can be used by an exact match identifier 140. An exact match identifier identifies exact matches, which will be described in greater detail below. User IDs and related attributes can be used by a probabilistic match identifier. A probabilistic match identifier identifies probable matches, as will be also be described in greater detail below.
Inclusion data can be data that indicates that two or more user IDs can correspond with the same user. Any attribute can be a piece of inclusion data. Inclusion data can be data that applies to a relatively small group of people (e.g., less than 50,000, less than 10,000, or less than 1,000). Inclusion data can include temporal or location data (e.g., the number of devices using a given internet protocol (IP) address at a particular point in time, or the number of devices that used a given IP address over a week). Inclusion data can be used to filter user IDs. For example, a dataset of user IDs and related attributes stored in the user identification system can be searched to determine how many users visited a coffee shop in a particular month.
Exclusion data can be data that indicates that two or more user IDs in a given dataset do not correspond to the same user. Exclusion data can include any attribute. Exclusion data can include device information. Exclusion data can also include temporal or location data (e.g., data that indicates that two user IDs were at different places at the same time). For example, exclusion data can indicate that two users were at two different coffee shops at the same time.
As briefly addressed above, the term “attributes” refers to a history of multiple network transactions, attributes associated with those network transactions, and the behavior of users associated with one or more user IDs. Attributes can include channel characteristics, demographic characteristics, behavioral characteristics, and spatial-temporal characteristics. Channel characteristics can define the specific delivery channel being used to deliver data across a network. For example, channel characteristics can include a type of electronic content, a type of device or user terminal, a type of operating system, a carrier or network provider, or any other characteristic that defines a specific delivery channel for a content package. Spatial-temporal characteristics can define a location, a location zone, a date, a time, or any other characteristic that defines a geographic location and/or a time for delivery of a content package. Demographic characteristics can define characteristics of the users corresponding to the user IDs. For example, demographic characteristics can include age, income, ethnicity, gender, occupation, or any other attributes. Behavioral characteristics can define user behaviors for one or more different types of content, separately or in combination with any other attributes. That is, different behavioral characteristics can be associated with different channel, demographic, or spatial-temporal characteristics. Attributes can also include characteristics descriptive of a user's state of mind including characteristics indicative of how likely a user is to click on or convert an item of invitational content if it were displayed to the user. Attributes can be learned directly or derived indirectly from a variety of sources or data suppliers. In some embodiments, attributes can be collected from one or more datasets, as discussed herein.
While the user identification system is presented with specific components, it should be understood by one skilled in the art, that the architectural configuration of the user identification system is simply one possible configuration and that other configurations with more or less components are also possible.
As discussed above, user IDs can come in various formats and types. For example,
Below, descriptions of various non-limiting methods and systems are described wherein exact matching is used, and wherein probabilistic matching is used. In some embodiments, exact matching can be used first to determine whether exact matches exist, then probabilistic matching can be used to determine the probability of a match existing. Sometimes only one of these methods may be used, or both may be used in any order (e.g., only using exact matching, or using probabilistic matching followed by exact matching). In some embodiments, a graphical user interface (GUI) may be used to determine the order of the application of exact matching and probabilistic matching.
With exact matches, a match either: (1) exists; or (2) does not exist. For example, if two user IDs match, they can be determined to be an exact match. As another example, if a hashed version of at least one of two or more user IDs match, those two or more user IDs can be an exact match. Similarly, if at least one of two or more user IDs is reverse hashed, and that reverse hash is found to match another user ID, an exact match can exist.
For example,
As one skilled in the art would understand, user IDs may be forward hashed using a variety of hashing algorithms or reverse hashed using a variety of hashing algorithms. User IDs may then compared to other user IDs, which may or may not have been hashed one or more times, to determine whether an exact match exists. As an example, if a dataset of user IDs were received by the system, and at least two of the user IDs shown in nodes 310, 320, 330, 340 and/or 350 appeared in the dataset, an exact match could be made by hashing or reverse hashing the user IDs shown in nodes 310, 320, 330, 340 and/or 350.
It should be understood by one skilled in the art that a system may receive a dataset in a variety of formats, and that a dataset can comprise a variety of attributes. For example, while a user ID can correspond with a user's name, address, gender and age, a user ID can also correspond to numerous other attributes such as device attributes, usage attributes, demographic attributes, behavioral attributes, temporal attributes, location attributes, etc. For example such attributes can include: device types, manufacturer information, timestamps, timestamps associated with various network transactions, MAC addresses, IP addresses, browser histories, operating system version, previous operating system versions, dates, user ethnicities, user occupations, shopping histories, advertisement conversion histories, carriers, network types, internet service providers (ISPs), keyboard settings, whether a user is about to have a baby, whether a user want a new car, etc.
With probabilistic matching, attributes corresponding with user IDs are compared to determine whether multiple user IDs correspond to the same unique user. In some embodiments, probabilistic matching is referred to as fingerprinting. As will be discussed below, comparisons can be made using inclusion data, which indicates whether two user IDs correspond to the same unique user. Conversely, in some embodiments comparisons can be made using exclusion data, which indicates whether two user IDs correspond to different unique users.
Probabilistic matching differs from exact matching in that rather than determining that two or more user IDs either do or do not correspond to the same user based on an exact match or not of two user IDs, values are assigned corresponding to a probability that the two or more (usually different) user IDs correspond to the same user. As used herein, the terms probability and a value corresponding to a probability are used interchangeably. In one example, determining that two or more user IDs demonstrate a history of connecting to the same IP addresses can indicate that there is a 70% probability that the two or more user IDs correspond to the same user. In another example, determining that two or more user IDs demonstrate a history of traveling frequently between the same few locations (e.g., work, home, a coffee shop) can indicate that there is a 90% probability that the two or more user IDs correspond to the same user. As a different example, determining that the two or more user IDs correspond to an identical MAC address can indicate that there is an 80% probability that the two or more user IDs correspond to the same user. In general, the likelihood that two or more IDs correspond to the same user increases when there are more identical attributes that correspond to the two or more user IDs. Moreover, the threshold probability required to determine a potential match may be based on a predetermined probability which may be configured by a user, or the threshold probability may be dynamic and change over time. For example, a 70% probability that two or more user IDs are the same can be enough for the system to indicate that a probable match (i.e., when two or more user IDs more likely correspond to the same user than not) has been found. In other cases, a probability of 90%, 99%, or more can be required for the system to indicate that a probable match has been found. The exact probability required is configurable by a system administrator.
In some embodiments, a subset of the dataset of user IDs is created based at least in part on probabilistic matching. In other words, a subset may be created comprising user IDs and their corresponding attributes based on a comparison of inclusion data. For example, if a particular threshold probability is met when comparing the inclusion data of two or more user IDs, the two or more user IDs are placed in a subset together as being possible that the two or more user IDs all represent the same user. Further, in some embodiments, the subset created by comparing inclusion data may further be analyzed to determine entries (i.e., user IDs) that do not correspond to the same users based on exclusion data. For example, of a subset comprising two or more user IDs that met a certain threshold of probability, user IDs that use different operating systems at the same time can be removed from the subset. In some embodiments, the order of applying inclusion data or exclusion data to derive a subset of a dataset, or a subset of another subset, may be reversed (i.e., exclusion data can be applied first to prune a dataset of user IDs, and then inclusion data can be applied to determine whether remaining entries correspond to the same unique user). Additional examples of these two methods of comparing attributes will be discussed in greater detail below.
Probabilistic matching can also assist with ID churn management. ID churn refers to instances where a unique user changes IDs. For example, a user can be associated with one ID for a period of time before changing IDs. In such a case, although probabilistic matching may not compare attributes that occur at the same time, probabilistic matching may compare other attributes that occur at different times. For example, when determining whether a user has changed user IDs, the system can determine whether the times that the user IDs were active overlap or not.
As briefly addressed above, in some embodiments, a system can determine the probability that two or more user IDs correspond to the same unique user. To do this, a system can apply inclusion data to determine a probability. In some embodiments, a subset of user IDs is created comprising IDs that match based on the application of the inclusion data the dataset. As used herein, the application of inclusion data to derive possible matches may be referred to as inclusive comparisons. In some embodiments, a subset can be created that stores user IDs and their attributes after inclusion data is applied to a dataset of user IDs.
Inclusion data may include any data that can be used to indicate that two user IDs correspond to the same user. For example, various attributes can indicate that a first ID and a second ID are probably the same user based on the frequency of the co-occurrence of two or more items of inclusive data corresponding to the first ID and the second ID. Items of inclusive data may indicate that that a particular user ID connects to a network via a particular IP address at a particular time. While the fact that a particular user ID connects to a particular IP address at a particular time might not identify a unique user by itself, other attributes may be analyzed in combination to identify unique users. For example, a particular user ID can connect to a plurality of networks at particular times, or over the course of a period, such as day, week, or month, etc. If two or more user IDs concurrently share the same attributes, the probability of a match may be high.
In some embodiments, a system can identify two or more locations associated with a user ID, and then determine whether other user IDs are associated with the same two locations. For example, an analysis of a dataset can indicate that two or more user IDs connect to a network at a house in the mornings and in the evenings. These attributes can also indicate that the user IDs connect to a network at a workplace during the weekdays. Also, these attributes can indicate that a user frequently connects to a network at a coffee shop every morning.
Similarly, combinations of other attributes can be used to determine a probability of whether two user IDs correspond to the same user. For example, application history can be examined. If a first device (e.g., a tablet computer) associated with a first user ID uses the same applications as those on a second device (e.g., a smart phone) associated with a second user ID, the probability that the two user IDs correspond to the same user can increase. In addition, if it is determined that a user logs into a particular application with the same username on the first device and the second device, the probability that the two user IDs correspond to the same user can increase even more.
In some embodiments, once a subset of user IDs is created after applying inclusion data to the dataset, exclusion data can be applied. Exclusion data is any data that can be used to determine that two or more user IDs do not correspond with the same user. As with inclusive comparisons, attributes, or a combination of attributes, can be compared to determine that two user IDs do not correspond to the same user. In some embodiments the process can be reversed such that the exclusion data is applied first and the inclusion data is applied after. In some cases only one set of inclusion or exclusion data is applied.
For example, determining that two user IDs were at a different geographic location at the same time can reduce the probability of a match. In some embodiments, at least one entry can be removed either from a dataset or a subset of a dataset. As another example, if one user ID corresponded with a new version of an operating system at some time in the past, while a second user ID corresponded with an older version of the same operating system at a more recent time, a determination can be made that the two user IDs are do not correspond to the same user. To further illustrate this example, if a first user ID corresponded with a device running Apple's operating system iOS 7 on Nov. 20, 2013, and a second user ID corresponded with a device running Apple's operating system iOS 6 on Dec. 31, 2013, the system can determine that the first and second user IDs do not correspond with the same user because it is not likely that user reverted to an earlier version of an operating system. However, in some cases a probability indicating that the first and second user IDs correspond to the same user can simply be lowered. For example, a system discussed herein can contemplate that the user from the above scenario either purchased a new device with an older operating system, or performed a system restore which caused the older operating system to be loaded. As such, the user ID may not be removed from the subset, but instead the probability that a match (i.e., the same user) is found can be reduced. Various configurations, either predetermined or configured by a user can be used to set values associated with different attributes. In addition, in some cases artificial intelligence can be used such that the algorithms used to determine whether two or more user IDs correspond to the same user can be adjusted.
Many attributes or combinations thereof can be used to determine that two or more user IDs do not correspond to the same user. As another example, if a first user ID corresponds to demographic information indicating that the user is a mother and expecting a child in Texas, and a second user ID corresponds to demographic information indicating that the user is a single man that lives in California, a determination can be made that the two user IDs do not correspond to the same user.
Step 410 of flow diagram 400 determines the user IDs. In some cases, multiple user IDs can be identical. User IDs may be a hexadecimal set of characters that can be hashed or reverse hashed one or more times and then compared to other user IDs to determine whether a match exists.
Step 420 of flow diagram 400 determines whether a match exists. If a match does exist, the flow diagram continues to step 430. If a match does not exist, the flow diagram continues to step 440.
Step 430 of diagram 400 describes returning data indicating that there is an exact match. As addressed above, this can mean that two user IDs were a match. Step 420 is shown in more detail in flow diagram 500 (of
Step 440 of diagram 400 describes applying inclusion criteria to determine the probability of a match. As discussed above, data associated with two or more user IDs' network transactions can be compared using inclusion data to generate a value corresponding to a probability that the two or more user IDs belong to the same user.
Step 450 of diagram 400 describes applying exclusion data to determine user IDs that do not correspond to the same user. In some embodiments, a subset of a dataset is created after inclusion data is applied, and then that subset is further pruned when exclusion data is applied. Steps 440 and 450 are shown in more detail in flow diagram 600 (of
Step 460 of diagram 400 discusses returning data indicating the probability of two or more user IDs corresponding to the same unique user.
Step 510 of flow diagram 500 discusses choosing a candidate user ID from a dataset. The candidate user ID may be of any type, and may be chosen at random.
Step 520 of flow diagram 500 determines whether the candidate user ID matches at least one other user ID in a dataset, and if a match is found the flow diagram continues to step 550 and returns data that indicates that an exact match was found.
Step 530 of flow diagram 500 determines whether a hashed or reverse hashed version of other user IDs in the dataset matches the candidate user ID. It should be understood that in some embodiments, for each dataset of user IDs, hashing can occur once or multiple times, forward or backward, and compared after each hash. In some embodiments, hashing can occur multiple times, forward or backward, and each hash may be compared after all the hashing has been performed. For example, every user ID may be hashed using a SHA-1, MD5, or another hashing algorithm and then compared against the candidate user ID. In some embodiments, each user ID other than the candidate user ID is hashed and then compared to the candidate user ID prior to hashing and comparing another user ID in the dataset. In some embodiments, every user ID other than the candidate ID is hashed first, and then each hashed user ID is compared to the candidate user ID. The same process may be applied using reverse hashing. For example, each user ID other than the candidate user ID may be reverse hashed, and then compared to the candidate ID before reverse hashing another user ID. In another example, every user ID other than the candidate user ID is reverse hashed first, and then each reverse hashed user ID is compared to the candidate ID. Similarly, the same process can be used for hashing or reverse hashing user IDs multiple times. If a match is found the flow diagram continues to step 550 and returns data that indicates that an exact match was found.
Step 540 of flow diagram 500 discusses determining whether a hashed or reverse hashed version of the candidate user ID matches another user ID or a hashed or reverse hashed version of another user ID. Similar to the examples described with respect to step 530, in some embodiments a candidate user ID may be hashed or reverse hashed, and then compared to other user IDs, or other hashed or reverse hashed versions of other user IDs. If a match is found the flow diagram continues to step 550 and returns data that indicates that an exact match was found. If a match is not found the diagram continues to step 560 and returns data that indicates that no exact match was found.
Step 550 of flow diagram 500 describes returning data indicating that an exact match was found. This data may include additional information, such as one or more user IDs, attributes corresponding to the one or more user IDs, what type of format the user IDs were in that matched, etc.
Step 560 of flow diagram 500 describes returning data indicating that no exact match was found.
Step 610 of flow diagram 600 discusses storing a dataset including identifiers corresponding to a history of multiple network transactions and attributes related to those transactions, in accordance with an embodiment. The attributes related to those transactions can include items of inclusion data. As described above, this inclusion data can include information related to at least one IP address and at least one geographic location of an electronic device. In some embodiments, the IP address(es) and the geographic location(s) associated with various network transactions and/or time(s) can be used to increase the probability that two user IDs correspond to a unique user.
Step 620 of flow diagram 600 discusses identifying co-occurrences of two or more items of inclusion data, wherein the two or more items correspond to the same unique user, in accordance with an embodiment. As with the example above, since there are co-occurrences (i.e., identical occurrences) of the IP address(es) and the geographic location(s) at the same frequencies, a unique user can be identified. In some cases, co-occurrences of items of inclusion data can increase a value corresponding to a probability that the co-occurrences correspond to the same user greatly, while in other cases co-occurrences of items of inclusion data can only slightly increase a value corresponding to a probability that the co-occurrences correspond to the same user.
Step 630 of diagram 600 discusses determining a probability that a first ID and a second ID identify the same user based on frequency of co-occurrence of two or more items of inclusion data corresponding to the first ID and the second ID, in accordance with an embodiment. For example, if two user IDs indicate that their respective users access the same IP address associated with the same location every weekday at a certain time, and that those two user IDs access a second, same IP address associated with a second, same location every weekday at a different time, then the system can determine that the two user IDs have a high probability of corresponding to the same user. Example Electronic Environments
To enable user interaction with the computing device 700, an input device 745 can represent any number of input mechanisms, such as a microphone for speech, a touch-sensitive screen for gesture or graphical input, keyboard, mouse, motion input, speech and so forth. An output device 735 can also be one or more of a number of output mechanisms known to those of skill in the art. In some instances, multimodal systems can enable a user to provide multiple types of input to communicate with the computing device 700. The communications interface 740 can generally govern and manage the user input and system output. There is no restriction on operating on any particular hardware arrangement and therefore the basic features here can easily be substituted for improved hardware or firmware arrangements as they are developed.
Storage device 730 is a non-volatile memory and can be a hard disk or other types of computer readable media which can store data that are accessible by a computer, such as magnetic cassettes, flash memory cards, solid state memory devices, digital versatile disks, cartridges, random access memories (RAMs) 725, read only memory (ROM) 720, and hybrids thereof.
The storage device 730 can include software modules 732, 734, 736 for controlling the processor 710. Other hardware or software modules are contemplated. The storage device 730 can be connected to the system bus 705. In one aspect, a hardware module that performs a particular function can include the software component stored in a computer-readable medium in connection with the necessary hardware components, such as the processor 710, bus 705, display 735, and so forth, to carry out the function.
Chipset 760 can also interface with one or more communication interfaces 790 that can have different physical interfaces. Such communication interfaces can include interfaces for wired and wireless local area networks, for broadband wireless networks, as well as personal area networks. Some applications of the methods for generating, displaying, and using the GUI disclosed herein can include receiving ordered datasets over the physical interface or be generated by the machine itself by processor 755 analyzing data stored in storage 770 or 775. Further, the machine can receive inputs from a user via user interface components 785 and execute appropriate functions, such as browsing functions by interpreting these inputs using processor 755.
It can be appreciated that exemplary systems 700 and 750 can have more than one processor 710 or be part of a group or cluster of computing devices networked together to provide greater processing capability.
For clarity of explanation, in some instances the present technology may be presented as including individual functional blocks including functional blocks comprising devices, device components, steps or routines in a method embodied in software, or combinations of hardware and software.
In some embodiments the computer-readable storage devices, mediums, and memories can include a cable or wireless signal containing a bit stream and the like. However, when mentioned, non-transitory computer-readable storage media expressly exclude media such as energy, carrier signals, electromagnetic waves, and signals per se.
Methods according to the above-described examples can be implemented using computer-executable instructions that are stored or otherwise available from computer readable media. Such instructions can comprise, for example, instructions and data which cause or otherwise configure a general purpose computer, special purpose computer, or special purpose processing device to perform a certain function or group of functions. Portions of computer resources used can be accessible over a network. The computer executable instructions can be, for example, binaries, intermediate format instructions such as assembly language, firmware, or source code. Examples of computer-readable media that can be used to store instructions, information used, and/or information created during methods according to described examples include magnetic or optical disks, flash memory, USB devices provided with non-volatile memory, networked storage devices, and so on.
Devices implementing methods according to these disclosures can comprise hardware, firmware and/or software, and can take any of a variety of form factors. Typical examples of such form factors include laptops, smart phones, small form factor personal computers, personal digital assistants, and so on. Functionality described herein also can be embodied in peripherals or add-in cards. Such functionality can also be implemented on a circuit board among different chips or different processes executing in a single device, by way of further example.
The instructions, media for conveying such instructions, computing resources for executing them, and other structures for supporting such computing resources are means for providing the functions described in these disclosures.
Although a variety of examples and other information was used to explain aspects within the scope of the appended claims, no limitation of the claims should be implied based on particular features or arrangements in such examples, as one of ordinary skill would be able to use these examples to derive a wide variety of implementations. Further and although some subject matter can have been described in language specific to examples of structural features and/or method steps, it is to be understood that the subject matter defined in the appended claims is not necessarily limited to these described features or acts. For example, such functionality can be distributed differently or performed in components other than those identified herein. Rather, the described features and steps are disclosed as examples of components of systems and methods within the scope of the appended claims.