|Publication number||US6037944 A|
|Application number||US 08/747,092|
|Publication date||Mar 14, 2000|
|Filing date||Nov 7, 1996|
|Priority date||Nov 7, 1996|
|Also published as||DE69739463D1, US6031537, US7203910|
|Publication number||08747092, 747092, US 6037944 A, US 6037944A, US-A-6037944, US6037944 A, US6037944A|
|Inventors||Harlan M. Hugh|
|Original Assignee||Natrificial Llc|
|Export Citation||BiBTeX, EndNote, RefMan|
|Patent Citations (43), Non-Patent Citations (40), Referenced by (147), Classifications (7), Legal Events (8)|
|External Links: USPTO, USPTO Assignment, Espacenet|
This invention relates to a computer-controlled graphical user interface ("GUI") for organizing and processing interrelated pieces of information, hereinafter referred to as "thoughts."
The general-purpose digital computer is one of the most powerful and remarkable information processing tools ever invented. Indeed, the advent of the digital computer has thrust the world headlong into what is now recognized by many analysts as an "information era" and an "information economy," in which the ability to access and process information in an effective manner is one of the most important forms of economic power.
The potential impact of the digital computer on information processing is undeniably revolutionary. Yet, conventional software environments are generally organized around metaphors and principles from earlier eras. Text-based operating systems like Microsoft DOS essentially treat the computer as a giant filing cabinet containing documents and applications. A strictly hierarchical file directory provides a rigid, tree-like structure for this digital file cabinet. Individual documents are the "leaves" of this tree hierarchy. The directory structure generally does not include or express relationships between leaves, and users generally access documents and applications individually, using the directory structure. Even the now ubiquitous graphical "desktop" computing environment, popularized for personal computers by the Apple Macintosh® and Microsoft Windows® operating systems, also simulates a traditional office environment. Individual documents and applications, represented by graphical icons, are displayed on the user's screen, to be accessed one-at-a-time. Once again, a strictly hierarchical, tree-like directory structure is imposed to organize the contents of the desktop.
Although the desktop and file cabinet metaphors have been commercially successful, the limitations and drawbacks of these traditional metaphors become clear when one considers the strikingly different way in which the world's other powerful information processing machine--the human brain--organizes information. Instead of being confined and limited to strictly hierarchical file directory structures, the human brain is thought to interconnect numerous pieces of information through flexible, non-hierarchical, associative networks. As those of skill and experience in the art are aware, it is often clumsy for users of traditional, prior art operating system interfaces to process multiple pieces of information if these pieces are contextually related in some way, but are stored in separate files and/or are associated with different application programs. These traditional limitations therefore often lead frustrated users to organize their thought processes around their computer software, instead of the reverse.
What is desired is an effective methodology for organizing and processing pieces of interrelated information (or "thoughts") using a digital computer. The methodology should support flexible, associative networks of digital thoughts, and not be limited to strict, tree hierarchies as are conventional, prior art technologies. A related goal is to create an intuitive and accessible scheme for graphically representing networks of thoughts, providing users with access to diverse types of information in a manner that maximizes access speed but minimizes navigational confusion.
The present invention enables users to organize information on a digital computer in a flexible, associative manner, akin to the way in which information is organized by the human mind. Accordingly, the present invention utilizes highly flexible, associative thought networks to organize and represent digitally-stored thoughts. A thought network specifies a plurality of thoughts, as well as network relationships among the thoughts. Because the network structure is flexible, each thought may be connected to a plurality of related thoughts. A graphical representation of the thought network is displayed, including a plurality of display icons corresponding to the thoughts, and a plurality of connecting lines corresponding to the relationships among the thoughts. Each of the thoughts may be associated with one or more software application programs, such as a word processing or spreadsheet utility. Users are able to select a current thought conveniently by interacting with the graphical representation, and the current thought is processed by automatically invoking the application program associated with the current thought in a transparent manner. Users can modify the thought network by interactively redrawing the connecting lines between thoughts, and relationships within the thought network are then automatically redefined in a corresponding manner.
In another aspect of the present invention, descriptive attribute values are associated with each thought of the network, and database searching is performed for thoughts that are characterized by desired attribute values. Other preferred features of the present invention include storing timing and usage information regarding the processing of thoughts, so that the system can report and describe the user's work patterns, and can "rewind" or "replay" portions of work previously performed by the user. Particular thoughts can also be scheduled for desired operations at specified times.
FIG. 1 illustrates the basic architecture of a computer system for use in implementing a preferred embodiment of the present invention.
FIG. 2 illustrates a preferred data architecture for thoughts, in accordance with the present invention.
FIGS. 3, 7-9, 11-15 illustrate preferred graphical user interface screen displays, in accordance with aspects of the present invention.
FIG. 4 illustrates the preferred graphical user interface of FIG. 3, reflecting the selection of a new current thought by a user.
FIG. 5 is a flow diagram showing the process for creating and relating thoughts in a preferred embodiment of the present invention.
FIG. 6 is a flow diagram showing the process for severing relationships between thoughts in a preferred embodiment of the present invention.
FIG. 10 discloses an algorithm which may be implemented in a preferred embodiment of the present invention.
FIG. 1 depicts the general architecture of a digital computer system 90 for practicing the present invention. Processor 100 is a standard digital computer microprocessor, such as a CPU of the Intel x86 series. Processor 100 runs system software 120 (such as Microsoft Windows®, Mac OS® or another graphical operating system for personal computers), which is stored on storage unit 110, e.g., a standard internal fixed disk drive. "Brain" software 130, also stored on storage unit 110, preferably includes computer program code for performing the tasks and steps described below, including the digital representation of thought networks, the display of graphical representations of such networks, and the processing of such networks in accordance with the principles of the present invention. Display output, including the visual GUI discussed below, is transmitted from processor 100 to an output device such as a video monitor 140 for display to users. Users utilize input devices such as standard personal computer keyboard 150, cursor control device 160 (e.g., a mouse or trackball), touch-screen sensors on the monitor display, or voice input to enter the GUI input commands discussed below, which are then transmitted to processor 100.
In a preferred embodiment of the present invention as illustrated in FIG. 2, a plurality of interrelated thoughts collectively make up a "Thought Network." Each such "thought" (i.e., a piece of information, such as a collection of spreadsheet data) is represented internally as comprising various elements, including properties and relationships. Properties can include, as in the example of thought 200,: number 205, name 210, key words 215, document 220, usage statistics 225, priority 230, flags 235, category 240. Relationships can include currently linked thoughts 245 and past linked thoughts 250. Except for document 220, all of the data for all thoughts is stored in a set of files 255 (which we designate "the HeadCase" in our preferred embodiment), which is invisible to the user and is transparently loaded to RAM and saved to data storage 111 as the user works.
Number 205. Each thought has a unique number which is invisible to the user but is used internally, by other thoughts or lists, to reference the thought. References to each thought thus occupy only a small amount of internal storage, and changes to a thought's user-specified name do not affect internal references.
Name 210. The "name" of a thought is intended to be a brief, textual description of that thought, written by the user. The purpose of a name is to enable users to identify the associated thought in a convenient manner.
Key Words 215. The "key words" of a thought are a list of descriptive terms inputted by the user, which list may be interactively searched using the search methods described in more detail below (see "Searching").
Document 220. Each thought includes an associated "document," which stores all of the specific content for that thought, such as word processing data or spreadsheet data. Each such document is stored internally in its own file in data storage 111 or separately stored in mass storage devices accessible by the computer system, whose name is based on the associated thought's number. As discussed further below, the user need not and does not consciously manage these files. Instead, accessing a thought automatically provides the user with a seamless, transparent way of accessing the associated document contents along with an appropriate application program or utility for processing those contents.
Usage Statistics 225. "Usage statistics" are preferably generated and stored for each thought as the user works on that thought, as discussed in greater detail below in the "Additional Features" section.
Priority 230. A priority number set by the user indicates the relative importance of a particular thought. The priority is normally manually set by the user, but can be calculated based upon the usage statistics and the relationships at the user's request. The priority can then be used to filter thoughts when searching or creating thought lists.
Flags 235. Flags provide a mechanism for designating the state of each thought. Preferably, each flag can be in one of three states: on, off, or default. When a flag is in default, the thought value is determined by the category of thought (see Category, below). Flags can be user-defined, or may be automatically provided by the system. An example of a preferred system flag is one that states whether a thought is part of long term memory.
Category 240. A thought's "category" is a number which designates a thought to be of a specific category. Thought categories are defined and named by the user. Each category specifies that thoughts of that category will have certain attributes or "fields," as well as certain default flag values (see the discussion of "flags" above). An example of a category might be "Person," in which case an example field might be "City of Residence." The use of fields to perform indexed searching is discussed in further detail below, in the "Processing Thoughts" section. Category definitions are preferably stored separately, as templates.
Relationships Between Thoughts 245. Preferably, three types of relationships are possible among thoughts: Child, Parent, and Jump. Each thought includes a separate list for each type of relationship. Each such relationship list stores a list of the other thoughts (identified by number) that are related to the instant thought by the instant type of relationship. The relationship lists are used to generate and navigate graphical representations of the thought network, as described in detail below, and are otherwise invisible to the user.
Past Relationships 250. Preferably, there is another set of three lists: for Child, Parent, and Jump relationships, respectively, which archive information about those relationships which have been severed or "forgotten" but which may be remembered upon request by the user. Essentially, this provides a long term memory facility that allows users to recall previous relationships when desired, without cluttering the current display with non-current data, as discussed below.
Graphically Representing and Navigating a Thought Network
FIG. 3 illustrates a typical, graphical representation ("plex 300") of a network of related thoughts which will be displayed on the monitor 140, in accordance with a preferred embodiment of the present invention. In the example of FIG. 3, central thought 310 labelled, "Cortex", is displayed in the center of the plex, preferably surrounded by a circle, a dashed rectangle, and a rotating or blinking graphic in order to call attention visually to the central thought. Thoughts that are directly related to the central thought 310 are represented in the plex 300 by display icons connected by lines to the central thought. In a preferred embodiment of the present invention, multiple categories or types of thought relationships can be specified, in the interests of providing users maximum organizational flexibility and clarity. Specifically, the present invention allows a plurality of Parent thoughts, a plurality of Child thoughts, a plurality of Jump thoughts. The present invention also provides for the display of a plurality of "Sibling" thoughts (such as the thought "ParaGen" 322), which are Child thoughts of any and all Parent thoughts (such as the thought "Software" 312) of the current Central thought ("Cortex" 330). For example, in the preferred embodiment of FIG. 3, above the central thought 310 are related Parent thoughts. In this plex there is only one, "Software" 312. Below the central thought are Child thoughts. In this plex there are three: "Projects" 314, "Resources" 316, and "Information" 318. To the left of the central thought are Jump thoughts, in this plex there is only one: "Nomenclature" 320. Finally, to the right of the central thought are Sibling thoughts which share a Parent with the central thought. In this plex there is only one--"ParaGen" 322. The underlying significance and semantics of these or other categories of thought relationships is of course entirely up to the individual practitioner and user.
Each thought in a plex preferably has three circles near it. These circles are thought "gates" (e.g. gates 330, 340, and 350 in FIG. 3), and are used to show and create the relationships between thoughts. The location of each gate tells what kind of relationship it represents. Thus, gate 330 above thought 310 is for relationships to Parent thoughts; gate 350 below thought 310 is for relationships to Child thoughts; and gate 340 on the side of thought 310 is for relationships to Jump thoughts. Note that each thought in the display of FIG. 3 is connected to central thought 310 by the appropriate gate. Preferably, each gate circle being used (i.e., a gate through which a thought is connected) is filled (e.g. gate 330); if no thought is connected through a gate, that gate's circle is empty (e.g. gate 340). In addition, gates are preferably color-coded according to the currently displayed thoughts. For example, in a preferred embodiment, if a gate is red (e.g. gate 350), this indicates that all the thoughts to which it connects are currently displayed. If a gate is green (e.g. gate 365), this indicates that there are other thoughts to which it is connected and which are not displayed on the network at this time.
Display of the network is preferably configured based upon the current thought. More specifically, the display positions of thoughts are determined by the way they are related and the number of thoughts that are related in that way. Thus, in a preferred embodiment of the invention, the central thought (e.g. 310) is always drawn in the center. Above are the Parent thoughts (e.g., 312), which are drawn in up to two columns extending upward. Below are the Child thoughts (e.g., 314, 316, 318), which are drawn in up to four columns extending downward. The Jump thoughts appear to the left in a single column which extends up and down until it hits the Child thoughts, at which point it begins to extend only upward. Siblings thought appear to the right in a single column which extends up and down until it hits the Child thoughts, at which point it begins to extend only upward. In practice, the actual drawing sequence on screen preferably is performed as follows. First the background is cleared. The scaling circle and the lines that connect the thoughts are then drawn. Next, the lines are drawn between the locations of the gates representing the appropriate relationships. Finally, the actual thought names and the gates are drawn.
Navigation and movement through the network is preferably accomplished by selecting the thought to be moved to, using control device 160 or keyboard 150 (e.g. arrows, tab, escape or space bar). The selected thought becomes the new central thought, and the network display is rearranged according to the new central thought's relationships, preferably with animation showing the movement of the thoughts. For example, FIG. 4 shows the thought network of FIG. 3, but rearranged after a user has interactively selected Software 312 as the new central thought, in place of Cortex 310. Window 360 is used to display and edit the document for the current thought, as discussed below in the section entitled "Processing Thoughts."
Creating New Thoughts. New thoughts are preferably created by interactively clicking and dragging, using mouse/control device 160, from any of the gates around an existing thought. FIG. 5 provides a flow diagram showing the basic steps of this process. At step 500, the user selects by clicking on a gate of an existing thought (a "source thought"), to which the new thought is to be related. At step 510, the user drags control device 160 away from the source thought; preferably, during this step, a "rubber-band" line is displayed coming out of the source thought gate and tracking the cursor controlled by mouse/control device 160. At step 520, the mouse/control device's 160 button is released. At that point, if the cursor controlled by mouse/control device 160 is located over an existing thought (a "target thought"), as indicated at decision point 530, then the system assumes the user desires to create a new relationship between the source thought and the target thought, as will be described shortly below. In order to create a new thought, the user simply releases mouse/control device 160 with the cursor at an unoccupied location on the screen. In that case, as shown at step 540, a new thought is created and added to Headcase 290. Preferably, a dialog box 710 (see FIG. 7) appears and asks for the new thought's name and/or other properties; a unique new thought number is created to refer to this thought; all of the new thought's data fields are initialized to default values; and the thought's number is added to a global list of all thoughts.
Next, at step 550, a relationship is created between the source thought and the new thought, preferably based upon the type of gate of the source thought that was selected at step 500. In particular, the new thought's number is added to the appropriate relationship list (245) of the source thought, and the source thought's number is added to the appropriate relationship list (245) of the new thought. Finally, at step 560, the updated plex is redrawn, reflecting the newly created thought and its relationship to the source thought.
Relating Existing Thoughts. Existing thoughts may be related using the same method as is used to create new thoughts. Referring again to FIG. 5, steps 500 through 520 are the same. However, at decision point 530, control device 160 is determined to have been released with the cursor located over an existing thought (the "target thought"). In that case, at step 535, the relationship list 245 (FIG. 2) of the source thought and target thought are checked to ensure that the thoughts are not already directly related. If such a relationship does exist, it is preferably deleted at step 545 by removing the source and target thoughts' numbers from each other's current relationship lists, to avoid any ambiguities. Next, at step 550, the source and target thoughts' numbers are added to each other's appropriate relationship list (245), as determined by the source thought's gate type originally selected at step 500. The redefined network is redrawn at step 560. If such a relationship does not exist, then step 545 is inapplicable and step 550 is processed immediately after step 535 is executed.
Reordering Relations. Related thoughts are drawn in the plex according to the order they are listed in the relationships list of the central thought. By dragging the thoughts in the display, the user can specify in what order they should be listed and as a result, where they will appear. In reference to FIG. 3, FIG. 8 provides an example of the display 800, in the preferred embodiment, which would result if a user were to interactively reverse the order of thoughts 316 and 318, causing the icons representing those thoughts 316 and 318 to switch horizontal positions as demonstrated by the positions of those thoughts 316 and 318 in FIG. 8.
Severing Relations Between Existing Thoughts. It is possible to sever the relationship between two existing thoughts, such as central thought 310 ("Cortex") and Child thought 314 ("Projects"), using a process similar to the process used to define a new relationship between existing thoughts. As the flow diagram in FIG. 6 outlines, at step 600, the user requests that a particular relationship be severed, by clicking on the relationship lines which connect two thoughts such as the line connecting thoughts 310 and 314 in FIG. 3. Next, at decision point 610, a check is made to see if the requested severing would involve the special case of "forgetting," as will be explained shortly. If no "forgetting" will occur, then at step 660 the numbers of the two thoughts are removed from each other's relationship lists and the line between thoughts 310 and 314 in the graphical display shown in FIG. 3 may be removed.
The special case of "forgetting" an existing relationship will now be explained. Consider the example network shown in FIG. 3. If the relation between thought 314 ("Projects") and central thought 310 ("Cortex") is severed, then there will be no path at all connecting thought 314 with central thought 310, and thus no way to access thought 314 from the current thought. Thought 314 will be isolated. In that sense, thought 314 will be "forgotten" if the severing is performed. Therefore, in the process depicted by FIG. 6, decision point 610 detects such cases (see below, "Determining if thoughts will be isolated"). In such cases, the number of the "forgotten" thought (i.e., thought 314) is deleted from the current relation list 245 (FIG. 2) of central thought 310 at step 620, and is added to the corresponding past relationship list 250 of central thought 310. Recall that the past relation lists 250 are included as part of each thought's data structure, as illustrated in FIG. 2. Next, the forgotten thought's own fields are revised to reflect its status as a "forgotten" thought: namely, at step 630, thought 314's current relationship lists 245 are merged into its past relations lists 250 (i.e., copied from 245 to 250 and then erased from 245), and at step 640 its "long term memory" flag is set to "on." At step 650, forgotten thought 314 is preferably added to a global long term memory thought list. At step 670, the plex is redrawn, reflecting the absence of forgotten thought 314. It is possible to forget more than one thought at once, in which case all of the forgotten thoughts will be modified as described for thought 314.
Determining If Thoughts Will Be Isolated. A thought will be isolated when it is not possible to return to the central thought via any link other than that link which is being severed. Similarly, any thoughts ("Rodin" 950 and "Liquid Noise" 960 in FIG. 9) related to the severed thought ("Projects" 314) will be forgotten so long as their only link to the central thought existed via the severed thought ("Projects" 314). One method of determining whether it is possible to return to the central thought from a thought whose link has been severed is illustrated by the recursive algorithm disclosed in FIG. 10.
Accessing Long Term Memory. To access thoughts that are stored in long term memory, preferably the user can interactively turn on the display of long term memory relationships (for example, by means of a menu selection or function key). The display will then be refreshed, and thoughts related by long term memory relationships will become visible and are connected (as shown in FIG. 11) to the central thought with a line, such as line 1110, of different sort than that used for normal relationships. A long term relationship can then be recreated as a current relationship by using the "Relating Existing Thoughts" technique described above. In that case, the appropriate thought numbers (See FIG. 2) are copied from past relationship lists 250 to the appropriate, current relationship lists 245. The appropriate thought numbers are then moved in the global long term and short term memory lists, and the display is once again redrawn.
In an alternative embodiment of the present invention, each thought's Head Case does not include a list of past relationships. Rather, each thought's Head Case merely contains a flag identifying it as a forgotten thought or a present thought. When a user interactively turns on a display of long term memory within this alternative embodiment, forgotten thoughts and their relationships to present thoughts are are added to the display, and severed relationships between present thoughts will not reappear. This alternative embodiment may offer certain advantages, including without limitation (i) presenting the user with a simpler, more readily comprehensible set of information regarding past relationships within the thought network; and (ii) reducing the complexity of the thought network's data structure and hence the computing resources used to operate the thought network.
Permanently Deleting a Thought. It is also possible to permanently remove a thought from the thought network. This is accomplished by clicking on a line (such as line 1110) which connects a thought which is already in long term memory. When severing a relationship in this manner results in a thought or thoughts becoming isolated, this thought or thoughts are removed from the global thought list and from the past relationships list 250 of the central thought.
Creating New Thought Flags and Types. To define a new thought flag, the user interactively selects a thought and then enters a flag name and its default state. To define a new thought type, the user enters the name of the new type, its default flag states, and any fields that the type has. The new types and flags can thereafter be referenced by the user when creating new thoughts or changing thought properties.
Thought Pins. Thought pins are used to get instant access to commonly used thoughts. In the upper left corner of FIG. 3 are two thought pins 370 and 375, labelled "Rodin" and "Liquid Noise." Thought pins can be moved by the user to any location or deleted. To create a new thought pin, the user simply moves the cursor (using mouse/control device 160), and clicks on or otherwise highlights the existing thought for which a thought pin is to be created, and then selects a "Create Pin" command or the like from an ensuing pop-up command menu (such as menu 1210). Selecting an existing thought pin (e.g., using mouse/control device 160 to position the cursor over the pin, then clicking the control devices's button) makes the pin-represented thought into the new central thought of the current plex. For example, selecting thought pin 370 ("Rodin") in FIG. 3 would result in the plex transforming into the plex displayed in FIG. 13, with thought 370 ("Rodin") as the central thought. Note that thought pins are preferably represented internally by the number(s) of the thought(s) they reference and an explicit, user-specified display location.
Creating Thought Plexes. As described earlier, thought plexes are the graphical displays of a group of related thoughts, consisting of Central thought and any Parent, Child, Jump, and Sibling thoughts. There is always at least one thought plex. Additional thought plexes can be created by using the control device 160 to position the cursor over any thought other than the central thought, and dragging the selected thought to the desired location of the new plex. Each time a user creates a plex, that plex is added to the screen display along with the other plexes previously presented on the screen display (See FIG. 9).
The figures demonstrate an example of the manner in which a new plex may be created. First, in FIG. 3, a user interactively selects the thought 314 ("Projects") to be a new central thought by using control device 160 to position the cursor over that thought, then selects the thought by clicking and holding a button on the cursor control device. The user then employs control device 160 to move the cursor to the desired location of the new plex and releases the button. FIG. 9 demonstrates the screen display which results. Plex 920 has been added to the screen display, with the thought 914 ("Projects") as the central thought of new plex 920.
Moving Thought Pins and Plexes. In the preferred embodiment, thought pins can be repositioned by dragging them with the mouse or other control device. Thought plexes can be reposited be dragging their central thought with the mouse or other control device. Thought pins and plexes can be deleted by dragging them off of the display. Eliminating a plex from the display does not result in any thoughts being forgotten. Forgetting involves a different user-interactive process discussed above (see "Severing Relations Between Existing Thoughts"). The separate process of forgetting is discussed above.
Resizing a Thought Plex. In the preferred embodiment, a thought plex can be seized by dragging the circle which surrounds the central thought. Making the circle bigger makes the entire plex bigger and vice-versa.
Changing a Thought Pin. A thought pin can be made to reference a different thought simply by dragging the desired thought onto the pin.
Doing a Brain Freeze. In response to a user's request or in response to a regularly scheduled system request for backup, a "Brain Freeze" saves the state of all parts of a thought network at a given point in time, copying all the information to a read-only format for later use.
Editing Thought Documents. Each thought's document contents are displayed in document window 360, as illustrated in FIG. 3. When the current thought is changed, the last thought's document is saved (unless otherwise directed by the user) if necessary and then the new current thought's document is loaded automatically. The user never has to issue "save" or "open" commands to access thought documents, nor does the user need to explicitly identify or invoke an editor or other application program to process the thoughts. These operations are performed automatically by the system, seamlessly and transparently. When a thought is activated by the user, the system saves the previously active thought, if it has changed, then loads the newly active thought. Well-known computer programming object technologies including without limitation Microsofts' Object Linking and Embedding ("OLE") allow the document to make references to data which is created and edited by other programs. Using standard operating systems calls, the present invention can display and allow the user to edit these objects with the appropriate computer programs. In addition, the document may also store references to the location of other documents on the storage systems available to the computer, allowing the user to open them with the appropriate computer programs using a more traditional operating system method.
Changing Thought Properties. Thought properties such as name, flags, priority, and category can be changed using a the thought properties dialog box, such as dialog box 710, which is accessed by the user employing mouse/control device 160 and/or keyboard 150 to select a particular thought and then the thought properties dialog box.
Editing Thought Fields. Thought fields can be edited in a dialog box or window such as 1410 in FIG. 14. In the preferred embodiment, the field names are displayed to the left and their contents to the right. Thought fields are automatically loaded and saved, in the same fashion as are the contents of thought documents, invisibly to the user every time a thought field is modified. All thoughts of a certain category possess the same available thought fields, which fields are defined by the user in establishing and modifying thought categories (see above, "Category").
In a preferred embodiment, every thought category 240 possesses at least two fields. Those default fields are the "Name" field and the "Key Words" field. The contents of these default fields are identical to the contents of the properties called "Name" and "Key Words" respectively.
Rewinding and Replaying Previous Operations. An event list is created automatically by the system, as the user works. The event list is a recording of each action the user takes. It stores how to undo each action and how to repeat each action. This information is then used to "rewind" and "replay" the actions of the user, upon the user's request.
Thought Lists. Internally, thought lists are simply a list of numbers. To the user, they are displayed as a list of thought names. A preferred embodiment of the present invention keeps a list of all short term memory thoughts and long term memory thoughts. In addition, a list of thoughts is created for each defined thought type. Lists of thoughts can also be manually created (see below, "Trains of Thought" and "Searching"). The user can activate a thought in a list (make it central in the current plex) by clicking on it. Thought lists can also be used to perform group operations on thoughts such as printing, changing properties, or even saving (to save only a selected portion of the thought network).
The Past Thought List. One special example of a preferred thought list is the past thought list. FIG. 3 illustrates how a past thought list 380 can be created automatically as the user works. Each time the user changes the current thought, the number of the last thought is added to the Past Thought List. In the preferred embodiment, it is possible to display the past thought list as a list (such as past thought list 380) of thoughts which scrolls along the bottom of the display as the user activates thoughts. For example, each time a user activates a separate thought, the previously activated thought is placed at the right-hand end of past thought list 380 pushing the older thoughts to the left of the screen. The oldest thought that cannot fit on screen is eliminated from view from the left-hand end of past thought list 380.
Trains of Thought. Another special example of a preferred thought list is the "train of thought," which lists a series of thoughts in a particular sequence as desired by the user. A train of thought can be created by simply navigating through the desired thoughts in the same order as the users wants them to appear in the train of thought. This will automatically cause the desired sequence of thoughts to become part of the past thought list, as noted above. As shown in FIG. 11, the user then interactively selects the desired section of the past thought list using mouse/control device 160. In the case of FIG. 11, the user has selected "Projects" and "Cortex"--the two most recent thoughts--for inclusion in a train of thought. The user then interactively selects the Create Train command 1120 by using a pull down menu, function key or similar means. In response, the selected sequence of thoughts is copied to a new thought list and the user is asked to name it, thus creating a new "train of thought" thought list.
Trains of thought can be used for accomplishing tasks that involve a number of pre-existing parts. For example, an attorney might use a train of thought to assemble a number of pre-existing sections of text (stored in separate thought documents) into a new contract, or an engineer or computer programmer can use trains of thought to assemble a new computer program out of a pre-existing library of subroutines.
Searching. Thought lists can preferably be filtered or "searched" according to thought category, priority, name, flags, fields, etc. This allows the thought network to be used as a searchable database. For example, one thought type might be the type "Person," which might include the attribute "City". Each thought of the Person type would then be assigned a specific "City" value by the user. Users could then request a search of the network for all thoughts involving persons they know who live in a certain city, by requesting a display of all thoughts on the "Person" type list, filtered as to those whose "City" attribute equals the desired value.
Similarly, enables users to create project plans, daily agendas, or to-do lists or other task-oriented thought lists and create relevant thought lists. First, the user assigns priority levels (e.g. "urgent," "important," "unimportant") or flags (e.g. "completed" or "incomplete") to thoughts as they work (See "Changing Thought Properties" above). The present invention enables users later to create a to-do list, for example, by searching for thoughts associated with a flag set in the "incomplete" position and a priority level of "urgent." The search engine operates in a method similar to those widely used in commercially available database programs.
Usage statistics. Usage statistics suitable for keeping track of billable time, productivity, work habits or efficiency are preferably generated and stored for each thought as the user works on that thought, according to the system clock. These statistics include time of creation, time of last modification, time of last access by user and the time (if applicable) at which the thought was "forgotten." Each thought also stores the total number of seconds the user has so far spent processing it, the number of "events" (keyboard and mouse clicks) that occurred, and the thought's modification history (., a list of all dates when that thought was modified and how long each such modification took).
Preferably, the system supports interactive commands for requesting the display of these usage statistics. For example, in the preferred embodiment, a user can request to view usage statistics falling within a given time period. FIG. 3 demonstrates how the preferred embodiment of the present invention can display usage information automatically. By default, the preferred embodiment shows a "C" next to each thought which was recently created (380); an "A" next to each thought which was recently accessed (380, 385); an "L" next to the last active thought (390, 395); and an "M" next to each thought which was recently modified (not illustrated).
Undoing and Redoing. Undoing and redoing of operations is preferably supported by an internally stored event list which keeps track of how data is affected and what is necessary to undo the effects of each event. When something is undone the undo event is recorded to the redo list to enable redoing.
Calendar Scheduling. By storing thought numbers in events, appointments, schedule data, or other time-based items, it is possible to associate time based events with thoughts. A calendar can then be used by the user to keep track of events and link related thoughts to the events. For example, in the preferred embodiment, rather than displaying thoughts graphically in plexes, thoughts can be displayed on a calendar as demonstrated in FIG. 15. For example, the calendar event 1510 ("9:00 am meeting with Liquid Noise project team") may be associated with "Liquid Noise" thought 960. The preferred embodiment of the present invention permits a user to create that association by using the mouse/control device 160 to draw a line connecting the calendar event 1510 and the desired thought 960. When a user interactively selects calendar event 1510, thought 960 becomes the new central thought (as illustrated).
In addition, thoughts may be associated through calendar events with computer program operations. For example, if calendar event 1510 were associated with an alarm program, then at 9:00 am, the alarm would sound, and the present invention could also be configured to display a reminder message, or activate "Liquid Noise" thought 960 as the new central thought.
Detailed illustrations of an improved scheme of ongoing information by an associative thought process in accordance with the present invention have been provided above for the edification of those of ordinary skill in the art, and not as a limitation on the scope of the invention. Numerous variations and modifications within the spirit of the present invention will of course occur to those of ordinary skill in the art in view of the preferred embodiments that have now been disclosed. For example, while in the described embodiment, the present invention is implemented for a GUI for desktop computers or local area or wide area computer networks (e.g. the Internet), the present invention may also be effectively implemented for any information appliance which can take advantage of the novel associative thought scheme of the present invention. Such variations, as well as any other systems embodying any of the following claims, all remain within the scope of the present invention.
|Cited Patent||Filing date||Publication date||Applicant||Title|
|US4712191 *||Jul 22, 1983||Dec 8, 1987||U.S. Philips Corporation||Display system with nested information display|
|US4752889 *||Aug 18, 1986||Jun 21, 1988||Neuron Data, Inc.||Dynamic, interactive display system for a knowledge base|
|US4764867 *||Jun 3, 1986||Aug 16, 1988||Banner Blue Software Incorporated||Display system and method for constructing and editing a hierarchical arrangement of information|
|US4773024 *||Jun 3, 1986||Sep 20, 1988||Synaptics, Inc.||Brain emulation circuit with reduced confusion|
|US4796199 *||Feb 24, 1987||Jan 3, 1989||Oregon Graduate Center||Neural-model, information-handling architecture and method|
|US4802103 *||Jun 3, 1986||Jan 31, 1989||Synaptics, Inc.||Brain learning and recognition emulation circuitry and method of recognizing events|
|US4821211 *||Nov 19, 1987||Apr 11, 1989||International Business Machines Corp.||Method of navigating among program menus using a graphical menu tree|
|US4891766 *||Jun 15, 1989||Jan 2, 1990||International Business Machines Corporation||Editor for expert system|
|US4982344 *||May 18, 1988||Jan 1, 1991||Xerox Corporation||Accelerating link creation|
|US5021976 *||Nov 14, 1988||Jun 4, 1991||Microelectronics And Computer Technology Corporation||Method and system for generating dynamic, interactive visual representations of information structures within a computer|
|US5072412 *||Mar 25, 1987||Dec 10, 1991||Xerox Corporation||User interface with multiple workspaces for sharing display system objects|
|US5115504 *||Nov 1, 1988||May 19, 1992||Lotus Development Corporation||Information management system|
|US5144693 *||Dec 30, 1988||Sep 1, 1992||Chipsoft Ca Corp.||Method and apparatus for generic form generation|
|US5204947 *||Oct 31, 1990||Apr 20, 1993||International Business Machines Corporation||Application independent (open) hypermedia enablement services|
|US5206950 *||Jul 8, 1991||Apr 27, 1993||Gupta Technologies, Inc.||Software development system and method using expanding outline interface|
|US5222196 *||Mar 10, 1992||Jun 22, 1993||International Business Machines Corporation||Neural network shell for application programs|
|US5226117 *||May 15, 1990||Jul 6, 1993||International Business Machines Corporation||Method for simultaneous update and change in parent and child windows|
|US5295242 *||Nov 2, 1990||Mar 15, 1994||Consilium, Inc.||Apparatus and method for viewing relationships in a factory management system|
|US5381524 *||Nov 12, 1991||Jan 10, 1995||Chronology Corp.||Automated development of timing diagrams for electrical circuits|
|US5418950 *||Sep 21, 1994||May 23, 1995||International Business Machines Corporation||System for interactive clause window construction of SQL queries|
|US5428738 *||May 21, 1993||Jun 27, 1995||Novell, Inc.||Logical expression calculation interface|
|US5437007 *||Nov 10, 1992||Jul 25, 1995||Hewlett-Packard Company||Control sequencer in an iconic programming system|
|US5469540 *||Jan 27, 1993||Nov 21, 1995||Apple Computer, Inc.||Method and apparatus for generating and displaying multiple simultaneously-active windows|
|US5491795 *||May 2, 1994||Feb 13, 1996||International Business Machines Corporation||Window management system with a hierarchical iconic array and miniature windows|
|US5499330 *||Sep 17, 1993||Mar 12, 1996||Digital Equipment Corp.||Document display system for organizing and displaying documents as screen objects organized along strand paths|
|US5506937 *||Apr 2, 1993||Apr 9, 1996||University Of West Florida||Concept mapbased multimedia computer system for facilitating user understanding of a domain of knowledge|
|US5530942 *||Feb 13, 1995||Jun 25, 1996||International Business Machines Corporation||Graphic and text interactive user interface for a program execution analyzer|
|US5546529 *||Jul 28, 1994||Aug 13, 1996||Xerox Corporation||Method and apparatus for visualization of database search results|
|US5553226 *||Oct 30, 1989||Sep 3, 1996||Hitachi, Ltd.||System for displaying concept networks|
|US5555354 *||Mar 23, 1993||Sep 10, 1996||Silicon Graphics Inc.||Method and apparatus for navigation within three-dimensional information landscape|
|US5602997 *||Jun 7, 1995||Feb 11, 1997||Starfish Software, Inc.||Customizable program control interface for a computer system|
|US5615346 *||Dec 23, 1994||Mar 25, 1997||International Business Machines Corporation||Method and system for a piano bar browser of information sets|
|US5619632 *||Sep 14, 1994||Apr 8, 1997||Xerox Corporation||Displaying node-link structure with region of greater spacings and peripheral branches|
|US5625783 *||Dec 13, 1994||Apr 29, 1997||Microsoft Corporation||Automated system and method for dynamic menu construction in a graphical user interface|
|US5644740 *||Nov 30, 1993||Jul 1, 1997||Hitachi, Ltd.||Method and apparatus for displaying items of information organized in a hierarchical structure|
|US5666503 *||Nov 14, 1994||Sep 9, 1997||Xerox Corporation||Structured image (SI) image editor and method for editing structured images|
|US5786820 *||Sep 23, 1996||Jul 28, 1998||Xerox Corporation||Method and apparatus for increasing the displayed detail of a tree structure|
|US5801702 *||Mar 9, 1995||Sep 1, 1998||Terrabyte Technology||System and method for adding network links in a displayed hierarchy|
|US5812134 *||Mar 28, 1996||Sep 22, 1998||Critical Thought, Inc.||User interface navigational system & method for interactive representation of information contained within a database|
|US5870559 *||Apr 11, 1997||Feb 9, 1999||Mercury Interactive||Software system and associated methods for facilitating the analysis and management of web sites|
|DE4440598C1 *||Nov 14, 1994||May 23, 1996||Siemens Ag||World Wide Web hypertext information highway navigator controlled by spoken word|
|EP0273435A2 *||Dec 29, 1987||Jul 6, 1988||Wang Laboratories Inc.||Office automation system with integrated image management|
|EP0325777A2 *||Dec 22, 1988||Aug 2, 1989||International Business Machines Corporation||A distributed auditing subsystem for an operating system|
|1||Apple Computer, Inc., "Apple Drives Initiative to Bring Structured Content to the Internet", Sep. 18, 1996.|
|2||*||Apple Computer, Inc., Apple Drives Initiative to Bring Structured Content to the Internet , Sep. 18, 1996.|
|3||*||Apple Computer, Inc., Macintosh Reference, 1990.|
|4||Axon Research, "Axon Idea Processor", copyright 1995-1997.|
|5||*||Axon Research, Axon Idea Processor , copyright 1995 1997.|
|6||Burns et al., "A Graphical Entity-Relationship Database Browser", IEEE, pp. 694-704, 1988.|
|7||*||Burns et al., A Graphical Entity Relationship Database Browser , IEEE, pp. 694 704, 1988.|
|8||Carr L., et al: "Open Information Services" Computer Networks and ISDN Systems, vol. 28, No. 11, May 1996, pp. 1027-1036, XP004018205.|
|9||*||Carr L., et al: Open Information Services Computer Networks and ISDN Systems, vol. 28, No. 11, May 1996, pp. 1027 1036, XP004018205.|
|10||Clearweb, Inc., "You Can See the Web Clearly Now", copyright date 1996.|
|11||*||Clearweb, Inc., You Can See the Web Clearly Now , copyright date 1996.|
|12||CoCo Systems, Ltd, "VisiMap", copyright date 1996-1998.|
|13||*||CoCo Systems, Ltd, VisiMap , copyright date 1996 1998.|
|14||Edward Tufte, "Envisioning Information", Global Business Network, Dec. 1990.|
|15||*||Edward Tufte, Envisioning Information , Global Business Network, Dec. 1990.|
|16||Foss, "Tools for Reading and Browsing Hypertext", Information Processing & Management, vol. 25, No. 4, pp. 407-418, 1989.|
|17||*||Foss, Tools for Reading and Browsing Hypertext , Information Processing & Management, vol. 25, No. 4, pp. 407 418, 1989.|
|18||Halasz et al., "NoteCards in a Nutshell", ACM, pp. 45-52, 1987.|
|19||*||Halasz et al., NoteCards in a Nutshell , ACM, pp. 45 52, 1987.|
|20||Inxight Software Inc., a Xerox New Enterprise Co., "Hyperbolic Tree Web Navigatikon", copyright date 1996-1997.|
|21||*||Inxight Software Inc., a Xerox New Enterprise Co., Hyperbolic Tree Web Navigatikon , copyright date 1996 1997.|
|22||James Farrows, "Navigating the Galaxies", The Atlantic Monthly, Apr. 1996, vol. 277, No. 4, pp. 119-124.|
|23||*||James Farrows, Navigating the Galaxies , The Atlantic Monthly, Apr. 1996, vol. 277, No. 4, pp. 119 124.|
|24||Kent, R.E., et al: "Creating a Web Analysis and Visualization Environment" Computer Networks and ISDN Systems, vol. 1, No. 28, Dec. 1995, pp. 109-117, XP004001216.|
|25||*||Kent, R.E., et al: Creating a Web Analysis and Visualization Environment Computer Networks and ISDN Systems, vol. 1, No. 28, Dec. 1995, pp. 109 117, XP004001216.|
|26||Michael Jetter, "Welcome to Mindman, the Creative MindManager", copyright date 1996-1998.|
|27||*||Michael Jetter, Welcome to Mindman, the Creative MindManager , copyright date 1996 1998.|
|28||*||Microsoft Corporation, Microsoft Windows 95, 1981.|
|29||Noah Robischon, "Mapping the Future", The Netly News Network, Feb. 4, 1998.|
|30||*||Noah Robischon, Mapping the Future , The Netly News Network, Feb. 4, 1998.|
|31||Olsen, K.A., et al: "Visualization of a Document Collection: The Vibe System" Information Processing and Management (Incorporating Information Technology), vol. 29, No. 1, Jan. 1, 1993, pp. 69-81, XP000574984.|
|32||*||Olsen, K.A., et al: Visualization of a Document Collection: The Vibe System Information Processing and Management (Incorporating Information Technology), vol. 29, No. 1, Jan. 1, 1993, pp. 69 81, XP000574984.|
|33||Plum Design, "Thinkmap", copyright date 1998.|
|34||*||Plum Design, Thinkmap , copyright date 1998.|
|35||Semino Corporation, "Semino", copyright 1996-1998.|
|36||*||Semino Corporation, Semino , copyright 1996 1998.|
|37||Tony Buzan, "The Mind Map Book", Plume, Mar. 1996.|
|38||*||Tony Buzan, The Mind Map Book , Plume, Mar. 1996.|
|39||Vannevar Bush, "As We May Think", The Atlantic Monthly, Jul. 1945, vol. 176, No. 1, pp. 101-108.|
|40||*||Vannevar Bush, As We May Think , The Atlantic Monthly, Jul. 1945, vol. 176, No. 1, pp. 101 108.|
|Citing Patent||Filing date||Publication date||Applicant||Title|
|US6166739 *||Mar 19, 1999||Dec 26, 2000||Natrificial, Llc||Method and apparatus for organizing and processing information using a digital computer|
|US6751620||Feb 14, 2001||Jun 15, 2004||Geophoenix, Inc.||Apparatus for viewing information in virtual space using multiple templates|
|US6785667||Feb 14, 2001||Aug 31, 2004||Geophoenix, Inc.||Method and apparatus for extracting data objects and locating them in virtual space|
|US6888554||May 24, 2001||May 3, 2005||Groxis, Inc.||User interface for bicontextual exploration of a graph|
|US6931604||Jan 23, 2002||Aug 16, 2005||Derek Graham Lane||Method of navigating a collection of interconnected nodes|
|US6957205||Mar 8, 2000||Oct 18, 2005||Accenture Llp||Knowledge model-based indexing of information|
|US6996774||Feb 12, 2002||Feb 7, 2006||Accenture Global Services Gmbh||Display of data element indicia based on data types|
|US7036093||Jun 5, 2001||Apr 25, 2006||Groxis, Inc.||User interface for exploring a graph of information|
|US7099854||Feb 17, 2005||Aug 29, 2006||Accenture Llp||Knowledgebase framework system|
|US7149729||Aug 30, 2005||Dec 12, 2006||Microsoft Corporation||System and method for filtering and organizing items based on common elements|
|US7162488||Apr 22, 2005||Jan 9, 2007||Microsoft Corporation||Systems, methods, and user interfaces for storing, searching, navigating, and retrieving electronic information|
|US7181463 *||Oct 24, 2003||Feb 20, 2007||Microsoft Corporation||System and method for managing data using static lists|
|US7188316||Apr 22, 2005||Mar 6, 2007||Microsoft Corporation||System and method for viewing and editing multi-value properties|
|US7213018||Jan 16, 2002||May 1, 2007||Aol Llc||Directory server views|
|US7234114||Mar 24, 2003||Jun 19, 2007||Microsoft Corporation||Extensible object previewer in a shell browser|
|US7240292||Apr 17, 2003||Jul 3, 2007||Microsoft Corporation||Virtual address bar user interface control|
|US7290223||Nov 10, 2004||Oct 30, 2007||Groxis, Inc.||Interface for displaying and exploring hierarchical information|
|US7383503||Feb 23, 2005||Jun 3, 2008||Microsoft Corporation||Filtering a collection of items|
|US7409644||May 16, 2003||Aug 5, 2008||Microsoft Corporation||File system shell|
|US7440931 *||Jul 6, 2000||Oct 21, 2008||Creative Brains, K.K.||Method and apparatus for analyzing thought system|
|US7496583||Apr 30, 2004||Feb 24, 2009||Microsoft Corporation||Property tree for metadata navigation and assignment|
|US7499925||Mar 27, 2003||Mar 3, 2009||Microsoft Corporation||File system for displaying items of different types and from different physical locations|
|US7502819||Jun 14, 2002||Mar 10, 2009||Consultores Ub57, S.L.||Dynamic browser interface|
|US7512586||Apr 21, 2006||Mar 31, 2009||Microsoft Corporation||System and method for filtering and organizing items based on common elements|
|US7526483||Oct 23, 2003||Apr 28, 2009||Microsoft Corporation||System and method for virtual folder sharing including utilization of static and dynamic lists|
|US7536386||Dec 5, 2003||May 19, 2009||Microsoft Corporation||System and method for sharing items in a computer system|
|US7536411||Jun 30, 2006||May 19, 2009||Aol Llc A Delaware Limited Liability Company||Directory server views|
|US7587411||Apr 22, 2005||Sep 8, 2009||Microsoft Corporation||System and method for filtering and organizing items based on common elements|
|US7614016||Apr 21, 2005||Nov 3, 2009||Microsoft Corporation||Multiple roots in navigation pane|
|US7627552||Dec 1, 2009||Microsoft Corporation||System and method for filtering and organizing items based on common elements|
|US7650575||Jul 13, 2005||Jan 19, 2010||Microsoft Corporation||Rich drag drop user interface|
|US7657846||Apr 23, 2004||Feb 2, 2010||Microsoft Corporation||System and method for displaying stack icons|
|US7665028||Jul 13, 2005||Feb 16, 2010||Microsoft Corporation||Rich drag drop user interface|
|US7694236||Jul 22, 2005||Apr 6, 2010||Microsoft Corporation||Stack icons representing multiple objects|
|US7707197||Oct 11, 2006||Apr 27, 2010||Microsoft Corporation||System and method for filtering and organizing items based on common elements|
|US7711754||Jan 26, 2007||May 4, 2010||Microsoft Corporation||System and method for managing data using static lists|
|US7712034||Apr 22, 2005||May 4, 2010||Microsoft Corporation||System and method for shell browser|
|US7730429 *||Dec 3, 2004||Jun 1, 2010||Spark-Space Ltd.||Graphical workspace for idea management|
|US7765176||Nov 13, 2006||Jul 27, 2010||Accenture Global Services Gmbh||Knowledge discovery system with user interactive analysis view for analyzing and generating relationships|
|US7769794||Aug 3, 2010||Microsoft Corporation||User interface for a file system shell|
|US7823077||Oct 26, 2010||Microsoft Corporation||System and method for user modification of metadata in a shell browser|
|US7827561||Mar 25, 2004||Nov 2, 2010||Microsoft Corporation||System and method for public consumption of communication events between arbitrary processes|
|US7853556||Dec 14, 2010||Accenture Global Services Limited||Navigating a software project respository|
|US7853890||Apr 22, 2005||Dec 14, 2010||Microsoft Corporation||Address bar user interface control|
|US7865904||Oct 23, 2003||Jan 4, 2011||Microsoft Corporation||Extensible user context system for delivery of notifications|
|US7890960||Mar 26, 2003||Feb 15, 2011||Microsoft Corporation||Extensible user context system for delivery of notifications|
|US7904411||Mar 8, 2011||Accenture Global Services Limited||Knowledge discovery tool relationship generation|
|US7925682||Mar 27, 2003||Apr 12, 2011||Microsoft Corporation||System and method utilizing virtual folders|
|US7953687||Jul 26, 2010||May 31, 2011||Accenture Global Services Limited||Knowledge discovery system with user interactive analysis view for analyzing and generating relationships|
|US7958451 *||Jan 27, 2003||Jun 7, 2011||Sony Corporation||Graphical user interface for an information mediation system|
|US7992103||Aug 2, 2011||Microsoft Corporation||Scaling icons for representing files|
|US8010581||Jul 18, 2008||Aug 30, 2011||Accenture Global Services Limited||Knowledge discovery tool navigation|
|US8024335||Jul 9, 2004||Sep 20, 2011||Microsoft Corporation||System and method for dynamically generating a selectable search extension|
|US8051102||Nov 1, 2011||Levitronics, Inc.||Data base and knowledge operating system|
|US8108430||Jan 31, 2012||Microsoft Corporation||Carousel control for metadata navigation and assignment|
|US8161396||Apr 17, 2012||Mindjet Llc||System and method for facilitating collaboration and communication in a visual mapping system by tracking user presence in individual topics|
|US8195646||Apr 22, 2005||Jun 5, 2012||Microsoft Corporation||Systems, methods, and user interfaces for storing, searching, navigating, and retrieving electronic information|
|US8204847 *||Jun 19, 2012||Kerika, Inc.||Idea page system and method|
|US8209624||Jun 26, 2012||Microsoft Corporation||Virtual address bar user interface control|
|US8356036||Jan 15, 2013||Accenture Global Services||Knowledge discovery tool extraction and integration|
|US8392267||Mar 5, 2013||Mindjet Llc||System, method, and software application for dynamically generating a link to an online procurement site within a software application|
|US8490015||Apr 15, 2005||Jul 16, 2013||Microsoft Corporation||Task dialog and programming interface for same|
|US8522154||Apr 22, 2005||Aug 27, 2013||Microsoft Corporation||Scenario specialization of file browser|
|US8631332 *||Sep 30, 2010||Jan 14, 2014||Linkedin Corporation||Content visualization|
|US8660977||Jan 28, 2011||Feb 25, 2014||Accenture Global Services Limited||Knowledge discovery tool relationship generation|
|US8661036||Jul 31, 2008||Feb 25, 2014||Microsoft Corporation||Metadata editing control|
|US8707209||Apr 22, 2005||Apr 22, 2014||Microsoft Corporation||Save preview representation of files being created|
|US8751940 *||Sep 27, 2013||Jun 10, 2014||Linkedin Corporation||Content visualization|
|US8869037 *||Jun 22, 2006||Oct 21, 2014||Linkedin Corporation||Event visualization|
|US8972342||Aug 21, 2008||Mar 3, 2015||Microsoft Corporation||Metadata editing control|
|US9038001 *||Jul 1, 2004||May 19, 2015||Mindjet Llc||System and method for graphically illustrating external data source information in the form of a visual hierarchy in an electronic workspace|
|US9047388||Nov 10, 2008||Jun 2, 2015||Mindjet Llc||System, method, and software application for displaying data from a web service in a visual map|
|US9213471 *||Nov 29, 2012||Dec 15, 2015||Linkedin Corporation||Content visualization|
|US9361312||Aug 30, 2005||Jun 7, 2016||Microsoft Technology Licensing, Llc||System and method for filtering and organizing items based on metadata|
|US9361313||Apr 26, 2010||Jun 7, 2016||Microsoft Technology Licensing, Llc||System and method for filtering and organizing items based on common elements|
|US9396282||Jun 1, 2015||Jul 19, 2016||Mindjet Llc||System, method, and software application for displaying data from a web service in a visual map|
|US9396455||Nov 10, 2008||Jul 19, 2016||Mindjet Llc||System, method, and software application for enabling a user to view and interact with a visual map in an external application|
|US20010052110 *||Feb 14, 2001||Dec 13, 2001||Julian Orbanes||System and method for graphically programming operators|
|US20020075311 *||Feb 14, 2001||Jun 20, 2002||Julian Orbanes||Method for viewing information in virtual space|
|US20020080177 *||Feb 14, 2001||Jun 27, 2002||Julian Orbanes||Method and apparatus for converting data objects to a custom format for viewing information in virtual space|
|US20020105552 *||Jan 23, 2002||Aug 8, 2002||Lane Derek Graham||Method of navigating a collection of interconnected nodes|
|US20030160817 *||Jan 27, 2003||Aug 28, 2003||Takayuki Ishida||Graphical user interface for an information mediation system|
|US20030163366 *||May 25, 2001||Aug 28, 2003||Taft Frederick I||Method and apparatus for organizing information and conducting thematic inquiry|
|US20040024790 *||Jul 16, 2003||Feb 5, 2004||Ron Everett||Data base and knowledge operating system|
|US20040189695 *||Mar 24, 2003||Sep 30, 2004||James Brian Kurtz||Extensible object previewer in a shell browser|
|US20040189707 *||Mar 27, 2003||Sep 30, 2004||Microsoft Corporation||System and method for filtering and organizing items based on common elements|
|US20040193621 *||Mar 27, 2003||Sep 30, 2004||Microsoft Corporation||System and method utilizing virtual folders|
|US20040194110 *||Mar 26, 2003||Sep 30, 2004||Microsoft Corporation||Extensible user context system for delivery of notifications|
|US20040194116 *||Mar 25, 2004||Sep 30, 2004||Mckee Timothy P.||System and method for public consumption of communication events between arbitrary processes|
|US20040210819 *||Jun 14, 2002||Oct 21, 2004||Alonso Antonio Used||Dynamic browser interface|
|US20040215732 *||Oct 23, 2003||Oct 28, 2004||Mckee Timothy P.||Extensible user context system for delivery of notifications|
|US20040230599 *||May 16, 2003||Nov 18, 2004||Microsoft Corporation||File system shell|
|US20050091235 *||Oct 24, 2003||Apr 28, 2005||Moore Jason F.||System and method for managing data using static lists|
|US20050114786 *||Nov 10, 2004||May 26, 2005||Jean Michel Decombe||Interface for displaying and exploring hierarchical information|
|US20050116953 *||Feb 12, 2002||Jun 2, 2005||Accenture Global Services||Display of data element indicia based on data types|
|US20050171760 *||Oct 8, 2004||Aug 4, 2005||Marc Tinkler||Visual thesaurus|
|US20050188174 *||Apr 19, 2005||Aug 25, 2005||Microsoft Corporation||Extensible creation and editing of collections of objects|
|US20050240878 *||Apr 26, 2004||Oct 27, 2005||Microsoft Corporation||System and method for scaling icons|
|US20050240880 *||Apr 23, 2004||Oct 27, 2005||Microsoft Corporation||System and method for displaying stack icons|
|US20050246331 *||Apr 22, 2005||Nov 3, 2005||Microsoft Corporation||System and method for filtering and organizing items based on common elements|
|US20050246352 *||Apr 30, 2004||Nov 3, 2005||Microsoft Corporation||Property tree for metadata navigation and assignment|
|US20050246648 *||Apr 22, 2005||Nov 3, 2005||Microsoft Corporation||Address bar user interface control|
|US20050283742 *||Jul 22, 2005||Dec 22, 2005||Microsoft Corporation||Stack icons representing multiple objects|
|US20060004739 *||Jul 9, 2004||Jan 5, 2006||Microsoft Corporation||System and method for dynamically generating a selectable search extension|
|US20060004873 *||Jul 29, 2005||Jan 5, 2006||Microsoft Corporation||Carousel control for metadata navigation and assignment|
|US20060005164 *||Jul 1, 2004||Jan 5, 2006||Jetter Michael B||System and method for graphically illustrating external data source information in the form of a visual hierarchy in an electronic workspace|
|US20060036568 *||Apr 22, 2005||Feb 16, 2006||Microsoft Corporation||File system shell|
|US20060121436 *||Dec 3, 2004||Jun 8, 2006||Elaine Kruse||Graphical workspace for idea management|
|US20060179027 *||May 11, 2005||Aug 10, 2006||Bechtel Michael E||Knowledge discovery tool relationship generation|
|US20060200466 *||Apr 21, 2006||Sep 7, 2006||Microsoft Corporation||System and Method for Filtering and Organizing Items Based on Common Elements|
|US20060236244 *||Apr 15, 2005||Oct 19, 2006||Microsoft Corporation||Command links|
|US20060236252 *||Apr 15, 2005||Oct 19, 2006||Microsoft Corporation||Task dialog and programming interface for same|
|US20060242121 *||Apr 22, 2005||Oct 26, 2006||Microsoft Corporation||Systems, methods, and user interfaces for storing, searching, navigating, and retrieving electronic information|
|US20060242122 *||Apr 22, 2005||Oct 26, 2006||Microsoft Corporation|
|US20060242164 *||Apr 22, 2005||Oct 26, 2006||Microsoft Corporation|
|US20060242585 *||Apr 22, 2005||Oct 26, 2006||Microsoft Corporation||Scenario specialization of file browser|
|US20060242591 *||Apr 22, 2005||Oct 26, 2006||Microsoft Corporation||File dialog user interfaces and creation of same|
|US20060242603 *||Apr 22, 2005||Oct 26, 2006||Microsoft Corporation||Dynamic multi-dimensional scrolling|
|US20060242604 *||Apr 21, 2005||Oct 26, 2006||Microsoft Corporation||Multiple roots in navigation pane|
|US20070168886 *||Mar 30, 2007||Jul 19, 2007||Microsoft Corporation||Virtual Address Bar User Interface Control|
|US20080147590 *||Feb 19, 2008||Jun 19, 2008||Accenture Global Services Gmbh||Knowledge discovery tool extraction and integration|
|US20080222547 *||Apr 22, 2005||Sep 11, 2008||Microsoft Corporation||Save Preview Representation of Files Being Created|
|US20080281841 *||May 2, 2008||Nov 13, 2008||Kishore Swaminathan||Navigating a software project respository|
|US20080288531 *||Jul 31, 2008||Nov 20, 2008||Microsoft Corporation||Metadata editing control|
|US20080307346 *||Aug 18, 2008||Dec 11, 2008||Microsoft Corporation||Metadata editing control|
|US20090055428 *||Aug 21, 2008||Feb 26, 2009||Microsoft Corporation||Metadata editing control|
|US20090157616 *||Dec 12, 2007||Jun 18, 2009||Richard Barber||System and method for enabling a user to search and retrieve individual topics in a visual mapping system|
|US20090157801 *||Dec 12, 2007||Jun 18, 2009||Richard Barber||System and method for integrating external system data in a visual mapping system|
|US20090164912 *||Dec 20, 2007||Jun 25, 2009||Richard Barber||System and method for facilitating collaboration and communication in a visual mapping system by tracking user presence in individual topics|
|US20090228447 *||Nov 10, 2008||Sep 10, 2009||Creekbaum William J||System, method, and solfware application for enabling a user to search an external domain within a visual mapping interface|
|US20090228785 *||Nov 10, 2008||Sep 10, 2009||Creekbaum William J||System, method, and software application for displaying data from a web service in a visual map|
|US20100070891 *||Feb 13, 2009||Mar 18, 2010||Creekbaum William J||System and method for configuring an application via a visual map interface|
|US20100122151 *||Nov 10, 2008||May 13, 2010||Mendelson Neil S||System, method, and software application for enabling a user to view and interact with a visual map in an external application|
|US20100205186 *||Aug 12, 2010||Microsoft Corporation||System and method for filtering and organizing items based on common elements|
|US20100293125 *||Jul 26, 2010||Nov 18, 2010||Simmons Hillery D||Knowledge discovery system with user interactive analysis view for analyzing and generating relationships|
|US20100325101 *||Dec 1, 2009||Dec 23, 2010||Beal Alexander M||Marketing asset exchange|
|US20110022966 *||Jan 27, 2011||Digg, Inc.||Content visualization|
|US20110131209 *||Jun 2, 2011||Bechtel Michael E||Knowledge discovery tool relationship generation|
|US20110213750 *||Sep 1, 2011||Kerika, Inc.||Idea page system and method|
|US20120077180 *||Sep 26, 2010||Mar 29, 2012||Ajay Sohmshetty||Method and system for knowledge representation and processing using a structured visual idea map|
|US20130066852 *||Jun 22, 2006||Mar 14, 2013||Digg, Inc.||Event visualization|
|US20130091436 *||Nov 29, 2012||Apr 11, 2013||Linkedin Corporation||Content visualization|
|US20130103663 *||Oct 22, 2011||Apr 25, 2013||Wikibrains, Ltd.||Networked mind mapping to enhance brainstorming|
|EP1282844A2 *||Apr 19, 2001||Feb 12, 2003||E-Base Ltd.||A method for creating content oriented databases and content files|
|WO2001014985A1 *||Aug 3, 2000||Mar 1, 2001||Web2P, Inc.||System and method for registering a data resource in a network|
|WO2002005170A1 *||Jul 5, 2001||Jan 17, 2002||Dossier Solutions As||Method for organizing, handling and displaying information with a computer|
|WO2002103556A1 *||Jun 14, 2002||Dec 27, 2002||Consultores Ub57, S.L.||Dynamic browser interface|
|U.S. Classification||715/854, 718/100, 707/E17.142, 715/858|
|Nov 7, 1996||AS||Assignment|
Owner name: NATRIFICIAL LLC. A CALIFORNIA LIMITED LIABILITY CO
Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:HUGH, HARLAN M.;REEL/FRAME:008303/0360
Effective date: 19961107
|Oct 2, 2003||REMI||Maintenance fee reminder mailed|
|Jan 29, 2004||FPAY||Fee payment|
Year of fee payment: 4
|Jan 29, 2004||SULP||Surcharge for late payment|
|Mar 10, 2006||AS||Assignment|
Owner name: THEBRAIN TECHNOLOGIES LP, CALIFORNIA
Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:THEBRAIN TECHNOLOGIES CORPORATION;REEL/FRAME:017325/0493
Effective date: 20060116
|Aug 8, 2007||FPAY||Fee payment|
Year of fee payment: 8
|Sep 12, 2011||FPAY||Fee payment|
Year of fee payment: 12
|Sep 23, 2015||AS||Assignment|
Owner name: THEBRAIN TECHNOLOGIES CORPORATION, CALIFORNIA
Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:NATRIFICIAL LLC;REEL/FRAME:036629/0948
Effective date: 20150917