The present disclosure generally relates to the techniques for exploring large data sets using visual queries.
The approaches described in this section are approaches that could be pursued, but not necessarily approaches that have been previously conceived or pursued. Therefore, unless otherwise indicated, it should not be assumed that any of the approaches described in this section qualify as prior art merely by virtue of their inclusion in this section.
Data analysts and other computer users often interact and request data from computer-based databases containing large collections of data objects. In many instances, the data objects stored in such databases include information from disparate sources and may represent a variety of real-world information. In order to analyze large and varied collections of data objects, analysts often desire to find patterns of interest based on particular relationships exhibited between the data objects. For example, given a database containing a large number of interrelated data objects representing individuals, merchants, financial institutions, and payment transactions, an analyst may desire all instances of data objects corresponding to a particular set of individuals making a payment to a merchant using a particular bank account.
In order to find patterns of interest in a data object collection stored in a database, analysts may formulate queries that correspond to desired data object patterns. However, formulating queries that represent data object patterns presents a number of challenges. For example, accurately specifying a query that may represent a number of relationships between data objects and properties of those data objects is often a cumbersome and error-prone task. Further, while an analyst may intuitively understand the data object relationships required to express a desired data object pattern, the analyst may not always be fluent in a query language required to specify the pattern to a query engine. What is needed is an intuitive mechanism for data analysts and other computer users to formulate queries of arbitrary complexity representing patterns over collections of data objects.
In the drawings:
In the following description, for the purposes of explanation, numerous specific details are set forth in order to provide a thorough understanding of the present invention. It will be apparent, however, that the present invention may be practiced without these specific details. In other instances, well-known structures and devices are shown in block diagram form in order to avoid unnecessarily obscuring the present invention.
Embodiments are described herein according to the following outline:
1.0 General Overview
According to some embodiments, systems and methods facilitate the formulation of queries on data object collections. In an embodiment, a user may use one or more graphical user interfaces to create a visual representation of a query and use the visually represented query to query a data object collection and retrieve instances of a data object pattern corresponding to the query. In an embodiment, a data analysis system is enabled to transform a visually represented query into a query format suitable for execution by a data object query engine. Visual representations of queries may use nodes, symbols and properties to indicate aspects or attributes of queries.
In an embodiment, a data object may represent any collection of information as part of a data object model. For example, a data object model representing information about a particular company may include data objects corresponding to employees, organizational units, inventory items, purchase orders, etc. A data object may be associated with a data object type (e.g., employee, inventory item, etc.) and may additionally include one or more data object properties (e.g., first name, cost, etc.). A data object type and any associated properties define a particular data object within a data object collection. For example, an employee at a company named “Bob Smith” may be represented in a data object collection with a data object of type Employee and with property information specifying the name “Bob Smith.” Furthermore, a data object collection may include information that defines relationships, or data object links, between data objects in the collection. In an embodiment, in the context of a data object collection, a pattern represents a structured collection of data object types, data object link types, and property values associated with the data object types and data object links.
In an embodiment, a query that is used to search for instances of a particular data object pattern comprises a textual representation of the pattern. The query may be specified in a query template that is executed by a query engine. Execution of a query template may return one or more result instances, wherein each result instance includes a set of data objects and data object links corresponding to the pattern specified by the query in the query template. In an embodiment, a pattern also may be visually represented as a graph that includes one or more graph nodes and graph edges representing the data object types and link types of a pattern, respectively.
In an embodiment, a data analysis system uses one or more graphical user interfaces comprising various interface elements that enable users to create visual queries as graphs that represent a data object pattern. The system may transform the graph into a query template based at least on the one or more graph nodes and one or more graph edges included in the graph. A query engine may execute a query template to search a data object collection for result instances corresponding to the specified pattern. The search for instances of a specified pattern in a collection of data objects is referred to herein as a “search around.”
2.0 Structural and Functional Overview
In the embodiment illustrated in
Application server 102 may be implemented as a special-purpose computer system having the logical elements shown in
When executed by one or more processors of the computer system, logic in application server 102 is operable to explore the universe of data items according to the techniques described herein. In one embodiment, application server 102 may be implemented in a Java Virtual Machine (JVM) that is executing in a distributed or non-distributed computer system. In other embodiments, application server 102 may be implemented as a combination of programming instructions written in any programming language (e.g. C++ or Visual Basic) and hardware components (e.g. memory, CPU time) that have been allocated for executing the program instructions.
In an embodiment, application server 102 comprises repository access logic 110 and data exploring logic 104. Repository access logic 110 may comprise a set of program instructions which, when executed by one or more processors, are operable to access and retrieve data from data repository 112. For example, repository access logic 110 may be a database client or an Open Database Connectivity (ODBC) client that supports calls to a database server that manages data repository 112. Data repository 112 may be any type of structured storage for storing data including, but not limited to, relational or object-oriented databases, data warehouses, directories, data files, and any other structured data storage.
In the embodiment illustrated in
In an embodiment, input receiver 106 is a set of program instructions which, when executed by one or more processors, are operable to receive input from a client.
Evaluation module 108 is a set of program instructions that implement logic to create, modify, delete and store objects that are associated with the universe of data items, evaluate these objects when instructed to do so by data analysis system 100, provide the evaluation results to a client. Evaluation results of one or more objects may also be rendered by GUI logic 122 on display 124.
2.1 Search Around Basics
In an embodiment, a query engine that executes a query template specifying a data object pattern is referred to herein as a search around engine. In general, a search around enables a user to find instances of data objects that exhibit particular relationships to other data objects in a data object collection.
A search around query may be specified in a query template. In an embodiment, a query template is a structured text document comprising a tree structure including an initial data object type as a root object in the tree and various other specified data object types and data object links branching from the root object. For example, a query template may be defined in an Extensible Markup Language (XML) file with XML elements representing the specified data object types and data object links. The document tree structure additionally includes any property information associated with the data object types and data object links. Each level in a query template tree represents a data object link level from an initial data object type in the pattern and is referred to herein as a search around “stage.”
In an embodiment, execution of a query template proceeds by processing a data object search defined by each stage in the template until all stages have been processed, with the data object results from each stage being used as the initial data objects for any existing child stages. The process of executing a query template may include further transformation of the defined data object searches into one or more underlying database operations such as, for example, Structured Query Language (SQL) operations. After performing the search defined by each stage of a query template, a search around engine may return one or more results. Each result returned by a search around is referred to herein as an “instance,” and includes a collection of data objects and data object links that satisfy the search conditions at each stage in the query template. Thus, the result of a search around on a particular data object collection is the union of all instances of a pattern specified by the query template. In an embodiment, each search around result instance may be represented visually by a graph that displays the particular data objects and data object links for the particular instance arranged according to the specified pattern.
For example, given a data object collection that includes data object types representing individuals (e.g., Person data objects) and data object links representing phone calls initiated between individuals, a user may specify a simple pattern corresponding to instances of any person initiating a call to any other person. The example pattern may be specified in a query template by defining two Person data object types and a data object link representing the initiation of a phone call associated with the two Person data object types. The example pattern includes only a single stage, represented by the link between the two Person data object types.
The execution of a query template corresponding to the example pattern may result in zero or more instances of data objects and data object links that are connected as specified by the pattern in a data object collection. For example, assuming the data object collection includes data object information representing an individual named John making a phone call to an individual named David, one result instance may include a first Person data object representing the individual named John, a second Person data object representing the individual named David, and a data object link representing a phone call initiated between John and David. The result instance may be displayed visually to a user as a graph that includes nodes for Person data objects representing John and David, respectively, and a graph edge connecting the two Person data objects.
2.2 Search Around Visual Queries
For the purposes of clearly illustrating how the functions described herein operate upon the construction of visual queries, the following sections describe example graphical user interface displays. However, the graphical user interface displays described herein represent only selected examples of visualizations for the visual query manipulation operations and query transformations that are described herein. Thus, the disclosure broadly encompasses any method of creating and transforming the visual queries that are described herein.
Further, no particular graphical user interface is required and the disclosure is intended to encompass the visual query creation processes and transformations that are described independent of any graphical user interface, and it is not intended to be limited to any particular graphical user interface or other form of display. For example, each example graphical user interface merely represents one way to receive input from a user to create the graph elements and graph properties that are shown in the graphical user interfaces, and represents only one way to display output resulting from the visual query creation and transformation processes described herein; in other embodiments, programmatic methods may be used to obtain the same graph elements and properties and other forms of data output may be used such as logging, reporting, storing in database tables, storing in spreadsheets, or out using the graphical user interface of another program or process.
In an embodiment, a data object pattern may be visually represented by a graph that includes one or more graph nodes and graph edges. The graph nodes and graph edges represent data object types and data object links of a pattern, respectively. In an embodiment, a user creates a visual query as a graph by using one or more graphical user interfaces that enable the user to add, remove, and modify the particular graph nodes, graph edges, and properties included in the graph in order to specify a desired pattern of interest.
One of several mechanisms may be used to initiate the creation of a visual query. In one embodiment, a user may select a user interface option indicating the creation of a new graph, resulting in the display of a graphical user interface without pre-existing graph elements on the display. In another embodiment, a user may identify a pre-existing graph pattern generated as a result of another search around or other system operation. For example, a user may select a graph or a portion of a graph displayed as search around result instance generated by the execution of another visual query. The selected graph or graph portion may serve as a starting point for the design of a new visual query.
As described above, each of the depicted graph nodes in graph 202 represents a data object type and each of graph edges represents a data object link between data object types. For example, graph node 204 represents a Person data object type as indicated by the graphic displayed in conjunction with the graph node. Similarly, graph node 206 represents a Payment data object type, and graph node 208 represents a Phone Call data object type. Each of the data object types and data object link types associated with the displayed graph node and graph edges indicates a data object type or data object link type that would be specified in a query template generated for the visual query represented by graph 202.
As further described below, graph edges, such as the example graph edge 210 in
2.2.1 Adding Graph Elements
In an embodiment, a user may add one or more graph elements to a visual query graph by using any number of interface elements including a selection of a button displayed the graphical user interface, drop-down menu selections, clicking on the interface with an input device, input device gestures, etc. For example, interface element 214 illustrates an example graphical interface button enabling a user to add a new graph node. In one embodiment, in response to a user selecting interface element 214, a new graph node or other graph element is added into an available space on the graphical user interface display 200. In an embodiment, after a graph node is added, a user may manually position the newly added graph node onto a desired area of graphical interface 200 by, for example, dragging the graph node around the display using an input device. In an embodiment, in response to a user selecting interface element 214 to add a new graph element, the user may be prompted to specify additional information about a newly added graph node, for example, the specification of an associated data object type and data object properties with the newly added graph node.
In an embodiment, graph nodes displayed as part of a graph may comprise an interface element enabling users to create one or more additional graph nodes. For example, graph node 208 is illustrated comprising interface element 216 representing an interface element enabling a user to add one or more additional graph node to graph 202. In an embodiment, the addition of a graph node using an interface element that is associated with an existing graph node, such as interface element 216, may indicate an automatic association of the new graph node with the existing graph node. For example, the selection of interface element 216 may create a new graph node on graphical interface 200 in close proximity to graph node 208. In an embodiment, the addition of a graph node using an interface element such as interface element 216 may also include the automatic addition of a graph edge between the existing graph node and the newly created graph node.
In an embodiment, a list of selectable data object types associated with a graph node may be presented to a user in an interface element such as interface element 220. A list of selectable data object types for a particular graph node may be refined in number of ways. For example, the list of selectable data object types may be refined by examining the current state of the graph and presenting only data object type options that are relevant to current graph state. For example, if a user adds a new graph node that is connected by a graph edge to another graph node representing a Payment data object type, then the selectable data object types presented for the new graph node may include only those data object types that have an association with any Payment data object type in a data object collection under examination. For example, in a particular data object collection, Payment data objects may be associated only with Person data objects and Merchant data objects, resulting in the display of those two data object types in a list associated with a new graph node connected to a Payment data object type. Filtering the data object types selectable by a user to only those found in a data object collection may assist a user in defining a pattern that will return at least one result instance.
2.2.2 Data Object Properties
Data object types represented by graph nodes in a visual query may additionally comprise one or more data object properties. Each data object property may be associated with one or more property values. For example, a Person data object type represented by a graph node may include one or more data object properties (e.g., an age, gender, and occupation), and a user may specify values for the properties (e.g, “38,” “male,” and “insurance agent”). Age, gender, and occupation as referenced herein are identified only as clear examples; other properties for nodes may be used as appropriate for particular applications. In an embodiment, data object property values specified in a visual query further refine the result instances returned by the query to those instances that include data objects having the specified data object property values.
In an embodiment, in addition to specifying a data object type, a user may specify one or more data object property values using an interface element similar to interface element 310. Interface element 310 comprises a number of form elements that enable a user to specify one or more data object property values. The form elements presented to a user may be based on the particular associated data object type. For example, a user may be presented a particular set of form elements in interface element 310 for a selected Person data object type (e.g., form elements to specify an age, gender, occupation, etc.) and a different set of form elements for an Academic Organization data object type (e.g., form elements to specify an organizational name, location, grade level, etc.). In an embodiment, the data object property form elements associated with a particular data object type may be determined by examining the data object properties stored in association with a particular data object type in a data object under examination.
2.2.3 Data Object Links
In the context of a search around pattern, a data object link represents a connection, event or relationship of two or more data object types. For example, a user may be interested in a particular set of individuals, currency transfers or exchanges of the individuals, bank deposits made by those individuals, and a particular set of bank accounts involved in the bank deposits. In the example, if the individuals are represented in a pattern by a Person data object type, and the bank accounts by a Bank Account data object type, the action of making a bank deposit may be represented by a data object link. In the example, each bank deposit may be represented in a data object collection as a separate data object that “links” particular Person and Bank Account data objects in the collection.
In an embodiment, a data object link is represented in a visual query by a graph edge connecting two graph nodes. Additional information about a data object link may be represented by one or more of a data object link type, object intermediaries, and property matches, each further described herein.
2.2.3.1 Data Object Link Types
In an embodiment, a data object link type specifies a particular type of data object link specified between data objects types. For example, a user specifying a pattern that includes a data object link between two Person data object types may further specify a link type associated with the data object link. In the context of Person data objects, data object link types may include link types representing relationships between individuals, such as “Friend Of,” “Neighbor Of,” “Colleague Of,” etc. Links also may have types of REQUIRED, OPTIONAL, or other attributes to establish Boolean operations between nodes. In an embodiment, relevant data object link types may depend on the particular data object types linked by a data object link.
In an embodiment, a list of selectable link types presented to a user in response to selecting a graph edge may be refined based on one or more characteristics of the currently constructed graph. For example, a particular set of link types may be presented based on the data object types and properties associated with the graph nodes connected by the selected graph edge. The particular set of link types may be determined based on the link types that exist between the corresponding data object types in a data object collection under examination.
In an embodiment, the selection of a particular data object link type determines the display of the associated graph edge. For example, in response to a user selecting a particular data object link type, a particular graphic, text, or other indicator may be displayed in conjunction with the associated graph edge to indicate the selected data object link type.
2.2.3.2 Data Object Intermediaries
In an embodiment, a data object link between data object types may be represented by a data object intermediary. A data object intermediary is a type of data object link that is itself represented by a data object type. For example, a user may desire to find instances a Person data object type, a Charity data object type, and a data object link between the two data object types representing a payment transaction occurring between the Person data object type and the Charity data object type. In the example, the data object link between the two data object types may be represented by a Payment transaction data object type that acts as a data object intermediary between the two other data object types. In a data object collection, a data object intermediary may be stored as a data object that includes a reference to each of the associated data objects.
Referring to
Referring to
2.2.3.3 Property Matches
In an embodiment, a data object link between data objects types may comprise one or more property matches. A property match specified between two data objects represents one or more data object property values or conditions that both linked data objects must satisfy. For example, in a pattern including two linked Person data object types, a property match may be specified indicating that the Person data object types should have a matching data object property specifying a first name. In the example, a resulting search around on the pattern would return only instances that included data objects having the same first name data object property value.
In an embodiment, a user may specify a property match by selecting a graph edge in a manner similar to the specification of other link properties. For example, in
In an embodiment, a user may specify one or more property matches that specify matches based on approximate, or “fuzzy,” matching. Approximate matching includes finding property matches that approximately or substantially match or by specifying a function over one or more data object properties. For example, a user may specify a property match associated with two Person data objects on a property value representing a person's full given name, but specify a function that ignores the person's middle name. In the example, returned result instances would include linked Person data objects that had a same first and a last name, but not necessarily the same middle name.
2.2.3.4 Link Strength
In an embodiment, a user may specify in a graph a link strength associated with one or more data object links between data object types. A link strength may represent, for example, a condition on the number of occurrences of some relationship between two data object types. For example, if two graph nodes representing Person data object types are connected by a graph edge representing a Phone Call data object link, a link strength may be associated with the graph edge specifying a minimum number of phone calls that occurred between two Person data object types. In the example, result instances returned for the specified pattern would include pairs of Person data objects in a data object collection that had initiated at least the minimum number of calls between each pair.
2.2.4 Branching Conditions
In an embodiment, a user may specify one or more branching conditions in a visual query. For example, a user may desire to specify a pattern corresponding to instances of individuals that made a payment to either an academic organization or a charity. The example pattern may be represented in a visual query by creating a Person, Academic Organization, and Charity data object types, a Payment object intermediary, and specifying a branching condition between the Payment object intermediary and the Academic Organization and Charity data object types. For example,
In an embodiment, a branching condition may represent either a logical conjunction or disjunction between the branches. For example, referring to the example pattern above, a user may desire to find either instances of individuals that made payments to an academic organization OR a charity (represented by a logical disjunction), or to find individuals that made payments to an academic organization AND a charity (represented by a logical conjunction). Interface element 510 illustrates an example interface element enabling a user to select a desired type of branching condition.
In an embodiment, depending on the selected branching condition type, various graphical elements may be displayed to indicate the currently selected branching condition type. For example, interface element 510 may display the word “ANY” to represent a logical disjunction of the linked data object types. In an embodiment, a user may modify a branching condition types by selecting an interface element such as interface element 407. In response to a user changing the branching condition from a logical conjunction to a logical disjunction, interface element 407 may display the word “ALL”. Any other graphical elements may be used to indicate the currently selected branching condition type including, for example, icons, text, colors, etc.
In another embodiment, a branching condition may be represented by a separate graph node that is linked by a graph edge to the each of the other graph nodes involved in the branching condition. For example, interface element 510 may be represented by a separate graph node that is connected by an edge to graph node 504, graph node 506, and graph node 508.
2.2.5 Optional and Required Stages
As described above, each level in a query template tree represents a data object link level from an initial data object type in a pattern. In an embodiment, one or more stages of a query template tree may be specified as either optional or required stages. If a particular stage in a query template is specified as a required stage, then any result instance returned by the execution of the query template will include data objects associated with the required link. If a stage is specified as optional, then result instances may or may not include data objects corresponding to the optional stage. In an embodiment, a user may specify one or more graph edges as being associated with either an optional or required stage by, for example, using one or more graphical user interface elements.
Interface element 610 illustrates an example interface element presented to a user in response to the selection of graph edge 608. Interface element 610 includes a check-box that enables a user to indicate whether the select graph edge is associated with an optional or required stage. In an embodiment, the display of the graph edge in a visual query may change depending on whether the graph edge is specified to be associated with an optional or required stage. For example, graph edge 606 is displayed as a dashed line, indicating that the graph edge currently represents an optional stage. If a user changes the link to required, the graph edge may be displayed instead, for example, as a solid line or otherwise visually indicated to be associated with a required stage.
2.2.6 Blank Graph Elements
In an embodiment, a user may specify one or more placeholder graph elements in a visual query, referred to herein as blank graph elements. A blank graph element represents a data object type, data object link type, property value, or other graph element or value of a visual query that a user desires to be supplied at the time an associated query template is executed. For example, a user may create a visual query that includes a graph node representing a Person data object type. A data object property representing a first name associated with the Person data object type may be a value that the user desires to be supplied at the time a query based on the graph is executed. In the example, a user may represent the first name property value associated with the Person data object type with a blank graph element in a constructed visual query.
In an embodiment, when a query template based on a visual query that includes one or more blank graph elements is executed, a user executing the query may be prompted to supply one or more particular values for the one or more blank graph elements. For example, a user may be presented with a graphical form that requests the user to supply particular values for the one or more blank graph elements. Execution of a visual query that includes one or more blank graph elements may result in one or more result instances that include the values supplied by a user for the blank graph elements.
2.2.7 Transforming a Visual Query
In an embodiment, after a user has constructed a visual query corresponding to a desired data object pattern, the user may initiate a search around based on the constructed visual query. For example, a user may use one or more interface elements to initiate the search around on a particular data object collection. In response to a user indicating the initiation of a search around, a data analysis system transforms the constructed visual query into a query template. In general, the transformation of a visual query into a query template comprises generating a textual representation of a pattern described by the visual query graph constructed by a user. The textual representation of the visual query may follow a syntax that is understood by and may be executed by a search around engine in order to return zero or more result instances. In other embodiments, transformation of a visual query may include transformations into other query representations including, but not limited to, a query tree, query execution plans, and/or other textual and non-textual query representations.
In block 700, the data analysis system 100 receives input via a graphical user interface to add, modify, or remove one or more graph nodes, graph edges, and graph properties of a graph representing a visual query. For example, through interacting with a user at client 120 via graphical user interface 200 illustrated in
In block 704, the data analysis system 100 receives input indicating the initiation of a search around based on the constructed visual query. For example, data analysis system 100 may receive input via a graphical user interface or other command interface indicating that the user desires to execute a search around based on a constructed visual query graph. In another embodiment, data analysis system 100 may transform a visual query periodically without a user specifically indicating that a visual query transformation should occur, for example, each time a user modifies a visual query graph.
In block 706, the data analysis system 100 transforms a visual query into a query template based at least in part on the one or more graph nodes, one or more graph edges, and associated property values included in the visual query graph. Based on the information associated with the graph elements, an equivalent textual query representation of the pattern described by the graph is generated. For example, a search around engine may start at an initial graph node and iteratively traverse the graph from the initial graph node along associated graph edges, determining the information associated with the graph elements at each step in the graph traversal. In an embodiment, based on any subsequent modifications to a visual query graph by a user, the data analysis system 100 may re-transform a visual query graph into a new query template reflecting the graph modifications.
In an embodiment, transformation of a visual query into a query template may include one or more steps of validation to ensure that the graph represents a valid query. For example, during query transformation, data analysis system 100 may determine whether all graph nodes are connected to at least one other graph node by a graph edge and that each graph edge is connected to two graph nodes. The validity check may include any other determinations to ensure that the user constructed graph represents a valid query according to the rules of the data analysis system 100. In response to determining that one or more rules are not met by a user constructed visual query, one or more error message may be presented to the user.
3.0 Implementation Mechanisms—Hardware Overview
According to one embodiment, the techniques described herein are implemented by one or more special-purpose computing devices. The special-purpose computing devices may be hard-wired to perform the techniques, or may include digital electronic devices such as one or more application-specific integrated circuits (ASICs) or field programmable gate arrays (FPGAs) that are persistently programmed to perform the techniques, or may include one or more general purpose hardware processors programmed to perform the techniques pursuant to program instructions in firmware, memory, other storage, or a combination. Such special-purpose computing devices may also combine custom hard-wired logic, ASICs, or FPGAs with custom programming to accomplish the techniques. The special-purpose computing devices may be desktop computer systems, portable computer systems, handheld devices, networking devices or any other device that incorporates hard-wired and/or program logic to implement the techniques.
For example,
Computer system 800 also includes a main memory 806, such as a random access memory (RAM) or other dynamic storage device, coupled to bus 802 for storing information and instructions to be executed by processor 804. Main memory 806 also may be used for storing temporary variables or other intermediate information during execution of instructions to be executed by processor 804. Such instructions, when stored in non-transitory storage media accessible to processor 804, render computer system 800 into a special-purpose machine that is customized to perform the operations specified in the instructions.
Computer system 800 further includes a read only memory (ROM) 808 or other static storage device coupled to bus 802 for storing static information and instructions for processor 804. A storage device 810, such as a magnetic disk, optical disk, or solid-state drive is provided and coupled to bus 802 for storing information and instructions.
Computer system 800 may be coupled via bus 802 to a display 812, such as a cathode ray tube (CRT), for displaying information to a computer user. An input device 814, including alphanumeric and other keys, is coupled to bus 802 for communicating information and command selections to processor 804. Another type of user input device is cursor control 816, such as a mouse, a trackball, or cursor direction keys for communicating direction information and command selections to processor 804 and for controlling cursor movement on display 812. This input device typically has two degrees of freedom in two axes, a first axis (e.g., x) and a second axis (e.g., y), that allows the device to specify positions in a plane.
Computer system 800 may implement the techniques described herein using customized hard-wired logic, one or more ASICs or FPGAs, firmware and/or program logic which in combination with the computer system causes or programs computer system 800 to be a special-purpose machine. According to one embodiment, the techniques herein are performed by computer system 800 in response to processor 804 executing one or more sequences of one or more instructions contained in main memory 806. Such instructions may be read into main memory 806 from another storage medium, such as storage device 810. Execution of the sequences of instructions contained in main memory 806 causes processor 804 to perform the process steps described herein. In alternative embodiments, hard-wired circuitry may be used in place of or in combination with software instructions.
The term “storage media” as used herein refers to any non-transitory media that store data and/or instructions that cause a machine to operate in a specific fashion. Such storage media may comprise non-volatile media and/or volatile media. Non-volatile media includes, for example, optical disks, magnetic disks, or solid-state drives, such as storage device 810. Volatile media includes dynamic memory, such as main memory 806. Common forms of storage media include, for example, a floppy disk, a flexible disk, hard disk, solid-state drive, magnetic tape, or any other magnetic data storage medium, a CD-ROM, any other optical data storage medium, any physical medium with patterns of holes, a RAM, a PROM, and EPROM, a FLASH-EPROM, NVRAM, any other memory chip or cartridge.
Storage media is distinct from but may be used in conjunction with transmission media. Transmission media participates in transferring information between storage media. For example, transmission media includes coaxial cables, copper wire and fiber optics, including the wires that comprise bus 802. Transmission media can also take the form of acoustic or light waves, such as those generated during radio-wave and infra-red data communications.
Various forms of media may be involved in carrying one or more sequences of one or more instructions to processor 804 for execution. For example, the instructions may initially be carried on a magnetic disk or solid-state drive of a remote computer. The remote computer can load the instructions into its dynamic memory and send the instructions over a telephone line using a modem. A modem local to computer system 800 can receive the data on the telephone line and use an infra-red transmitter to convert the data to an infra-red signal. An infra-red detector can receive the data carried in the infra-red signal and appropriate circuitry can place the data on bus 802. Bus 802 carries the data to main memory 806, from which processor 804 retrieves and executes the instructions. The instructions received by main memory 806 may optionally be stored on storage device 810 either before or after execution by processor 804.
Computer system 800 also includes a communication interface 818 coupled to bus 802. Communication interface 818 provides a two-way data communication coupling to a network link 820 that is connected to a local network 822. For example, communication interface 818 may be an integrated services digital network (ISDN) card, cable modem, satellite modem, or a modem to provide a data communication connection to a corresponding type of telephone line. As another example, communication interface 818 may be a local area network (LAN) card to provide a data communication connection to a compatible LAN. Wireless links may also be implemented. In any such implementation, communication interface 818 sends and receives electrical, electromagnetic or optical signals that carry digital data streams representing various types of information.
Network link 820 typically provides data communication through one or more networks to other data devices. For example, network link 820 may provide a connection through local network 822 to a host computer 824 or to data equipment operated by an Internet Service Provider (ISP) 826. ISP 826 in turn provides data communication services through the world wide packet data communication network now commonly referred to as the “Internet” 828. Local network 822 and Internet 828 both use electrical, electromagnetic or optical signals that carry digital data streams. The signals through the various networks and the signals on network link 820 and through communication interface 818, which carry the digital data to and from computer system 800, are example forms of transmission media.
Computer system 800 can send messages and receive data, including program code, through the network(s), network link 820 and communication interface 818. In the Internet example, a server 830 might transmit a requested code for an application program through Internet 828, ISP 826, local network 822 and communication interface 818.
The received code may be executed by processor 804 as it is received, and/or stored in storage device 810, or other non-volatile storage for later execution.
In the foregoing specification, embodiments of the invention have been described with reference to numerous specific details that may vary from implementation to implementation. The specification and drawings are, accordingly, to be regarded in an illustrative rather than a restrictive sense. The sole and exclusive indicator of the scope of the invention, and what is intended by the applicants to be the scope of the invention, is the literal and equivalent scope of the set of claims that issue from this application, in the specific form in which such claims issue, including any subsequent correction.
This application claims the benefit under 35 U.S.C. § 120 as a continuation of application Ser. No. 13/608,864, filed Sep. 10, 2012, the entire contents of which is hereby incorporated by reference for all purposes as if fully set forth herein. The applicants hereby rescind any disclaimer of claim scope in the parent applications or the prosecution history thereof and advise the USPTO that the claims in this application may be broader than any claim in the parent applications.
Number | Name | Date | Kind |
---|---|---|---|
5241625 | Epard et al. | Aug 1993 | A |
5418950 | Li et al. | May 1995 | A |
5428737 | Li et al. | Jun 1995 | A |
5428776 | Rothfield | Jun 1995 | A |
5542089 | Lindsay et al. | Jul 1996 | A |
5608899 | Li et al. | Mar 1997 | A |
5613105 | Xbikowski et al. | Mar 1997 | A |
5701456 | Jacopi et al. | Dec 1997 | A |
5724575 | Hoover et al. | Mar 1998 | A |
5794228 | French et al. | Aug 1998 | A |
5794229 | French et al. | Aug 1998 | A |
5845300 | Comer | Dec 1998 | A |
5857329 | Bingham | Jan 1999 | A |
5911138 | Li et al. | Jun 1999 | A |
5918225 | White et al. | Jun 1999 | A |
6065026 | Cornelia et al. | May 2000 | A |
6208985 | Krehel | Mar 2001 | B1 |
6232971 | Haynes | May 2001 | B1 |
6236994 | Swartz et al. | May 2001 | B1 |
6237138 | Hameluck et al. | May 2001 | B1 |
6243706 | Moreau et al. | Jun 2001 | B1 |
6289334 | Reiner et al. | Sep 2001 | B1 |
6311181 | Lee et al. | Oct 2001 | B1 |
6321274 | Shakib et al. | Nov 2001 | B1 |
6430305 | Decker | Aug 2002 | B1 |
6523019 | Borthwick | Feb 2003 | B1 |
6851108 | Syme et al. | Feb 2005 | B1 |
6857120 | Arnold et al. | Feb 2005 | B1 |
6877137 | Rivette et al. | Apr 2005 | B1 |
6944821 | Bates et al. | Sep 2005 | B1 |
6976024 | Chavez et al. | Dec 2005 | B1 |
6978419 | Kantrowitz | Dec 2005 | B1 |
7085890 | Kashyap | Aug 2006 | B2 |
7168039 | Bertram | Jan 2007 | B2 |
7174377 | Bernard et al. | Feb 2007 | B2 |
7392254 | Jenkins | Jun 2008 | B1 |
7406592 | Polyudov | Jul 2008 | B1 |
7519589 | Charnock et al. | Apr 2009 | B2 |
7546353 | Hesselink et al. | Jun 2009 | B2 |
7601290 | Kruy et al. | Oct 2009 | B2 |
7617232 | Gabbert et al. | Nov 2009 | B2 |
7627489 | Schaeffer et al. | Dec 2009 | B2 |
7657540 | Bayliss | Feb 2010 | B1 |
7765489 | Shah | Jul 2010 | B1 |
7783679 | Bley | Aug 2010 | B2 |
7853573 | Warner et al. | Dec 2010 | B2 |
7877421 | Berger et al. | Jan 2011 | B2 |
7880921 | Dattilo et al. | Feb 2011 | B2 |
7899796 | Borthwick et al. | Mar 2011 | B1 |
7900052 | Jonas | Mar 2011 | B2 |
7908521 | Sridharan et al. | Mar 2011 | B2 |
7917376 | Bellin et al. | Mar 2011 | B2 |
7941321 | Greenstein et al. | May 2011 | B2 |
7941336 | Robin-Jan | May 2011 | B1 |
7958147 | Turner et al. | Jun 2011 | B1 |
7966199 | Frasher | Jun 2011 | B1 |
7979424 | Dettinger et al. | Jul 2011 | B2 |
8036971 | Aymeloglu et al. | Oct 2011 | B2 |
8046283 | Burns | Oct 2011 | B2 |
8054756 | Chand et al. | Nov 2011 | B2 |
8073857 | Sreekanth | Dec 2011 | B2 |
8103962 | Embley et al. | Jan 2012 | B2 |
8229902 | Vishniac et al. | Jul 2012 | B2 |
8290838 | Thakur et al. | Oct 2012 | B1 |
8302855 | Ma et al. | Nov 2012 | B2 |
8417715 | Bruckhaus et al. | Apr 2013 | B1 |
8429194 | Aymeloglu et al. | Apr 2013 | B2 |
8433703 | Carrino et al. | Apr 2013 | B1 |
8473454 | Evanitsky et al. | Jun 2013 | B2 |
8484115 | Aymeloglu et al. | Jul 2013 | B2 |
8499287 | Shafi et al. | Jul 2013 | B2 |
8560494 | Downing | Oct 2013 | B1 |
8589273 | Creeden et al. | Nov 2013 | B2 |
8639552 | Chen et al. | Jan 2014 | B1 |
8682696 | Shanmugam | Mar 2014 | B1 |
8688573 | Ruknoic et al. | Apr 2014 | B1 |
8732574 | Burr et al. | May 2014 | B2 |
8799313 | Satlow | Aug 2014 | B2 |
8812960 | Sun et al. | Aug 2014 | B1 |
8909597 | Aymeloglu et al. | Dec 2014 | B2 |
8924388 | Elliot et al. | Dec 2014 | B2 |
8924389 | Elliot et al. | Dec 2014 | B2 |
8924429 | Fisher et al. | Dec 2014 | B1 |
8935201 | Fisher et al. | Jan 2015 | B1 |
8938686 | Erenrich et al. | Jan 2015 | B1 |
8984390 | Aymeloglu et al. | Mar 2015 | B2 |
9058315 | Burr et al. | Jun 2015 | B2 |
9348880 | Kramer et al. | May 2016 | B1 |
9547923 | Nevin | Jan 2017 | B2 |
20020032677 | Morgenthaler et al. | Mar 2002 | A1 |
20020065708 | Senay et al. | May 2002 | A1 |
20020083039 | Ferrari | Jun 2002 | A1 |
20020095360 | Joao | Jul 2002 | A1 |
20020095658 | Shulman | Jul 2002 | A1 |
20020103705 | Brady | Aug 2002 | A1 |
20020147805 | Leshem et al. | Oct 2002 | A1 |
20020184111 | Swanson | Dec 2002 | A1 |
20030004770 | Miller et al. | Jan 2003 | A1 |
20030023620 | Trotta | Jan 2003 | A1 |
20030036927 | Bowen | Feb 2003 | A1 |
20030105833 | Daniels | Jun 2003 | A1 |
20030126102 | Borthwick | Jul 2003 | A1 |
20040034570 | Davis | Feb 2004 | A1 |
20040044648 | Anfindsen et al. | Mar 2004 | A1 |
20040088177 | Travis et al. | May 2004 | A1 |
20040098731 | Demsey et al. | May 2004 | A1 |
20040103088 | Cragun et al. | May 2004 | A1 |
20040126840 | Cheng et al. | Jul 2004 | A1 |
20040139212 | Mukherjee et al. | Jul 2004 | A1 |
20040153418 | Hanweck | Aug 2004 | A1 |
20040205492 | Newsome | Oct 2004 | A1 |
20040236688 | Bozeman | Nov 2004 | A1 |
20040239674 | Ewald et al. | Dec 2004 | A1 |
20050004911 | Goldberg et al. | Jan 2005 | A1 |
20050010472 | Quatse et al. | Jan 2005 | A1 |
20050021397 | Cui et al. | Jan 2005 | A1 |
20050028094 | Allyn | Feb 2005 | A1 |
20050039116 | Slack-Smith | Feb 2005 | A1 |
20050086207 | Heuer et al. | Apr 2005 | A1 |
20050091186 | Elish | Apr 2005 | A1 |
20050120080 | Weinreb et al. | Jun 2005 | A1 |
20050125715 | Di Franco et al. | Jun 2005 | A1 |
20050183005 | Denoue et al. | Aug 2005 | A1 |
20050226473 | Ramesh | Oct 2005 | A1 |
20050278286 | Djugash et al. | Dec 2005 | A1 |
20060004740 | Dettinger et al. | Jan 2006 | A1 |
20060026120 | Carolan et al. | Feb 2006 | A1 |
20060026561 | Bauman et al. | Feb 2006 | A1 |
20060031779 | Theurer et al. | Feb 2006 | A1 |
20060053170 | Hill et al. | Mar 2006 | A1 |
20060059423 | Lehmann et al. | Mar 2006 | A1 |
20060070046 | Balakrishnan et al. | Mar 2006 | A1 |
20060074967 | Shaburov | Apr 2006 | A1 |
20060080139 | Mainzer | Apr 2006 | A1 |
20060080616 | Vogel et al. | Apr 2006 | A1 |
20060106847 | Eckardt, III | May 2006 | A1 |
20060116991 | Calderwood | Jun 2006 | A1 |
20060129746 | Porter | Jun 2006 | A1 |
20060136513 | Ngo et al. | Jun 2006 | A1 |
20060142949 | Helt | Jun 2006 | A1 |
20060143075 | Carr et al. | Jun 2006 | A1 |
20060143079 | Basak et al. | Jun 2006 | A1 |
20060178915 | Chao | Aug 2006 | A1 |
20060209085 | Wong et al. | Sep 2006 | A1 |
20060265417 | Amato et al. | Nov 2006 | A1 |
20060271884 | Hurst | Nov 2006 | A1 |
20060277460 | Forstall et al. | Dec 2006 | A1 |
20060288046 | Gupta et al. | Dec 2006 | A1 |
20070000999 | Kubo et al. | Jan 2007 | A1 |
20070005582 | Navratil et al. | Jan 2007 | A1 |
20070011304 | Error | Jan 2007 | A1 |
20070022107 | Yuan et al. | Jan 2007 | A1 |
20070027851 | Kruy et al. | Feb 2007 | A1 |
20070043686 | Teng et al. | Feb 2007 | A1 |
20070061752 | Cory | Mar 2007 | A1 |
20070094248 | McVeigh et al. | Apr 2007 | A1 |
20070113164 | Hansen et al. | May 2007 | A1 |
20070130206 | Zhou et al. | Jun 2007 | A1 |
20070136095 | Weinstein | Jun 2007 | A1 |
20070168336 | Ransil et al. | Jul 2007 | A1 |
20070178501 | Rabinowitz et al. | Aug 2007 | A1 |
20070192281 | Cradick et al. | Aug 2007 | A1 |
20070245339 | Bauman et al. | Oct 2007 | A1 |
20070260582 | Liang | Nov 2007 | A1 |
20070284433 | Domenica et al. | Dec 2007 | A1 |
20070299697 | Friedlander et al. | Dec 2007 | A1 |
20080016155 | Khalatian | Jan 2008 | A1 |
20080071731 | Ma et al. | Mar 2008 | A1 |
20080077598 | Wilmering et al. | Mar 2008 | A1 |
20080091693 | Murthy | Apr 2008 | A1 |
20080109714 | Kumar et al. | May 2008 | A1 |
20080126344 | Hoffman et al. | May 2008 | A1 |
20080126951 | Sood et al. | May 2008 | A1 |
20080155440 | Trevor et al. | Jun 2008 | A1 |
20080201313 | Dettinger et al. | Aug 2008 | A1 |
20080215543 | Huang et al. | Sep 2008 | A1 |
20080222295 | Robinson et al. | Sep 2008 | A1 |
20080249820 | Pathria | Oct 2008 | A1 |
20080255973 | El Wade et al. | Oct 2008 | A1 |
20080267386 | Cooper | Oct 2008 | A1 |
20080313132 | Hao et al. | Dec 2008 | A1 |
20090006150 | Prigge et al. | Jan 2009 | A1 |
20090007056 | Prigge et al. | Jan 2009 | A1 |
20090024589 | Sood et al. | Jan 2009 | A1 |
20090043762 | Shiverick et al. | Feb 2009 | A1 |
20090043801 | LeClair | Feb 2009 | A1 |
20090055487 | Moraes et al. | Feb 2009 | A1 |
20090083275 | Jacob et al. | Mar 2009 | A1 |
20090089651 | Herberger et al. | Apr 2009 | A1 |
20090094217 | Dettinger et al. | Apr 2009 | A1 |
20090106178 | Chu | Apr 2009 | A1 |
20090112745 | Stefanescu | Apr 2009 | A1 |
20090125459 | Norton et al. | May 2009 | A1 |
20090144747 | Baker | Jun 2009 | A1 |
20090150868 | Chakra et al. | Jun 2009 | A1 |
20090161147 | Klave | Jun 2009 | A1 |
20090172674 | Bobak et al. | Jul 2009 | A1 |
20090187546 | Whyte et al. | Jul 2009 | A1 |
20090187548 | Ji et al. | Jul 2009 | A1 |
20090187556 | Ross et al. | Jul 2009 | A1 |
20090193012 | Williams | Jul 2009 | A1 |
20090199106 | Jonsson et al. | Aug 2009 | A1 |
20090248721 | Burton et al. | Oct 2009 | A1 |
20090248757 | Havewala et al. | Oct 2009 | A1 |
20090249244 | Robinson et al. | Oct 2009 | A1 |
20090252046 | Canright | Oct 2009 | A1 |
20090271343 | Vaiciulis et al. | Oct 2009 | A1 |
20090281839 | Lynn et al. | Nov 2009 | A1 |
20090282068 | Shockro et al. | Nov 2009 | A1 |
20090299830 | West et al. | Dec 2009 | A1 |
20090307049 | Elliott et al. | Dec 2009 | A1 |
20090313463 | Pang et al. | Dec 2009 | A1 |
20090319418 | Herz | Dec 2009 | A1 |
20090319891 | MacKinlay | Dec 2009 | A1 |
20100011282 | Dollard et al. | Jan 2010 | A1 |
20100042922 | Bradateanu et al. | Feb 2010 | A1 |
20100057622 | Faith et al. | Mar 2010 | A1 |
20100070842 | Aymeloglu et al. | Mar 2010 | A1 |
20100073315 | Lee et al. | Mar 2010 | A1 |
20100082671 | Li et al. | Apr 2010 | A1 |
20100083172 | Breeds | Apr 2010 | A1 |
20100098318 | Anderson | Apr 2010 | A1 |
20100145902 | Boyan et al. | Jun 2010 | A1 |
20100161646 | Ceballos et al. | Jun 2010 | A1 |
20100161735 | Sharma | Jun 2010 | A1 |
20100169376 | Chu | Jul 2010 | A1 |
20100169405 | Zhang | Jul 2010 | A1 |
20100191563 | Schlaifer et al. | Jul 2010 | A1 |
20100199167 | Uematsu et al. | Aug 2010 | A1 |
20100223260 | Wu | Sep 2010 | A1 |
20100262688 | Hussain et al. | Oct 2010 | A1 |
20100280851 | Merkin | Nov 2010 | A1 |
20100313239 | Chakra et al. | Dec 2010 | A1 |
20110035396 | Merz et al. | Feb 2011 | A1 |
20110041084 | Karam | Feb 2011 | A1 |
20110061013 | Bilicki et al. | Mar 2011 | A1 |
20110066497 | Gopinath et al. | Mar 2011 | A1 |
20110074811 | Hanson et al. | Mar 2011 | A1 |
20110078173 | Seligmann et al. | Mar 2011 | A1 |
20110093327 | Fordyce, III et al. | Apr 2011 | A1 |
20110093490 | Schindlauer et al. | Apr 2011 | A1 |
20110099133 | Chang et al. | Apr 2011 | A1 |
20110131547 | Elaasar | Jun 2011 | A1 |
20110153384 | Horne et al. | Jun 2011 | A1 |
20110161409 | Nair | Jun 2011 | A1 |
20110173093 | Psota et al. | Jul 2011 | A1 |
20110179048 | Satlow | Jul 2011 | A1 |
20110208565 | Ross et al. | Aug 2011 | A1 |
20110208822 | Rathod | Aug 2011 | A1 |
20110225482 | Chan et al. | Sep 2011 | A1 |
20110252282 | Meek et al. | Oct 2011 | A1 |
20110258190 | Chen et al. | Oct 2011 | A1 |
20110258216 | Supakkul et al. | Oct 2011 | A1 |
20110270604 | Qi et al. | Nov 2011 | A1 |
20110270871 | He et al. | Nov 2011 | A1 |
20110289397 | Eastmond et al. | Nov 2011 | A1 |
20110314007 | Dassa et al. | Dec 2011 | A1 |
20120004894 | Butler | Jan 2012 | A1 |
20120011238 | Rathod | Jan 2012 | A1 |
20120022945 | Falkenborg et al. | Jan 2012 | A1 |
20120054284 | Rakshit | Mar 2012 | A1 |
20120059853 | Jagota | Mar 2012 | A1 |
20120066166 | Curbera et al. | Mar 2012 | A1 |
20120078595 | Balandin et al. | Mar 2012 | A1 |
20120079363 | Folting et al. | Mar 2012 | A1 |
20120084117 | Tavares et al. | Apr 2012 | A1 |
20120084184 | Raleigh | Apr 2012 | A1 |
20120102022 | Miranker et al. | Apr 2012 | A1 |
20120131512 | Takeuchi et al. | May 2012 | A1 |
20120150873 | Tokai | Jun 2012 | A1 |
20120159312 | Mital et al. | Jun 2012 | A1 |
20120159362 | Brown et al. | Jun 2012 | A1 |
20120173381 | Smith | Jul 2012 | A1 |
20120174057 | Narendra et al. | Jul 2012 | A1 |
20120188252 | Law | Jul 2012 | A1 |
20120197657 | Prodanovic | Aug 2012 | A1 |
20120197660 | Prodanovic | Aug 2012 | A1 |
20120209886 | Henderson | Aug 2012 | A1 |
20120215784 | King et al. | Aug 2012 | A1 |
20120221553 | Wittmer et al. | Aug 2012 | A1 |
20120226590 | Love et al. | Sep 2012 | A1 |
20120278273 | Fang | Nov 2012 | A1 |
20120284719 | Phan et al. | Nov 2012 | A1 |
20120323888 | Osann, Jr. | Dec 2012 | A1 |
20130016106 | Yip et al. | Jan 2013 | A1 |
20130054551 | Lange | Feb 2013 | A1 |
20130096968 | Van Pelt et al. | Apr 2013 | A1 |
20130096988 | Grossman et al. | Apr 2013 | A1 |
20130151453 | Bhanot et al. | Jun 2013 | A1 |
20130166348 | Scotto | Jun 2013 | A1 |
20130166480 | Popescu et al. | Jun 2013 | A1 |
20130185307 | El-Yaniv et al. | Jul 2013 | A1 |
20130198624 | Aymeloglu et al. | Aug 2013 | A1 |
20130226944 | Baid et al. | Aug 2013 | A1 |
20130232220 | Sampson | Sep 2013 | A1 |
20130238616 | Rose et al. | Sep 2013 | A1 |
20130246170 | Gross et al. | Sep 2013 | A1 |
20130246537 | Gaddala | Sep 2013 | A1 |
20130263019 | Castellanos et al. | Oct 2013 | A1 |
20130282696 | John et al. | Oct 2013 | A1 |
20130290825 | Arndt et al. | Oct 2013 | A1 |
20130297619 | Chandrasekaran et al. | Nov 2013 | A1 |
20140012796 | Petersen et al. | Jan 2014 | A1 |
20140012886 | Downing et al. | Jan 2014 | A1 |
20140040371 | Gurevich et al. | Feb 2014 | A1 |
20140068487 | Steiger et al. | Mar 2014 | A1 |
20140074888 | Potter et al. | Mar 2014 | A1 |
20140095509 | Patton | Apr 2014 | A1 |
20140108074 | Miller et al. | Apr 2014 | A1 |
20140108380 | Gotz et al. | Apr 2014 | A1 |
20140108985 | Scott et al. | Apr 2014 | A1 |
20140115589 | Marinelli, III et al. | Apr 2014 | A1 |
20140115610 | Marinelli, III et al. | Apr 2014 | A1 |
20140123279 | Bishop et al. | May 2014 | A1 |
20140129936 | Richards et al. | May 2014 | A1 |
20140136285 | Carvalho | May 2014 | A1 |
20140143009 | Brice et al. | May 2014 | A1 |
20140157172 | Peery et al. | Jun 2014 | A1 |
20140164502 | Khodorenko et al. | Jun 2014 | A1 |
20140189536 | Lange et al. | Jul 2014 | A1 |
20140195515 | Baker et al. | Jul 2014 | A1 |
20140222793 | Sadkin et al. | Aug 2014 | A1 |
20140244284 | Smith | Aug 2014 | A1 |
20140330845 | Feldschuh | Nov 2014 | A1 |
20140344230 | Krause et al. | Nov 2014 | A1 |
20140358829 | Hurwitz | Dec 2014 | A1 |
20140366132 | Stiansen et al. | Dec 2014 | A1 |
20140379755 | Kuriakose et al. | Dec 2014 | A1 |
20150073954 | Braff | Mar 2015 | A1 |
20150100897 | Sun et al. | Apr 2015 | A1 |
20150106379 | Elliot et al. | Apr 2015 | A1 |
20150188872 | White | Jul 2015 | A1 |
20150254220 | Burr et al. | Sep 2015 | A1 |
20150269231 | Huynh | Sep 2015 | A1 |
Number | Date | Country |
---|---|---|
102546446 | Jul 2012 | CN |
103167093 | Jun 2013 | CN |
102054015 | May 2014 | CN |
102014103482 | Sep 2014 | DE |
102014204827 | Sep 2014 | DE |
102014204830 | Sep 2014 | DE |
102014204834 | Sep 2014 | DE |
1647908 | Apr 2006 | EP |
1672527 | Jun 2006 | EP |
2634745 | Sep 2013 | EP |
2743839 | Jun 2014 | EP |
2778986 | Sep 2014 | EP |
2858018 | Apr 2015 | EP |
2869211 | May 2015 | EP |
2889814 | Jul 2015 | EP |
2892197 | Jul 2015 | EP |
2366498 | Mar 2002 | GB |
2508503 | Jun 2014 | GB |
2508293 | Apr 2015 | GB |
622485 | Mar 2015 | NZ |
616212 | May 2015 | NZ |
WO 2000034895 | Jun 2000 | WO |
WO 01025906 | Apr 2001 | WO |
WO 2001088750 | Nov 2001 | WO |
WO 2010030913 | Mar 2010 | WO |
WO 2010030914 | Mar 2010 | WO |
WO 2010030917 | Mar 2010 | WO |
WO 2012119008 | Sep 2012 | WO |
Entry |
---|
U.S. Appl. No. 14/479,863, filed Sep. 8, 2014, First Office Action Interview, dated Dec. 26, 2014. |
U.S. Appl. No. 14/463,615, filed Aug. 19, 2014, First Office Action Interview, dated Nov. 13, 2014. |
U.S. Appl. No. 14/225,160, filed Mar. 25, 2014, First Office Action Interview, dated Jul. 29, 2014. |
U.S. Appl. No. 14/225,084, filed Mar. 25, 2014, First Office Action Interview, dated Feb. 20, 2015. |
U.S. Appl. No. 14/571,098, filed Dec. 15, 2014, First Office Action Interview, dated Mar. 11, 2015. |
U.S. Appl. No. 14/571,098, filed Dec. 15, 2014, First Office Action Interview, dated Nov. 10, 2015. |
U.S. Appl. No. 14/571,098, filed Dec. 15, 2014, First Office Action Interview, dated Aug. 5, 2015. |
U.S. Appl. No. 14/225,084, filed Mar. 25, 2014, Notice of Allowance, dated May 4, 2015. |
U.S. Appl. No. 14/225,006, filed Mar. 25, 2014, Final Office Action, dated Sep. 2, 2015. |
U.S. Appl. No. 14/676,621, filed Apr. 1, 2015, Notice of Allowance, dated Feb. 10, 2016. |
U.S. Appl. No. 14/225,006, filed Mar. 25, 2014, First Office Action Interview, dated Sep. 10, 2014. |
U.S. Appl. No. 13/827,491, filed Mar. 14, 2013, Office Action, dated Oct. 9, 2015. |
U.S. Appl. No. 13/827,491, filed Mar. 14, 2013, Office Action, dated Dec. 1, 2014. |
U.S. Appl. No. 14/451,221, filed Aug. 4, 2014, Office Action, dated Oct. 21, 2014. |
U.S. Appl. No. 14/483,527, filed Sep. 11, 2014, Final Office Action, dated Jun. 22, 2015. |
U.S. Appl. No. 14/225,006, filed Mar. 25, 2014, First Office Action Interview, dated Feb. 27, 2015. |
U.S. Appl. No. 14/225,160, filed Mar. 25, 2014, Final Office Action, dated Feb. 11, 2015. |
U.S. Appl. No. 14/479,863, filed Sep. 8, 2014, Notice of Allowance, dated Mar. 31, 2015. |
U.S. Appl. No. 14/842,734, filed Sep. 1, 2015, First Office Action Interview, dated Nov. 19, 2015. |
U.S. Appl. No. 14/676,621, filed Apr. 1, 2015, First Office Action Interview, dated Jul. 7, 2015. |
U.S. Appl. No. 14/225,160, filed Mar. 25, 2014, Office Action, dated Aug. 12, 2015. |
U.S. Appl. No. 14/265,637, filed Apr. 30, 2014, Notice of Allowance, dated Feb. 13, 2015. |
U.S. Appl. No. 13/767,779, filed Feb. 14, 2013, Final Office Action, dated Oct. 30, 2014. |
U.S. Appl. No. 13/669,274, filed Nov. 5, 2012, Advisory Action, dated Aug. 26, 2015. |
U.S. Appl. No. 14/463,615, filed Aug. 19, 2014, Final Office, dated May 21, 2015. |
U.S. Appl. No. 14/225,160, filed Mar. 25, 2014, First Office Action Interview, dated Oct. 22, 2014. |
U.S. Appl. No. 14/552,336, filed Nov. 24, 2014, First Office Action Interview, dated Jul. 20, 2015. |
U.S. Appl. No. 14/225,084, filed Mar. 25, 2014, First Office Action Interview, dated Sep. 2, 2014. |
U.S. Appl. No. 14/571,098, filed Dec. 15, 2014, First Office Action Interview, dated Aug. 24, 2015. |
U.S. Appl. No. 14/463,615, filed Aug. 19, 2014, First Office Action Interview, dated Jan. 28, 2015. |
U.S. Appl. No. 14/676,621, filed Apr. 1, 2015, Final Office Action, dated Oct. 29, 2015. |
U.S. Appl. No. 14/225,160, filed Mar. 25, 2014, Advisory Action, dated May 20, 2015. |
U.S. Appl. No. 14/800,447, filed Jul. 15, 2012, First Office Action Interview, dated Dec. 10, 2010. |
U.S. Appl. No. 14/807,658, filed Jul. 23, 2015, Final Office Action, dated Nov. 22, 2016. |
U.S. Appl. No. 14/552,336, filed Nov. 24, 2014, Notice of Allowance, dated Nov. 3, 2015. |
U.S. Appl. No. 13/827,491, filed Mar. 14, 2013, Final Office Action, dated Jun. 22, 2015. |
U.S. Appl. No. 14/319,161, filed Jun. 30, 2014, Final Office Action, dated Jan. 23, 2015. |
U.S. Appl. No. 14/676,621, filed Apr. 1, 2015, First Office Action Interview, dated Jul. 30, 2015. |
U.S. Appl. No. 14/807,658, filed Jul. 23, 2015, First Office Action Interview, dated Aug. 1, 2016. |
U.S. Appl. No. 14/222,364, filed Mar. 21, 2014, Office Action, dated Dec. 9, 2015. |
U.S. Appl. No. 14/807,658, filed Jul. 23, 2015, First Office Action Interview, dated Jul. 5, 2016. |
U.S. Appl. No. 14/807,658, filed Jul. 23, 2015, Office Action, dated Apr. 26, 2017. |
U.S. Appl. No. 14/483,527, filed Sep. 11, 2014, First Office Action Interview, dated Jan. 28, 2015. |
U.S. Appl. No. 13/767,779, filed Feb. 14, 2013, Interview Summary, dated Jan. 16, 2015. |
U.S. Appl. No. 13/657,656, filed Oct. 22, 2012, Office Action, dated Oct. 7, 2014. |
U.S. Appl. No. 14/254,773, filed Apr. 16, 2014, Notice of Allowance, dated Aug. 20, 2014. |
U.S. Appl. No. 14/304,741, filed Jun. 13, 2014, Office Action, dated Aug. 6, 2014. |
U.S. Appl. No. 13/657,635, filed Oct. 22, 2012, Office Action, dated Mar. 30, 2015. |
U.S. Appl. No. 13/657,656, filed Oct. 22, 2012, Final Office Action, dated May 6, 2015. |
U.S. Appl. No. 13/767,779, filed Feb. 14, 2013, Notice of Allowance, dated Mar. 17, 2015. |
U.S. Appl. No. 13/827,627, filed Mar. 14, 2013, Office Action, dated Mar. 2, 2015. |
U.S. Appl. No. 13/831,791, filed Mar. 15, 2013, Office Action, dated Mar. 4, 2015. |
U.S. Appl. No. 14/254,757, filed Apr. 16, 2014, Notice of Allowance, dated Sep. 10, 2014. |
U.S. Appl. No. 14/304,741, filed Jun. 13, 2014, Final Office Action, dated Mar. 3, 2015. |
U.S. Appl. No. 14/304,741, filed Jun. 13, 2014, Pre Interview Communication, dated Aug. 6, 2014. |
U.S. Appl. No. 14/304,741, filed Jun. 13, 2014, Notice of Allowance, dated Apr. 7, 2015. |
U.S. Appl. No. 13/767,779, filed Feb. 14, 2013, Final Office Action, dated Aug. 21, 2013. |
U.S. Appl. No. 13/767,779, filed Feb. 14, 2013, Interview Summary, dated May 6, 2013. |
U.S. Appl. No. 13/767,779, filed Feb. 14, 2013, Office Action, dated Jun. 24, 2013. |
U.S. Appl. No. 13/767,779, filed Feb. 14, 2013, Office Action, dated Jul. 10, 2014. |
U.S. Appl. No. 13/608,864, filed Sep. 10, 2012, First Office Action Interview, dated Mar. 17, 2015. |
U.S. Appl. No. 13/608,864, filed Sep. 10, 2012, Final Office Action, dated Jun. 8, 2015. |
U.S. Appl. No. 13/608,864, filed Sep. 10, 2012, Final Office Action, dated Nov. 2, 2016. |
U.S. Appl. No. 13/608,864, filed Sep. 10, 2012, Notice of Allowance, dated Jun. 12, 2017. |
Abbey, Kristen, “Review of Google Docs,” May 1, 2007, pp. 2. |
Official Communication for European Patent Application No. 14187996.5 dated Feb. 12, 2015. |
Hansen et al., “Analyzing Social Media Networks with NodeXL: Insights from a Connected World”, Chapter 4, pp. 53-67 and Chapter 10, pp. 143-164, published Sep. 2010. |
Amnet, “5 Great Tools for Visualizing Your Twitter Followers,” posted Aug. 4, 2010, http://www.amnetblog.com/component/content/article/115-5-grate-tools-for. |
SnagIt, “SnagIt Online Help Guide,” <http://download.techsmith.com/snagit/docs/onlinehelp/enu/snagit_help.pdf>. |
Official Communication for Great Britain Patent Application No. 1404486.1 dated May 21, 2015. |
“GrabUp—What a Timesaver!” <http://atichris.com/191/grabup/>, Aug. 11, 2008, pp. 3. |
Microsoft, “Registering an Application to a URI Scheme,” <http://msdn.microsoft.com/en-us/library/aa767914.aspx>, printed Apr. 4, 2009 in 4 pages. |
Kwout, <http://web.archive.org/web/20080905132448/http://www.kwout.com/> Sep. 5, 2008, pp. 2. |
Schroder, Stan, “15 Ways to Create Website Screenshots,” <http://mashable.com/2007/08/24/web-screenshots/>, Aug. 24, 2007, pp. 2. |
Conner, Nancy, “Google Apps: The Missing Manual,” May 1, 2008, pp. 15. |
Vose et al., “Help File for ModelRisk Version 5,” 2007, Vose Software, pp. 349-353. [Uploaded in 2 Parts]. |
Piwik—Free Web Analytics Software. <http://piwik.org/> Printed Jul. 19, 2013 in18 pages. |
Official Communication for New Zealand Patent Application No. 622473 dated Jun. 19, 2014. |
trak.io, <http://trak.io/> printed Jul. 18, 2013 in 3 pages. |
Manno et al., “Introducing Collaboration in Single-user Applications through the Centralized Control Architecture,” 2010, pp. 10. |
Microsoft Windows, “Microsoft Windows Version 2002 Print Out 2,” 2002, pp. 1-6. |
Adams et al., “Worklets: A Service-Oriented Implementation of Dynamic Flexibility in Workflows,” R. Meersman, Z. Tari et al. (Eds.): OTM 2006, LNCS, 4275, pp. 291-308, 2006. |
Gorr et al., “Crime Hot Spot Forecasting: Modeling and Comparative Evaluation”, Grant 98-IJ-CX-K005, May 6, 2002, 37 pages. |
SnagIt, “SnagIt 8.1.0 Print Out,” Software release date Jun. 15, 2006, pp. 6. |
Gu et al., “Record Linkage: Current Practice and Future Directions,” Jan. 15, 2004, pp. 32. |
Official Communication for Netherlands Patent Application No. 2011729 dated Aug. 13, 2015. |
Apsalar, “Data Powered Mobile Advertising,” “Free Mobile App Analytics” and various analytics related screen shots <http://apsalar.com> Printed Jul. 18, 2013 in 8 pages. |
Wang et al., “Research on a Clustering Data De-Duplication Mechanism Based on Bloom Filter,” IEEE 2010, 5 pages. |
Flurry Analytics, <http://www.flurry.com/> Printed Jul. 18, 2013 in 14 pages. |
Official Communication for Great Britain Patent Application No. 1404499.4 dated Jun. 11, 2015. |
Nitro, “Trick: How to Capture a Screenshot as Pdf, Annotate, Then Share It,” <http://blog.nitropdf.com/2008/03/04/trick-how-to-capture-a-screenshot-as-pdf. |
Localytics—Mobile App Marketing & Analytics, <http://www.localytics.com/> Printed Jul. 18, 2013 in 12 pages. |
TestFlight—Beta Testing on the Fly, <http://testflightapp.com/> Printed Jul. 18, 2013 in 3 pages. |
Official Communication for European Patent Application No. 12181585.6 dated Sep. 4, 2015. |
Hua et al., “A Multi-attribute Data Structure with Parallel Bloom Filters for Network Services”, HiPC 2006, LNCS 4297, pp. 277-288, 2006. |
Keylines.com, “An Introduction to KeyLines and Network Visualization,” Mar. 2014, <http://keylines.com/wp-content/uploads/2014/03/KeyLines-White-Paper.pdf> downloaded May 12, 2014 in 8 pages. |
Official Communication for European Patent Application No. 14200298.9 dated May 13, 2015. |
Galliford, Miles, “SnagIt Versus Free Screen Capture Software: Critical Tools for Website Owners,” <http://www.subhub.com/articles/free-screen-capture-software>, Mar. 27, 2008, pp. 11. |
DISTIMO—App Analytics, <http://www.distimo.com/app-analytics> Printed Jul. 18, 2013 in 5 pages. |
Capptain—Pilot Your Apps, <http://www.capptain.com> Printed Jul. 18, 2013 in 6 pages. |
Kontagent Mobile Analytics, <http://www.kontagent.com/> Printed Jul. 18, 2013 in 9 pages. |
Keylines.com, “Visualizing Threats: Improved Cyber Security Through Network Visualization,” Apr. 2014, <http://keylines.com/wp-content/uploads/2014/04/Visualizing-Threats1.pdf> downloaded May 12, 2014 in 10 pages. |
Official Communication for Great Britain Patent Application No. 1404499.4 dated Sep. 29, 2014. |
Keylines.com, “KeyLines Datasheet,” Mar. 2014, <http://keylines.com/wp-content/uploads/2014/03/KeyLines-datasheet.pdf> downloaded May 12, 2014 in 2 pages. |
Official Communication for Canadian Patent Application No. 2831660 dated Jun. 9, 2015. |
Online Tech Tips, “Clip2Net—Share files, folders and screenshots easily,” <http://www.online-tech-tips.com/free-software-downloads/share-files-folders-screenshots/>, Apr. 2, 2008, pp. 5. |
Chaudhuri et al., “An Overview of Business Intelligence Technology,” Communications of the ACM, Aug. 2011, vol. 54, No. 8. |
Official Communication for New Zealand Patent Application No. 628161 dated Aug. 25, 2014. |
Official Communication for New Zealand Patent Application No. 622513 dated Apr. 3, 2014. |
Official Communication for European Patent Application No. 14191540.5 dated May 27, 2015. |
Official Communication for Great Britain Patent Application No. 1404486.1 dated Aug. 27, 2014. |
“HunchLab: Heat Map and Kernel Density Calculation for Crime Analysis,” Azavea Journal, printed from www.azavea.com/blogs/newsletter/v4i4/kernel-density-capabilities-added-to-hunchlab/ on Sep. 9, 2014, 2 pages. |
“Refresh CSS Ellipsis When Resizing Container—Stack Overflow,” Jul. 31, 2013, retrieved from internet http://stackoverflow.com/questions/17964681/refresh-css-ellipsis-when-resizing-container, retrieved on May 18, 2015. |
StatCounter—Free Invisible Web Tracker, Hit Counter and Web Stats, <http://statcounter.com/> Printed Jul. 19, 2013 in 17 pages. |
Official Communication for Great Britain Patent Application No. 1404499.4 dated Aug. 20, 2014. |
JetScreenshot.com, “Share Screenshots via Internet in Seconds,” <http://web.archive.org/web/20130807164204/http://www.jetscreenshot.com/>, Aug. 7, 2013, pp. 1. |
Bluttman et al., “Excel Formulas and Functions for Dummies,” 2005, Wiley Publishing, Inc., pp. 280, 284-286. |
UserMetrix, <http://usermetrix.com/android-analytics> printed Jul. 18, 2013 in 3 pages. |
Mixpanel—Mobile Analytics, <https://mixpanel.com/> Printed Jul. 18, 2013 in 13 pages. |
Official Communication for Great Britain Patent Application No. 1404489.5 dated May 21, 2015. |
Open Web Analytics (OWA), <http://www.openwebanalytics.com/> Printed Jul. 19, 2013 in 5 pages. |
Official Communication for Great Britain Patent Application No. 1404489.5 dated Aug. 27, 2014. |
Countly Mobile Analytics, <http://count.ly/> Printed Jul. 18, 2013 in 9 pages. |
Cohn, et al., “Semi-supervised clustering with user feedback,” Constrained Clustering: Advances in Algorithms, Theory, and Applications 4.1 (2003): 17-32. |
Official Communication for Great Britain Patent Application No. 1404489.5 dated Oct. 6, 2014. |
Warren, Christina, “TUAW Faceoff: Screenshot apps on the firing line,” <http://www.tuaw.com/2008/05/05/tuaw-faceoff-screenshot-apps-on-the-firing-line/>, May 5, 2008, pp. 11. |
Official Communication for New Zealand Patent Application No. 622473 dated Mar. 27, 2014. |
Official Communication for Australian Patent Application No. 2013251186 dated Mar. 12, 2015. |
Celik, Tantek, “CSS Basic User Interface Module Level 3 (CSS3 UI),” Section 8 Resizing and Overflow, Jan. 17, 2012, retrieved from internet http://www.w3.org/TR/2012/WD-css3-ui-20120117/#resizing-amp-overflow retrieved on May 18, 2015. |
Valentini et al., “Ensembles of Learning Machines”, M. Marinaro and R. Tagliaferri (Eds.): WIRN VIETRI 2002, LNCS 2486, pp. 3-20. |
Notice of Acceptance for Australian Patent Application No. 2013251186 dated Nov. 6, 2015. |
Appacts, “Smart Thinking for Super Apps,” <http://www.appacts.com> Printed Jul. 18, 2013 in 4 pages. |
Microsoft, “Using the Clipboard,” <http://msdn.microsoft.com/en-us/library/ms649016.aspx>, printed Jun. 8, 2009 in 20 pages. |
Google Analytics Official Website—Web Analytics & Reporting, <http://www.google.com/analytics.index.html> Printed Jul. 18, 2013 in 22 pages. |
SnagIt, “SnagIt 8.1.0 Print Out 2,” Software release date Jun. 15, 2006, pp. 1-3. |
O'Reilly.com, http://oreilly.com/digitalmedia/2006/01/01/mac-os-x-screenshot-secrets.html published Jan. 1, 2006 in 10 pages. |
Mendes et al., “TcruziKB: Enabling Complex Queries for Genomic Data Exploration”, IEEE, dated 2008, 8 pages. |
Russell et al., “NIELIGHT: A Graphical Tool for Semantic Query”, dated 2008, 10 pages. |
Smart et al., “A Visual Approach to Semantic Query Design Using a Web-Based Graphical Query Designer”, dated 2008, 17 pages. |
Ballesteros et al., “Batching: A Design Pattern for Efficient and Flexible Client/Server Interaction,” Transactions on Pattern Languages of Programming, Springer Berlin Heildeberg, 2009, pp. 48-66. |
Bogle et al., “Reducing Cross-Domain Call Overhead Using Batched Futures,” SIGPLAN No. 29, (Oct. 10, 1994) pp. 341-54. |
Stamos et al., “Remote Evaluation,” Journal ACM Transactions on Programming Languages and Systems (TOPLAS) vol. 12, Issue 4, Oct. 1990, pp. 537-564. |
Notice of Acceptance for New Zealand Patent Application No. 616299 dated Apr. 7, 2015. |
Official Communication for Australian Patent Application No. 2013237710 dated Jan. 16, 2015. |
Official Communication for Australian Patent Application No. 2014201580 dated Feb. 27, 2015. |
Official Communication for German Patent Application No. 10 2013 221 057.4 dated Mar. 23, 2015. |
Official Communication for German Patent Application No. 10 2013 221 052.3 dated Mar. 24, 2015. |
Official Communication for Canadian Patent Application No. 2829266 dated Apr. 28, 2015. |
Official Communication for Canadian Patent Application No. 2828264 dated Apr. 28, 2015. |
“A Quick Guide to UniProtKB Swiss-Prot & TrEMBL,” Sep. 2011, pp. 2. |
“A Tour of Pinboard,” <http://pinboard.in/tour> as printed May 15, 2014 in 6 pages. |
Bae et al., “Partitioning Algorithms for the Computation of Average Iceberg Queries,” DaWaK 2000, LNCS 1874, pp. 276-286. |
Bogle, Phillip Lee, “Reducing Cross-Domain Call Overhead Using Batched Futures,” May 1994, Massachusetts Institute of Technology, pp. 96. |
Canese et al., “Chapter 2: PubMed: The Bibliographic Database,” The NCBI Handbook, Oct. 2002, pp. 1-10. |
Chazelle et al., “The Bloomier Filter: An Efficient Data Structure for Static Support Lookup Tables,” SODA '04 Proceedings of the Fifteenth Annual ACM-SIAM Symposium on Discrete Algorithms, 2004, pp. 30-39. |
Delcher et al., “Identifying Bacterial Genes and Endosymbiont DNA with Glimmer,” Biolnformatics, vol. 23, No. 6, 2007, pp. 673-679. |
Delicious, <http://delicious.com/> as printed May 15, 2014 in 1 page. |
Donjerkovic et al., “Probabilistic Optimization of Top N Queries,” Proceedings of the 25th VLDB Conference, Edinburgh, Scotland, 1999, pp. 411-422. |
Fang et al., “Computing Iceberg Queries Efficiently,” Proceedings of the 24th VLDB Conference New York, 1998, pp. 299-310. |
“Frequently Asked Questions about Office Binder 97,” http://web.archive.org/web/20100210112922/http://support.microsoft.com/kb/843147 printed Dec. 18, 2006 in 5 pages. |
Han et al., “Efficient Computation of Iceberg Cubes with Complex Measures,” ACM Sigmod, May 21-24, 2001, pp. 1-12. |
Ivanova et al., “An Architecture for Recycling Intermediates in a Column-Store,” Proceedings of the 35th Sigmod International Conference on Management of Data, Sigmod '09, Jun. 29, 2009, p. 309. |
Jacques, M., “An extensible math expression parser with plug-ins,” Code Project, Mar. 13, 2008. Retrieved on Jan. 30, 2015 from the internet: <http://www.codeproject.com/Articles/7335/An-extensible-math-expression-parser-with-plug-ins>. |
Kahan et al., “Annotea: an Open RDF Infastructure for Shared Web Annotations”, Computer Networks, Elsevier Science Publishers B.V., vol. 39, No. 5, dated Aug. 5, 2002, pp. 589-608. |
Karp et al., “A Simple Algorithm for Finding Frequent Elements in Streams and Bags,” ACM Transactions on Database Systems, vol. 28, No. 1, Mar. 2003, pp. 51-55. |
Kitts, Paul, “Chapter 14: Genome Assembly and Annotation Process,” The NCBI Handbook, Oct. 2002, pp. 1-21. |
Leela et al., “On Incorporating Iceberg Queries in Query Processors,” Technical Report, TR-2002-01, Database Systems for Advanced Applications Lecture Notes in Computer Science, 2004, vol. 2973. |
Liu et al., “Methods for Mining Frequent Items in Data Streams: An Overview,” Knowledge and Information Systems, vol. 26, No. 1, Jan. 2011, pp. 1-30. |
Madden, Tom, “Chapter 16: The BLAST Sequence Analysis Tool,” The NCBI Handbook, Oct. 2002, pp. 1-15. |
Mizrachi, Ilene, “Chapter 1: GenBank: The Nuckeotide Sequence Database,” The NCBI Handbook, Oct. 2002, pp. 1-14. |
Sigrist, et al., “PROSITE, a Protein Domain Database for Functional Characterization and Annotation,” Nucleic Acids Research, 2010, vol. 38, pp. D161-D166. |
Sirotkin et al., “Chapter 13: The Processing of Biological Sequence Data at NCBI,” The NCBI Handbook, Oct. 2002, pp. 1-11. |
“The FASTA Program Package,” fasta-36.3.4, Mar. 25, 2011, pp. 29. |
Wkipedia, “Machine Code” p. 1-5, printed Aug. 11, 2014. |
Notice of Acceptance for New Zealand Patent Application No. 622485 dated Nov. 24, 2014. |
Notice of Acceptance for New Zealand Patent Application No. 616212 dated Jan. 23, 2015. |
Official Communication for European Patent Application No. 14159175.0 dated Jul. 17, 2014. |
Official Communication for European Patent Application No. 14159629.6 dated Jul. 31, 2014. |
Official Communication for European Patent Application No. 14159629.6 dated Sep. 22, 2014. |
Official Communication for New Zealand Patent Application No. 622414 dated Mar. 24, 2014. |
Official Communication for New Zealand Patent Application No. 622484 dated Apr. 2, 2014. |
Official Communication for New Zealand Patent Application No. 622485 dated Nov. 21, 2014. |
Official Communication for Great Britain Patent Application No. 1404574.4 dated Dec. 18, 2014. |
Official Communication for New Zealand Patent Application No. 616299 dated Jan. 26, 2015. |
Official Communication for Canadian Patent Application No. 2807899 dated Oct. 24, 2014. |
Official Communication for Australian Patent Application No. 2013237658 dated Feb. 2, 2015. |
Number | Date | Country | |
---|---|---|---|
20180032571 A1 | Feb 2018 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 13608864 | Sep 2012 | US |
Child | 15730634 | US |