This invention is related to databases and the manner in which information is represented and searched.
Computers are often used to store and maintain databases. Databases can be of many types. One type of database stores data in tabular form. One type of tabular form is the relational database that stores information in tables related to each other. Relational databases are defined by properties that are present in the table. The table holds data records, which conform to the properties that define the table. However, if one record presents a new piece of information a new table structure needs to be defined to hold that one record.
Other types of databases include hierarchical databases and flat-file structures that are similar to a table or a spreadsheet. Another type of database is the so-called object-oriented database. Object-oriented databases are also called “persistent objects.” Persistent objects are defined in classes that have data structure and procedural function and at run time are instantiated to have actual values. The object database can persistently store that object so that it can be retrieved with the same run time state as when it was stored.
The world wide web stores information in resources that can be found through an address such as a uniform resource locator (URL). Initially, most resources on the world wide web were plain text or hypertext mark-up language (HTML) documents. Now there are more dynamic forms of resources available. A resource will use a database to provide information and display it as an HTML document.
A Web crawler is a software program used to search information on the web. A web crawler starts at a page or a set of pages and searches through documents by following links. The links lead from one document to another. The links only contain locational information, i.e., a uniform resource locator (URL) that gives an address or location of the resource, i.e., a server that contains the referenced page.
According to an aspect of the invention, a method of searching for information to construct an information object includes querying a resource having information stored as bindable data elements and returning results from querying the resource to construct the information object.
According to an additional aspect of the invention, a computer-based system includes a search engine that produces a search query and a fragment base that stores data fragments and/or primitives that may be used to satisfy the query.
According to an additional aspect of the invention, a computer based system includes a fragment database and a sense process that reads data referred to a client process and tests the data to determine whether the data can be bound to existing data or produces new data within the fragment database.
According to an additional aspect of the invention, a data structure for a primitive data element resides on a computer readable medium. The data structure includes a type field that specifies the type of primitive element data structure, a binding field that defines how primitive data structure can connect to other primitive data structures to provide fragments and a content field that specifies a value associated with the type, said content field including a referral that specifies a location.
According to an additional aspect of the invention, a fragment data structure residing on a computer readable medium includes at least two primitive elements that have an binding relation to each other.
According to an additional aspect of the invention, a canonical, two primitive fragment data structure residing on a computer readable medium includes a primitive of a first primitive type bound to a primitive of a second type.
According to an additional aspect of the invention, a method of constructing an information object from primitives and/or fragments provided as a result of a query includes providing a set of focused primitives that correspond to a starting set of primitives that are related to the information object and linking primitives in accordance with binding fields of the primitives to produce the information object.
According to an additional aspect of the invention, a method of transforming a fragment of a first form into a second, different fragment of a second form includes applying a transformation function to the first fragment to produce the second, different fragment of a second form.
One or more the following advantages may be provided by aspects of the invention. A search request can allow for expansion of a search space beyond immediate contents of a fragment database. References to external resources may be obtained for the search process. The search process can respond to a direct request for information and the search process can also work in sense mode, in which the search process senses or is given information to read, in order to accumulate and alter information stored a fragment data base.
Fragments and primitives represent information in small pieces that can have both generalized structure and particular data. For example, a fragment can denote an instance of a classification, similar as an object is to a programmed class. However, classification as used with fragments is differentiated from programming class because a programming class is a well-, defined, bounded whole, with pre-defined data structure and functionality. The “classification” on the other hand, is a more primitive starting point, as a label that forms a hierarchical structure. A loose form of search-based inheritance rules can be imposed on classifications, though not with the rigor of conventional programmed class inheritance. By defining fragments to be additive, the fragments do not have to be designed in an object oriented manner of predefined classes. Another distinction from conventional software objects, therefore, is that conventional software objects are quite rigidly defined prior to use, in both data structure and functionality. The addition of attributes to a class definition requires reprogramming. Conventional programmed ‘objects’ therefore have to be preconceived to a high degree of precision. This requirement often runs counter to how people naturally develop a gradual cumulative concept, i.e., information about a thing. In contrast, as information changes and grows incrementally, fragments can be added to or modified within the fragment base to define a larger composite concept of information objects.
A special form of assembly technique is the transformation of one fragment into another fragment based on a transformation function. Fragment transformations can be specified in terms of general fragment structure, i.e. a sequence of primitive-types, without regard to their primitive content. Transformations can be applied to the data in a fragment database to maintain consistency, check and remove identified structures, or change the way information is expressed structurally. Other advantages are disclosed herein.
FIGS. 39 is a tabular representation of fragment data represented in a relational, tabular form for searching.
Referring to
The fragment database 24 can work without or in conjunction with application 21 and the search process 22. A communication pathway 9 exists between the fragment database 24 and the search process 22 and application 21. The communication pathway 9 can be a standard inter-process communication (IPC) mechanism such as a pipe or socket.
The fragment database 24 can respond to a request from a remote client 12, from the search process 22 or application 21. The request from the client can be for retrieving, adding, removing or manipulating information contained within or referenced by the fragment database 24. A.
The search process 22 can operate in a response mode (
The search process 22 can be used as a server process, as shown, or as a process such as an embedded part (not shown) of the application 21. An application 21 can be, for example, an electronic mail reader or a hypertext browser application. Information accessed within the application 21 can be shared with the search process 22 and fragment database 24. The search process 22 can parse and incorporate the information based on goals and directives in the search process 22 and the fragment base 24. The server process 19 can be used to construct new pieces of information by binding together primitives and/or fragment data elements (as will be described). These elements are additive data elements and are characterized as having the ability to bind together in a generalized manner that is governed by binding rules.
Referring now to
The search request can ask for an information object by name. Alternatively, the search request can ask for a property of information objects or an information object. The request can ask for information objects by classifications, property, membership in a group, or relationship between information objects. The search module 22 queries its current store of information in the fragment base 24. If the information is not present, the search module 22 enters a search loop (described in
Referring now to
The external data 12 can be native fragment data, or be translated into such a form by the client 12. The binding of such external data to the fragment database 24 can be incorporated into the connected collection of fragments and primitives within the fragment base.
In the case of external data not natively formed as fragments composed of primitives, the existence of words, word phrases, tags, field values or other properties within the contents of the data 14 or its location can be used by the resource parser 26 along with any particular instructions sent by the client 12. For example, the search process may ‘sense’ data 14 loaded by the client 12 that contain the words “news”, “interest rates” and “stock market”, and create a referral to the data 14 within the fragment database 24 as an instance of news about the stock market.
Referring now to
The goals 34a of the search are dependent on what the search is asking for. For example, if search request seeks all instances of a classification, it will try to search only for instances of a particular classification. Search process 22 can be regulated by search rules 34b. Search rules 34b can regulate the handling of error conditions, such as disallowed connections between primitives. Search rules can specify the conditions under which particular search algorithms are applied, for example, when or whether search by inheritance, by membership, by application of transformations should be applied. The search engine 22 also includes an evaluator 36 that is an interface between the search engine 22 and the fragment base 24 where the data is stored. The evaluator 36 determines whether the contents of the fragment base have satisfied the search.
The search limits are, for example, the amount of CPU time that can be expended for a search. The request 13 comes in, a search is initialized and the evaluator 36 evaluates available information in the fragment base to see whether information in the fragment base 24 can satisfy the search. If the requested information is not available in the fragment base 24, then the search engine 22 initializes an expansion of the search space to continue searching. At each loop, the search module determines whether the goals 34a have been satisfied. If the goals 34a have not been satisfied and the limits 34c have been exceeded, then the search module responds with a message that the request could not be satisfied within the limits of the parameters of the search.
An inquiry and modification interface 41 interfaces the search module 22 or other client to the fragment database 24. The inquiry and modification interface 41 allows the search module 22 to search for internal data in or referenced by the fragment base 24. The fragment database 24 can be asked to select 41g a particular piece of information. Retrieved or external resources 14 can be requested for incorporation into the fragment database 24 via the external data reader 26. Requests can be made to add 41a, assemble 41b, update 41c, remove 41d, or transform 41e information in the fragment database. Requests can also be made to load 41f or unload data sets, and export information from the fragment database 24.
The fragment base 24 holds fragments 40. The fragments 40 are comprised of primitives 42. The primitives 42 can be of several types, including classification 42a, instance 42b, attribute 42c, assigned-value 42d, condition 42e, action 42f, and container 42g. In addition to constituent primitives, fragment sequences 40a, equivalent identities 40b, fragments, relationships 40c and bindings 40d are maintained for individual primitives and for fragments.
During the course of search and evaluation, it may be more efficient to hold particular intermediate products. Therefore, the fragment base 24 can include a cache 44 that holds intermediate or derived constructs, such as search history 44a, composed information objects 44b that are focused upon during search, common properties among instances 44c, classification chains 44d, containership chains 44e, and transformation history 44f. The fragment base 24 includes settings 47 for its operation, including general operational rules and preferences.
The fragment base 24 can hold statistics 46 on how it is performing or whether something has been searched already or how many times something has been accessed. Statistics 46 can work with fragment store 40, the primitives store 42, and the cache 44 to access the quality of pieces of information. Quality can be based upon what was requested via inquiry 41, details of the search 44a, including what yielded positive or negative results. Information stored can be removed, added, transformed or otherwise altered based on an assessment of quality.
Referring now to
Referring now to
The search process 22 expands the search space 72 based on a set of methods that can be pursued in parallel. The search module 22 can evaluate memberships 74a in the system 10 and transformations 74b in, the system. The search engine 22 can also evaluate equivalences 74c between primitives, evaluate references 74d, evaluate inheritance relationships 74e, evaluate conditions 74f, and evaluate plug-in algorithms based on either the request for the particular search or on a setting local to the search engine 22. For some requests, resources 14 are retrieved from the network 16, such as evaluating new references 74d. The search process 22 gets resources from the network 16 and parses the resources 78 into primitives and/or fragments and adds the data to the fragment base 24. The resources pointed to by the references can be retrieved through a gateway such as TCP/IP HTTP gateway (not shown) over the network 16.
In contrast to the search process 22 responding to a direct request for information, the search process 22 can work in sense mode, in which the search module senses or is given information to read, in order to accumulate and alter information stored in the fragment based 24 based on the search module's goals and directives. This mode is one way in which the search module can acquire information.
Referring to
A client 12 for the search process 22 can include, for example, a hypertext browser or electronic mail reader. A current browsed page within the browser or the current read mail message within the electronic mail reader can be used as the external data source 14. The search process 22 senses each page or message accessed by the user operating the client application 12. The fragment database 24 contains information used to control the way in which the external resource is used. Data is incorporated by the creation of information fragments. By testing, content filling, and binding rules, new information is produced and is bound to existing information. User organized information within the fragment database can be associated with external data.
Referring now to
Three new conceptual structures are introduced here, composed information objects 93, fragments 94, and primitives 96. An information object 93 is composed from an assembly of fragments 94. Fragments are composed of, primitives 96. The term “information object” is used broadly to denote any identifiable thing in the physical, electronic or virtual world, and not directly tied to a conventional software programming object. For example, a particular friend, a person's bank account, or a book a person is reading are instances of real-world personal objects. Fragments 94 are small pieces of information about an information object 93. Fragments 94, in their smallest canonical form, are single minute statements, i.e., expressions or utterances of information about an information object 93. Primitives, fragments and information objects are bindable. That is, these structures can be bound to each other in a manner that is governed by binding rules. They are additive elements. That is, they can be added together through binding to produce new information. Thus, unlike hard linking, i.e., pointers or URL's, for example, these elements are free-form. That is, they can be bound together in various ways to produce information objects, but are not limited to a hard linking arrangement, since they can bind with any other primitive, fragment, and/or information object according to binding rules and general primitive type considerations.
Fragments 94 include both general information and particular information. For example, a fragment 94 can be “the best contact time” to contact someone. This fragment has a general property a “concept of time” and also has a particular property a “contact time” for a particular person. Other examples of fragments 94 include the usual amount of money that someone withdraws from a checking account. Again this fragment has a general concept withdrawing money from a bank account and a particular concept that is an actual value withdrawn. The name of a person and the person's bank are also quantities of information. Those are small fragments that are quantified as being “object like” statements people make about things that they have or do and that are below the level of a whole object.
Below defining building blocks of fragments 94, involves identifying particular types of information, i.e. primitives 96, that go into making these fragments 94. For example, an instance name, can be a bank name, a person's name. A classification can be an account type. An attribute of an account, for example, would be the balance.
Several differences exist between standard software objects, primitives, fragments and information objects. A first difference is the way that software objects are produced. Conventional objects are created as a combination of data structure and functions or methods. The actual data structure does not hold a value until run time. A customer object could be produced but until the customer object is instantiated at run time it does not have a customer number, it only has a general data structure to hold numbers, default values and functions. When the customer object is instantiated at run time, then it acquires a particular data like customer number or name.
Object databases or persistent objects store traditional run time objects in a database. This is a two-phase process that requires sophistication to create the whole pre-defined concept of an object first, then at run time, to store this elaborate run time structure. At run time, it is the, object's state that is retrieved.
Fragments 94 do not replace the functionality of traditional software objects and persistent object bases, but they represent information in a different way and can be formed and manipulated in different ways. Traditional software objects are carefully pre-defined and encapsulated. Information objects, on the other hand, are composed from fragments in an open and distributed manner.
Fragments 94 represent information in small pieces that can have both generalized structure and particular data. For example, a fragment can denote an instance of a classification, similar as an object is to a programmed class. However, classification as used with fragments is differentiated from programming class because a programming class is a well-defined, bounded whole, with pre-defined data structure and functionality. The “classification” on the other hand, is a more primitive starting point, as a label that forms a hierarchical structure. Semantically, an instance of a classification and an instance of a programmed class belongs to a grouping of similar-typed things. A loose form of search-based inheritance rules can be imposed on classifications, though not with the rigor of conventional programmed class inheritance. This is part of differences between objects and, fragments and primitives. Objects are bigger and more well defined than fragments and primitives.
By defining fragments to be additive, the fragments do not have to be designed in an object oriented manner of predefined classes. Another distinction from conventional software objects, therefore, is that conventional software objects are quite rigidly defined prior to use, in both data structure and functionality. The addition of attributes to a class definition requires reprogramming. Conventional programmed. ‘objects’ therefore have to be preconceived to a high degree of precision. This requirement often runs counter to how people naturally develop a gradual cumulative concept, i.e., information about a thing. In contrast, as information changes and grows incrementally, fragments can be added to or modified within the fragment base 24 (
Referring now to
A type field is defined. The types are similar to object-oriented software concepts and define the fundamental structure of a primitive. The content field 102 is used to represent a value or a referral to a value as will be shown below. The primitives can be represented minimally in plain text permitting them to be embedded into documents. The binding field 103 defines how the primitive 100 can connect to other primitives to form fragments. The ownership field 104 can specify the past owners and intended destinations of the primitive. The life span field 105 specified when the primitive was first formed, its expiration date, if it has one, and its status, i.e. whether it is active or dormant. Ownership 104 and life span 105 can be used as a distinguishing factor in fragment assembly and search. Life span 105 can be used to control the time period and status based validity of information contained in primitives and fragments.
In the schema, primitive types 101 are used to represent different types of information. For example, a classification is a generalized category of things based on common features. A classification can be a part of a hierarchical structure. An instance is a particular named or unnamed thing, such as a particular person, or a particular book, and so forth. Instances may belong to zero, one or more classifications. An attribute is a named property of an instance or classification. For example, “E-mail address” may be an attribute of a friend or of all friends. Values can be assigned to primitives to quantify an attribute or to equate a primitive with another primitive. A condition is an event. An action is a description or specification of behavior. Action indicates computational function, but also descriptions of actions and calls to remote server functions. Examples of the latter actions could be a reference to a function over a gateway, including a call to retrieve a remote resource. A container is differentiated from a classification. Dissimilarly classified instances can be members of a container.
Referring now to
The binding field 103 includes a list of individual bindings, described in conjunction with
The life span 105 includes a date and time of creation 105a, expiration 105b and a status 105c of whether it is active or inactive. The life span 105 can optionally include a refresh specification 105d to indicate the frequency of reloading its source data. Whereas, the expiration field 105b can facilitate removal of old data, refresh 105d can facilitate keeping rapidly changing data up to date once it is read into the fragment database 24.
Referring now to
Binding relation 106d can specify a relation to a primitive type. For example, the binding relation 106d can 4 specify a super-ordinate relation from one classification primitive to another classification primitive, or an attribution of an instance primitive by an attribute, primitive.
The binding points 106f can specify the primitive within a connected structure of primitives at which to bind. This can be specified as a position within pattern of connected primitives to match with. For example, the binding point can be at the top, middle or bottom of a sequence of classifications, or as an attribute to a particular classified instance.
Binding storage directionality 106g specifies if the binding is to result in incorporation “in” to the fragment base 24 holding the primitive, or to result in serving “out” of the primitive to the owners of the source, or both. Potentially, the binding of two primitives from different sources can result in a change in information in two or more databases, i.e. within the database that the binding occurs, and out at the database where the bound-to primitive came from. The binding directionality specification 106g controls how information gets incorporated into or distributed out of a fragment base 24. The binding of two primitives with binding directionality as “in”, can result in the binding effecting local and remote data. The binding of two primitives with directionality as “out” will not effect any data. The binding of two primitives with one directionality as “in” and the other as “out” will alter the data where the “in” primitive originated.
Binding notification 106h, allows for signaling of the source owner that binding with its primitive occurred. The source owner, if it is a compatible search process 22 and fragment database 24, can update its data.
Directionality 106g and notification 106h facilitate primitives and fragments composed of primitives, to exist out as stand alone data units that can be read, bound and accepted into databases, and/or act as requests for information that if recognized, can result in a change in the originating database.
Referring now to
Referring now to
Here the primitives 108 and 109 are instance type primitives and have a content field containing “War & Peace” and “Moby Dick”, respectively.
Referring now to
Referring now to
Referring now to
Classification primitives 101a are shown to bind with any primitive-type, allowing any primitive to be classified. A classification primitive can bind with another classification primitive in a super-ordinate or subordinate relationship 155a. Most connections between two primitive-types establish an implicit primitive-type based relationship. Some connections, particularly connections between primitives of the same type, such as two classifications must specify an explicit binding relation. The connection between two classifications must specify which is super-ordinate and which is subordinate. One or more such bindings create a classification hierarchy fragment. A classification can bind with an instance, yielding a classified instance fragment 155b and 156a. The formation of classified instances 155b and 156a is an important starting point for describing a thing as an instance of a general type. A classification can bind with an attribute yielding a fragment denoting a general attribute for a classification 155c and 157a. A classification can bind to an assigned value 155d which in turn can be bound to another classification 158a, yielding an equivalent, i.e. alias, classification 163.
The value primitive allows primitives such as a classification to be equated with another primitive of the same type, thereby establishing equivalences. For example, the classification “car” can be made equivalent to the classification “automobile”.
A classification can bind with a condition yielding a classified condition fragment 155e and 159a. A classified condition fragment 155e, 159a specifies a condition that is general to the classification and therefore to instances of the classification. “A classification can bind with an action, yielding a classified action fragment 155f and 160a. A classified action is an action that is general to the classification and its instances. A classification can bind with a container, yielding a classified container fragment 155g and 161a.
Instance primitives can 101b can bind to-an attribute primitive yielding an instance-attribute fragment 156c and 157b. An instance attribute fragment 156c is the smallest expression of a property for an instance, such, as “Dan's age” where “Dan” is an instance and “age” is an attribute. An instance primitive can, bind to an assigned value primitive 156d which in turn can be bound to another instance 158b, yielding an equivalent instance 164. This fragment 164 expresses that an instance is the same as another instance, such as “the instance ban is the same as the instance Daniel”. An instance can bind to a condition yielding a condition that the instance responds to 156e and 159b. An instance can bind to an action yielding an action that the instance can perform 156f and 160b. As mentioned, an action can be descriptive or computational. For example, an instance “Dan” can be bound to ah action “reads”. Even without associated computational function, such an instance-action fragment 156f expresses a small fact that can be used during a search, such as for an inquiry on what people like to do.
An attribute primitive 11c can bind with an assigned value primitive 101d yielding an attribute value fragment 157d and 158c. This is the fragment form of the basic pairing of attributes and values. An important difference here is that the attribute-value fragment 157d is part of a larger system and structure of information. For example, an attribute-value 157d can belong to an instance 156c, which in turn can be classified 155b, yielding a ‘attribute-value of a classified instance’ fragment 162 (
The value primitive 101d can be used to specify equivalence relations between primitives, such an equivalence between two classification primitives, or between two instance primitives.
A condition primitive 101e can bind with a value primitive yielding an equivalent condition 159d and 158e. A condition primitive can bind to an action primitive yielding a condition-action fragment 159f and 160e. This is the fragment expression of a condition-action pair. A condition primitive can bind to another condition primitive to form a nested condition 159e. The super-ordinate subordinate relationship 159e between condition primitives must be made explicitly.
An action primitive can bind 160d to a value primitive which in turn is bound 158f to another action, yielding an equivalent action 168.
Container binding allows primitives to be grouped without classified likeness, as is the case with classification. A container primitive can bind to an instance primitive, yielding a contained instance fragment 161b and 156g. A contained instance 161b is distinct from a classified instance 155b. For example, “War and Peace” is an instance of a book. The instance can be contained in “my library” but “War and Peace” is not an instance of a library. A container primitive can bind 161d to a value primitive which in turn can be bound 158g to another container, yielding an equivalent container 167. A container primitive can bind to another container, yielding a container hierarchy fragment 161g. The super-ordinate subordinate relation between two connected containers must be made explicit.
Referring now to
Assembly of fragments can also be determined through an explicit binding specification.
Referring now to
The second fragment 137 is a classification instance fragment 155b. The fragment expresses that “Explore USA” is an instance of the classification “USA”. The classification “USA” has an open binding 138 that allows 106a any source 106b to bind the relation 106c superclassification”, i.e. as a super ordinate classification. In this example context, the two fragments 130, 137 can be bound based on explicit binding allowances, yielding the new fragment 141. The “USA” classification primitive 139 now is bound to the “travel” classification primitive. The composed fragment 141 extends the classification of the primitive “Explore USA” as an instance of a USA travel book. Note that the fragment 141 express no direct relationship between the classification primitive 133 ‘Europe’ and classification primitive 139, but infers an indirect relationship that both sub-classification primitives 133 and 139 relate to ‘travel’. The open binding 134 of the instance 140 will allow an attribute to bind to it. In the present example, binding has been shown without much limitation, in order to emphasize the basic assembly process.
Referring now to
Referring to
Referring to
Both transformations 465, 482 result in the transformation of fragments from one form into another. More importantly, both transforms create generalized information from more specific information. Such transformations can be used to alter fragment bases 24 so that information is more structurally suitable for evaluation and searching.
Referring now to
Referring now to
Referring now to
Referring now to
Referring to
The resultant fragments 292 are individual classification hierarchy fragments fitting the structure of the original fragment 280, with the referred 283 external data 287 occupying the contents field of each classification primitive 297, 298, 299 and 301. The fragments 293, 201, 294 and 295 express the categories “Travel Book”, “Health and Fitness Book”, “Cooking Book”, and “Science Book”, respectively. The fragment database 24 can assemble these fragments 292 into a collective: hierarchy 304, if possible. In this example, the classification “Book” 208 is the super-classification of four classifications, “Travel” 297, “Health and Fitness” 209, “Cooking” 299 and “Science” 301.
Referring now to FIG., 29, an external HTML file 340 is used to produce fragment data. A fragment 320 is of the canonical fragment form of a classified instance 155b (
Referring now to
The external data mapping functions shown included the mapping of relational or flat tabular data onto fragments. This process can work in the reverse direction to allow the storage of composed objects into one or more relational databases. Since composed objects may not have singular structure, a common structural specification can be searched via the fragment database 24, and search module 22. Customized properties can be stored as well.
The examples above show how a variety of external data sources can be used to fill the contents; of fragments 94 contained within a fragment database 24. The use of external data to fill the contents 102 of fragments allows fragments to work in conjunction with other forms of data such as relational databases 221, text files 250, and tagged documents 225 (
A composed, information object 93 is a flexible and dynamic representation of information that is assembled on demand from fragments 94 and primitives. Almost any aspect of an object (i.e., a physical, virtual or electronic object) can be modified and customized on an instance to instance basis. This differs from conventional object-oriented software objects, and this is a powerful difference. The real world is full of cases where information is partially specified or attributes of one category do not apply to all members of a category. The example instance of a health and fitness book 230 has the attribute ‘borrower’. Other books may not have this attribute at all, yet they are still considered as instances of books. Then, the composed information object has this distinct feature that frees the user from the constraints of standard programmed objects that have strict pre-defined data structures. The use of primitive binding specifications 103a can regulate the openness and regularity of composed information objects. For example, the common assumption that a subclass inherits its superclass's attributes can be enabled via the use of the “require” binding mode 106a, which would require that a primitive, such as an instance, bind to an attribute, for example. A classification hierarchy can limit inheritance by denying additional classifications to be bound to particular classification primitives. Classification inheritance searching can also be further regulated by selectively recognizing primitives by ownership or other properties.
In the present system, composed objects of a classification can have varied properties and behaviors. The fragment database 24 and search module 22 can identify commonalities and cache 44 this data 44c. Since composed objects, do not have to conform to one pre-defined structure and still be of one classification is significant and different. Classifications can embody greater generality and flexibility, without complex subclassifications. Commonality can be sought but variability and therefore flexibility in defining information objects can be enhanced. Subclassifications and re-classifications can be accomplished on-the data through search and transformation of the fragment data.
Referring now to
Elaborated information on the composed information object “Bob” 402 is also shown. The composed information object “Bob” 402 has an attribute 407 “Title” with assigned value 408 “Dr”. The composed information object alpo has a condition 409 “contact me” with action value “mailto:bob@school.edu.” i.e., a hyperlink. The condition is descriptive and can be searched or inspected. The action example shows that the composed information object responds to the request to ‘contact me’ with the invocation of a mail message. The second action “works out” 411 is an action primitive 10f without a condition and is descriptive of an activity, i.e. that “Bob works out” instead of a computational function. As mentioned previously, actions 101f are broadly defined to include computational or descriptive actions, in order to express virtual actions that a computer can perform as well as to express physical actions that are performed outside the realm of the computer.
A new classification 401 comprised of classifications 405 and 4.06 is provided. The classification “level” 405 is a super-classification of the classification “novice” 224. The classification “borrower” 406 is a classification of the instance “Bob” 228. These classifications are of note because they are derived from transformations, as previously described (
Referring now to
Referring now to
A transformation can be used to loosen information structure represented by primitives and fragments. Transformations can be performed in the event that the data within the fragment database 24 is expressed in a particular way that does not yield any searchable structure. By unloosening the fragment data the transformation produces new generalized structures, in this case, that can be more useful for searching.
Referring now to
In the second example 444, is a request for all attribute primitives for the instance named “Stretch yourself!” and where the instance classification is “Book”. Using the fragment data in the example,
In the third example 446, a connection between two instances “Stretch yourself!” and “Bob.” are asked for. Using the fragment data in the example,
In the fourth example 448, the classifications for the instance “Bob” is requested. Using the fragment data in the example,
In the fifth example 450, instances are requested for classification “Book” and container “top shelf”and where the fragment owner is “dan@myschool.edu”, a person specified by an E-mail address. In descriptive terms, this request is for books on the top shelf. Using the fragment data in the example,
These examples of inquiries in conjunction with the example fragment data show how fragment data can be formed and searched.
Referring now to
The keyword “REFERRAL” 532f can precede the specification of a referral information 102b. The keyword “MAPPING” 532g can precede the specification of a data mapping function 107b. The keywords “CLASSIFICATION” 532h, “INSTANCE” 532i, “ATTRIBUTE” 532j, “VALUE” 532k, “CONTAINER” 5321, “CONDITION” 532m, and “ACTION” 532n can follow the keyword “PRIMITIVE” 532b to specify the primitive types. The keyword “SLOT” 532 can specify a placeholder for unfilled and to-be-filled data. The keyword “RELATION” 532p can precede the specification of a binding relation 106d within a binding. The keywords “SUPER” 532g and “SUB” 532r can partially specify the binding relation 106d between two primitives, such as between two classification primitives 101a where one classification is superordinate and the other is subordinate. The keyword “EQUIVALENT” 532s can specify the type of relation for the primitive-type Value binding. The keyword “SEQUENTIAL” 532t can specify the fragment is to be interpreted as a sequence of implicitly bound fragments. The keyword “KEY” 532u can specify one or more primitive or fragment fields for inclusion in a key used to determine primitive uniqueness or similarity. For example, primitive type, content and owner can be used to designate uniqueness. The key can be used to regulate identity binding (described in
Referring now to
A second plain text representation 510 is shown to indicate how two fragments stored separately can relate to each other. The fragment 510 descriptively states that “Stretch Yourself! was borrowed by Bob”. The second fragment 510 is owned 122 by “Bob@myschool.edu” 510b and has a lifespan 123 from “Jan. 1, 1998” to “Jan. 1, 1999” and is active 510c. A fragment binding specification 510d “allows” binding of any of the primitives within the fragment to the person “Dan@myschool.edu.” The fragment has a primitive instance “Stretch Yourself” 510e. The primitive 510e has a binding specification 510f to “require”, binding to a classification primitive at the url “http://myschool.edu/dan/mybooks.txt”. The binding further specifies a binding point below the classification hierarchy “Book” and “Health and Fitness” 510h, indicated in this example by the underscore “______”. The instance primitive “Stretch Yourself” 510e is followed by the attribute primitive “borrower” 510i and value primitive “Bob” 510j. The fragment 510 corresponds to the fragment 207 from the prior example,
The two fragments 521 and 510 can be assembled and form part of the composite information object as described previously and as shown in
Referring now to
Referring now to
Referring now to
Referring now to
Primitive-handling functions 51 include a method to add a primitive to the fragment database 51a based on supplied data, a method to remove a primitive 51b within the fragment database, a method to set individual properties of a primitive 51c, a method to get the owners of a primitive 51d, a method to get a particular property of a primitive 51e, a method to get a primitive's type 51f, a method to get a primitive's contents 51g, a method to get a primitives bindings 51b, a method to get equivalent primitives 51i.
Composite information objects are, a focused, i.e. an identified, subset of the primitives within the fragment database 24. Composite handling functions include a method to add a primitive to the focused set 52a, a method to set the focus to a previously defined set 52b, a method to assign a numeric or named level to focused primitives 52c, and to export the composite object 52d.
Fragment handling functions 53a include a method to create a new fragment 53a, a method to remove an existing fragment from the fragment base 53b, a method to set a property of a fragment 53c, a method to get the classifications of an instance as a fragment 53d, a method to get the attributes of an instance 53d, a method to get attribute-value fragments 53g, a method to get container hierarchies as a fragment 53h, a method to get the super-ordinate 53i or subordinate 53j classifications of a primitive as a fragment, a method to get the super-ordinate 53k subordinate 531 containers of a container, a method to get the fragment by owner 53m, by originating source 53n, or by a property 53o. A method for getting a fragment's internal identifier 53p is included.
Database utility functions include a method to load a dataset into the fragment base 54a, a method to load fragments into the fragment base 54b, a method to clear fragments from the fragment base 54c, a method to read external resources 54d, a method to export data from the fragment base 54e, and a method to map contents as specified in a content referral 102b (
Referring now to
Referring now to
An example composite information object 93 was described in
Referring now to
Search algorithms are selected 681 from an available set 34b based upon the inquiry and the type of primitives in the focused set. All starting primitives are queued into a search queue, a first in first out (FIFO) structure 683. Each queued primitive is accompanied by the algorithms to use and the search depth. Each item is removed from the queue and search algorithms are applied. Search algorithms are based on the inquiry. Search and composition algorithms include classification hierarchy searching, classified-instance searching, instance-attribution searching, primitive equivalence searching, contained-instance searching, container hierarchy searching, transform pattern searching, instance-action searching and condition-action searching.
The mentioned searches can be reduced to search graphs, which specify-by starting primitive-types, valid connections to primitive-types and end goal primitives. To start at a primitive of the specified type, and be able to apply the general connections within the graph to the fragment base and arrive at the end primitive, is to satisfy the goal of the search graph. The product of the search using the graph, is to ‘focus’, i.e. identify, the primitives in the fragment database that match the characteristics of the search graph, such as the traversal of primitives by type.
Iterative applications of selected searches, as described by the search graphs, forms the composite objects within the answer set. The traversal success is tested 686. Unsuccessful traversals end in a non-end state. The ending primitive can be placed onto the queue with new algorithms 687. Primitives traversed during a successful traversal of a search graph are added to the set of focused primitives 688. The new focused set of primitives is compared to the end goals to determine if further searching is needed 689.
Referring now to
A second search graph 710 starts with an instance primitive and ends with an attribute primitive.
Referring now to
Referring now to
Referring now to
Referring now to
In the second scenario 825, the primitive “B” 812b sent from fragment base 24b has a binding direction set to “in” 814b, and the primitive “A” 810b in fragment base 24a has a binding direction “out” 817b. Fragment base 24a does not bind to the new data 812b, but instead, notifies 822 fragment base 24b of the possible binding with its primitive “A” 810b, as specified by the notification setting in the primitive “B” 812b. The binding between primitives “A” 810b and “B” 812b occurs not in the fragment base 24a but in the fragment base 24b.
In the third scenario 826, the primitive “B” 812c sent from fragment base 24b has a binding direction set to “in” 814c with notification 815c, and the primitive “A” 810c in the fragment base 24a has a binding direction set to “in” 817c. Both fragment bases 24a and 24b are changed internally. Fragment base 24a incorporates primitive “B” 812c, and notifies 822 fragment base 224b to bind with fragment “A” 810c.
A fourth scenario (not shown) in which both binding directions are “out” have no effect on either fragment base 24a or 24b.
The ability of fragments and their contained primitives to specify how they are to be bound to, and where this effect is to take place, allows for the fragment and primitive data to be distributed in an actively transmitted fashion such as a broadcasted stream of data, or in stored files, and when used, i.e. bound to, have the effect selectively take place where the data is being read and/or where the data came from.
The schema can be built into new web pages or existing web pages can be modified. One approach can have a client that has a agent that helps form information object statements and embeds then into HTML pages. There are several ways that this data can be put into web documents or on the web. One way would be as an embedded comment that would be invisible except to a search engine or something that searches for a particular comment with a header of a particular type. Another way would be that it could be in an XML format with a particular reader of that document applying that XML format to it.
A browser could have an agent that would be the client side part of the system. The agent would be designed to read fragments and primitives and splice them together to point to a resource or to give information in terms of a web page. The actual data need hot be visible as text on the page. The agent could add information to data embedded into documents. Data could also be embedded into images as a way of highlighting regions within a two-dimensional or three-dimensional representation. Therefore, the actual source document does not have to change. To express some object fragment information about a page, a local process can store fragment data and reference a URL for the page. In this manner, the fragment data can be stored locally along with the reference to the URL.
There exists alternative implementation versions of the above schema. In one alternate implementation, the schema can be represented as actual firmware on an integrated circuit. The alternate implementation can have a search engine and fragment base. One example application could have the implementation in an appliance that can acquire information on how the appliance is used. For example, the appliance could be a telephone and the schema can acquire an object type model that can learn behavior and produce a profile of a user by building an object type database on favorite restaurants, etc.
It is to be understood that while the invention has been described in conjunction with the detailed description thereof, the foregoing description is intended to illustrate and not limit the scope of the invention, which is defined by the scope of the appended claims. Other aspects, advantages, and modifications are within the scope of the following claims.
Number | Date | Country | |
---|---|---|---|
Parent | 09225974 | Jan 1999 | US |
Child | 11311921 | Dec 2005 | US |