1. Field of the Invention
The present invention is generally related to tools for data processing, and more particularly related to tools for patent-centric and group-oriented data processing. These tools comprise diverse capabilities for data presentation and processing, including data presentation and processing using hyperbolic trees. The tools include modules to track and process IP related transactions, such as license agreements.
2. Related Art
Patents are becoming more and more important to a business's success, especially in today's global economy. Patents can be viewed as a new type of currency in this global economy because they grant the holder with a right to exclude others from making, using, or selling the patented technology. In some industries, product turnover is fairly rapid. However, core technology, product features, and markets change at a much slower rate. Accordingly, even in fast-moving industries, patents which cover core technology are very valuable at protecting a company's research and development investment for an extended period of time.
Patents are also valuable as revenue generators. In 1993, for example, the revenue generated from patents by U.S. companies was over $60 billion. Fred Warshofsky, The Patent Wars, John Wiley & Sons, Inc., New York, 1994. These patent revenue dollars are rising each year.
Patents are further valuable because they collectively represent a vast technological database. Much of this database is only available as issued patents (i.e., it is not released in any other form). According to Larry Kahaner's book, Competitive Intelligence, Simon & Schuster, 1996, “More than 75 percent of the information contained in U.S. patents is never released anywhere else.”
If corporations searched this database before developing and releasing new products they might be able to avoid costly patent infringement litigation. Often, however, corporations do not conduct such patent searches. One significant reason for this is the difficulty in identifying relevant patents, and the difficulty in analyzing patents. Computerized search tools are becoming available to the public, such as web sites on the Internet, that can be used to conduct patent searches. Many companies and practitioners are reluctant to use such tools, however, due to the concern that their highly sensitive patent searches will not be maintained in confidence when using such tools.
More and more corporations are recognizing the value of patents. The number of patents applied for and issued to U.S. companies is increasing every year, especially in fast moving industries such as computer software and biotechnology. Many international companies have also recognized the value of patents. In fact, foreign companies regularly rank among the leaders in issued U.S. patents.
Of course, not all patents are as valuable to the patent owner or patent licensees as others. Some owned or licensed patents provide little or no value to the corporate entity. These patents become a drain on corporate resources, both in obtaining the patents, paying maintenance fees, and paying license fees. It is difficult for corporations to assess the value of their patents because automated tools for patent analysis do not exist.
Yet, for all the heightened awareness being paid to patents in some quarters, patents remain one of the most underutilized assets in a company's portfolio. This is due, at least in significant part, to the fact that patent analysis, whether for purposes of licensing, infringement, enforcement, freedom to operate, technical research, product development, etc., is a very difficult, tedious, time consuming, and expensive task, particularly when performed with paper copies of patents.
Software providers have been slow in developing software tools for aiding in the patent analysis process. As a result, there are few automated tools for patent analysis currently available. There are software tools available for managing corporate patent prosecution and payment of maintenance fees, such as products from Master Data Corporation. The patent analysis capabilities of these tools are limited. These tools, for example, cannot be used to facilitate the analysis and development of business strategies to increase corporate shareholder value through the strategic and tactical use of patents.
A number of patent searching tools are available, such as the United States Patent and Trademark Office (USPTO) Automated Patent System (APS), and the on-line search services offered by Lexis and Westlaw. Other providers of patent information and patent search tools include Derwent, MicroPatent, Questel, Corporate Intelligence, STN, IFI/Plenum, The Shadow Patent Office (EDS), IBM, and CAS. These tools are not analysis tools. Instead, they are search tools. These tools enable a user to identify patents that satisfy a specified key word search criteria. In essence, these tools provide the user with the ability to possibly find “the needle-in-the-haystack.” However, these tools have limited, if any, automated functions to aid a user in analyzing the patents, whether the company's own patents or those of competitors, for the purpose of making tactical and strategic business decisions based on the patents.
SmartPatents Inc. (SPI) of Mountain View, Calif., provides electronic tools for analyzing patents. These tools, collectively called the SmartPatent Workbench, are very useful for analyzing patents. With the SmartPatent Workbench, a user can view the text and image of a patent, conduct text searches in the patent, copy and paste portions of the patent to other documents, build a case of patents, annotate the case and the patents in the case, import and export patents and cases, etc. The SmartPatent Workbench is commercially available from SPI, and is described in a number of publicly available documents, such as U.S. Pat. No. 5,623,679 and U.S. Pat. No. 5,623,681, incorporated by reference herein.
The SmartPatent Workbench is a patent analysis tool. The SmartPatent Workbench is primarily designed to assist a user in working with a single patent or a small collection of patents at a time. However, there are many instances when it would be very beneficial to be able to automatically and simultaneously analyze, correlate, or otherwise process multiple patents.
For example, in some instances it would be beneficial to automatically analyze the inventorship of a collection of patents. More particularly, it would be beneficial to identify the persons who are named most frequently on a collection of patents. It would be very useful if this task could be performed automatically. However, no existing software tools can perform this task automatically.
For the most part, existing patent-related tools can process only the information contained in patents. (It is noted, however, that the SmartPatent Workbench has functions to annotate patents with any information, whether or not patent related, and has additional functions to search within annotations.) These tools do not have functions for correlating, analyzing, and otherwise processing patent-related information with non-patent related information, including but not limited to corporate operational data, financial information, production information, human resources information, and other types of corporate information. Such non-patent information is critically important when evaluating the full strategic and tactical value and applicability of any given patent, or developing a corporate patent business strategy for gaining competitive advantage and increasing shareholder value based on patents.
Consider, for example,
A business analyst 126 may be assigned the job of evaluating the value of the corporation's patent portfolio (represented as part of the patent information 120). In order to fully and accurately analyze the value and applicability of the corporation's patent portfolio, the analyst 126 should ideally take into account non-patent information, such as R&D information 106, financial information 114, manufacturing information 110, and licensing information 118.
For example, a patent's value may be linked to whether it covers technology that the corporation is currently using, or that the corporation may use in the future. Thus, an analysis of the patent should include an analysis of and correlation with manufacturing information 110 and R&D information 106. Also, a patent's value may be linked to whether it has generated licensing revenue. Thus, an analysis of the patent should include an analysis of and correlation with licensing information 118. Further, a patent's value may be linked to the degree of success of the corporation's commercial products that correspond to the patent (i.e., the commercial embodiments of the patented technology). Thus, an analysis of the patent should include an analysis of and correlation with financial information 114.
The processing described above, however, is usually not done (or it is done in an ad hoc, unorganized, incomplete, inefficient, and/or ineffective manner) because it is difficult or, in many cases, impossible to manually collect, organize, correlate, and process all of the information pertinent to the patents under study. Often times, it is a difficult or even impossible task to simply identify the relevant patents. Accordingly, it would be very beneficial to have automated tools that automatically process patent-related information and non-patent related information for making corporate business decisions. Existing patent-related tools do not have this capability.
Briefly stated, the present invention is directed to a system, method, and computer program product for processing data. The present invention maintains first databases of patents, and second databases of non-patent information of interest to a corporate entity.
The present invention also maintains one or more groups. Each of the groups comprises any number of patents from the first databases. The present invention, upon receiving appropriate operator commands, automatically processes the patents in one or more of the groups in conjunction with non-patent information from the second databases. Accordingly, the present invention performs patent-centric and group-oriented processing of data.
A group can also include any number of non-patent documents.
The groups may be defined by the business practices of the corporation and could include groupings that are product based, person based, corporate entity based, or user-defined. Other types of groups also fall within the scope of the invention. For example, the invention supports temporary groups that are automatically generated in the course of the automatic processing performed by the invention.
The processing automatically performed by the invention relates to (but is a not limited to) patent mapping, document mapping, document/patent citation (both forward and backward), document/patent aging, patent bracketing/clustering (both forward and backward), inventor patent count, inventor employment information, and finance. Other functions also fall within the scope of the invention.
The present invention includes the ability to display data in a wide range of formats, including the ability to display and process data using hyperbolic trees.
The present invention includes the ability to track, analyze, and report on information related to intellectual property (IP) transactions, including license and related agreements.
Further features and advantages of the invention, as well as the structure and operation of various embodiments of the invention, are described in detail below with reference to the accompanying drawings. In the drawings, like reference numbers generally indicate identical, functionally similar, and/or structurally similar elements. The drawing in which an element first appears is indicated by the leftmost digit(s) in the corresponding reference number.
The present invention will be described with reference to the accompanying drawings, wherein:
FIGS. 263A and 264-266 illustrate example screen shots related to royalty statements according to an embodiment of the invention;
In the following text, reference is sometimes made to existing U.S. patents. Also, some of the figures reference or illustrate existing U.S. patents. For illustrative purposes, information from and/or about these patents has sometimes been modified or created in order to support the particular examples being discussed. Accordingly, the information provided herein about these existing U.S. patents should be considered to be fictional unless verified through comparison with copies of the actual U.S. patents that are available from the U.S. Patent and Trademark Office.
The present invention is directed to a system, components of the system, a method, components of the method, and a computer program product for patent-centric and group-oriented data processing. Such processing includes, but is not limited to, reporting, analyzing, and planning.
The present invention is intended to aid a corporate entity in developing business-related strategies, plans, and actions. Accordingly, the present invention is also referred to herein as a business decision system and method.
More generally, the present invention processes any documents, some of which are related to patents, and others which are unrelated to patents. These documents are preferably of interest to a business entity, and include contracts, licenses, leases, notes, commercial papers, other legal and/or financial papers, etc., as well as patents.
For illustrative purposes, the invention is often described herein with respect to patents. However, it should be understood that the invention is also applicable to all types of documents, and the structures, functions, and operations described herein are applicable to all types of documents, whether patent or non-patent.
The present invention also processes other information, preferably business-related information, including (but not limited to) research and development (R&D) information 206, financial information 216, patent licensing information 214, manufacturing information 208, and other relevant business information 210 (which may, for example, include human resources information). This other information is generally called non-patent information (since it includes documents other than patents and may further include information from operational and non-operational corporate databases).
The present invention is adapted to maintain and process massive amounts of documents (several hundred thousand or more). It is often necessary to maintain and process this large number of documents in order to develop strategic, patent-related business plans for the customer.
According to the present invention, processing of the patent information 204 can be conducted either with or without consideration of any of the other information 206, 216, 214, 210, 208.
For example, a user 212 (who may be a business analyst) may be assigned the job of evaluating the value of the corporation's patent portfolio (represented as part of the patent information 204). In order to fully analyze the value and applicability of the corporation's patent portfolio, the user 212 must take into account other information, such as R&D information 206, financial information 216, manufacturing information 208, and licensing information 214, for both the corporation and its competitors.
For example, a patent's value may be linked to whether it covers technology that the corporation is currently using, or that the corporation may use in the future. For this and other purposes, the present invention includes functions for automatically analyzing the patent information 204 in conjunction with manufacturing information 208 and/or R&D information 206. Also, a patent's value may be linked to whether it has generated licensing revenue. For this and other purposes, the present invention includes functions for automatically analyzing the patent information 204 in conjunction with the licensing information 214. Further, a patent's value may be linked to the degree of success of the corporation's commercial products related to the patent (i.e., the commercial embodiments of the patented technology). For this and other purposes, the present invention includes functions for automatically analyzing the patent information 204 in conjunction with the financial information 216.
The invention could also be used to determine the value of a corporate entity's patent portfolio for purposes of a merger or acquisition. The invention could also be used in a merger or acquisition context to determine a corporate entity's business direction. For example, if Company A is interested in acquiring Company B, Company A could use the invention to categorize all of Company B's patents into groups. The nature of these groups would be an indication of the types of work that Company B is involved in. Other uses of the invention are described below. Further uses of the invention will be apparent to persons skilled in the relevant art(s) based on the discussion contained herein.
The present invention is group enabled. According to the present invention, a group is a data structure that includes a collection of patents. The patents in a group typically follow a common theme or characteristic (although this is not a mandatory requirement of groups). For example, a first group may include patents that map to a product being manufactured and sold by a company. A second group may include patents that map to a product or product feature being considered for future manufacture and sale by a company. A third group may include patents owned by a corporate entity. A fourth group may include patents each having a particular person named as an inventor. A fifth group may include patents owned by a competitor. A sixth group may include patents related to a research project. A seventh group may include licensed patents. An eighth group may include patents and/or non-patent documents related to a litigation in which the customer is involved or has an interest (such a group is also herein called a case). A ninth group may include patents and other documents arbitrarily selected by a customer.
The present invention is capable of automatically processing the patents in a group, or the patents in multiple groups (alternatively, the invention can automatically process a single patent). Accordingly, the present invention is said to support “group-oriented” data processing.
Being able to automatically process information on a group basis is a very important feature of the invention, and proves to be very valuable and useful. Consider the above example of
Consider, now, the scenario where the user 212 analyzes the data with regard to groups, in this case a first group composed of patents that map to Product A, and a second group composed of patents that map to Product B. The user 212 will find that corporation's revenue per patent is $2 million for the first group (i.e., patents that map to Product A), and $10 million for the second group (i.e., patents that map to Product B). According to this scenario, the user 212 will conclude that the corporation is potentially devoting too much of its patent-related resources with respect to its technology related to Product A (it is “overpatenting” technology related to Product A), and potentially devoting too little of its patent-related resources with respect to its technology related to Product B (it is “underpatenting” technology related to Product B).
In addition, an analysis of the patents relative to a product may indicate that the core features or technology of the product are not patented and, thus, could be freely and legally copied by a competitor. This could adversely affect the product's price floor and revenue stream. With this information in hand, the company could then take steps to more comprehensively patent its technology (or make a conscious and knowledgeable decision to not seek further patent protection). Without group-oriented processing of the patents related to the product, this information is unavailable. Without this information, the company is more likely to make unwise and costly business decisions.
As indicated by the above example, group-oriented processing yields information on a scale whose granularity is defined by the definition of the group. The information produced by group-oriented processing is specific to the patents in the group. Accordingly, as with the above example, group-oriented processing is often more useful and more illuminating than non-group-processing.
Also, the invention supports hierarchically structured groups. The invention, in performing a function requested by the operator, may identify a particular group. Such identification of this group may yield very useful information, as apparent from the above example. This group, however, may have a number of parent and/or child groups. The operator may be able to uncover additional useful data by viewing, analyzing, and/or processing these parent and child groups, either with or without the original group.
Accordingly, the invention supports and facilitates “data drilling” and/or “data mining.”
As noted above, according to the present invention, processing of the patent information 204 is conducted with consideration of other information 206, 216, 214, 210, 208, called non-patent information. The process of assigning patents to groups is an example of processing patent information with non-patent information. This is the case, because groups are often created according to non-patent considerations. Accordingly, any subsequent processing of the patents in a group involve, by definition, non-patent considerations.
For example, the customer may create groups to represent its products. In this case, the groups are created according to the customer's production information. In another example, the customer may create groups to represent persons of interest. In this case, the groups are created according to HR (human resources) information. In another example, the customer may create groups to represent its competitors. In this case, the groups are created according to business information or practices. In another example, the customer may create groups based on its future products or feature requirement. In this case, the groups are created according to its R&D information.
All of these groups are created based on or in consideration of non-patent information, not patent information. Accordingly, any subsequent group processing of the patents contained in any of these groups represents, by definition, processing of the patent information 204 with consideration of, or in conjunction with, or based on non-patent information 206, 216, 214, 210, 208. This is the case, even if such subsequent group processing involves only, for example, patent bibliographic information (i.e., patent information), such as group processing based on patent issue dates or group processing based on patent references, since the groups being processed were created based on or in consideration of non-patent information, including non-patent information 206, 216, 214, 210, 208.
A group may also contain non-patent documents. In fact, a group may contain only non-patent documents. Accordingly, a group is more generally defined as a collection of documents (such as patent documents only, non-patent documents only, or a combination of patent and non-patent documents). The documents in a group typically follow a common theme or characteristic (although this is not a mandatory requirement of groups). Referring to
Components of the Invention
An enterprise server 314 accesses and processes the information in the databases 316. In particular, the enterprise server 314 includes modules that are capable of automatically accessing and processing the information in the databases 316 in a patent-centric (or document-centric) and group-oriented manner. These modules are also capable of automatically accessing and processing the information in the databases on a patent by patent basis (“one patent at a time”). Such processing includes, but is not limited to, reporting, analyzing, and planning.
The enterprise server 314 may be a single physical server, or may be a hierarchy of multiple servers 502, 504, 506, 508. An example of this multiple server embodiment is illustrated in
The system 302 preferably includes two types of clients, network clients 306 and web clients 304. These clients 304, 306, pursuant to instructions from human operators or users (not shown), interact with the enterprise server 314 to access and process the information in the databases 316. For example, the clients 304, 306 may request that the enterprise server 314 retrieve certain information, or automatically analyze certain information. The enterprise server 314 performs the requested tasks, and sends the results to the requesting clients 304, 306. The clients 304, 306 present these results to their respective operators, and enable the operators to process the results.
Clients 304, 306 may also perform additional processing of data, such as creating a visualization of the data obtained from the enterprise server 314.
Generally speaking, the network clients 306 preferably communicate with the enterprise server 314 using the enterprise server 314's natural language, which is called the enterprise server API (described in detail below). Accordingly, the network clients 306 communicate directly with the enterprise server 314 via a communication network 312, which is preferably a network that uses the well known HTTP (hypertext transport) protocol. Other protocols could alternatively be used. This network 312 may be of any size, such as (but not limited to) a local area network or a wide area network (it can even be a global network).
The web clients 304 do not preferably utilize the enterprise server 314's natural language. Accordingly, the web clients 304 communicate with the enterprise server 314 via a web server 310, which translates between the language of the web clients 304 and the language of the enterprise server 314. This translation is described below.
In an embodiment of the present invention, the components of the present invention shown in
The computer 1102 includes one or more processors (also called central processing units, or CPUs), such as a processor 1106. The processor 1106 is connected to a communication bus 1104. The computer 1102 also includes a main or primary memory 1108, preferably random access memory (RAM). The primary memory 1108 has stored therein control logic 1110 (computer software), and data 1112.
The computer 1102 also includes one or more secondary storage devices 1114. The secondary storage devices 1114 include, for example, a hard disk drive 1116 and/or a removable storage device or drive 1118. The removable storage drive 1118 represents a floppy disk drive, a magnetic tape drive, a compact disk drive, an optical storage device, tape backup, ZIP drive, JAZZ drive, etc.
The removable storage drive 1118 interacts with a removable storage unit 1120. As will be appreciated, the removable storage unit 1120 includes a computer usable or readable storage medium having stored therein computer software (control logic) and/or data. The removable storage drive 1118 reads from and/or writes to the removable storage unit 1120 in a well known manner.
Removable storage unit 1120, also called a program storage device or a computer program product, represents a floppy disk, magnetic tape, compact disk, optical storage disk, ZIP disk, JAZZ disk/tape, or any other computer data storage device. Program storage devices or computer program products also include any device in which computer programs can be stored, such as hard drives.
In an embodiment, the present invention is directed to computer program products or program storage devices having software that enables the computer 1102 to perform any combination of the functions described herein.
Computer programs (also called computer control logic) are stored in main memory 1108 and/or the secondary storage devices 1114. Such computer programs, when executed, enable the computer 1102 to perform the functions of the present invention as discussed herein. In particular, the computer programs, when executed, enable the processor 1106 to perform the functions of the present invention. Accordingly, such computer programs represent controllers of the computer 1102.
The modules of the invention discussed herein, such as the grouping module 412, the analysis modules 416, etc., preferably represent software executing in the computer 1102.
The computer 1102 also includes a display unit 1122, such as a computer monitor, and one or more input devices 1124, such as a keyboard, a mouse, other pointing devices (such as a light pen and trackball), etc.
The computer 1102 further includes a communication or network interface 1126. The network interface 1126 enables the computer 1102 to communicate over communication networks, such as networks 308 and 312, which preferably use the well known HTTP communication protocol.
The components of the invention (shown in
Customer Corporate Entity
Preferably, the system 302 is adapted for use by a particular customer. Typically, the customer is a corporate entity. Accordingly, the customer is also called herein the customer corporate entity.
It should be understood, however, that the customer can be any organization or individual, such as an academic institution, a research organization, a non-profit or for-profit organization, or any person. Generally, the customer is any entity having an interest in patents.
The customer is an entity (such as a company) that has arranged to have use of the system 302 (by purchasing, leasing, or renting the system 302, for example).
The databases 316 and data contained therein are specific to the customer. For example, the databases 316 may contain information on the patents that the customer owns and/or licensees, and information on the patents that the customer's competitors owns and/or licenses. Also, the databases 316 may contain the customer's and the customer's competitors' R&D information, financial information, licensing information, manufacturing information, and HR information.
Also, the methodology functions supported by the enterprise server 314 may be specialized or augmented to meet the needs of the customer.
Implementation and use of the present invention may involve a number of persons associated with the customer corporate entity, such as employees, consultants, associates, and persons retained by the customer, such as attorneys. When interacting with the invention, these people are called operators or users. Table 1 lists some of such persons and their respective responsibilities according to an embodiment of the invention. These persons may be involved in all aspects of the invention for the customer, or may be involved in only some phases of the invention for the customer, such as the extract and load of the databases 316. It should be noted that the set up and use of the invention may also involve other people with different knowledge, skills, and/or abilities.
In the discussion contained herein, reference is often made to a user or an operator associated with the customer. It should be understood that the terms “user” and “operator” are synonymous, and refer to one or more persons from Table 1.
Databases
The databases 316 of
Many of the databases 316, such as the BOM databases 626, the inventor databases 628, and corporate entity databases 630, the financial databases 638, the person databases 632, and the employee databases 634, are initially loaded using information provided by the customer. Such information includes R&D (research and development) information, financial information, licensing information, manufacturing information, HR (human resources) information, and any other information that may be pertinent to the analysis of the customer's patents and other relevant documents. After initial loading, these databases 316 are updated as necessary to reflect changes in the customer's information.
Other information, such as information for the patent bibliographic databases 604 and the patent database 614, may be loaded using information provided by a third party provider, such as a third party provider that specializes in the provision of patent information in electronic form. One such third party provider is SmartPatents Inc. (SPI) of Mountain View, Calif. The patent bibliographic databases 604 may be periodically updated through a subscription service from such third party providers. Similarly, the patent database 614 may be augmented through as-needed orders to the third party providers. It should be understood that the present invention works equally well with data provided by any party as long as the data's format matches the formats of the patent bibliographic databases 604 and the patent database 614.
The databases 316 are described in greater detail below.
Document Databases
The document databases 612 preferably include electronic representations of documents of interest to the customer. The document databases 612 represent the customer's repository of documents, and are thus also called the customer's document repository. (The “repository” could alternatively represent all documents represented in the databases 316, whether represented in the document databases 612 or the bibliographic databases 602.)
For example, the patent database 614 includes electronic representations of U.S. and foreign patents of interest to the customer. These patents may be patents owned and/or licensed by the customer, patents owned and/or licensed by competitors of the customer, patents that the customer is considering acquiring, patents that, for whatever reason, the customer is studying, etc. The patent database 614 represents the customer's repository of patents, and is thus also called (in some embodiments) the customer's patent repository.
The patent database 614 preferably has stored therein an image file and a text file for each patent represented in the patent database 614, where the image file and the text file are representations of the patent. Details of an embodiment of the image file and the text file are described in U.S. Pat. No. 5,623,681 and U.S. Pat. No. 5,623,679, which are both incorporated herein by reference in their entireties.
The document databases 612 also include electronic representations of other documents of interest to the customer, such as depositions, pleadings, and prior art references. These documents are respectively stored in a deposition database 618, a pleadings database 616 (generally, pleadings are papers filed with a court), and a prior art database 620. Text and/or image representations of these documents may be stored. These documents may be pertinent to a patent litigation that the customer is involved in.
The documents in the document databases 612 may be text, images, graphics, audio, video, multimedia, and/or any other information representation that can be stored in electronic form.
It should be understood that the document databases 612 of
Document Bibliographic Databases
The document bibliographic databases 602 store information about documents (as opposed to the documents themselves). More particularly, the document bibliographic databases 602 store bibliographic information about documents.
Patent Bibliographic Databases
The patent bibliographic databases 604 store bibliographic data about U.S. and non-U.S. patents. Such patent bibliographic data includes, but is not limited to, the information on the front page of patents, such as: the patent number, the issue date, the inventors, the title, the assignee, the serial number, the filing date, the U.S. and international classifications, the fields of search, the references cited, the primary examiner, the assistant examiner, the attorney, the agent, the law firm, priority information, related application information, the number of claims, the number of drawing pages, the patent term, the expiration date, etc. The patent bibliographic databases 604 can also include one or more user defined fields that can store large amounts of data, such as 32 Kbytes or more of data.
Operators can extend the bibliographic databases 602 in patent-centric ways. For example, a “current licensee” field can be added to the patent bibliographic databases 604. This could be accomplished, for example, by defining one of the user defined fields to be a current licensee field.
In an embodiment of the invention, the patent bibliographic databases 604 store bibliographic information on all U.S. patents. In other embodiments of the invention, the patent bibliographic databases 604 store patent bibliographic information on a subset of all U.S. patents, such as all U.S. patents that are available in electronic form from the U.S. Patent Office, or all U.S. patents that issued after a certain date.
Generally, there is not a one-to-one relationship between the patents in the patent database 614, and the patents represented in the patent bibliographic databases 604. That is, the patent database 614 does not generally include a copy of each patent represented in the patent bibliographic databases 604. Instead, the patent database 614 includes only those patents that are of interest to the customer. In contrast, the patent bibliographic databases 604 store bibliographic information on all U.S. patents and/or foreign patents (or, alternatively, all U.S. patents that issued after a certain date, and/or a subset of foreign patents). Of course, if the customer has an interest in all U.S. patents, such that electronic copies of all U.S. patents are stored in the patent database 614, then there would be a one-to-one relationship between the patents in the patent database 614, and the patents represented in the patent bibliographic databases 604.
Other Document Bibliographic Databases
The document bibliographic databases 602 include store bibliographic information on other types of documents that are of interest to the customer. For example, if the customer is interested in depositions, pleadings, or prior art references, then the document bibliographic databases 602 would store bibliographic information on depositions, pleadings, or prior art references in deposition bibliographic databases 606, pleadings bibliographic databases 608, and prior art bibliographic databases 610, respectively.
The bibliographic information may include the parties or persons involved, the date of creation, the date of modification, the subject, the number of pages, the number of figures, etc. Such bibliographic information may be generated manually, and/or may be generated automatically during the generation of the source document. For example, word processing tools often automatically generate bibliographic information about a document as the document is being created. Such information may include the creator, the typist, the date of creation, the date of modification, the subject, the title, the type of document, the storage format, etc. This automatically-created bibliographic information could be loaded into the document bibliographic databases 602.
Notes Database
The present invention supports annotation of the documents in the document databases 612. More particularly, the present invention allows users to create and link annotations (also called notes) to any portions of the documents in the document databases 612. Such annotations can include text, graphics, images, video, audio, and/or any other information representation that can be stored in electronic form.
The present invention also allows various information to be stored with annotations, such as the date of creation, the creator, the date of modification, a note title and/or subject, access rights, etc.
The annotations, linkage information (i.e., information that specifies the link between a note and a portion of a document), and information related to the annotations and/or the linkage information (such as the position of the linked portion in the document, the date of creation, the creator, the date of modification, a note title and/or subject, access rights, etc.) are stored in the notes databases 640. Embodiments of the notes databases 640 are described in U.S. Pat. No. 5,623,679 and U.S. Pat. No. 5,623,681, incorporated by reference herein, and in pending U.S. application Ser. No. 08/590,082, which is herein incorporated by reference in its entirety.
Groups Databases
Information on groups is stored in the group databases 621. Generally, a group is a data structure that includes any number of documents that typically follow a common theme or characteristic (although this is not a mandatory requirement of groups). More particularly, a group is a data structure that includes any number of patents that typically follow a common theme or characteristic (although, again, this is not a mandatory requirement of groups). Groups are document-centric, or in many cases, patent-centric.
There are two classes of groups: predefined groups (also called system defined groups) and user-defined groups (also called arbitrary groups).
However, the invention also supports other types of groups. For example, the invention supports temporary groups. A temporary group is automatically created by the invention in the course of processing a command. One application of temporary groups involves search operations. Specifically, when conducting a search for documents, a new temporary group is created, and the search results are stored in the temporary group. The invention permits operators to convert temporary groups to predefined groups or user-defined groups.
Patents (and/or documents) in predefined groups follow a predefined theme or characteristic. Database tables, fields, and attributes of a predefined group are specific to the predefined theme/characteristic of the predefined group. Accordingly, different predefined groups have different database tables, different database fields, and different database attributes. Information on predefined groups is stored in the predefined or system defined group databases 622.
Patents (and/or documents) in user-defined groups may or may not follow a common theme or characteristic. Any theme or characteristic that they do follow is defined by the user. Accordingly, user-defined groups are also called arbitrary groups.
All user-defined groups have the same, generic database tables, fields, and attributes. However, users may elect to use these database tables, fields and attributes differently for different user-defined groups. Information on user-defined groups is stored in the user-defined group databases 624.
Predefined groups can be more powerful than user-defined groups for at least two reasons. First, the databases associated with a predefined group store information that is specific to the predefined characteristics of the predefined group. As a result, more useful and specific information can be stored in predefined groups. Second, since the data attributes and characteristics of predefined groups are known in advance, specific functions can be generated in advance to automatically process the information associated with predefined groups. As a result, the information associated with predefined groups can be automatically processed in powerful and diverse ways that are useful given the attributes and characteristics of the predefined groups.
The tables and attributes of predefined groups are typically not applicable to other types of groups. In contrast, the tables and attributes of user-defined groups are generic, and are applicable to all groups. Thus, user-defined groups are more flexible than predefined groups.
Accordingly, in practice, a user-defined group is used by a customer until its attributes, characteristics, and functions are well defined. Once they are well defined, a new predefined group is created to replace the user-defined group. This new predefined group is designed to encompass and take advantage of the specific attributes, characteristics, and functions of the group. In other words, this new predefined group is designed to encompass and take advantage of the well defined structure of the group. Then, analysis and reporting modules are created which automatically analyze and report on the data in the new predefined group. It is possible to create such analysis and reporting modules specific to the new predefined group because of the well defined structure of the new predefined group. The new predefined groups and their reporting and analysis modules can then be distributed (i.e., its databases and functional modules can then be distributed) to interested customers of the invention.
The scope of the present invention includes the creation of new predefined groups and their reporting and analysis functions in the manner described above. The scope of the present invention also includes such new predefined groups and their reporting and analysis functions. The structure and operation of such new predefined groups and their reporting and analysis functions are implementation dependent, but would be apparent to persons skilled in the relevant art(s) based on the discussion contained herein.
In the present invention, groups are structured. Specifically, groups are organized into a directed, acyclic graph, where a group can have multiple children groups and multiple parent groups.
The system of the invention discourages or prevents non-sensical organizations of groups. Such non-sensical organizations of groups is at least partially discouraged or prevented by the automatic functions performed by the invention. For example, the system discourages or prevents making a corporate entity group a child of a BOM group, since running an analysis report on all of the subassemblies of the BOM group would yield questionable or undefined results since a corporate entity does not have subassemblies. In an embodiment of the invention, such non-sensical organization of groups is prevented by computer programming.
Also, when a specialized (predefined) group is created to perform specialized analysis functions, new restrictions regarding the rules that govern the inter-relationships between groups are also created. The rules manifest themselves in the database schema. The database schema of the invention prevents the creation of non-sensical group relationships.
Predefined Groups Databases
Various predefined groups are described below. It should be understood that the following represents examples of predefined groups supported by the invention. The invention is adapted and intended to include other predefined groups. As described above, predefined groups are often created from user-defined groups once the attributes, characteristics, and functions of the user-defined groups are well defined. The invention is adapted and intended to include these types of predefined groups. Accordingly, the following is provided for purposes of illustration, and not limitation.
Bill of Materials (BOM) Databases
A BOM (bill of materials) group is a group that contains patents (and perhaps other documents) that map to a product, or that map to parts of a product. More particularly, a BOM group is a group that contains patents that map to an assembly, a subassembly, or a part, where an assembly is composed of one or more subassemblies, and a subassembly is composed of other subassemblies and/or parts.
The phrase “a patent maps to a product” means that the patent includes claims that appear to read on the product or process of making and/or using the product, and/or includes claims that are related to or relevant to the product or process of making and/or using the product, and/or that the patent discloses subject matter than encompasses the product or process of making and/or using the product, and/or that the patent discloses subject matter than is related to or relevant to the product or process of making and/or using the product.
Information on BOM groups is stored in the BOM databases 626. BOM groups and the BOM databases 626 are discussed in greater detail in sections below.
Corporate Entity Databases
A corporate entity group is a group that contains patents (or other documents) that are owned, licensed, or otherwise of interest to a corporate entity. Information on corporate entity groups is stored in corporate entity databases 630. The corporate entity databases 630 can include information on any number of corporate entity groups. Such corporate entity groups can correspond to any corporate entities that are of interest to the customer, such as the customer itself, affiliates of the customer, competitors of the customer, etc. Corporate entity groups and the corporate entity databases 630 are discussed in greater detail in sections below.
Inventor Databases (and Employees and Person Databases)
An inventor group is a group that contains patents each of which name as inventor a particular person. Information on inventor groups is stored in inventor databases 628. The inventor databases 628 are supported by person databases 632, which include information on people of interest to the customer (people who play a role in the processing of the invention, such as an inventor or employee), and employee databases 634, which include information on employees of interest to the customer. Inventor groups, the inventor databases 628, the employee databases 634, and the person databases 632 are discussed in greater detail in sections below.
User-Defined Group Databases
A user-defined group is a data structure that contains documents that follow some user-defined theme or characteristic. Information on user-defined groups is stored in the user-defined group databases 624.
These user-defined group databases 624 are common to all user-defined groups. In particular, the attributes in these user-defined group databases 624 are the same for all user-defined groups. However, the customer can choose to utilize these attributes differently for each user-defined group. For example, the customer may choose to store different types of data in these attributes for different user-defined groups. User-defined groups and the user-defined group databases 624 are discussed in greater detail in sections below.
Financial Databases
The financial databases 638 store financial information pertaining to the customer's business. The financial databases 638 may also include financial information on competitors' businesses (to the extent that such information is publicly known, or can be determined or estimated based on publicly known information or business practices). Such financial information may include money spent on R&D on a product line basis, gross and net revenue on a product line basis, patent licensing revenue, patent acquisition costs, etc. The invention correlates and analyzes the information in the financial databases 638 with patent information to determine, among other things, the financial impact of patents on the customer's and competitors' respective businesses. The financial databases 638 are discussed in greater detail in sections below.
Security Database
The present invention includes multileveled security features for limiting access to data stored in the databases 316. Security is defined herein as privilege levels associated with operators and data objects, and a security methodology for applying the privilege levels so as to restrict access to the data objects to operators having the appropriate privilege levels.
The invention is capable of supporting security for all data items, including security for notes (stored in the notes databases 640), groups (stored in the group databases 621), financial information (stored in the financial databases 638), personal information (stored in the person databases 632 and the employee databases 634), and documents (stored in the document databases 612 and the document bibliographic databases 602). Information for implementing these security features is stored in the security databases 636, which are discussed in greater detail in sections below.
Enterprise Server
The enterprise server 314 is preferably implemented as one or more computers (such as the computer 1102 shown in
The enterprise server 314 can be a single computer, or a hierarchy of multiple computers (
The Network transport layer or interface 401 is used to receive command request objects from the client 304, 306 based on a specific network protocol, preferably HTTP. On the enterprise server 314 these network command objects are reconstructed from a stream of bits received from the client 304, 306. Once the command objects have been reconstructed the specific operations (described herein) defined in this object are performed by the appropriate enterprise server modules. The command objects represent enterprise server API commands, discussed below.
According to an embodiment of the invention, command objects include autonomous intelligent agents that perform appropriate operations at the enterprise server 314 on behalf of the operator (i.e., the client 304, 306). In this embodiment, the command objects sent to the enterprise server 314 represent computer programs that are executed in the enterprise server 314. These executing computer programs preferably represent threads each having an address space. These computer programs, when executing in the enterprise server 314, perform the functions discussed herein, such as patent mapping, patent aging, inventor count, inventor information, financial functions, etc.
The enterprise server 314 is a highly secure business decision system. The specific operations in each command object are checked against the security information maintained about each user in the system. This is logically done through a comprehensive security layer or module 402. (The specific implementation of security requires the interaction with ODBC 420, as all security information is stored in the databases 316). Alternatively, the security module 402 could logically be shown as being under the server configuration module 404 and the command dispatch module 406.
As described elsewhere herein, the document storage and retrieval module 408 is part of a Virtual Patent System 11304 (
The Searching subsystem or module 410 provides for patent searching using a search language (syntax) described below, an extensible language for searching patent and other patent-related documents. The search layer 410 also encapsulates the specific search engine 424 used in the implementation of the system, which can and will vary based on available search technologies.
The other layers shown in
Each of these layers provides a mechanism to further decouple the operation of the enterprise server 314 from the specific implementation of the databases 316. Each of these layers also interact with ODBC (Open Database Connectivity) 420, a Microsoft defined industry standard mechanism for manipulating relational databases (other software for interacting with and manipulating databases could alternatively be used). ODBC 420 provides a final layer of decoupling and enables the enterprise server 314 to transparently connect to different relational databases 316.
The enterprise server modules are further described below.
Document Storage and Retrieval Module
The document storage and retrieval module 408 in the enterprise server 314 stores and retrieves documents from the document databases 612. Preferably, especially with respect to patent documents, the document storage and retrieval module 408 stores and retrieves text files and image files representative of documents in the document databases 612. The document storage and retrieval module 408 performs such data storage and retrieval operations pursuant to commands that conform to the enterprise server API, described below.
The document storage and retrieval module 408 preferably interacts directly with the operating system 422 of the enterprise server 314, where such direct interaction primarily pertains to data retrieval and storage.
As just noted, the document storage and retrieval module 408 operates to access data in the document databases 612, such as the customer's repository of patents represented by the patent database 614. Preferably, the patent database 614 stores electronic representations of all patents which are of interest to the customer. Additional electronic patents can be added to the patent database 614 at any time as the customer's interests change. The patent database 614 is capable of storing electronic representations of all U.S. patents, or any subset of all U.S. patents, and of any number of foreign patents as required by the customer's needs and interests. Accordingly, the document storage and retrieval module 408, in combination with the patent database 614 and the patent bibliographic databases 604, provide the customer with the ability to quickly, efficiently, and effectively access, display, and process any patent of interest. Accordingly, from the perspective of the client, the document storage and retrieval module 408, in combination with the patent database 614 and the patent bibliographic databases 604, represent a virtual patent system.
The client document storage and retrieval module 708 in the clients 304, 306 (
The client document storage and retrieval module 708 has features and functions for enabling a user to manipulate and otherwise process the displayed data. For example, the client document storage and retrieval module 708 includes text searching features, powerful text and image navigation features, text processing features, image processing features (as represented by image toolbox 11206 shown in
The document storage and retrieval module 408 in the enterprise server 314 and the client document storage and retrieval module 708 in the clients 304, 306 are collectively further described in U.S. Pat. No. 5,623,679 and U.S. Pat. No. 5,623,681, incorporated by reference herein, and in pending U.S. application Ser. No. 08/341,129, which is herein incorporated by reference in its entirety.
Notes Module
The notes module 414 manages and interacts with the notes databases 640. The notes module 414 processes enterprise server API commands (described below) to: create new notes, update existing notes, add notes to a document, remove notes from a document, and retrieve all notes associated with a document.
The client notes module 714 enables a user to view and manipulate notes.
The client notes module 714 receives from the user commands to, for example, edit note contents, create new notes, link new or existing notes to portions of documents, modify notes, and delete notes. The client notes module 714 modifies the display of the notes window 11108 as necessary to reflect these user commands. The client notes module 714 also generates enterprise server API commands corresponding to these user commands, and forwards these enterprise server API commands to the enterprise server 314 for processing by the notes module 414 in the enterprise server 314.
Notes may have attributes, such as (but not limited to) the person who created the notes (relevant for security purposes), the date the note was created, the data format(s) of data stored in the note (text, image, graphics, video, audio, spreadsheet, database, etc.), the note title, the note subject, whether the note contains information that would be considered to be Attorney/Client privileged or confidential, and the date the note was last modified.
According to an embodiment of the invention, notes are hierarchically organized. That is, a given note may be a child note of any number of parent notes, and may have any number of child notes. This, of course, is in addition to the linkage of notes to portions of documents. This hierarchical organization may be implemented by having in the note databases 640 a note_note_xref table, that would be similar to the group_group_xref table 1229. The note_note_xref table would have a parent note attribute storing the note ID of the parent note, and a child note attribute storing the note ID of the child note. There would be a record in the note_note_xref table for each parent note/child note relationship in the note hierarchies. It is noted that this note hierarchy provides a structure, organization, and hierarchy to the documents linked to the notes.
The notes module 414 in the enterprise server 314 and the client notes module 714 in the client 304, 306 are collectively further described in U.S. Pat. No. 5,623,679 and U.S. Pat. No. 5,623,681, incorporated by reference herein, and in pending U.S. application Ser. No. 08/590,082, incorporated by reference herein.
Searching Module
The searching module 410 in the enterprise server 314 interacts with a search engine 424 to conduct searches through the data in the databases 316 pursuant to search requests from the clients 304, 306. The search engine 424 is any commercial and well known search engine. Preferably, the search engine 424 is implemented as the Fulcrum search engine available from Fulcrum Technologies, Inc., Ottawa, Canada. Other commercial search engines could also be used, including (but not limited to) those from Verity Incorporated, Sunnyvale, Calif., Open Text of Canada, and others.
Preferably, the data in the databases 316 is indexed to facilitate and enhance searching by the search engine 424. For example, each field in each table of the patent bibliographic databases 604 is preferably indexed and searchable. Also, the documents (including the text files and possibly the image files) in the document databases 612 are preferably indexed and searchable. Any well known indexing procedure can be used to index the data in the databases 604. According to an embodiment of the invention, indexing and searching are performed as described in pending U.S. patent application Ser. No. 08/422,528, which is incorporated herein by reference in its entirety. Searching for documents is performed by searching through these indexes. The index tables are preferably stored in the searching module 410, in the searching engine 424, and/or in the databases 316.
An embodiment of the invention permits operator-defined indexing of data. In this embodiment, an operator can define what data in the databases 316 is to be indexed. For example, an operator can specify that only patents having as assignee “IBM” should be indexed. Or, the operator can specify that only the documents in a given group should be indexed. Such operator-defined indexing enhances searching performance, because the index that is searched is smaller and more targeted.
The searching module 410 receives enterprise server API commands from the clients 304, 306. The searching module 410 processes these enterprise server API commands and, as a result, causes the search engine 424 to perform at least the following functions: conduct a search to identify documents that satisfy a client-supplied search parameter (for example, to identify documents that contain instances of key words), retrieve and return the search results of a previously executed search, and retrieve and return search hit information for a particular document so that search term highlighting can be performed on the document.
According to the present invention, the documents identified by a search can be easily added to a new group or an existing group by invoking appropriate enterprise server commands, such as the ReqAddDocListToGroup command or the ReqAddPatents command. In the user interface at the client 304, 306, the operator implements this function using drag-and-drop techniques.
Preferably, the invention creates a new, temporary group to hold the results of a search. A subsequent search could then be scoped or restricted to the documents in this temporary group. Accordingly, the invention supports iterative searching using groups.
The invention supports many search strategies, including but not limited to keyword, keyword phrase, keyword phrases with boolean, thesaurus, concept searching, object searching, and graphical searching based on likeness of words/images.
The client searching module 710 in the clients 304, 306 receives search commands from the user. The client search module 710 converts these search commands to corresponding enterprise server API commands, if necessary, and transfers these enterprise server API commands to the enterprise server 314. The client searching module 710 receives from the enterprise server 314 search results. The client searching module 710 displays these search results and enables the user to manipulate and process the search results (such as by enabling the user to add the documents identified by a search to a new or existing group—note that this functionality may also involve the client grouping module 712).
The invention also supports restricting or defining a search according to aspects of the system, such as historical information. Such historical information can include, for example, the results of a prior search. Thus, the scope of a new search can be restricted to the results of a prior search, or the search criteria in a new search can be added to the search criteria in a prior search. Preferably, the system maintains a search log so that the operator can view and select prior search results and prior search criterions.
In some embodiments, a user's characteristics (i.e., security level) define the groups that the user can search in. In other words, searches are restricted to groups for which the user has access rights.
The operation of the client searching module 710 in a client 304, 306 and the searching module 410 in the enterprise server 314 shall now be described in greater detail with reference to
Considering first
The fields in the searching window 5302 allow the user to specify a search of patent bibliographic information, and/or a search of the text of patents. The user can search through patent bibliographic information by entering key terms in the patent number field 5306, the title field 5308, the inventor field 5310, the assignee field 5312, the class field 5314, and/or the date of issue field 5315. The date of issue field 5315 allows the user to specify patents that issued before or after a given date (by filling in fields 5316 and 5318), or that issued between two dates (by filling in fields 5320, 5322, and 5324). It is noted that only some of the attributes of the patent bibliographic databases 604 are shown as being searchable in
The user can search through the text of patents by entering search parameters in an abstract field 5326 and/or the full patent text field 5328.
It is noted that not all users may have access to all of the search options described above. For example, some users may be only able to search through the patent bibliographic information. Other users may be only able to search through certain attributes of the patent bibliographic information. Other users may be only able to search through the text of patents. The server configuration module 404, described below, controls the search options and capabilities of each user.
The user can specify the fields to include in the list of search results by appropriately selecting fields 5330. The user can specify a sorting order to display the search results via field 5332. Sorting options include: descending patent numbers, ascending patent numbers, issue date, filing date, serial number, score (the number of search hits), etc.
By selecting a “patents not in local repository” command 5410, the user can display a list of the patents from the search results that are not represented in the patent database 614 (i.e., patents for which the user does not own electronic copies of). The report resulting from selecting the patents not in local repository command 5410 can be used by the user to generate a purchase order to obtain electronic copies of the patents of interest from the search results. In some embodiments, electing this option will cause an electronic message to be sent to a third party service provider. The third party service provider would then electronically send electronic copies of the patents to the customer.
If the user selects (by double clicking or other well known GUI operation such as selecting a patent and pressing a return button) a patent from the list shown in
The field driven GUI 5702 of
Referring again to
The enterprise server API commands related to querying include the ReqSearch command. As described further below, this command takes searchParameters as a passed parameter. This passed parameter stores the search parameters for the search. A preferred syntax of the search parameters according to the enterprise server API is described below in Tables 2 and 3.
Each of the Operators in Table 2 (including any spaces to its immediate left or right) is considered to be a search syntax delimiter. Each sequence of characters before, after, or between one of these delimiters will be called a search string “element”. Each search string element will be enclosed between a pair of apostrophes to translate it for transmission to Fulcrum. The meaning of and translations for the specific characters that can appear in an element are listed below in Table 3.
—
The searching module 410 in the enterprise server 314 receives the query request 908A. A query language syntax analyzer 914 in the searching module 410 checks the query request 908A for any format or syntax errors, such as unbalanced parentheses. The searching module 410 then translates the query request 908A to a new query request in the language of the search engine 424. The new query request is then transferred to the search engine 424 for processing.
The present invention also supports a native language command line GUI 904 for enabling a user to enter a search request. The command line GUI 904 is typically only used by users who are familiar with the enterprise server API. When using the command line GUI 904, the user enters at the command line a query request 908B. This query request 908B must conform to the enterprise server API. This query request 908B is then transferred to the searching module 410 in the enterprise server 314 where it is processed in the manner described above.
The present invention further supports any number of foreign language command line GUIs 906 for enabling the user to enter query requests. The invention provides foreign language command line GUIs 906 to support those users who are familiar with database query languages other than the enterprise server API. Such database query languages are herein called foreign query languages for reference purposes. There are many well known foreign query languages, such as the patent specific query language used by the U.S. Patent Office Web Site which is located at http://patents.cnidr.org/access/access.html. The client searching module 710 has a foreign language command line GUI 906 for each foreign query language of interest.
When using a foreign language command line GUI 906, the user enters at the command line a query request 910. The query request 910 is in the foreign query language associated with the foreign language command line GUI 906. The query request 910 is translated to a query request 908C in the enterprise server API by a translator 912 (there is a translator for each foreign query language supported by the invention). This query request 908C is then transferred to the searching module 410 in the enterprise server 314 where it is processed in the manner described above.
The present invention also supports searching of other data objects, such as groups (in the group databases 621) and notes (in the notes databases 640). In fact, the present invention supports searching of all the tables in the databases 316. Preferably, all fields in all tables of the databases 316 are indexed and searchable. In some embodiments, only some of the tables are indexed and searchable, such as the group databases 621 and the notes 640. GUIs, such as those discussed above, are used to enable operators to define searches of any attributes of these tables.
The present invention also supports context and linguistic type searching, and also supports image and object searching. The invention can be used, for example, with data blade search tools, such as those available from Informix.
Automatic Searches Related to Groups
The present invention also supports an automated search function related to groups. According to this aspect of the invention, a search is performed of all or part of the document databases 612 and/or the document bibliographic databases 602 to identify documents that satisfy a specified search criteria. The documents identified via this search are added to a specified group.
For example, suppose that the customer has a group called XYZ group. This group contains the patents that name XYZ corporation as assignee. Periodically, the invention automatically searches the patent bibliographic databases 604 for any patents that name the XYZ corporation as assignee. Any patents found from this search are automatically added to the XYZ group.
The invention supports performing such automatic searches at user defined intervals (such as every month), or at the occurrence of user-specified events, such as whenever the patent bibliographic databases 604 are updated.
The invention allows the customer to define such automatic searches. In defining an automatic search, the customer specifies the target databases (what databases to search), the target groups (which groups receive the identified documents), the search criteria, and the frequency or circumstances that the automatic searches take place.
Preferably, the searching module 410 performs the automatic searches.
Searching Algorithm
The searching module 410 processes a search string according to a preferred searching algorithm that is designed to take advantage of the searching and data accessing capabilities of the objects that directly interact with the databases 316. Such objects are herein called database accessing objects because they directly access and interact with the databases 316, and include the search engine(s) 424, the SQL server 426, and other database servers 428.
A flowchart 13902 shown in
The search string includes one or more search string components, also called search string elements, which are preferably in the format shown in Table 3. The search string components/elements are separated by search syntax delimiters (Table 2).
In step 13906, the searching module 410 identifies the search string components in the search string. The searching module 410 preferably performs step 13906 by parsing through the search string. In the course of such parsing, the searching module 410 identifies search string components based on the location of search string delimiters (that is, search string components represent groups of characters that are separated by search string delimiters). For example, consider the following example search string:
(Phrase1 AND Phrase2) OR (Phrase6 AND (Phrase3 OR (Phrase4 AND Phrase5))).
In step 13906, the searching module 410 identifies the following as search string components (parsing the example search string from left to right):
Phrase1, Phrase2, Phrase6, Phrase3, Phrase4, and Phrase5.
In step 13908, the searching module 410 analyzes each search string component (identified in step 13906) and assigns each search string component to a database accessing object. The searching module 410 in step 13908 assigns a search string component to a database accessing object based on the characteristics of the search string component and the capabilities of the database accessing object. Specifically, the searching module 410 analyzes and identifies the characteristics of the search string component. The searching module 410 then assigns the search string component to a data accessing object whose capabilities are matched to these characteristics (that is, whose capabilities are well suited for processing search string components having those characteristics).
For example, suppose that the search string component being considered represents a text search in a collection of documents. This type of search is best suited to be performed by a search engine, such as search engine 424. Search engine 424 is well suited for performing text searches because the text in the databases 316 is indexed.
As another example, suppose that the search string component represents a search for all patents that are referenced by U.S. Pat. No. 1,234,567. This search string component is best represented as a relational database query. Accordingly, it would be best processed by a relational database engine, such as the SQL server 426 or other relational database servers 428.
After the search string components have been assigned to data accessing objects, the data accessing objects in step 13908 process their assigned search string components. Such processing preferably occurs in parallel. By processing the search string components in parallel, the length of time that it takes to conduct the search is reduced.
In step 13910, the data accessing objects transfer their respective result sets or search results to the searching module 410. These search results represent multiple data streams. The searching module 410 in step 13910 combines these data streams according to the logical linking operations represented by the search syntax delimiters in the original search string.
For example,
The searching module 410 combines R4 and R5 by logically AND'ing R4 and R5. That result is OR'd with R3. The result of that OR operation is AND'd with R6. The result of that AND operation is OR'd with the result of the logical AND'ing operation of R1 and R2. The result of this OR operation represents the final result of processing the original search string.
Preferably, for efficiency purposes, the result sets received from the database accessing objects are ordered according to a common criteria. Preferably, the result sets are ordered according to patent number.
The searching module 410 in step 13910 then returns this final result to the requester. Operation of flowchart 13902 is then complete, as indicated by step 13912.
In the present invention, it is not necessary to store the intermediate search results. For example, it is not necessary to store R1, R2, R3, R4, R5, and R6. Instead, the searching module 410 processes the intermediate search results as they are received. Referring to
The searching algorithm of the present invention shall now be further described with reference to the processing of the “patents in local repository” command 5408 and the “patents not in local repository” command 5410 (
The searching module 410 executes the “patents in local repository” command 5408 by first processing a search string in the manner shown in the flowchart 13902 (
The searching module 410 performs the “patents not in local repository” command 5410 by first processing a search string in a manner discussed above with reference to flowchart 13902 in
Grouping Module
The grouping module 412 in the enterprise server 314 manages and interacts with the group databases 621. The grouping module 412 receives and processes enterprise server API commands (sent from clients 304, 306) to perform at least the following functions: obtain information on the hierarchy of the groups stored in the group databases 621, make an existing group a child of another group, unlink a child group from one of its parent groups, update group properties, create a new group as a child of an existing group, obtain a list of documents in a group, add documents to a group, and remove documents from a group.
The grouping module 412 also supports group import and export functions. Some of these group import functions relating to BOM groups, corporate entity groups, and inventorship groups are described below. The grouping module 412 also supports a user-defined group (or generic) group import function. When performing this function, the grouping module 412 receives a properly structured file comprising a plurality of records (or lines of information), where each record specifies a name of a group and a physical level of the group in the group hierarchy. From this file, the grouping module 412 creates a user-defined group hierarchy in the user-defined group databases 624.
An example file for group importation is shown below (other file structures could alternatively be used):
The first column corresponds to the physical level in the group hierarchy, and the second column corresponds to the group name. The information contained in this example file corresponds to a group hierarchy shown in
The grouping module 412, upon receipt of this file, creates a record in the group_table 1227 for each of the groups represented in the file (i.e., for groups A, B, C, D, E, F, and G). The physical level information from the file is stored in the group_group_xref table 1229. For example, the group_group_xref table 1229 would have a record that indicates that Group A is the parent of Group B. The group_group_xref table 1229 would also have a record that would indicate that Group G is a child of Group D. (It is noted that similar physical level information is also preferably in the customer BOM data 4704 (
The client grouping module 712 displays the group hierarchy and the documents in a group, and enables a user to manipulate and process groups.
Selecting (by double clicking) a document from the list in the second window 5806 causes the selected document to be displayed. For example, suppose that the user selected U.S. Pat. No. 4,760,478 from the list displayed in the second window. This would cause the client 304, 306 to obtain the text and image of this patent from the databases 316 via the enterprise server 314. The client document storage retrieval module 708 would then display the retrieved text and image of the '478 patent at the client monitor 1122 using the format shown in
The client grouping module 712 receives from the user commands to navigate through the group hierarchy, to edit the group hierarchy, to edit groups, to add documents to groups, to delete documents from groups, to delete groups, etc. The client grouping module 712 modifies the display of the window 5802 as necessary to reflect these user commands. The client grouping module 712 also generates enterprise server API commands corresponding to these user commands, and forwards these enterprise server API commands to the enterprise server 314 for processing by the grouping module 412 in the enterprise server 314.
Analysis Modules
The analysis modules 416 are shown in
It should be understood that the invention is adapted and intended to include a wide and varied range of analysis modules 416. The analysis modules 416 shown in
For illustrative purposes, the analysis modules 416 are sometimes described herein as working with particular types of groups, such as BOM groups. However, it should be understood that the analysis modules 416 can work with any types of groups.
The analysis modules 416 are described in detail in sections below.
Security Module
The security module 402 in the enterprise server 314 manages and interacts with the security databases 636, which stores information required to implement the security features of the invention. The security module 402 utilizes the information in the security databases 636 to implement a multilevel security methodology. The security databases 636 and the multilevel security methodology implemented by the security module 402 are described in detail in sections below.
The client security module 702 in the clients 304, 306 enable a user to access and modify the security information in the security databases 636. Typically, access to the client security module 702 and the security databases 636 is limited to users with high security clearances, such as system administrators.
Server Administration Module
The server administration module 418 performs functions related to the enterprise server 314's resources, such as the databases 316 and the indexes to the databases 316. Some of the server administration module 418 functions include performing reindexing operations of the databases 316, when necessary, importing and exporting large portions of the databases 316, upon request, managing directories, etc. The server administration module 418 is also responsible for establishing user sessions with the enterprise server 314.
The client server administration module 718 at the client 304, 306 and/or the server administration module 418 in the enterprise server 314 preferably maintains one or more server configuration files. Information in the server configuration files identifies, for example, the physical location of the databases, the number of possible concurrent users, memory size allocations, etc. The server configuration files can also include log files. The server configuration files would indicate what events are to be logged to the log files, such as whether to track all user actions, track error conditions, etc.
Server Configuration Module
Not all users have access to all of the enterprise server functions. A normal user, for example, may be only able to search documents and document bibliographical information, view documents, and print documents. Accordingly, a normal user would be able to access only the document storage and retrieval module 408 and the searching module 410 of the enterprise server 314.
Also, different users may have different search capabilities. Some users may be able to search only document bibliographic information, while other users may be able to search both document bibliographic information and the text of documents.
A power user may be allowed access to all enterprise server functions. The power user could search documents and document bibliographical information, view documents, print documents, work with groups, work with notes, and invoke analysis functions. Accordingly, the power user would be able to access the document storage and retrieval module 408, the searching module 410, the grouping module 412, the notes module 414, and the analysis modules 416 of the enterprise server 314.
A system administrator may be able to set user security levels and perform enterprise server administration functions. Accordingly, a system administrator would have access to at least the security module 402 and the server administration module 418.
The modules loaded on a user's computer preferably depend on the user's security level, and correspond to the modules in the enterprise server 314 to which the user has access. Referring to
The system configuration module 404 in the enterprise server 314 keeps track of the functions and modules that each user is permitted to access. Preferably, the server configuration module 404 maintains a database (not shown) having access privilege information for each user (note that this is different than security access information). As shown in
The functions and enterprise server modules that a user is allowed to access is dependent on a number of factors, such as the user's level of need, the user's level of expertise, and/or whether or not the user has purchased the modules and/or databases (in some embodiments, it may be necessary for the user to pay a fee to access and obtain the benefits of an enterprise server module, such as the notes module 414, the grouping module 412, and/or the analysis modules 416).
The user's computer platform is also a consideration. In some embodiments, software for some client modules (such as the client grouping module 712, the client notes module 714, and/or the client analysis module 716) may not exist for the user's particular computer platform. This is especially true for the computer platforms used to implement the web clients 304. In these cases, the user will not be able to access any of the enterprise server modules for which the user's platform does not have a corresponding client module. In other embodiments, however, software for all of the client modules are available for all platforms. Accordingly, the user's computer platform is not a consideration with respect to the issue of which enterprise server modules the user is capable of accessing. In these embodiments, the client modules may be implemented using multi-platform enabled software, such as Java or other such software.
In some embodiments, the modules are not loaded on the user's computer. Instead, they are run from a server connected to the user's computer. However, a particular user may not have access to all of the modules on the server, for the reasons discussed above.
Command Dispatch Module
The command dispatch module 406 routes enterprise server API commands received from clients 304, 306 to the enterprise server modules that are responsible for processing the commands. This functionality is represented in step 10110 of
Clients
As noted above, the system 302 preferably includes two types of clients, network clients 306 and web clients 304. The network clients 306 and the web clients 304 are discussed in greater detail below.
It is noted that the functional capabilities of network clients 306 and web clients 304 may differ in some embodiments, and may be the same in other embodiments (this is described below). However, for simplicity purposes, the present invention is sometimes described as interacting with “clients 304, 306,” which may represent one or more network clients 306, one or more web clients 304, or any combination of network clients 306 and web clients 304.
Network Clients
The network clients 306 preferably communicate with the enterprise server 314 using the enterprise server 314's natural language, which is called the enterprise server API (application program interface). The network clients 306 can be considered to represent web browsers that are specific to the language and the functions supported by the enterprise server 314. The enterprise server API is described below.
The network clients 306 preferably communicate directly with the enterprise server 314 via a communication network 312, which is preferably a network that supports the well known HTTP (hypertext transport) protocol.
Each network client 306 is preferably implemented using a computer, such as the computer 1102 shown in
In fact, preferably all software of the invention is written using the C++ computer programming language. Database manipulation code is written in a combination of SQL and C++. Other computer programming languages could alternatively be used, such as SmallTalk, Java, C, Pascal, ADA, etc.
Web Clients
The web clients 304 are each preferably implemented using a computer such as that shown in
Unlike the network clients 306, the web clients 304 do not typically utilize the enterprise server API. Accordingly, the web clients 304 communicate indirectly with the enterprise server 314 via the web server 310.
Specifically, the enterprise server 314 sends raw data 802 to the web server 310 over the network 312. The translator 804 in the web server 310 translates the raw data 802 to data in the well known HTML data format. This HTML data 806 is sent to the web client 304 over network 308. A browser 808 in the web client 304 renders the HTML data 806. The translator 804 translates data going from the web client 304 to the enterprise server 314 in a similar manner. It is noted that data formats other than HTML could alternatively be used. In particular, any data format used by the browser 808 could alternatively be used in the invention.
Since the web server 310 communicates with the enterprise server over the network 312 using the enterprise server API, the web server 310 appears to be a network client 306 from the perspective of the enterprise server 314. The interaction between the web clients 304 and the enterprise server 314, and the network clients 306 and the enterprise server 314, is further described below.
The use of commercial web browser software in the web clients 304 is advantageous because such software executes on different computer platforms (that is, there are versions of the browser software that executes on different computer platforms), such as computer platforms produced by IBM, Apple, Sun, SGI, HP, companies producing computers that are compatible with those produced by these companies, etc. Thus, the present invention via the web clients 304 enables users working on any type of computer platform for which a commercial web browser is available to access the enterprise server 314 and the databases 316. This feature of the invention is particularly important in the data processing world of today, where any given corporate entity may have users on many different computer platforms. The present invention allows all of these users (using commercial web browser software, which the corporation may already own) to access and work with the enterprise server 314 and the databases 316, irrespective of the type of computer that they are using.
Enterprise Server API (Application Programming Interface)
The enterprise server API includes commands for accessing functions and capabilities supported by the enterprise server modules (shown in
Interaction between the clients 304, 306 and the enterprise server 314 is conducted via direct or indirect use of the enterprise server API, whether or not stated explicitly herein.
Other applications (not discussed herein) may interact with the enterprise server 314 as long as such applications conform to the enterprise server API.
An embodiment of the invention includes timed, automatic executing commands (such as the automatic searches described above). These commands execute upon the occurrence of an event (the event can be defined in the passed parameters of the commands). Such events include time (for example, execute every 30 days), system update (for example, run this search every time new patents are loaded into the enterprise server), data change (for example, automatically regroup these patents every time a corporate entity changes), etc. These timed automatic executing commands are essentially those listed and described below, with additional logic for detecting the occurrence of the defined condition(s)/event(s), and for automatic execution upon such detection.
The commands that make up the enterprise server API according to an embodiment of the invention are described below. It should be understood that the enterprise server API is extendable to support other enterprise server modules, or to support additional or modified functions in existing enterprise server modules, or to support other functions described herein. Embodiments of the enterprise server API may include only a subset of the following commands. Also, modules other than the ones identified could process the following commands. For example, the Server Administration Module 418 could process the Security Module 402's commands.
Commands Processed by the Server Administration Module 418
ReqLogin(username, password)
Returns: sessionID
Description: Login command for the enterprise server 314 for user authentication and to establish a user session on the enterprise server 314.
ReqLogout( )
Returns: nothing
Description: Terminates user session with enterprise server 314.
ReqAddUsers(userList userSet)
Returns: nothing
Description: Adds the users specified in userSet to the system (as being able to access the system).
ReqGetAllUsers( )
Returns: list of users in system
Description: Returns a list of users registered to work with the system.
ReqGetUsers(userIdList userIDSet)
Description: Returns a list of users (identified by userIDSet) and their user IDs.
ReqRemoveUsers(userIdList userIDSet)
Description: Removes a list of users from system, specified by their user IDs (userIDSet).
Commands Processed by the Security Module 402
ReqGetPermissionList(string docGroupID)
Description: Gets and returns the permission list for a group specified by docGroupID.
ReqRemovePermission(string docGroupID, string entityID)
Description: Removes all access privileges to a group (specified by docGroupID) from an entity (specified by entityID).
ReqSetPermission(string docGroupID, string entityID, string mode)
Description: Sets access permission (specified by mode) for an entity (specified by entityID) to use a group (specified by docGroupID).
Commands Processed by the Document Storage and Retrieval Module 408
ReqCanPage(document, section, page)
Returns: raw image data
Description: Gets the bitmap image (also called the canonical representation) associated with a section and page of a document as specified in the passed parameter.
ReqDocList( )
Description/Returns: Retrieves and returns a list of documents in the repository.
ReqTxt(document)
Returns: raw text data
Description: Gets the ASCII text of a document specified in the passed parameters.
ReqRawCan(document)
Returns: entire image file
Description: Gets the entire collection of images associated with a document specified in the passed parameter.
ReqRawEqv(document)
Returns: entire equivalent or text file
Description: Gets the document equivalent data or text data of a document specified in the passed parameter. This return data is a textual representation of the document.
ReqCanHeader(document)
Returns: Image file header data
Description: Gets header information about the collection of images associated with the document specified in the passed parameter, including the size, width, and height of the images.
ReqAbstract(spStringSet patentlist)
Returns: A list of abstract/patent number pairs
Description: Retrieves abstracts associated with the patent list specified in the patentList parameter.
ReqGetAllPatentData(int sindex, int eindex)
Returns: list of patents with their bibliographic information, search handle
Description: Gets the list of patents plus their bibliographic information, starting from sindex and ending with eindex, where sindex and eindex are based on the ordering of the patents in the patent bibliographic databases 604. Example: ReqGetAllPatentData(0, 5) returns the first 6 patents in the patent bibliographic databases 604 with their bibliographic information. Also returns a handle that identifies the persistent result set on the enterprise server in order to get more patents from the result set.
ReqGetAllPatents(int sindex, int eindex)
Returns: list of patents, search handle
Description: Gets the list of patents, starting from sindex and ending with eindex, where sindex and eindex are based on the ordering of the patents in the patent bibliographic databases 604. Example: ReqGetAllPatents(0, 5) returns the first 6 patents in the patent bibliographic databases 604. Also returns a handle that identifies the persistent result set on the enterprise server in order to get more patents from the result set.
ReqGetPatentDatalnGroup(string groupID, int sindex, int eindex)
Returns: list of patents with their bibliographic information, search handle
Description: Gets a list of the patents in a group (specified by groupID) with their bibliographic information, starting from sindex and ending with eindex (relative to the ordering of the patents in the group). Example: ReqGetPatentDataInGroup(groupid, 0, 5) returns the first 6 patents and their bibliographic information from the group. Also returns a handle that identifies the persistent result set on the enterprise server in order to get more patents from the result set.
ReqGetPatents(string groupID, int sindex, int eindex)
Returns: list of patents from sindex to eindex.
Description: This is similar to ReqDocsInGroup (described below), except it returns patents from sindex to eindex from the group specified by groupID. sindex and eindex are relative to the ordering of the patents in the group. Example: ReqGetPatents(groupid, 0, 5) returns the first 6 patents in the group. ReqGetPatents(groupid, 6, 11) returns the second 6 patents in the group. Also returns a search handle on which to get subsequent patents.
ReqDeletePatentHandle(string handle)
Returns: nothing
Description: Deletes a generated result set of patents specified by handle, generated by ReqGetAllPatents or ReqGetPatents.
ReqGetPatentDataFromHandle(string handle, int sindex, int eindex)
Returns: list of patents with their bibliographic information, search handle
Description: Receives a handle. From that handle, gets the patents from sindex to eindex (where sindex and eindex are relative to the handle), and also gets their bibliographic information. The handle is generated by ReqGetPatentDataInGroup or ReqGetAllPatentData.
ReqGetPatentsFromHandle(string handle, int sindex, int eindex)
Returns: list of patents, search handle
Description: Receives a handle. From that handle, gets the patents from sindex to eindex (where sindex and eindex are relative to the handle). The handle is generated by ReqGetPatents or ReqGetAllPatents
ReqGetPatentsWithBibInfo(patentList list)
Returns: list of patents with their bibliographic information
Description: Given a list of patents (specified by list), returns a list of patents with their bibliographic information.
Commands Processed by the Grouping Module 412
ReqGetGroupHierarchy( )
Returns: group hierarchy information
Description: Retrieves information about the hierarchical structure of the groups stored in the databases 316.
ReqAddDocGroup(groupParentID, groupID)
Returns: nothing
Description: Adds an existing group (specified by groupID) as a child to another group (specified by groupParentID).
ReqRemoveDocGroup(groupParentID, groupID)
Returns: nothing
Description: Unlinks a group (specified by groupID) from its parent group (specified by groupParentID). If the group has no parent, the group is deleted.
ReqUpdateDocGroupProperties(group)
Returns: updated group
Description: Update group properties (such as description and title) of the group specified by the passed parameter.
ReqNewDocGroup(groupParentID, group)
Returns: new group
Description: Create a new group (corresponding to the group passed parameter) on the enterprise server 314 as a child of another group (specified by groupParentID).
ReqDocsInGroup(groupID)
Returns: list of document names
Description: Get the list of documents in the group specified by the passed parameter.
ReqAddDocListToGroup(groupID, documentList)
Returns: nothing
Description: Add a list of existing documents (specified by documentList) to the group specified by groupID.
ReqAddPatents(string groupID, patentList pList)
Returns: nothing
Description: Add the list of patents (specified by pList) to the group specified by groupID.
ReqRemoveDocListFromGroup(groupID, documentList)
Returns: nothing
Description: Remove a list of documents (specified by documentlist) from the group specified by groupID.
ReqRemovePatents(string groupID, patentlist pList)
Returns: nothing
Description: This is similar to ReqRemoveDocListFromGroup. This removes a list of patents (specified by pList) from the group specified by groupID.
ReqNewGroupWithSearchPatents(parentID, grp, handle)
Returns: group
Description: Creates a new group specified by grp under the parent group specified by parentID with documents/patents from a persistent result set generated by ReqSearchRelevant. The persistent result set is specified by handle.
Commands Processed by the Notes Module 414
ReqCreateNote(noteID, text, reference)
Returns: created note
Description: Create a new note on the enterprise server 314. The identifier of the new note is noteId, the text (or pointer to any type of data in any form) or content of the note is specified by text, and linkage information is specified by reference. The linkage information specifies the document and the portion within the document to which the new note is linked.
ReqUpdateNote(noteID, text, reference)
Returns: updated note
Description: Update a note (specified by noteID) on the enterprise server 314 with new text (specified by text) or reference (i.e., linkage information specified by reference).
ReqAddNoteListToDoc(groupID, documentID, noteList)
Returns: nothing
Description: Add a list of notes (specified to noteList) to a document (specified by documentID) in a group specified by groupID. groupID is used for security purposes (i.e., to ensure that the operator has the proper security level to add the notes to the document).
ReqRemoveNoteListFromDoc(groupID, documentID, noteList)
Returns: nothing
Description: Remove a list of notes (specified by noteList) from a document (specified by documentID) in a group (specified by groupID). groupID is used for security purposes (i.e., to ensure that the operator has the proper security level to remove the notes from the document).
ReqNotesOnDoc(groupID, documentID)
Returns: nothing
Description: Get all notes associated with a document (specified by documentID) in a group (specified by groupID). groupID is used for security purposes (i.e., to ensure that the operator has the proper security level to retrieve the notes associated with the document).
AddGroupNote(groupID, gnote)
Returns: A group note
Description: Adds a new group note represented by gnote to the group identified by groupID. Updates the note if it already exists.
AddPatent Note(groupID, note)
Returns: note
Description: Adds a new patent note represented by the parameter note to the group identified by groupID. Updates the note if it already exists.
GetGroupNotes(groupID)
Returns: returns group notes
Description: Retrieves all group notes associated with the group identified by groupID.
GetPatent Notes(groupID)
Returns: returns patent notes
Description: Retrieves all patent notes associated with the group identified by groupID.
RemoveGroupNote(groupID, groupNoteID)
Returns: nothing
Description: Removes the group note with groupNoteID from the group specified by groupID.
RemovePatent Note(groupID, noteID)
Returns: nothing
Description: Removes the patent note with NoteID from the group specified by groupID.
UpdateGroupNote(gnote)
Returns: a group note
Description: Updates an existing group note.
UpdatePatent Note(note)
Returns: a patent note
Description: Updates the properties of an existing note.
AddNoteSegment(noteID, noteseg)
Returns: a note segment
Description: Add given note segment represented by noteseg to a patent note identified by noteID.
GetGroupNotesMatchingString(groupID, search)
Returns: List of notes
Description: Return group note identifiers of notes in a group (specified by groupID) that contain the search string (represented by the search parameter).
GetNoteSegments(noteID)
Return/Description: Get and return all note segments associated with the given patent note specified by noteID. Also return their location information.
GetNoteSegmentsMatchingString(groupID, search)
Returns: List of note segments
Description: Return note segment identifiers of notes in a group (specified by groupID) that contain the search string (represented by the search parameter).
GetPatentLocations(groupID, patentName)
Returns: patent location list
Description: Returns all patent locations attached to the patentName.
LinkNoteSegment(noteSegmentID, location)
Returns: nothing
Description: Links note segment to location in a patent.
UnlinkNoteSegment(noteSegmentID)
Returns: nothing
Description: Unlinks note segment from location in patent.
UpdateNoteSegment(noteseg)
Returns: note segment
Description: Updates an existing note segment.
RemoveNoteSegment(noteID, noteSegmentID)
Returns: nothing
Description: Removes note segment specified by noteSegmentID from a patent note specified by noteID.
Commands Processed by the Searching Module 410
ReqSearch(searchParameters, startIndex, endIndex)
Returns: list of search results, search handle
Description: Execute a search based on searchParameters, retrieve search results from startIndex to endIndex in result table.
ReqRetrieveSearchResult(searchHandle, startIndex, endIndex)
Returns: list of documents
Description: Retrieve search results of previously executed search (identified by searchHandle) from startIndex to endIndex in result table. Also implemented as ReqRetrieveSearchRelevantResult(string handle, int sindex, int eindex).
ReqSearchHighlights(searchHandle, documentID)
Returns: list of text offsets for highlighting
Description: Retrieve search hit information for a particular document (specified by documentID) so that search term highlighting can be performed on the document. The search is specified by searchHandle.
ReqSearchBib(spSearchParameters s, int sindex, int eindex)
Returns: list of search results, search handle
Description: Executes a search based on SearchParameters, retrieves search results from startIndex to endindex in result table, where the search results include the bibliographic information of the documents identified by the search.
ReqSearchRelevant(ReqRetrieveSearchRelevantResult(searchType, searchOrder, query, sindex, eindex, minRelevance)
Return: search results with bibliographic information
Description: Performs a search on either the repository patents, all patents, or patents not in the repository (selected by searchType) using the search parameters. Returns the results sorted by field specified in searchOrder. Only return results that have a relevance number greater than minRelevance. Gets the results from row sindex to row eindex. Also returns a handle that identifies the persistent result set on the enterprise server in order to get more patents from the result set.
ReqRetrieveSearchRelevantResult(handle, sindex, eindex)
Returns: List of patent bibliographic information, and a search handle
Description: Retrieves portions of a persistent search result set generated by ReqSearchRelevant and identified by handle, from row sindex to row eindex.
Commands Processed by the Analysis Modules 416
ReqFunction(function, level, PatExp1, PatExp2, PatTerm1, PatTerm2, GroupID)
Returns: Results generated by performing the function specified by the function passed parameter
Description: Performs the function specified by the function passed parameter. The function passed parameter can identify any function performed by the enterprise server 314, such as Patent Mapping, Patent Aging, Patent Citation, Inventor Employment Information, and Patent Count. Level specifies the number of levels in the group hierarchy to drill down. PatExp1 and PatExp2 specify two dates (a time range) that designate a search scope based on patent expiration (see
ReqAnalysis Citation (documentID, direction, levels)
Returns: patent/child table and patent bibliographic information table
Description: Performs a patent citation function for a patent identified by documentID. Either a forward or a backward citation function is performed, as identified by the direction parameter. A multilevel citation function can be performed. The number of levels is specified by the levels parameter. For a detailed description of the operation of the enterprise server 314 when processing the ReqAnalysis Citation command, see step 15806 (
Client/Server Interaction
In step 10108, the security module 402 and the server configuration module 404 (see
In step 10110, the command dispatch module 406 in the enterprise server 314 routes the command and the information to the appropriate enterprise server module. These enterprise server modules are described above.
In step 10112, the enterprise server module performs the requested function.
In step 10114, the Enterprise server 314 sends the results of the command to the client 304, 306. In the case of the web client 304, the web server 310 translates the results received from the enterprise server 314 to the language supported by the web client 304 (preferably HTML), and then forwards these translated results to the web client 304 over the network 308. This network may be a local area network or a wide area network (it can even be a global network).
In step 10116, modules in the client 304, 306 operate to display the results to the user, and also operate to enable the user to manipulate, process, and otherwise utilize the results.
The corresponding module in the clients 304, 306 receives these results and presents them to the user, and enables the user to work with and manipulate the results. For example, the client document storage and retrieval module 708 presents to the user the information retrieved by the document storage and retrieval module 408 in the enterprise server 314.
The process just described is an iterative one, as represented by control arrow 10118.
The interaction between the web clients 304 and the enterprise server 314, and the network clients 306 and the enterprise server 314, is further described with reference to
Patent-Centric URL Commands
The interaction between the enterprise server 314 and the web clients 304 shall now be more particularly described.
As discussed above, the web client 304 preferably includes a browser 808, which can be any commercially available browser, such as (but not limited to) those available from Netscape, Microsoft, IBM, SUN, Novell, etc. In an embodiment of the invention, the browser 808 issues URL (Uniform Resource Locator) commands in order to access and retrieve data from the databases 316 via the enterprise server 314.
The general format of URL commands is well known, and is presented in
The protocol field 15004 specifies the protocol that is to be used in transporting the URL command 15002 from its source to its destination. Example protocols include HTTP and FTP (file transfer protocol).
The destination field 15006 specifies the destination of the URL command 15002. For example, the destination field 15006 may include information that identifies the server (such as the enterprise server 314) from whom information is being requested from.
The Command field 15008 stores information representing a command or an action or an identification of requested data. The effect of the URL command 15002 is to request that the entity identified by the destination field 15006 perform the command or action specified in the command field 15008.
According to the invention, the commands inserted into the command field 15008 are patent-centric or patent-specific. Accordingly, the URL commands generated by the present invention are patent-centric, or patent-specific.
In practice, HTML data representative of a web page is transferred to the browser 808 in the web client 304 upon connection with the Enterprise server 314. The browser 808 processes this received HTML data and, as a result, displays a web page. HTML processing is well known. Examples of web pages are shown in
For example, with reference to
Referring again to
According to an embodiment of the present invention, the URL commands sent from the browser 808 in the web client 304 to the translator 804 in the Web server 310 conform to a patent-centric URL command language. Accordingly, the URL commands sent from the browser 808 to the translator 804 represent patent-centric URL commands.
The patent-centric URL command language of the present invention essentially represents an API (Application Programming Interface) of the Web server 310. The patent-centric URL command language of the present invention includes the following patent-specific commands that are inserted in the command field 15008 of URL commands. It should be understood that the following is a representation of the types of commands that can be placed into the command field 15008 of URL commands according to the invention. The invention can support other patent-centric/specific commands. Thus, the following is provided for purposes of illustration, not limitation.
Operation:
An operator defines a search using, for example, the patent search screen 14002 of
For a new search, the begin parameter is equal to 0, indicating that the enterprise server 314 should return the search results beginning from record 0 (of the search results). The numberpage parameter indicates to the enterprise server 314 the number of items to return search results on. For example, if the numberpage parameter equals 10, then the enterprise server 314 returns information on 10 search results items, starting with the first item (where begin is equal to 0).
In a new search, the total parameter is returned by the enterprise server 314, and represents the number of search hits. This value of the total parameter is then returned to the enterprise server 314 in any subsequent, related search commands (to obtain additional search results, for example). The browser 808 receives the search results provided by the enterprise server 314 and displays the search results in a screen such as that shown in
For this and any other subsequent, related search commands, the parameters (such as scope, search key terms, items to display, etc.) that define the search are the same as in the original search command. In this and subsequent related search commands, however, the GUID of the original search results is provided. The enterprise server 314 uses this GUID to access the original search results, if they are still available on the enterprise server 314 (they may have expired). If the original search results are not still available on the enterprise server 314, then the enterprise server 314 reexecutes the search.
In the case where the operator pressed the Next icon 14109, the rel field is set equal to NEXT. If the operator pressed the Previous icon 14111, the rel field is set equal to PREVIOUS. If the operator presses a Last icon 14119, the rel field is set equal to LAST. If the operator pressed a First icon 14191, the rel field is set equal to FIRST.
In the case where the operator pressed the Next icon 14109, the begin field is set to 0. The enterprise server 314, upon receipt of this command, identifies the next page of search results to send to the web client 304. The enterprise server 314 does this by adding the value of the numberpage to the value of begin. The result of this addition operation identifies the first record in the search results to send to the web client 304. Starting from this value, the enterprise server 314 sends numberpage items to the web client 304. Thus, where the begin field is equal to 0, and the numberpage is equal to 10, the enterprise server 314 sends records 10-19 of the search results to the web client 304.
Suppose that the operator again presses the Next icon 14109. In the resulting search command, the begin field is set to 10 (this is done by software associated with the link associated with the Next icon 14109 in the display 14102 in
If rel is equal to GET_RESULTS_IN_FILE, then the enterprise server 314 returns HTML data to the web client 304. The web client 304 prompts the operator for a file name, and then saves this data in the file identified by the file name.
If rel is equal to SKIM_IMAGES, then the enterprise server 314 returns information that identifies two frames (or windows or panes). The enterprise server 314 supplies, for one of the frames, information that identifies a file in the enterprise server 314. This file stores a list of the search results. The web client 304 issues a URL command to retrieve this file from the enterprise server 314. The web client 304 then displays the list of the search results into this first frame. For the second frame, the enterprise server 314 provides information that identifies the location of the image of the first item in the search results. The web client 304 issues a URL command to retrieve this image (or a portion of the image, like the portion of the image corresponding to the first page of the document) from the enterprise server 314. The web client 304 then displays this image in the second frame. This two frame display is shown, for example, in
In the above description, the enterprise server 314 is described as interpreting the URL commands generated by the web client 304. In practice, according to a preferred embodiment of the invention, the translator 804 in the web server 310 translates the URL commands to commands in the enterprise server API language. The enterprise server 314 then processes these enterprise server API commands as discussed herein. Such translation is described below.
Translation
As described above, the translator 804 in the web server 310 translates between patent-centric URL commands and enterprise server API commands (see
Client Architecture
The User Interface layer 11404 may be based on various well known user interfaces. The user interface layer in the web client 304 preferably processes HTML data. The user interface layer 11404 in the network client 306 preferably uses MFC, or the Microsoft Foundation Class Library. In some embodiments, the user interface layer 11404 is built using multi-platform enabled languages, such as Java.
The client modules 701 are shown in
The transaction management layer 11406 implements the specific business-related operations of the invention. These operations include creating a group or changing the security permissions of the group (this could alternatively be done by the domain layer 11408). The transaction management layer 11406 interacts with the client modules 701 to perform these functions.
The domain layer 11408 includes all of the objects that are required to properly implement a patent-centric decision support system. These objects in the domain layer 11408 represent the business and other high level intelligence of the client 304, 306, and enables the client 304, 306 to work with business rules, notes, analysis modules, etc.
Supporting the domain layer 11408 is a broker layer 11410 that provides for sophisticated brokering and caching of objects in the client 304, 306. The broker layer 11410 is responsible for managing the communication between the domain layer 11408 and the server layer 11416. This decouples the domain layer 11408 from the enterprise server 314 and provides for maximum flexibility in the implementation of different enterprise servers 314.
The caching subsystem 11412 of the broker layer 11410 provides a means for objects to be cached on the client 304, 306 after they have been retrieved from the enterprise server 314. The caching subsystem 11412 enables the client 304, 306 to manage an infinite number of objects obtained from the enterprise server 314 by only storing those objects that have been most recently used. In an embodiment of the invention, the client 304, 306 utilizes a demand paging algorithm. In an embodiment of the invention, caching only takes place on the network client 306.
A demand paging algorithm according to an embodiment of the invention is represented by a flowchart 14902 shown in
In step 14906, the Cache subsystem 11412 receives a request for data from a requester (the requester is typically an upper layer in the architecture). This data request is described herein as being a request for patent data. However, the discussion described herein applies to both patent and non-patent data.
At this point, it would be useful to describe an example of how a data request is generated. Consider an example console user interface 11802 shown in
In a preferred embodiment of the invention, at any given time, all of the information pertaining to the patents in the repository 11710 is not stored in the client 304, 306. Instead, only a portion of the information pertaining to the patents in the repository 11710 are stored in the client 304,306. Preferably, the client 304, 306 retrieves data from the databases 316 as it needs it.
For example, 13 patents are currently listed in the second pane 11706. The client 304, 306 need only store information on these 13 listed patents. In practice, however, at any given time the client 304, 306 may store information on more than the patents being displayed in the second pane 11706. More generally, at any given time, the client 304, 306 may store information on more than the patents being processed, analyzed, displayed, etc., at the client 304, 306. However, the client 304, 306 does not store all of the data from the repository 11710 (unless, for some reason, the client 304, 306 is processing all of that data). Also, during a session with the enterprise server 314, the client 304, 306 does not discard information that it has received from the enterprise server 314, even when the information is no longer being used at the client 304, 306. In other embodiments, the client 304, 306 discards unused data received from the enterprise server 314 in order to make room for additional data.
The client 304,306 retrieves information from the enterprise server 314 by sending a data retrieval request to the Caching subsystem 11412. The Caching subsystem 11412 receives this request in step 14906.
Further in step 14906, the Caching subsystem 11412 identifies from the data retrieval request the patent and the portions of the patent that are being requested. Preferably, in the present invention, a patent has multiple parts or portions. These parts include the patent bibliographic information, the patent (equivalent) text file, and the patent image file. A given data retrieval request may be requesting any or all of these portions of the patent. In step 14906, the Caching subsystem 11412 identifies from the data request which patent is being requested, and also which portions of the patent are being requested. For reference purposes, the patent that is being requested is called the identified patent, and the portions of the identified patent that are being requested are called the identified portions.
In step 14910, the Caching subsystem 11412 determines whether the identified portions of the identified patent are already stored in the local cache. For purposes of the present invention, the local cache is represented by the main memory 1108 in the client 304, 306. In alternate embodiments of the invention, the local cache is represented by cache memory in the client 304,306.
If the identified portions of the identified patent are currently in the local cache, then in step 14912 the Caching subsystem 11412 retrieves those identified portions of the identified patent from the local cache and returns them to the requester. Operation of flowchart 14902 is then complete, as indicated by step 14922.
If, in step 14910, the Caching subsystem 11412 determines that the identified portions of the identified patent are not in the local cache, then step 14914 is performed. In step 14914, the caching subsystem 11412 sends a message to the Enterprise server 314 to request retrieval of the identified portions of the identified patent from the databases 316.
As should be clear by the above description of steps 14906, 14910, 14912, and 14914, the caching subsystem 11412 in the client 304,306 operates according to a caching methodology in which some data is stored in the local cache. When retrieving data, the Caching subsystem 11412 first looks in the local cache to determine whether the requested data is located in the local cache. If the data is not found in the local cache, then the Caching subsystem 11412 requests the data from the Enterprise server 314.
This caching methodology performed by the Caching subsystem 11412 in the client 304,306 represents a first level caching methodology according to the present invention. As mentioned above, the Enterprise server 314 performs a second level caching methodology. This second level caching methodology shall now be described.
In step 14916, the Enterprise server 314 receives the message from the client 304,306. The Enterprise server 314 determines whether the identified portions of the identified patent (as indicated in the received message) are currently stored in the local cache of the Enterprise server 314. The local cache of the Enterprise server 314 is represented by the Main memory 1108 of the Enterprise server 314. In an alternative embodiment, the local cache of the Enterprise server 314 is represented by Cache memory in the Enterprise server 314.
If the identified portions of the identified patent are located in the local cache of the Enterprise server 314, then in step 14920 the Enterprise server 314 retrieves the identified portions of the identified patent from its local cache, and sends this retrieved data to the client 304,306.
If, in step 14916, the Enterprise server 314 determines that the identified portions of the identified patent were not located in its local cache, then in step 14918 the Enterprise server 314 retrieves the identified portions of the identified patent from the databases 316. The Enterprise server 314 then in step 14920 returns this retrieved data to the client 304,306. The operation of flowchart 14902 is complete after the performance of step 14920, as indicated by step 14922.
As described above, in an embodiment of the invention, the Enterprise server 314 retrieves and returns only the identified portions of the identified patent. In some cases, the Enterprise server 314 instead returns data representative of a plurality of patents, where such data includes the identified portions of the identified patent. This is called the bulk or cluster retrieval mode of the invention.
Consider again
A patent cluster represents a given number of patents. In an embodiment of the invention, the number of patents in a patent cluster is equal to 50, but this value is tuneable, and this value may be different for different contexts of the invention. When operating according to the cluster or bulk mode, the Enterprise server 314 in step 14916 determines whether the identified portions of the identified patent are in a cluster that is stored in the local cache of the Enterprise server 314. If the identified portions of the identified patent are in a cluster stored in the Enterprise server 314, then in step 14920 the Enterprise server 314 sends data representative of this cluster of patents to the client 304, 306. If, instead, the Enterprise server 314 determines in step 14916 that the identified portions of the identified patent are not in a cluster currently stored in the Enterprise server 314, then the Enterprise server in step 14918 retrieves data representative of the cluster from the databases 316. The Enterprise server 314 then, in step 14920, sends this retrieved information to the client 304, 306.
Supporting both the domain layer 11408 and the broker layer 11410 is the persistence mapping layer 11414. The persistence layer 11414 is responsible for managing all interactions between the domain layer 11408 and a specific persistent storage device (not shown in
Supporting all aspects of the client 304, 306 is the abstract server interface 11416. This layer 11416 presents a logical server to the other layers of the client 304, 306. It is important to note that all interactions between the client 304, 306 and the enterprise server 314 take place using a high-level, patent-centric set of business decision system command objects. These command objects represent atomic transactions between the client 304, 306 and the enterprise server 314. These commands (or command objects) allow the client 304, 306 to communicate with the enterprise server 314 in a manner that decouples the client 304, 306 from any specific physical implementation of the enterprise server 314. For example, the enterprise server 314 could be running MS-DOS and storing objects in a flat file, or be running Unix and storing objects in Informix. As long as the enterprise server 314 responds to the set of command requests presented by the client 304, 306 through the abstract server interface 11416, the client 304, 306 will work correctly. These commands represent the Enterprise server API commands.
The abstract server interface 11416 communicates to make a physical connection to the enterprise server 314. This is done through the network transport layer 11418, which is responsible for taking command objects and transmitting these command objects over a suitable communications network. The network transport layer 11418 also manages appropriate context information that is needed to manage a network connection. The network transport layer 11418: (a) does not require the physical presence of a network—it is possible to run the client 304, 306 and enterprise server 314 on the same physical machine and still have the system used properly; and (b) does not require the use of any specific network, even though one implementation of the system will be based on HTTP (HyperText Transport Protocol).
Additionally, general features of the architecture of
Databases
Referring to
The database structures of the document bibliographic databases 602, the group databases 621, the person databases 632, the employee databases 634, the security databases 636, the financial databases 638, and the methodology support databases 642 are shown in
It should be understood that the tables and attributes shown in
In step 9506, the customer provides data 4504 for upload into the databases 4508 being processed. The customer provided data 4504 is pertinent to the databases 4508. For example, if the databases 4508 are intended to store financial information, then the customer provided data 4504 would comprise financial information of interest to the customer, including possibly both the customer's financial information and financial information of competitors.
In step 9508, a filter 4506 modifies the format of the customer provided data 4504 to conform to the database format of the databases 4508. The structure and operation of database filters, such as filter 4506, are well known.
In step 9510, the formatted customer provided data is loaded into the databases 4508. More particularly, the formatted customer provided data 4504 is loaded into a portion of the databases 4508, called a first part 4510 of the databases 4508. Remaining portions of the databases 4508, called the second part 4512 of the databases 4508, cannot be loaded using only the formatted customer provided data 4504. Instead, loading of the second part 4512 may require other information 4516 pertinent to the databases 4508. Additionally, loading of the second part 4512 may require analysis of such additional information 4516 in conjunction with the information in the first part 4510 of the databases 4508. Such analysis is performed by operators 4514 with, potentially, the assistance of the system of the invention.
Accordingly, in step 9512, other information 4516 pertinent to the databases 4508 is obtained.
In step 9514, methodology reports 4518 are run, as needed. Such methodology reports 4518 represent the result of automatic processing and analysis of the databases 4508 with other tables in the databases 316. Such automatic processing and methodology reports are performed and generated by the enterprise server 314, and is described in detail below.
In step 9516, operators 4514 analyze the customer provided data 4504 in the first part 4510 of the databases 4508. The operators 4514 may also analyze the other information 4516. In performing this analysis, the operators 4514 may refer to the methodology reports 4518 run in step 9514. Since these methodology reports 4518 were prepared by the enterprise server 314, the system of the invention assists the operators 4514 in performing this analysis. Based on the analysis of the operators 4514, additional database information for the databases 4508 is generated.
In step 9518, this additional database information is loaded into the second part 4512 of the databases 4508. The databases 4508, at that point, are fully loaded. Periodically, the steps of flowchart 9502 must be repeated in order to update the databases 4508 with additional and/or modified customer provided data 4504 and/or additional and/or modified other information 4516.
In an alternate embodiment of the invention, data is not preloaded into the invention's databases. Instead, the invention accesses the customer's corporate databases for data on an as needed basis. This alternate embodiment is described below with respect to the BOM databases 626, but are applicable to the other tables in the databases 316 as well.
Document Bibliographic Databases
The patent bibliographic databases 604 include a patent table 1222 (
Each record of the patent database 1222 also includes attributes that, for the most part, correspond to the bibliographic information on the first page of U.S. patents. In an embodiment of the invention, each record of the patent database 1222 includes attributes that, for the most part, correspond to the bibliographic information contained in the electronic representations of U.S. patents publicly available from the U.S. Patent and Trademark Office.
For example, a record in the patent database 1222 includes a document_number attribute that stores a patent number 4004 (see the example patent in
Also in each record of the patent database 1222, the NumDrawingPages corresponds to the number of drawing sheets 4038, the disclaimer date corresponds to any terminal disclaimer 4106 (
Each record of the patent database 1222 also includes attributes that correspond to patent bibliographic information not shown on the front page of U.S. patents. For example, a record of the patent database 1222 also includes a SeriesCode that corresponds to the series code of the patent. Other information contained in each record of the patent database 1222 and not shown on the front page of the U.S. patent is the AppType, PubLevel, ArtUnit, ExemplaryClaimNo, NumFigures, NumSpecPages, TermYears, and IntlEdition. Each record of the patent database 1222 may also include fields whose values are calculated during the loading phase. For example, each record of the patent database 1222 may include a calc_exp_date that corresponds to the expiration date of the patent. This date is calculated and loaded into the patent database 1222 during the load phase of the patent database 1222 (described below). calc_exp_date and issue date are collectively referred to as patent term expiration related information.
Each record of the patent database 1222 also includes one or more user_defined fields. Users may enter any information into this field. The amount of information that can be entered into this field is relatively large, such as 32 kbytes or greater. This field is preferably indexed searchable. The user can enter into this field information that is specific and/or of interest to his company. For example, a user may enter into this field its own matter or reference/tracking number.
Additionally, the invention allows operators to add any number of additional user defined fields, both into the patent database 1222 and into any other table of the databases 316. The fields must be of certain predefined types, such as date fields, string fields, numeric fields, etc. The user can define the name of these fields and the types of these fields (from a number of available field types). Preferably, these fields are indexed and searchable.
The record in the patent table 1222 corresponding to a particular patent is herein called the base record for the patent (because this record in the patent table 1222 includes most of the bibliographical information about the patent). The patent bibliographic databases 604 include other tables that store additional patent bibliographic information about each patent represented in the patent bibliographic databases 604. Records in these other tables are linked to their respective base records in the patent database 1222 via the document_id attribute.
An assignee table 1201 (
An intlclass table 1203 (
The patent_class_xref table 1204 (
A patent class/subclass is stored in a record of the patent_class_xref table 1204 using the patent_class_id attribute, the subclass_id attribute, and the suffix_id attribute. Consider the following class/subclass: 364/419.19. For this example, the patent_class_id is equal to 364. The subclass_id is equal to 419. The suffix_id attribute is equal to 19. By breaking the class/subclass into these three fields, it is possible to fine tune searches and direct searches to any combination of the class, subclass, or subclass suffix.
The patent_class_id attribute is actually a code. The same is true of the subclass_id and the suffix_id attributes. These patent class codes are defined in a patent_class table 1209 (
A RelatedApp table 1206 (
A LegalRepAttor table 1205 includes information on the attorney or agent who prosecuted the patent. Such information is shown in
Referring to
Referring now to
The inventor table 1212 includes information on the inventors of a patent. The inventor table 1212 includes a record for each inventor of a given patent. Records in the inventor table 1212 are linked to the corresponding base record in the patent table 1222 via the document_id attribute. Inventorship information is shown, for example, in
Referring now to
The PatCoopTreaty table 1214 stores information on a PCT application, in those cases where the U.S. patent was first filed as a PCT application. Such PCT information is shown, for example, in
The priority table 1215 includes priority information related to the patent. Such priority information is shown, for example, in
Referring now to
Referring again to
A pleadings table 1224 corresponds to the pleadings bibliographic databases 608. The pleadings table 1224 includes a record for each pleadings-related document that is of interest to the customer. Each record of the pleadings table 1224 includes a document_id attribute that stores a key that uniquely identifies the pleadings-related document. Each record of the pleadings database 1224 may also include other bibliographic information, such as a pleadings_id attribute. The pleadings table 1224 may include other attributes, such as attributes that identify the author of the pleadings, the date that the pleadings were created, the subject matter of the pleadings, the number of pages of the pleadings, the parties involved in the pleadings, the title of the pleadings, the type of the pleadings, etc.
The prior_art table 1226 corresponds to the prior art bibliographic databases 610. There is a record in the prior_art table 1226 for each prior art reference that is of interest to the customer. Each reference of the prior_art table 1226 includes a document_id attribute that uniquely identifies the prior art reference. Each record of the prior_art table 1226 also includes other attributes, such as a prior_art_id attribute, and attributes to store information identifying the author of the prior art reference, the publication date of the prior art reference, the title of the prior art reference, the subject matter of the prior art reference, the number of pages of the prior art reference, etc.
Still referring to
The document bibliographic databases 602 shall now be further described with reference to an example shown in
The preferred procedure for loading the document bibliographic databases 602 shall now be described.
In step 9606, the patent text file 4604 and the patent image file 4624 of the patent being processed is received. For U.S. patents, electronic text and image files of patents are available from the U.S. Patent and Trademark Office. Similarly, text and image files corresponding to foreign patents are available from foreign patent offices.
In step 9608, an error detection and correction module 4612 in a parser 4610 analyzes the patent text file 4604 and detects any errors in the bibliographic data contained in the patent text file 4604. The error detection and correction module 4612 detects many types of errors. For example, an error which is detected by the error detection and correction module 4612 involves the issue date. With regard to patent text files 4604 received from the U.S. Patent Office, the issue date appears in the following format:
Thus, the issue date information is set off by the ISD token. This token is followed by four digits representing the year, two digits representing the month, and two digits representing the day. The error detection and correction module 4612 detects errors in the date given known date ranges. For example, the error detection and correction module would identify the following as an error:
The error detection and correction module 4612 would detect this as an error, since the year value is out of range. The error detection and correction module 4612 operates in this manner to detect all date-related errors.
Another error which the error detection and correction module 4612 detects involves state information and zip code information. The error detection and correction module 4612 correlates the state information and zip code information contained in the patent text file 4604 to determine if the zip code is possibly incorrect given the state, and vice versa. Such processing is possible, since each state is associated with a finite set of zip codes.
Another error which the error detection and correction module 4612 detects involves the patent number. The patent number of a U.S. patent comprises seven digits. The error detection and correction module 4612 confirms that the patent number has seven digits, and detects an error if it does not. The error detection and correction module 4612 performs a similar function for non-U.S. patents, and other types of patent documents, such as reissues, reexams, etc.
The patent number of a reissued patent has the token RE followed by five digits. The error detection and correction module 4612 detects an error if the patent number of a reissued patent does not follow this format.
The detection performed by the error detection and correction module 4612 also involves street addresses. The error detection and correction module 4612 detects a possible error if the street address has no alphabetic characters, or has no space characters, or has no digit characters. Similarly, the error detection and correction module 4612 detects a possible error with the city name if the information in the patent text file 4604 corresponding to a city name has no alphabetic characters.
The error detection and correction module 4612 performs additional error correction with regard to U.S. states by comparing information corresponding to U.S. state names from the patent text file 4604 with a list of the U.S. state abbreviations used by the U.S. Patent Office. If the state information does not match one of the state abbreviations, the error detection and correction module 4612 detects an error.
Similarly, the error detection and correction module 4612 detects errors with information in the patent text file 4604 corresponding to country abbreviations by comparing such country information from the patent text file 4604 with the list of country codes utilized by the U.S. Patent and Trademark Office (and any other appropriate foreign patent office).
The error detection and correction module 4612 also checks to ensure that mandatory data is contained in the patent text file 4604. Some bibliographic fields in the patent text file 4604 are mandatory, while others are optional. For example, the patent text file 4604 must contain document type information that identifies whether the patent is a utility patent, a design patent, a plant patent, a defensive publication, etc. In contrast, the patent text file 4604 may or may not include assignee information, since a patent does not have to have an assignee. The error detection and correction module 4612 checks for mandatory information, and detects an error if mandatory information is not contained in the patent text file 4604.
Many fields in the patent text file 4604 must be in a proper format. Some of these fields were already discussed above, such as the patent number and date. Other fields which must be in a certain format are classes and subclasses, and dates. The error detection and correction module 4612 determines whether this information from the patent text file 4604 is in the proper format, and detects an error if they are not.
Also in step 9608, the error detection and correction module 4612 automatically corrects the errors that it detects, where such automatic correction is possible. For example, given the patent number, the error detection and correction module 4612 can estimate the issue date. If the error detection and correction module 4612 detected an error with the issue date, then the error detection and correction module 4612 can attempt to automatically correct the error in the issue date based on the patent number (assuming that the patent number was found to contain no errors).
If the error detection and correction module 4612 cannot automatically correct the errors that it detected, then the error detection and correction module 4612 notifies an operator 4616. The operator 4616 then manually corrects the error.
The error detection and correction module 4612 also detects for errors in the information in the patent text file 4604 corresponding to assignees. The same company can be listed as assignee in different patents using different names. For example, IBM can be listed as the assignee in patents using various different names, such as IBM; International Business Machines; IBM, Inc.; etc. The error detection and correction module 4612 includes a thesaurus feature that lists the most commonly used names for well-known companies. The error detection and correction module 4612 compares the assignee name from the patent text file 4604 with this thesaurus and replaces the assignee information in the patent text file 4604 with the name retrieved from the thesaurus. Alternatively, the name retrieved from the thesaurus may be written to an appropriate user-defined field of the bibliographic databases 602.
In step 9610, a formatting module 4614 in the parser 4610 formats the error detected and corrected patent text file 4604. This formatting is performed in order to convert the format of the patent text file 4604 to the format of the patent bibliographic databases 604. Such formatting includes formatting performed with respect to patent numbers. The required formats for different types of patents are presented in Table 4, below. It is noted that Table 4 is not a complete list, but just an illustrative one. Other types of patents (applicable in both the U.S. and foreign countries) could also be processed by the formatting module 4614.
The formatting module 4614 confirms that the information in the patent text file 4604 corresponding to patent numbers corresponds to the formats shown in Table 4. If the format is not as shown in Table 4, the formatting module 4614 modifies the patent text file 4604 so that the patent number conforms with the format of Table 4. For example, consider the format of a plant patent, which is a token PP immediately followed by five digits. Assume that the information in the patent text file 4604 was as follows: PP-11111 (for illustrative purposes, spaces are indicated as dashes). This patent number is not in the proper format because five digits do not immediately follow the PP token. Instead, there is a space between the PP token and the five digits. Accordingly, the formatting module 4614 modifies the patent text file 4604 so that the patent number is in the proper format. In the example above, the formatting module 4614 deletes the space between the PP token and the five digits.
In step 9612, the parser 4610 generates a corrected and normalized patent text file 4618 from the error detected and corrected, and formatted patent text file 4604. The corrected and normalized patent text file includes both the text from the patent text file 4604 and the error detected and corrected, and formatted patent bibliographic information from the patent text file 4604.
When generating the corrected and normalized patent text file 4618, the parser 4610 may take into consideration other patent information 4605. The parser 4610 may modify the information from the patent text file 4604 with this other patent information 4605 when generating the corrected and normalized patent text file 4619. For example, a patent is sometimes reassigned to another company after it issues. The new assignee, however, is not indicated on the front page of the patent (because the patent was published before the reassignment took place). Often, patent reassignment information is in the assignment records of the U.S. Patent and Trademark Office (if such information was recorded with the USPTO). Such assignment records may constitute part of the other patent information 4605. The parser 4610 in generating the corrected and normalized patent text file 4618 may take into account such assignment information when generating the corrected and normalized patent text file. For example, the parser 4610 may include a note in the corresponding record of the corrected and normalized patent text file 4618 that the patent has been reassigned, and indicate the new assignee(s). This note may be, for example, in a field of the corrected and normalized patent text file 4618 corresponding to the user defined attribute in the record of the patent table 1222 (
The patent bibliographic information in the corrected and normalized patent text file 4618 is stored in normalized format. Preferably, this normalized format is a condensed, field delimited format. Essentially, in normalizing the patent bibliographic information from the patent text file 4604, the parser 4610 separates the patent bibliographic information into fields that correspond to the attributes in the patent bibliographic databases 604. These fields are delimited either using commas, tabs, or some other symbol.
For example, the format of a class/subclass in the patent text file 4604 is as follows: XCL---17-34-2 (for illustrative purposes, spaces are indicated as dashes). Therefore, in the patent text file 4604, a class/subclass is denoted by the token XCL, followed by two spaces. Three characters follow this token that correspond to the class. This is followed by three characters that correspond to the subclass. Finally, two characters follow the subclass. These two characters correspond to the suffix. In the corrected and normalized patent text file 4618, this class/subclass information is represented in a field delimited format, as follows: 17, 34, 2. This is a comma delimited format. In other embodiments, the corrected and normalized patent text file 4618 uses a tab delimited format for the patent bibliographic information.
In step 9614, the corrected and normalized patent text file 4618 is used to regenerate the patent text file 4604. The regenerated patent text file is designated by reference number 4608. A comparison module 4606 then compares the patent text file 4604 with the regenerated patent text file 4608. If the regenerated patent text file 4608 differs from the patent text file 4604, then the comparison module 4606 determines that the parser 4610 incorrectly generated the corrected and normalized patent text file 4618 from the patent text file 4604. If such an error is detected, then the comparison module 4606 notifies an operator 4616. It is noted that step 9614 is optional.
Preferably, the corrected and normalized patent text file 4618 represents an object-oriented framework. Generating the corrected and normalized patent text file 4618 as a framework is useful because it can then be easily exported to a number of different formats, for later processing. Accordingly, in step 9616, the corrected and normalized patent text file is stored in various formats for later retrieval. Such formats may include a human editable production format 4620, and/or a SPML format 4622. It is noted that step 9616 is optional.
In step 9618, the corrected and normalized patent text file is paginated by a pagination module 4626 to generate a patent equivalent text file 4630. The patent equivalent text file 4630 includes equivalency information that establishes an equivalency relationship between the text in the patent equivalent text file 4630 and the image in the patent image file 4624. For example, this equivalency information includes pagination information that enables the patent equivalent text file 4630 to be displayed having the same pagination (line breaks, column breaks, page breaks) as the patent image file 4624. The pagination module 4626 generates the patent equivalent text file 4630 by comparing the patent text in the corrected and normalized patent text file 4618 with the patent image file 4624 to detect equivalency information. This equivalency information is then embedded in the patent equivalent text file 4630, along with the patent text. While the pagination module 4626 is capable of performing the pagination operation automatically, in some cases some manual intervention is required. In accordance, an operator 4628 is sometimes involved with the pagination process performed by the pagination module 4626. The pagination process performed by the pagination module 4626 is further described in U.S. Pat. No. 5,623,681, U.S. Pat. No. 5,623,679, and pending U.S. patent application Ser. No. 08/341,129, all of which are incorporated by reference herein. It is noted that step 9618 is optional.
In step 9620, a patent bibliographic flat file 4619 is generated from the corrected and normalized patent text file 4618. The patent bibliographic flat file 4619 includes the normalized patent bibliographic information from the corrected and normalized patent text file 4618. Preferably, the patent bibliographic flat file 4619 does not include the patent text. The patent bibliographic flat file 4619 is generated using standard database utilities.
In step 9622, the patent bibliographic information in the patent bibliographic flat file 4619 is loaded into the tables of the patent bibliographic databases 604. This loading operation is performed by using standard database loading utilities.
After completion of step 9622, the patent bibliographic information from the patent being processed is completely loaded into the patent bibliographic databases 604. The steps of flowchart 9602 are repeated for each patent that is to be represented in the patent bibliographic databases 604.
Referring again to
Group Databases
The group databases 621 are described below. In particular, the structure of the group databases 621 and the methodologies for loading the group databases 621 with data are described in the following sections.
User Defined Groups
According to the present invention, groups are hierarchically organized. In other words, a given group can be a child of one or more parent groups, and can also be a parent to one or more child groups. This hierarchical organization is illustrated by way of example in
A user-defined group is also a child of the root group. The user-defined group has a number of child groups. These child groups are user-defined groups. In the example, the child groups are: companies to acquire, patents about bikes, and litigation. The companies to acquire user-defined group has a number of child user-defined groups. They include: ABC Corp., XYZ Corp., and PQR Corp.
The hierarchical structure of the user-defined groups is defined by information in a group_group_xref table 1229 (
The group_table database 1227 and the group_group_xref table 1229 shall be further described with reference to an example illustrated in
Referring again to
A group_document_xref table 1228 stores information that identifies the documents that are in each user-defined group. The group_document_xref table 1228 includes a record for each document in each user-defined group. Each record of the group_document_xref table 1228 stores a group_id attribute to identify the user-defined group, a document_id attribute to identify a document in that group, and a modification_date attribute that stores the date that the record in the group_document_xref table 1228 was last modified.
The group_document_xref table 1228 shall be further described with reference to an example shown in
Referring again to
A user can view a document by double-clicking (or use any other well known GUI technique) on that document in the window 1804. In the example of
The procedures for initially loading the user-defined group databases 624 with data generally track the generic extract and load procedures illustrated in
Predefined Group Databases
The predefined group databases 622 (also called system defined group databases) are described in the following sections.
Bill of Materials (BOM) Databases
A bill of materials (BOM) is a well-known data structure often used by companies to abstractly represent a product. A BOM is a hierarchical and recursive data structure that identifies the subassemblies of a product, and that identifies the parts of the subassemblies. Accordingly, a product's BOM is useful for recording the sub-assemblies and parts needed to construct the product. BOMs are also called herein BOM data structures, or BOM structures, or BOM trees.
The frame, the two wheels, and the handle bar are subassemblies because they each are composed of one or more subassemblies or parts. For example, the frame subassembly includes a screw, which is a part. A part is defined as an item which does not have component parts separately represented in the BOM. Each of the two wheel subassemblies includes a rim and a tire, which are both parts. The handlebar subassembly includes a metal rod and two hand grips, all three of which are parts.
Although not indicated in the example of
The BOM 2202 in
In the context of and as applied by the present invention, each BOM node has a logical level in the hierarchical structure of the BOM. According to an embodiment of the invention, there are three BOM logical levels (although a customer can define others): assembly, subassembly, and part. Accordingly, the logical level of the bicycle node is assembly. The logical level of the frame, wheel, and handle bar nodes is subassembly. The logical level of the screw, rim, tire, metal rod, and hand grip is part.
In the invention, the reason for using logical levels is to enable enhanced reporting and analysis functions, such as the reporting functions described herein that are organized according to BOM logical level. As discussed above, an advantage of predefined groups is that their structure and attributes are better defined and more extensive than user-defined groups. Accordingly, more extensive and more useful analysis and reporting functions can be developed for predefined groups.
The BOM databases 626 are illustrated in
The BOM table 1217 includes entries for only unique BOM nodes of interest. Again referring to
Each record in the BOM table 1217 includes a BOM_id attribute which stores a key that is unique to the associated BOM node. Each record of the BOM table 1217 also includes a BOM_guid representing an alternate key of the record, a name attribute storing a name of the BOM node, a level_id attribute representing the logical level of the BOM node (that is, whether the BOM node represents an assembly, a subassembly, apart, etc.), a status_id attribute representing the status of the BOM node in the customer's business (that is, whether the part, subassembly, or assembly represented by the BOM node is in production, is discontinued, is contemplated for a future product, etc.), a creation_date attribute identifying the date that the record was created, a modification_date attribute indicating the date that the BOM record was last modified, and a version_number attribute identifying the version of the BOM record.
The level_id attribute is actually a code. The values of the level_id codes are defined in a BOM_level table 1220. Similarly, the status_id attribute is a code whose values are defined in a BOM_status table 1221.
As evident by the examples of
The BOM_BOM_xref table 1219 includes a record for each parent/child relationship in the BOMs represented in the BOM table 1217. Each record of the BOM_BOM_xreftable 1219 includes a parent_BOM_id attribute and a BOM_id attribute. The parent_BOM_id attribute stores the BOM_id of the parent BOM node, and the BOM_id attribute stores the BOM_id of the child BOM node. Each record of the BOM_BOM_xref table 1219 also includes a sort_order attribute which specifies the order in which the records in the BOM_BOM_xref table 1219 should be displayed or printed, when an appropriate command is received from the user. The value of the sort_order attribute is set to a default value, which is preferably 100. The user may change this value to any other number, either below or above 100. When printing or displaying the records of the BOM_BOM_xref table 1219, such records are printed or displayed in ascending or descending order (as indicated in the user command) based on the sort_order attribute.
The BOM table 1217 and the BOM_BOM_xref table 1219 shall be further described by reference to examples shown in
Information pertaining to the hierarchical structure of the bicycle BOM 2202 and the lawnmower 2302 is contained in an example BOM_BOM_xref table 1219X shown in
A BOM group represented in the BOM table 1217 may contain any number of documents. Preferably, the documents in a BOM group include patents that map to the BOM group. In other words, the documents in a BOM group include patents that map to the product represented by the BOM node corresponding to the BOM group in the BOM table 1217. As used herein, the term “product” refers to any assembly, subassembly, or part in a BOM.
A BOM_patent_xref table 1218 stores information that identifies the documents in a BOM group. The BOM_patent_xref table 1218 includes a record for each document in each BOM group. Each record of the BOM_patent_xref table 1218 includes a BOM_id attribute that identifies the BOM group, and a document_id attribute that identifies the document that is in that BOM group.
The preferred methodology for initially loading the BOM databases 626 is represented by a data flow diagram in
In step 9708, a BOM filter 4706 formats the customer BOM data 4704 so as to conform with the format of the BOM databases 626. The formatting done by the BOM filter 4706 may be minor or extensive, depending on whether, during the extract of the BOM data from the customer's databases, the customer was able to format the extracted data (represented as the customer BOM data 4704) in a format that closely matched the format of the BOM databases 626. Database filters, such as the BOM filter 4706, for formatting data in preparation for upload to a database are well-known.
In some embodiments, the invention includes a filter that is specific to the database format of the BOM databases 626 (this is true for all filters discussed herein—that is, the filters are specific to their respective databases). The structure and operation of this specialized filter will be apparent to persons skilled in the relevant art(s) based on the discussion herein, particularly the discussion of the database formats.
In step 9710, the formatted customer BOM data 4704 is loaded into a portion of the BOM databases 626. This portion is indicated as the first part 4708 in
In step 9712, data on the customer's products is obtained. This data is obtained from the customer, such as the customer's production department or R&D) department, and pertains to the status of the products (such as whether the products or parts are currently in production, whether they are contemplated for future production, whether they are discontinued, etc.).
In step 9714, patent related information is obtained. This patent related information may include, for example, a list of the customer's patents, and a list of competitor patents. Bibliographic information on these patents are loaded into the patent bibliographic databases 604 in the manner described above, to the extent that the patent bibliographic databases 604 do not already include patent bibliographic information on these patents.
In step 9716, operators 4712 may run methodology reports which will be later used to aid in the analysis of the data gathered in prior steps. The methodology reports which may be run include a patent mapping report (described below). The patent mapping report may be incomplete due to the lack of information in the BOM databases 626. However, even an incomplete patent mapping report may be useful to aid in the analysis of the data.
In step 9718, operators 4712 analyze the customer BOM data 4704, the product data 4716, and the patent related information 4714 to determine, for each BOM group, the BOM level, the BOM status, and the documents (that is, patents) that map to the BOM groups. For example, the operators 4712 will analyze the BOM data and the product data to determine the status (that is, whether discontinued, in production, contemplated for future production, etc.) of the BOM node associated with each BOM group. Additionally, the operators 4712 will analyze the customer BOM data 4704 and the patent related information to identify patents which map to the BOM group (that is, patents which map to the products represented by the BOM nodes corresponding to the BOM groups).
In step 9720, the information generated in step 9718 is loaded into the appropriate attribute fields of the BOM databases 626 (i.e., the second part 4710 of the BOM databases 626).
The steps of flowchart 9702 are periodically performed to update the BOM databases 626 with changes in BOMs, patents that map to BOMs, production changes, new products and features, etc.
In an alternate embodiment, the BOM databases 626 are not preloaded in the manner shown in
It is noted that this alternative embodiment could also be used with the other tables of the databases 316.
The approach of
BOM groups (and, in fact, any predefined group) can also be represented using user-defined groups as long as the operator is willing to abstract and map the BOM group attributes to the attributes supported by the user-defined groups. Such definition of BOM groups may be useful with BOMs that change frequently but core technologies change slowly, as in consumer products.
Corporate Entity Databases
A corporate entity is considered to be a predefined group because any number of documents can be associated with the corporate entity. These documents are preferably relevant and of interest to the corporate entity. For example, the documents could be patents that are owned, licensed, or otherwise of interest to the corporate entity.
The corporate entity databases 630 include information on the customer corporation, the corporations associated or affiliated with the customer corporation, and/or corporations that are otherwise of interest to the customer corporation, such as the customer corporation's competitors or potential competitors.
The corporate entity databases 630 are shown in
Information on the corporate structure is also stored in the corporate_entity table 1230. In particular, each entry of the corporate_entity table 1230 includes a parent_corp_entity_id attribute. This attribute stores the corp_entity_id of the immediate parent corporation of the corporate entity.
A sort_order attribute stores information that identifies the order in which the records of the corporate entity database 1230 should be displayed or printed when requested by the user. The sort_order attribute is set to a default value of preferably 100. The user can change this value of the sort_order attribute. The records of the corporate_entity table 1230 are displayed and printed according to the sort_order attribute in the records. In particular, the records of the corporate_entity table 1230 are displayed or printed in ascending or descending order (specified by the user) of the sort_order attributes in the records.
The corp_level_id attribute is implemented as a code whose values are defined in a corporate_level database 1232.
A primary_corp database 1231 stores the corp_entity_id of the customer corporation. This primary_corp table 1231 is referenced when the enterprise server 314 needs to identify who the customer is during analysis operations. For example, if the user requests a listing of all patents owned by the customer corporation, the enterprise server 314 refers to the primary_corp table 1231 to identify who the customer is, and then refers to the corp_patents_xref table 1233 (described below) to identify all patents owned by the corporate customer.
A corporate entity group represented in the corporate_entity table 1230 can include any number of documents, such as any number of patents. Typically, the patents in a corporate entity group represent patents for which the corporate entity has some interest, such as patents owned by the corporate entity, patents assigned to the corporate entity, or patents that, for whatever reason, the corporate entity is analyzing. A corp_patent_xref table 1233 stores information that identifies the documents contained in each corporate entity group. The corp_patent_xref table 1233 includes a record for each document in each corporate entity group.
Each record of the corp_patent_xref table 1233 includes a corp_entity_id attribute that identifies the corporate entity group, and a document_id attribute that identifies the document that is in the corporate entity group.
Each record of the corp_patent_xref table 1233 also includes an ownership_id attribute and a relevance_id attribute. The ownership_attribute identifies the relationship of the document to the corporate entity. Possible values of the ownership_id attribute include owned, assigned, interested in, etc. The ownership_id attribute is implemented as a code whose values are defined by a patent_ownership table 1234, and are ultimately under the control of (i.e., defined by) the customer.
The relevance_id attribute identifies the relevance of the document to the corporate entity. Preferably, the possible values of the relevant_id attribute are core and non-core. A relevance of core indicates that the patent (identified by the document_id) maps to an assembly, subassembly or part that is currently in production, or that is contemplated for future production, or for some other reason is important to the corporate entity. As discussed above, such assemblies, subassemblies and parts are represented in the BOM table 1217 as BOM groups. A non-core relevancy value indicates that the patent either does not map to any assembly, subassembly or part of interest or that the patent maps to an assembly, subassembly, or part that is currently discontinued, or that, for whatever reason the corporate entity does not have great interest in the patent. The relevance_id attribute is implemented as a code whose values are specified in a relevance table 1235, and are ultimately under the control of (i.e., defined by) the customer.
The corporate entity databases 630 shall be further described with reference to an example in
Note that corp5 in
The corporate_entity table 1230X also includes a record 3310 for corp 5. As indicated above, corp5 is a competitor of the customer corporation corp1. Therefore, the example of
The methodology for initially loading the corporate entity databases 630 shall now be described with reference to the data flow diagrams in
In step 10008, a corporate entity filter 5106 formats the corporate entity data 5104 to conform to the format of the corporate_entity table 1230. Database filters for formatting data prior to upload to a database are well known.
In step 10010, the formatted corporate entity data 5104 is loaded into a part of the corporate_entity table 1230 (this portion is indicated as the first part 5108 in
In step 10014, information on patents of interest which are not already represented in the patent bibliographic databases 604 is obtained. This information is loaded into the patent bibliographic databases 604 in the manner discussed above to the extent that it is not already represented in the patent bibliographic databases 604.
Referring to
In step 10016, operators 5208 map patents to corporate entities. In particular, these operators 5208 determine which patents are relevant to which corporate entities. This data is stored in the corporate_patent_xref table 1233. In other words, the operators 5208 determine which patents go into which corporate entity groups, and store this information in the corp_patent_xref table 233.
In step 10018, the operators 5208 and 5214 run methodology reports, as needed, such as patent mapping reports. These reports will aid the operators 5208 and 5214 in performing the analysis of 10020.
In step 10020, the operators 5208 and 5214 identify the ownership relationship for each patent/corporate entity pair specified in the corp_patent_xref table 1233. In other words, for each record in the corp_patent_xref table 1233, the operators 5208 and 5214 identify the ownership relationship between the corporate entity and the patent. Additionally in step 10020, the operators 5208 and 5214 identify, for each record of the corp_patent_xref table 1233, the relevance of the patent to the corporate entity. Relevance can be core, non-core, etc.
In step 10022, this additional data generated in step 10020 is stored in the appropriate fields of the corp_patent_xref table 1233. These fields are presented by the second part 5212 in
The steps of flowchart 10002 are periodically performed to update the corporate entity databases 630 to reflect changes in corporate structure, corporate acquisitions, corporate acquisition of patents, product line changes (that may change the relevance_id attribute), patent expirations (that would change the ownership_id attribute), etc.
Inventor, Employee, and Person Databases
An inventor is a predefined group because any number of patents can be associated with the inventor (i.e., patents where the person has been named an inventor). The inventorship databases 628 of the present invention preferably include information on the customer's past and present employee inventors, inventors of other companies, such as competitors, and inventors of any other patents of interest to the customer.
The inventor databases 628 are shown in
In particular, the person table 1242 represents the person databases 632. The person table 1242 includes a record of each person of interest to the customer. These persons could be past and present employees of the customer, inventors of patents of interest to the customer, employees (past and present) of competitors, etc. Each record of the person table 1242 includes a person_id attribute that represents a unique key of the person. Also included in each record of the person_id table 1242 are attributes that store the first name, middle name, and last name of the person, and the preferred suffix (Mr., Mrs., Ms., Dr., etc.) of the person.
An employee table 1243 is a table in the employee databases 634. The employee table 1243 includes a record of each employee of interest (whether or not the employee is an employee of the customer or a competitor, or is a past or present employee). Each record of the employee database 1243 includes a person_id attribute that identifies the person (from the person table 1242), and a corporate_entity_id attribute that identifies the corporate entity who is related to the person_id. There could be multiple entries in the employee table 1243 for the same person, if the person worked for many corporate entities represented in the databases 316.
Each record of the employee table 1243 further includes a job_function_id attribute that identifies the job function of the employee (for example, engineer, attorney, computer programmer, etc.), an employee_type_id that identifies the type of employee (such as part-time, full-time, etc.), an employee_status_id attribute that identifies the status of the employee (active, inactive, etc.), a start_date attribute and an end_date attribute that identify the period that the employee was employed by the corporate entity, and an employee_id attribute that indicates the employee's identification number within the corporate entity. The job_function_id attribute, the employee_type_id, and the employee_status_id attribute are preferably implemented as codes whose values are defined in an employee_job_func table 1245, an employee_type table 1244, and an employee_status table 1246, respectively.
Referring to
The inventor databases 628, person databases 632, and employee databases 634 will now further be described with reference to the example shown in
The preferred methodology for initially loading the person databases 632, the employee databases 634, and the inventor databases 628 shall now be described with reference to the data flow diagrams in
In step 9808, information on other people of interest (such as inventors of patents of interest or employees of competitors) is obtained. Such information is represented in
In step 9810, a person filter 4910 modifies the format of the customer provided person and employee data 4904 and the other person and employee data 4906 to match the format of the person databases 632 (that is, the person table 1242). Database filters for formatting data in preparation for database uploading are well-known.
In step 9812, the formatted customer provided person and employee data 4904 and the formatted other person and employee data 4906 are loaded into the person databases 632 (that is, the person table 1242).
In step 9814, an employee filter 4914 formats the customer provided person and employee data 4904 and the other person and employee data 4906 to match the format of the employee databases 634.
In step 9816, the formatted customer provided person and employee data 4904 and the formatted other person and employee data 4906 are loaded into the employee databases 634.
It is noted that in some cases, depending on the state of the data 4904, 4906, loading of the person databases 632 and the employee databases 634 may require the involvement of operators 4912, 4916.
In step 9908, bibliographic information on the patents obtained in step 9906 is loaded into the patent bibliographic databases 604 to the extent that such information is not already stored in the patent bibliographic databases 604.
In step 9910, operators 5008 analyze the patent information 5004 in conjunction with the person databases 632 and the employee databases 634 to map the patents obtained in step 9906 to the persons represented in the person databases 632 and in the employee databases 634. In other words, in step 9910, the operators 5008 identify, for each person represented in the person databases 632 and in the employee databases 634, the patents where that person is a named inventor.
In step 9912, the information generated in step 9910 is modified by a validated inventor filter 5006 to place the information in a form conforming with the format of the validated_inventor table 1236. Such formatted information is then loaded into the validated_inventor table 1236.
The steps of flowcharts 9802 in
Financial Databases
Example financial databases 638 are shown in
The patent licensing table 1248 includes financial information pertaining to the licensing fees generated by patents of interest. Each record of the patent licensing table 1248 includes a document_id attribute that identifies a document (more specifically, that identifies a patent). Each record of the patent licensing table 1248 also includes attributes that identifies the licensee of the patent, the licensor of the patent, and the current licensing revenue generated by such licensing of the patent.
It is noted that the financial tables 1247 and 1248 shown in
The financial databases 638 are generally loaded as described above with reference to
Security Databases
The security databases 636 are shown in
The present invention supports a multi-level security methodology. A first level of this security methodology specifies that the creator of a data item has full access privileges with respect to the data item. For example, consider the group_table database 1227 in
A second level of the invention's security methodology defines that a user may have specific access privileges with respect to an object, called a secured object. Such secured objects include, for example, a note, a document and its notes, a document, and a database. Such secured objects also include a user-defined group.
This level of the security methodology as it relates to user-defined groups as secured objects is implemented using a group_user_xref table 1237. It is noted that other types of secured objects can be implemented in a similar manner.
Each record of the group_user_xref table 1237 includes a group_id attribute that identifies a user-defined group, and a user_id attributed that defines a user. Each record of the group_user_xref table 1237 also includes a permission attribute which defines the access privileges that the user has with respect to the group. Possible access privileges include no access privileges, a read access privilege, a change access privilege (which allows the user to both read and modify the data item), and a delete access privilege (that allows the user to read, modify, and delete the data item). Other access privileges could also be defined. Accordingly, a record in the group_user_xref table 1237 specifies that a person (represented by user_id) has specific privileges (indicated by the permission attribute) to a particular user-defined group (represented by the group_id).
A third level of the security methodology of the present invention specifies that a user group (such as a department) may have a particular access privilege with respect to a user-defined group. If a user is in that user group, then that user would also have that access privilege with respect to the user-defined group. This level of the security methodology is implemented using a grp_usr_grp_xref table 1240. Each record of this table 1240 includes a group_id attribute that identifies a user-defined group, and a user_group_id that identifies a user group. The user_group_id attribute is implemented as a code whose values are defined in a user_group table 1241. Each record of the grp_usr_grp_xref table 1240 also includes a permission attribute that defines the access privilege that the user group (specified by the user_group_id attribute) has with respect to the user-defined group (specified by the group_id attribute). Preferably, a user group permission is overridden by a users explicit permission, allowing the system administrator to give a user a higher or lower permission than the user group that the user is in.
A usr_grp_usr_xref table 1239 specifies the users who are in each user group. In particular, each record of this table 1239 includes a user_group_id attribute that identifies a user group, and a user_id attribute that identifies a user who is in that user group.
The security databases 636 will now be further described with reference to an example in
The various levels of the security methodology of the present invention do not work individually. Instead, these security methodology levels work together in a well defined and integrated manner. This integrated security methodology is implemented by the security module 402 in the enterprise server 314. The operation of the security module 402 when processing a request to access a data item (in particular, a user-defined group) is depicted in a flowchart 11002 in
The security module 402 performs the steps of flowchart 11002 to determine whether a user who is requesting an operation involving a data item has sufficient security access privileges with respect to that data item. Preferably, all operations performed by the enterprise server 314 are security checked. In other embodiments, only some operations performed by the enterprise server 314 are security checked. For example, operations involving reading patent documents are not security checked in some embodiments because patents are widely available public documents.
The user requesting the operation involving the data item is called the requestor for reference purposes. For purposes of example, the data item that is involved in the operation is assumed to be a user-defined group having associated with it a record in the group_table database 1227 (
In step 11006, the security module 402 determines whether or not the requester is the owner of the requested user-defined group. The security module 402 performs step 11006 by comparing the requestor's user_id with the owner_user_id attribute in the record of the group_table database 1227 corresponding to the requested user-defined group. If it is determined that the requestor is the owner of the requested user-defined group, then the requester is granted all access privileges (that is, the delete access privilege) with respect to the requested user-defined group. Processing of flowchart 11002 is then complete. If it is determined that the requester is not the owner of the requested user-defined group, then step 11008 is performed.
In step 11008, the security module 402 determines if the requester has an explicit access right with respect to the requested user-defined group. The security module 402 performs step 11008 by referring to the group_user_xref table 1237 (
In step 11010, the security module 402 determines whether or not the requestor is in a user group that has an explicit access right with respect to the requested user-defined group. The security module 402 performs step 11010 by accessing the usr_grp_usr_xref table 1239 to identify all groups that has the requestor as a member. The security module 402 then accesses the grp_usr_grp_xref table 1240 to determine whether any of the user groups in which the requester is a member has an explicit access right with respect to the requested user-defined group. This is done by identifying a record in the grp_usr_grp_xref table 1240 where the group_id attribute is equal to the identifier of the requested user-defined group, and the user_group_id attribute is equal to an identifier of a user group in which the requestor is a member. If such a record exists, then the requester is given the explicit access right specified by the permission attribute in the record of the grp_usr_grp_xref table 1240.
Processing of flowchart 11002 is then complete. If such a record does not exist in the grp_usr_grp_xref table 1240, then step 11012 is performed.
In step 11012, the security module 402 accesses a record in the grp_usr_grp_xref table 1240 corresponding to a user group called World, if such a record is available. All users are considered to be a member of the user group World. The requester is then granted the access rights associated with the user group World (again, if such a World record is available). Referring to the example in
Some embodiments of the invention also include other levels of security. These levels can be in addition to, or in place of, one or more levels of security shown in
In an embodiment of the invention, the security module 402 preferably processes these security levels in the following order (other orderings of the security levels could also be used):
It is noted that the security databases 636 shown in
In order to extent the security methodology to the notes databases 640, it would only be necessary to modify the notes databases 640 to include an owner_user_id. No modifications to the security databases 636 would be necessary, as long as the group_id attribute in the security databases 636 could be overloaded to store the identifiers of notes. Alternatively, additional security tables could be added to the security databases 636.
Only select persons have the ability to view and/or modify the data in the security databases 636. Such persons must have a high security level, and are typically system administrators. The client security module 702 provides a user interface at the clients 304, 306 that enable persons with sufficient security to view and/or modify the data in the security databases 636.
Some security information may be obtained from the underlying operating system, such as user IDs and passwords, and perhaps even access privileges. This information is then loaded into the security databases 636.
Enterprise Server and Client Functional Modules
The analysis modules 416 in the enterprise server 314 and the corresponding client analysis module 716 in the clients 304, 306 are described in detail below.
For the most part, the analysis modules 416 perform functions in a patent-centric and a group-oriented manner. In other words, the analysis modules 416 perform functions on patent related information, with or without consideration of other information. Also, the analysis modules 416 perform functions on documents in groups.
Patent Mapping Module
The patent mapping module 1002 operates to identify all patents that are mapped to a product. As discussed above, each product (assembly, subassembly, part) of interest to the customer is represented by a node in a BOM. Each BOM node is represented by a BOM group. Each BOM group is represented by a record in the BOM table 1217 (
The operation of the patent mapping module 1002 is represented by a flowchart 8402 in
In step 8408, the patent mapping module 1002 identifies the patents contained in the BOM groups having the BOM_ids identified in step 8406. The patent mapping module 1002 performs step 8408 by searching in the BOM_patent_xref table 1218 for records having BOM_id attributes equal to the BOM_ids identified in step 8406.
In step 8410, the patent mapping module 1002 retrieves patent bibliographical information pertaining to the patents identified in step 8408. This is done by using the document_ids from the records of the BOM_patent_xref table 1218 identified in step 8408 as indexes into the patent bibliographic databases 604. This patent bibliographic information is transferred to the requesting client 304, 306.
In step 8412, the corresponding client analysis module 716 in the requesting client 304, 306 displays the received information.
The display format 6002 in
In some embodiments of the invention, the patent mapping module 1002 can also perform a document (as opposed to a patent) mapping function. This functionality is depicted in flowchart 8502 in
In step 8508, the patent mapping module 1002 identifies the documents that are in the groups corresponding to the group_ids identified in step 8506. The patent mapping module 1002 performs step 8508 by reference to the BOM_patent_xref table 1218. These identified documents may include patents and non-patent documents.
In step 8510, the patent mapping module 1002 extracts bibliographic information pertaining to the documents identified in step 8508 from the appropriate document bibliographic databases 602. This information is transferred to the requesting client 304, 306.
In step 8512, the client analysis module 716 in the requesting client 304, 306 displays the information using display formats similar to that shown in
Patent Citation Module
The patent citation module 1004 operates to identify, for a particular patent (called the source patent), the patents which were cited during the prosecution of the selected patent (these patents are called citing patents). This is called a backwards citation report, because its focus is on looking backwards from the perspective of the source patent.
The patent citation module 1004 also performs a forward citation function. In performing the forward patent citation function, the patent citation module 1004 identifies, for a source patent, the patents in which the source patent was cited. Again, these patents are called citing patents for reference purposes.
A flowchart 8602 in
In step 8606, the patent citation module 1004 receives information from the operator (at a client 304, 306 called the requesting client 304, 306) that identifies one or more BOM groups. In an embodiment of the invention, the information provided by the operator identifies one or more group names corresponding to one or more BOM groups. The patent citation module 1004 identifies the BOM_ids for the BOM groups corresponding to the BOM group names by conducting a search through the BOM table 1217 using the BOM group names (provided by the operator) as an index.
More generally, the patent citation module 1004 operates on any type of group, such as user-defined groups, inventor groups, corporate entity groups, etc. The operation of the patent citation module 1004 is discussed herein with reference to BOM groups for illustrative purposes only.
In step 8608, the patent citation module 1004 identifies the patents which are mapped to the BOM groups corresponding to the BOM_ids identified in step 8606. The patent citation module 1004 performs step 8608 by searching in the BOM_patent_xref table 1218 using the BOM_ids identified in step 8606 as indexes.
In step 8610, the patent citation module 1004 identifies the patents (called the citing patents) that are cited in the patents identified in step 8608 by reference to the PatentRef table 1208 (
Also in step 8610, patent bibliographic information is retrieved from the patent bibliographic databases 604 for each of the citing patents.
Also in step 8610, the patent citation module 1004 forwards the results of the above operations to the requesting client 304, 306.
In step 8612, the client analysis module 716 in the requesting client 304, 306, displays the data received from the patent citation module 1004 to the operator. The client analysis module 716 displays this data in a format selected by the operator.
For example, if the operator chooses to view the patent citation information organized by BOM group, then the display format illustrated in
The display format 6302 in
Referring again to step 8612, if the operator elects to display the patent citation information sorted by selected patent characteristics, such as owned/license, then the display format 6402 in
Referring again to step 8612, if the operator elects to display the patent citation information in conjunction with ownership information, then display format 6202 in
Referring again to step 8612 in
The patent citation module 1004 collects data for a multi-level patent citation report by repetitively performing the steps of flowchart 8602, which will be apparent to persons skilled in the relevant arts. The level of the report desired by the operator could be contained in the information that the patent citation module 1004 receives in step 8606.
The forward patent citation function performed by the patent citation module 1004 is depicted in a flowchart 8702 shown in
In step 8708, the patent citation module 1004 identifies the patents which are mapped to the BOM groups associated with the BOM_ids identified in step 8706. The patent citation module 1004 performs step 8708 by conducting a search in the BOM_patent_xref table 1218 using the BOM_ids identified in step 8706 as indexes.
In step 8710, the patent citation module 1004 determines the patents that cite the patents identified in step 8708. The patent citation module 1004 performs step 8710 by conducting a search through the PatentRef table 1208 using the document_ids corresponding to the citing patents identified in step 8708 as indexes. The patent citation module 1004 forwards the results of the above operation to the client analysis module 716 in the requesting client 304, 306.
In step 8712, the client analysis module 716 displays this information received from the patent citation module 1004 on the client display monitor 1122. The client analysis module 716 displays this information to the operator in any one of a number of display formats, examples of which are shown in
Patent Aging Module
The patent aging module 1006 operates to identify and analyze the remaining terms of patents that map to products, corporate entities, or inventors (that is, that are in BOM groups, corporate entity groups, or inventor groups that correspond to the products, corporate entities, or inventors). The patent aging module 1006 also operates to identify and analyze the remaining terms of patents that are in user-defined groups. The operation of the patent aging module 1006 is depicted in a flowchart 8802 shown in
In step 8806, the patent aging module 1006 receives from the operator at the requesting client 304, 306, information that identifies one or more groups. These can be user-defined groups or predefined groups, or any combination of such groups. In an embodiment of the invention, the patent aging module 1006 receives information from the operator that identifies group names that correspond to groups. The operator can identify such groups while located at the client 304, 306 by selecting one or more groups from the group hierarchy user interface (
In some embodiments, the information may also have to identify the group types (i.e., BOM group, corporate entity group, inventor group, user-defined group, etc.). The patent aging module 1006 identifies the appropriate group IDs of these groups by reference to the appropriate group tables (that is, the BOM table 1217 for BOM groups, the corporate_entity table 1230 for corporate entity groups, the validated_inventor table 1236 for inventor groups, the group_table database 1227 for user-defined groups, etc.).
In step 8808, the patent aging module 1006 identifies the patents which are contained in the groups corresponding to the group IDs identified in step 8806. The patent aging module 1006 performs step 8808 by searching through the appropriate patent xref tables, for example, the BOM_patent_xref table 1218, the group_document_xref table 1228, the corp_patent_xref table 1233, the validated_inventor table 1236, etc.
In step 8810, the patent aging module 1006 identifies the issue dates of the patents identified in step 8808 by reference to the patent table 1222 (
In step 8812, to the extent that the expiration dates of the identified patents were not loaded in the patent table 1222, the patent aging module 1006 calculates the expiration dates of the identified patents in accordance with the existing patent laws of the appropriate jurisdiction. The patent aging module 1006 does this by using the patent issue dates. The patent aging module 1006 then forwards the results of the above operation to the client analysis module 716 in the requesting client 304, 306.
The client analysis module 716 then displays this information received from the patent aging module 1006 in an operator selected format. Such display of the patent aging information is described in the following steps.
In step 8814, the client analysis module 716 determines whether the operator requested to display the patent aging information in a standard report format. If the operator wishes to display the patent aging information in a standard report format, then the client analysis module 716 uses the display formats shown in
The display format 6602 of
The display format 6702 shown in
In step 8818, the client analysis module 716 determines whether the operator wishes to display the patent information in a standard format in conjunction with ownership information. If the operator elects to display the patent aging information in a standard report in conjunction with ownership information, then example display format 6902 shown in
The example display format 6902 shown in
In step 8824, the patent aging module 1006 determines whether or not the operator wishes to view the patent aging information sorted by group. If the operator wishes to view the patent aging information sorted by group, then in step 8826 the patent aging information is displayed using an example format 6802 shown in
In step 8828, the patent aging module 1006 determines whether the operator wishes to view the patent aging information sorted by organization level. If the operator wishes to view the patent aging information sorted by organization level, then the patent aging information is displayed in step 8834 using an example format 7002 shown in
In the display format 7002 of
In step 8836, the patent aging module 1006 determines whether the operator wishes to view the patent aging information organized by BOM level. If the operator wishes to view the patent aging information organized by BOM level, then the client analysis module 716 displays the patent aging information in a display format similar to that shown in
Patent Clustering and Bracketing Module
The patent clustering/bracketing module 1008 in the enterprise server 314 operates to identify and graphically represent potential relationships between a source patent and citing patents, where the citing patents are either cited in the source patent, or cite the source patent. Accordingly, the patent bracketing/clustering module performs a backwards operation, where it operates to identify potential relationships between a source patent and citing patents which were cited during the prosecution of the source patent. Additionally, the patent bracketing/clustering module 1008 also performs a forward function, where it attempts to identify potential relationships between a source patent and citing patents in which the source patent was cited.
The operation of the patent clustering/bracketing module 1008 when performing its backwards operation is represented by a flowchart 8902 in
In step 8908, the patent clustering/bracketing module 1008 identifies patents (called citing patents) that are cited by the source patent. The patent clustering/bracketing module 1008 performs step 8908 by using the document_id identified in step 8906 as an index during a search of the PatentRef table 1208.
In step 8910, the patent clustering/bracketing module 1008 identifies the ownership of the source patent and ownership of the citing patents by reference to the assignee table 1201 and/or the core_patent_xref table 1233. The patent clustering/bracketing module 1008 forwards the results of the above operations to the client analysis module 716 in the requesting client 304,306.
In step 8912, the client analysis module 716 displays the information received from the patent clustering/bracketing module 1008 in the client display unit 1122. The client analysis module 716 displays this information using any one of a number of formats, such as the example formats shown in
In an embodiment, the display format 7102 in
In the display format 7102, links 7148 are used to represent the relationship between the source patent (represented by icon 7104) and the citing patents (represented by icons 7106, 7108 and 7110). In particular, the links 7148 indicate that the citing patterns were cited during the prosecution of the source patent 7104.
The icons 7106, 7108, 7110 corresponding to citing patents are filled with the same pattern 7150 of the icon 7104 corresponding to the source patent if the citing patents are owned by the same corporate entity as the source patent. In the example of
The example display format 7202 shown in
The patent clustering/bracketing module 1008 is capable of performing a multi-level, recursive patent bracketing/clustering function. The patent clustering/bracketing module 1008 performs such a function by performing steps 8908 and 8910 for each of the citing patents. This operation by the patent clustering/bracketing module 1008 can continue to any operator specified level of recursion. An example display format generated by the client analysis module 716 on the client display unit 1122 is shown in
The operation of the patent clustering/bracketing module 1008 when performing its forward operation is represented by a flowchart 9002 in
In step 9008, the patent clustering/bracketing module 1008 identifies patents (called citing patents) in which the source patent is cited. The patent clustering/bracketing module 1008 performs step 9008 by reference to the PatentRef table 1208.
In step 9010, the patent clustering/bracketing module 1008 identifies the ownership of the source patent and the citing patents by reference to the assignee table 1201 and/or the core_patent_xref table 1233. The patent clustering/bracketing module 1008 sends the information obtained by the above operation to the client analysis module 716 at the requesting client 304, 306.
In step 9012, the client analysis module 716 displays this information on the client display unit 1122 using any of a number of display formats, such as the display formats shown in
It is noted that the operation of the patent clustering/bracketing module 1008, in performing the backwards operation (
Financial Module
The financial modules 1010 in the enterprise server 314 perform patent-centric and group-oriented processing of the data in the financial databases 638. Examples of the functions performed by the financial modules 1010 include determining the research and design (R&D) expenditures on a product or product line basis, determining the R&D expenditures per inventor or per employee on a product or product line basis, determining net licensing revenue on a product or product line basis, determining the number of patents issued on a product or product line basis, determining patent maintenance fees on a product or product line basis, determining market share on a product or product line basis, determining the tax rate on a product or product line basis, determining marketing costs on a product or product line basis, determining selling costs on a product or product line basis, determining the number of outstanding shares (P/E) on a product or product line basis, determining revenue on a product or product line basis, determining cumulative product revenue on a product or product line basis, etc. The financial modules 1010 can also perform the above processing on a geographical region basis, or on a time basis.
Reference is made to the financial databases 1247 and 1248 shown in
As another example, the financial modules 1010 can determine the licensing revenue associated with any patent owned by the company. This is done by referencing the patent licensing table 1248 using the document_id of the operator-specified patent as an index to identify the record(s) in the patent licensing table 1248 corresponding to that operator-specified patent. Once the record is found, the financial modules 1010 can retrieve information on the licensee, licensor, and license revenue related to the license of the patent from the licensor to the licensee. It is noted that a given patent may have multiple entries in the patent licensing table 1248, corresponding to each licensor/licensee combination.
The financial modules 1010 transfer the information generated from the above-described operation to the client analysis module 716 in the requesting client 304, 306. The client analysis module 716 displays this information on the client display unit 1122, and enables the operator to manipulate the information.
Inventor Patent Count Module
The inventor patent count module 1012 in the enterprise server 314 operates to analyze patent inventor information to identify the top inventors for an operator-specified group. Top inventors are defined herein as being persons who most frequently are named as inventors on the patents in the group. The operation of the inventor patent count module is represented in the flowchart 9102 and
In step 9106, the inventor patent count module 1012 receives from the operator at the requesting client 304, 306 information that identifies one or more groups. These can be any types of groups, such as BOM groups, corporate entity groups, operator-defined groups, etc. In an embodiment of the invention, the information received from the user identifies the group names of groups. These groups are called the operator-specified groups for reference purposes. In some embodiments, this information may also identify the types of the groups (i.e., BOM group, corporate entity group, user-defined group, etc.).
The inventor patent count module 1012 identifies the group IDs of the operator-specified groups by using the group names as indexes in searches of the appropriate group table (that is, the BOM table 1217, the group_table database 1227, and the corporate_entity table 1230).
In step 9108, the inventor patent count module 1012 identifies patents that are contained in the operator-specified groups. The inventor patent count module 1012 performs step 9108 by accessing the appropriate cross-reference tables using the group keys (identified in step 9106) as indexes. Such cross-reference tables include the BOM_patent_xref table 1218, the group_document_xref table 1228, and the corp_patent_xref table 1233.
In step 9110, the inventor patent count module 1012 identifies the inventors of the patents identified in step 9108 by reference to the validated_inventor table 1236. The inventor patent count module 1012 accesses the validated_inventor table 1236 using the document_ids of the patents identified in step 9108 as indexes. The inventor patent count module 1012 processes the patent and inventorship information obtained as described above to determine, for each person, the number of patents (in the operator-specified group) in which the person is named as an inventor.
In step 9112, the inventor patent count module 1012 extracts additional pertinent information from the databases 316, such as each person's employment status from the employee table 1243, the relevance of the identified patents from the corp_patent_xref table 1233, and the corporate levels of the corporate entities that own the identified patents from the corporate_entity table 1230. The inventor patent count module 1012 forwards the information resulting from the above operation to the client analysis module 716 in the requesting client 304, 306.
In step 9114, the client analysis module 716 displays this data to the operator on the client display unit 1122. The client analysis module 716 displays the inventor patent count information in any of a number of display formats, such as display formats shown in
The sample displays in
The display format 7602 in
The example display format 7702 in
Inventor Employment Information Module
The inventor employment information module 1014 in the enterprise server 314 operates to obtain information on persons who are named as inventors in patents that map to operator-specified groups. The operation of the inventor employment information module 1014 is represented by a flowchart 9202 in
In step 9206, the inventor employment information module 1014 receives information from the operator at the requesting client 304, 306. This information identifies one or more groups, called operator-specified groups for reference purposes. Such groups may be BOM groups, user-defined groups, corporate entity groups, etc. In an embodiment of the invention, the information received from the operator identifies one or more group names that correspond to the operator-specified groups. The inventor employment information module 1014 identifies the group IDs of the operator-specified groups by reference to the appropriate group tables, such as the BOM table 1217, the corporate_entity table 1230, the group_table database 1227, etc. The inventor employment information module 1014 accesses these group tables using the group names as indexes.
In step 9208, the inventor employment information module 1014 identifies the patents which are contained in these operator-specified groups. These patents are called the identified patents for reference purposes.
The inventor employment information module 1014 performs step 9208 by accessing the appropriate cross-reference tables using the group IDs identified in step 9206. These cross-reference tables include the BOM_patent_xref table 1218, the group_document_xref table 1228, the corp_patent_xref table 1233, etc.
In step 9210, the inventor employment information module 1014 identifies the inventors of the identified patents (identified in step 9208) by reference to the validated_inventor table 1236. The inventor employment information module 1014 accesses the validated_inventor table 1236 using the document IDs for the identified patents identified in step 9208.
In step 9212, the inventor employment information module 1014 extracts from the databases 316 information about the inventors. Such information is extracted by the inventor employment information module 1014 from the person table 1242 and the employee table 1243.
In step 9214, the inventor employment information module 1014 extracts other information for display in reports, such as the names of the corporate entities who own or license the identified patents. Such information is retrieved from at least the corporate_entity table 1230. The inventor employment information module 1014 transfers the information obtained from the above processing to the client analysis module 716 at the requesting client 304, 306.
In step 9216, the client analysis module 716 displays this information on the client display unit 1122 in a variety of operator-selected display formats, such as the example display formats shown in
The display format 7802 in
The display format 8002 in
Exporting Patent Data Module
The exporting patent data module 1018 in the enterprise server 314 operates to copy data from the databases 316 to an operator-specified location. For example, the exporting patent data module 1018, pursuant to operator command, can export a subset of the patent database 614 to an operator-specified location. The operator could then utilize this data locally, separate from the enterprise server 314. Operation of the exporting patent data module 1018 is represented by flowchart 9402 in
In step 9406, the client analysis module 716 in the client 304, 306 enables the operator to select which of the patents in the patent database 614 to export. The operator can select such patents by group, or individually, or both by group and individually. The client analysis module 716 transfers this operator request to the exporting patent data module 1018 in the enterprise server 314.
In step 9408, the exporting patent data module 1018 causes the document storage and retrieval module 408 to retrieve information from the patent database 614 corresponding to the patents selected by the operator in step 9406. The enterprise server 314 transmits this information to the client 304, 306.
In step 9410, the client analysis module 716 copies the information retrieved from the enterprise server 314 to a operator-specified location.
Importing Patent Data Module
As discussed above, the exporting patent data module 1018 operates to copy a portion of the customer's patent repository (stored in the patent database 614) to a operator-specified location. The operator can then work locally with this patent information. Eventually, the operator may want to update the databases 316 in the enterprise server 314 with any updates made to this subset of the patent database 614.
The importing patent data module 1016 in the enterprise server 314 operates to perform this functionality. In particular, the importing patent data module 1016 imports to the databases 316 data that a operator has been working with locally, separate from the enterprise server 314. The operation of the importing patent data module 1016 is represented by a flowchart 9302 in
In step 9306, the client analysis module 716 in the client 304, 306 accesses patent information stored in an operator-specified location 9306 which is local to the client 304, 306. The client 304, 306 transfers this patent information to the enterprise server 314.
In step 9308, the importing patent data module 1016 receives this information from the client 304, 306 and loads the patent information into the databases 316, including the patent database 614 and the patent bibliographic databases 604.
Methodology Embodiments
The present invention can be used to perform many patent-centric and/or group-oriented tasks. These tasks would be of interest to business customers. These tasks include, but are not limited to:
The tasks listed above, and other tasks that would be useful to the business customer, can be performed by invoking the analysis modules 416, either individually or in combination. For example, some of the tasks mentioned above can be performed by invoking the patent mapping module 1002 alone. Others of the tasks listed above require, for example, the invocation of the patent mapping module 1002 in combination with one or more of the other analysis modules 416, such as the patent citation module 1004 or the patent aging module 1006.
The performance of some of the tasks mentioned above involve human intervention. Specifically, with some of the tasks, one or more of the analysis modules 416 are invoked. These analysis modules 416 automatically process data in the databases 316, and automatically prepare reports (generally called methodology reports) based on such processing. One or more human operators then analyze the reports to complete the tasks. The invention supports and assists the human operators in performing their functions by automatically analyzing data and running reports.
In some embodiments, the invention includes expert system(s) 1020 to automatically analyze and process the data in the reports that were automatically generated by the analysis modules 416. It is noted that the expert system 1020 is shown as being a part of the analysis modules 416 in
In these embodiments, the expert system 1020 either aids the human operators in performing the above-listed tasks, or completely replaces the human operators in analyzing the data that was automatically generated by the analysis modules 416. Such expert systems 1020 could be trained (using well known procedures) with the knowledge and experience of the human operators. The structure and operation of expert and rule based systems, and the training of such systems, are well known and are described in a number of publicly available documents, including (but not limited to) Charniak et al., Introduction to Artificial Intelligence, Addison Wesley, 1986, and Nils J. Nilsson, Principles of Artificial Intelligence, Morgan Kaufmann, Los Altos, Calif., 1980, which are incorporated herein by reference in their entireties. The manner in which to construct and train expert systems to automatically perform a part of or all of the processing described herein as being performed by human operators will be apparent to persons skilled in the relevant art(s).
Various patent-centric and group-oriented methodologies of the present invention are described below. These methodologies represent tasks that can be performed (either with or without human involvement) through use of the invention. These methodologies essentially involve two steps. In the first step, one or more analysis modules 416 are invoked for the purpose of automatically accessing and processing data contained in the databases 316, and for the purpose of automatically reporting on such processing (such reports are generally called methodology reports). In the second step, the reports generated by the analysis modules 416 are analyzed, and business-related actions, plans, and/or strategies are taken or developed based on the analysis. This second step may be performed by human operators, or may be automatically performed by expert systems (as described above), or may be performed by a combination of human operators and expert systems. In the following description of the methodologies, the second step is described as being performed by human operators. It should be understood, however, that the second step could alternatively be performed by expert systems, or by expert systems in combination with human operators.
The methodologies described below represent a sampling of the tasks that can be performed through use of the invention. The invention is adapted and intended to perform other patent-centric and group-oriented tasks, particularly tasks that can be implemented through mining and/or processing of the data in the databases 316. Accordingly, the following methodologies are described herein for purposes of illustration, and not limitation.
Patent Mapping and Mining
A corporate entity can utilize the present invention in order to perform a patent mapping and mining process. This process is an internally focused analysis where the impact of the corporate entity's patents (both owned and licensed) on the corporate entity is analyzed. The business impact of this process is to provide high financial leverage within the corporate entity. The patent mapping and mining process provides a tangible way of defining core (active) and non-core (non-active) patents and how they relate to the corporate entity's business. Short term financial results of the patent mapping and mining process can be found in licensing opportunities and non-renewal of inactive patents and licensed patents.
It is noted that the customer may, based on its own practices or needs, define the meaning of core and non-core. For example, core could correspond to patents being used by the customer, and non-core could correspond to patents not being used by the customer. Accordingly, the definition of core and non-core is implementation dependent.
A flowchart 10202 in
In step 10208, the operator identifies from the patent mapping reports the core and non-core patents that map to the BOM group corresponding to the operator-specified product. For example, in the example display of
In step 10210, the operator considers various business options with respect to the non-core patents. In particular, the operator considers whether the non-core patents should be licensed or sold. This determination may be based on whether the corporate entity is contemplating the introduction of future products having features that would be covered by the non-core patents.
The operator may also consider whether or not the non-core patents should be held in reserve as a shield against a possible allegation of infringement by a competitor. This issue may depend on whether the non-core patents cover technology which is used by competitors. The operator can run patent citation reports (performed by the patent citation module 1004) and/or patent clustering/bracketing reports (performed by the patent clustering/bracketing module 1008) to determine whether it appears that its competitors are active in the areas of technology covered by the non-core patents.
The operator could also consider whether patent maintenance fees should be paid on the non-core patents. This issue, like those discussed above, may depend on whether the corporate entity intends to use the technology covered by the non-core patents in future products, or whether or not the corporate entity's competitors are currently using the technology covered by the non-core patents. A decision to discontinue payment of maintenance fees on the non-core patents would result in an immediate monetary savings for the corporate entity.
Also, the operator could consider whether or not the corporate entity should continue to license the non-core patents. The issues involved with this determination are similar to those discussed above. If the corporate entity decides to discontinue the license of the non-core patents, then the corporate entity could realize an immediate cost savings.
Further, the operator could consider whether the technology covered by the non-core patents could be used in the development of new features or products for the corporate entity.
In the above, step 10210 is described as being performed by a single operator. In practice, the performance of step 10210 may require the involvement of many people with knowledge in many different fields and having different abilities (or expert systems with this knowledge and abilities).
The patent mapping and mining process as represented in flowchart 10202 is an iterative process, as represented by control arrow 10212. In other words, the patent mapping and mining process represented in flowchart 10202 could be performed repeatedly over time for the same product, or could be performed a number of times, each time for a different product.
Situation Assessment
A corporate entity could use the present invention to perform a situation assessment process. A situation assessment process focuses on the corporate entity's current business situation. The situation assessment process determines the strategic “playing field” of the corporate entity's business as it relates to its patents and products. By performing a situation assessment process or analysis, the corporate entity can begin to analyze its current market in the competitive situation in relation to its products and patents. The situation assessment analysis begins by running a number of methodology reports in order to better understand the corporate entity's competitive situation. These methodology reports provide a clear understanding of a number of patent related business metrics, including:
Based on the above patent related business metrics, the corporate entity can determine what strategic steps need to be implemented in relation to: merger and acquisitions, human resources (HR) retention programs, patent licensing programs, patent acquisition programs, product or division sale, appropriate tax strategies, etc.
A flowchart 10302 in
In step 10306, a competitive analysis process is performed to identify and analyze the positions of the corporate entity's competitors. In performing the competitive analysis process, the corporate entity examines the competitor's products per product line, examines competitor's patents via aging reports, profiles competitor's inventors, and determines whether competitors are potentially infringing the corporate entity's patents. Details of the competitive analysis process is described below.
In step 10308, patent clustering and bracketing are evaluated. In performing this evaluation, the corporate entity runs clustering and bracketing reports for future product protection, determines if product features have been adequately protected, determines if the corporate entity's present and future core technologies have been adequately protected by patents, etc. Details of the clustering and bracketing process are described below.
In step 10310, an inventor analysis is performed. In performing this inventor analysis, the corporate entity analyzes inventorship with respect to patents covering its core technology, analyzes cornpetitor's inventors, determines whether it should consider hiring the inventors of its competitors, determines whether its own employee retention program should be modified in any way, etc. Details of the inventor analysis are described below.
In step 10312, the corporate entity performs a financial analysis process using the present invention. In performing this financial analysis, the corporate entity evaluates a number of patent-centric and group-oriented business metrics, such as the R&D expenditures per product, the R&D expenditures per inventor for a product line, the net licensing revenue per product line, the patent budget for a product line, the patent maintenance fees associated with a product line, the market share of a product line, the tax rate of a product line, marketing costs of a product line, selling costs of a product line, allocated costs of a product line, product revenue over product costs, etc. Details of this financial analysis process are described below.
The situation assessment process is an iterative one, as represented by control arrow 10314 in the flowchart 10302. The steps of flowchart 10302 can be performed repeatedly, and in any order. Thus, the steps in
Competitive Analysis
In step 10406, an operator associated with the corporate entity (such as an employee or consultant of the corporate entity) located at a client 304, 306 issues a command to the patent citation module 1004 to run a patent citation report on the patents in a group specified by the operator. The operator may request that either a backwards and/or a forwards patent citation report be formed. The manner in which the patent citation module 1004 performs the patent citation process is described above. Examples of patent citation reports are shown in
In step 10408, the operator, by reference to the patent citation report, identifies the companies who are the current assignees of the citing patents. These companies may be potentially working in the same technological areas as the source patents since their patents either cited the source patents (in the case of forwards patent citation reports), or they were cited in the source patents (in the case of backwards patent citation reports). Accordingly, the assignees of the citing patents may potentially be competitors of the customer corporate entity (assuming, of course, that the assignees of the citing patents are not the same as the customer corporate entity). Accordingly, in step 10408, the operator, through analysis of the patent citation report, is able to identify potential competitors of the customer client entity with respect to the technological area of the operator-specified group. It is noted that these potential competitors may be infringing the corporate entity's patents (that is, the source patents). These potential competitors may also be interested in licensing the corporate entity's patents (the source patents). Further, the customer corporate entity may be interested in licensing or purchasing the patents listed as citing patents in the patent citation report.
In step 10410, the operator further analyzes the patent citation report to determine the potential strength of the competitors' positions in the technological areas relative to the source patents. For example, if a large number of the citing patents are assigned to a given competitor company, then that may indicate that the competitor company has a strong patent position with respect to the technological area of the associated source patent. An operator may conclude from this that the customer corporate entity should consider reducing its product line or even discontinuing the product line given the potential strengths of the competitor's patents in the area. Other options would be to sell the product line to the potential competitor, or modify the product line to avoid any potential patent infringement by the customer client entity of the competitor's patents.
In step 10412, the operator reviews the patent citation report to identify a competitor's potential future product direction. The operator performs step 10412 by noting the number of patents that a potential competitor has in an area, and also noting the filing and issue dates of those patents. This information may indicate the extent to which a potential competitor is interested in a technological area. For example, if a potential competitor has a large number of patents in an area, and those patents were filed or issued relatively recently, then that may be an indication that the potential competitor is preparing to move into or expand its presence in the area.
In step 10414, the operator issues a command that causes the patent aging module 1006 to run an aging report. The patent aging reports are run with respect to the citing patents (that is, the patents which are owned by potential competitors). The manner in which the patent aging module 1006 performs the patent aging function is described above. Examples of patent aging reports are shown in
In step 10416, the operator issues commands that cause the inventor patent count module 1012 and the inventor employment information module 1014 to run inventorship reports on the patents owned by the potential competitors. The manner in which the inventor patent count module 1012 and the inventor employment information module 1014 operate to run these inventorship reports are described above. Examples of inventor patent count reports are shown in
In step 10418, the operator analyzes inventor patent count reports to identify the top inventors of patents covering key technology. The operator analyzes the inventor employment information reports to determine if these key inventors are still with the competitors. If they are not, then the operator can consider whether the corporate entity should consider hiring the inventors. Also from the inventor employment information reports, the operator can determine if the top inventors were former employees of the customer corporate entity. If they were, then the operator can set in motion processes to insure that these inventors are complying with their former employment agreements with the customer corporate entity. Further from the inventor employment information reports, the operator can determine if the top inventors are still employed by the competitors. If they are, the operator can consider whether the corporate entity should consider hiring these top inventors.
The competitive analysis process is an iterative one, as indicated by control arrow 10420. The steps of flowchart 10402 can be performed repeatedly, and in any order. Therefore, the steps of flowchart 10402 are provided in
The above operation is described as being performed by a single operator. In practice, the above operation may require the involvement of many people with knowledge in many different fields and having different abilities (or expert systems with this knowledge and abilities).
Clustering and/or Bracketing
The clustering and/or bracketing process is illustrated in a flowchart 10502 in
In step 10508, the operator studies the patent clustering/bracketing reports to determine whether the customer client entity's product has been adequately protected by the customer corporate entity's patents. In other words, the operator reviews the clustering/bracketing report to determine whether or not clustering exists. An example of clustering is shown in
In step 10510, the operator reviews the patent clustering/bracketing reports to determine the extent to which others have patented the technology related to the patents in the BOM group associated with the operator-specified product. In other words, the operator in step 10510 analyzes the patent clustering/bracketing reports to determine whether full or partial bracketing exists. An example of full bracketing is shown in
Based on the above analysis, the operator evaluates whether these patents owned by others should be licensed, purchased, ignored, designed around, etc. To assist in performing this evaluation, the operator may run patent aging reports and/or inventorship reports on these patents owned by others. These reports will aid the operator in conducting the evaluation.
The clustering and/or bracketing process is an iterative one, as represented by control flow arrow 10512. The steps of the clustering and/or bracketing flowchart 10502 can be performed repeatedly for the same or different BOM groups, and can be performed in any order. Accordingly, the steps of the clustering and/or bracketing flowchart 10502 are presented in
The above operation is described as being performed by a single operator. In practice, the above operation may require the involvement of many people with knowledge in many different fields and having different abilities (or expert systems with this knowledge and abilities).
Inventor Analysis
The inventor analysis process is illustrated in the flowchart 10602 shown in
In step 10608, the operator identifies key or top inventors of the customer corporate entity's patents based on the inventorship reports.
In step 10610, the operator refers to the inventor employment information reports to identify whether these key inventors are still employed by the customer corporate entity. If they are still employed by the customer corporate entity, then the operator can initiate steps to ensure that the customer corporate entity retains them. If they are not still employed by the customer corporate entity, then the operator can initiate steps to ensure that these former employees are in compliance with their employment agreement with the customer corporate entity. Also, the operator can consider whether the customer corporate entity should consider rehiring them.
In step 10612, if the key inventors are still employed by the customer corporate entity, then the operator refers to the inventor employment information reports to determine whether the talents of these inventors are being most effectively utilized by the corporate entity. For example, if the inventors are no longer assigned to the department that developed the operator specified product, then the corporate entity may want to transfer them back to that department so that they can further enhance the product.
The inventor analysis process is an iterative one, as represented by control flow arrow 10614. The steps of the inventor analysis flowchart 10602 can be performed repeatedly or in any order for any given BOM group. Accordingly, the steps in the inventor analysis flowchart 10602 are provided for purposes of illustration, not limitation.
The above operation is described as being performed by a single operator. In practice, the above operation may require the involvement of many people with knowledge in many different fields and having different abilities (or expert systems with this knowledge and abilities).
Financial Analysis
The financial analysis process is represented by a flowchart 10702 in
In step 10706, an operator associated with the customer corporate entity at a client 304, 306 issues instructions to the financial modules 1010 in the enterprise server 314. These instructions command the financial modules 1010 to calculate the research and development dollars per patent in a BOM group. The BOM group is specified by the operator.
The financial modules 1010 perform this function by first determining the number of customer patents that map to the BOM group (by reference to the BOM_patent_xref table 1218). Next, the financial modules 1010 determine the R&D dollars for a project (by reference to the BOM financial table 1247). Then, the financial modules 1010 divide the R&D dollars by the number of patents.
In step 10710, the financial modules 1010 calculate the licensing dollars resulting from a project by identifying the customer patents that map to the product (by reference to the BOM_patent_xref table 1218), and determining the licensing revenue generated by those patents (by reference to the patent licensing table 1248).
Operators analyze the data obtained from the above processing to evaluate the customer's business from a patent/financial point of view.
It is noted that the steps of flowchart 10702 are provided for purposes of illustration, and not limitation. Additional steps directed to other financial operations that process the data in databases 316 can be added to the flowchart 10702. Additionally, the financial analysis process of
Strategic Planning
The customer corporate entity can utilize the present invention to perform a strategic planning process. The overall goal of the strategic planning process is to develop a future product direction and/or future business strategy that cannot be easily duplicated by competitors. This future product direction and/or business strategy leverages the customer corporate entity's patent protection and technology ownership. The strategic planning process may result in considerable business process re-engineering based on future business analysis.
An example of the strategic planning process is represented by flowchart 10802 shown in
In step 10808, an operator associated with the customer corporate entity maps the customer corporate entity's patents (both owned and licensed) to the new future product. The operator also maps competitors' patents to the new future product.
In step 10810, the operator issues instructions to run patent mapping reports pertaining to the BOM group of the proposed future product. The operator also issues reports to run clustering/bracketing reports for the proposed future product. The patent mapping module 1002 and the patent clustering/bracketing module 1008 in the enterprise server 314 automatically runs these reports in the manner discussed above.
From these methodology reports, the operator is able to determine if the proposed future product is adequately protected by the patents which the customer corporate entity currently owns or licenses. If the proposed future product is not adequately covered by the customer corporate entity's current patents, then the customer corporate entity may consider whether or not it should prepare and file additional patent applications to further cover the proposed future product.
Also from these methodology reports, the operator can determine if the features of the proposed future product are covered by the patents owned by others. If some features of the proposed future product are covered by patents owned by others, then the customer corporate entity can consider whether it should license the patents, purchase the patents, modify the proposed future product in order to design around the patents, ignore the patents, abandon plans for the proposed future product, etc.
The above operation is described as being performed by a single operator. In practice, the above operation may require the involvement of many people with knowledge in many different fields and having different abilities (or expert systems with this knowledge and abilities).
The above analysis and decision making process performed by the customer corporate entity may involve running additional methodology reports, such as patent citation reports, patent aging reports, inventorship reports, and financial reports.
It is noted that the steps of the strategic planning flowchart 10802 shown in
The strategic planning process is an iterative one, as represented by control flow arrow 10812. The steps of the strategic planning flowchart 10802 can be performed repeatedly, and in any order. Additional steps can be added to represent the additional strategic planning functions mentioned above. Accordingly, the steps of the strategic planning flowchart 10802 shown in
Integrated Methodology Embodiment
The functions and methodologies described above can be performed individually or in any combination to achieve the objectives of the customer corporate entity. For example, at times, the customer may wish to run individual reports to examine a particular aspect of its business, such as the remaining patent terms of patents that map to a particular product line. At other times, the customer may wish to run a combination of reports to analyze a larger part of its business, such as a strategic planning analysis to develop a patent strategy for a proposed future product. At still other times, the customer may wish to perform an extensive and integrated examination of its business from a patent-centric and group-oriented point of view.
An example of such an integrated methodology is represented by a flowchart 10902 in
It should be understood that the patent mapping and mining process, the situation assessment process, and the strategic planning process can be performed individually or in any combination with any other functions described herein according to the needs, requirements, and characteristics of the particular corporate entity being served.
User Interface
Referring to
Other user interface display formats, display windows, and display screens supported and provided by the user interface module 11404 in the client 304, 306 shall now be described. It should be understood that the present invention is intended and adapted to support and provide display formats, display windows, and display screens other than those shown and described herein. In fact, the present invention can support and provide any display format, display window, or display screen useful for enabling operators to view and interact with the data and the data processing described herein. Accordingly, the display screens, display windows, and the display formats shown in the figures and discussed herein are provided solely for purposes of illustration, and not limitation.
User Login
In order to establish a session with the Enterprise server 314, the operator enters his user name in a login field 11608, and enters his password into a password field 11610. If the operator wishes to connect with the Enterprise server 314 via a specific server, then the operator enters the address of this server in a server field 11604. If the customer's network is configured to use “fire walls” with proxy servers, the operator enters information about the proxy server(s) in the proxy field 11606.
Console
A group hierarchy is depicted in the group pane 11704. In the example of
Referring again to
The operator can restructure the group hierarchy displayed in the Group pane 11704 using well-known drag-and-dop operations. The operator can add any of the documents displayed in the Docunent pane 11706 to any group in the group hierarchy displayed in the Group pane 11704 by using well-known drag-and-drop operations.
The notes pane 11708 displays a list of the notes associated with either a group selected in the group pane 11704, or a patent or document selected in the document pane 11706. The list of notes in the notes pane 11708 is presented in a tabular or “spreadsheet” format. The list of notes in the notes pane 11708 includes information that identifies the type of the note (that is, either a patent/document note or a group note), and the title of the note. All other bibliographic or other information relating to notes can be viewed by manipulating the horizontal scroll bar 11722 in order to sideways scroll in the notes pane 11708.
As indicated above,
According to the present invention, the operator can view the text and/or image of any patent or other document listed in the document pane 11706 by selecting the patent or document using well know item selection techniques. An operator can select a patent, for example, by double clicking on the patent number, or by using any other type of well known operator navigation procedure.
Suppose that the operator selects, from the document pane 11706, U.S. Pat. No. 5,029,013. In accordance with this selection, the user interface module 11404 displays the text of the selected patent in a text window 12302, (see
Console Tool Bars
Referring again to
The Group toolbar 11724 is illustrated in greater detail in
Referring to
An operator presses a Show Group Properties button 13508 in the Group toolbar 11724 in order to view and edit the properties of the group selected in the Group pane 11704. An operator presses an Import Data button 13510 in order to import data from an external data file into the repository 612, 602. An operator presses an Export Data button 13512 in order to export data from the repository 612, 602 into a user specified location, such as an external file.
An operator presses a Refresh Data button 13514 in the Group toolbar 11724 in order to refresh the listing of all data in the Group pane 11704, the Document pane 11706, and the Notes pane 11708. Refresh is needed to synchronize multi-user access to the database. Such data refresh is performed by reading from the databases 316. An operator presses a Reports button 13516 in order to execute methodology reports.
Referring now to
An operator selects a Skim Images button 13606 in the Document toolbar 111726 in order to perform a Skim Images function. In accordance with the Skim Images function, the first image page of each document listed in the Document window 11706 is displayed in succession by repeatedly clicking the Show Images button 13606.
An operator presses an Add Patent button 13608 in order to add a new patent or document to the list of patents displayed in the Document pane 11706 (that is, to add a new patent or document to the group selected in the Group pane 11704). An operator presses a delete patent button 13610 in order to delete the patent or document selected in the Document pane 11706 from the group selected in the Group pane 11704 (this does not delete the document from the repository).
Referring now to
An operator presses a Delete Selected Group Or Patent Note button 13706 in order to delete the note selected in the Notes window 11708. An operator presses the Sort Notes By Type button 13708 in order to sort the list of notes depicted in the Notes window 11708 by their type (that is, by group or by patent). An operator presses a Sort Notes By Title button 13710 in order to sort the list of notes depicted in the Notes window 11708 according to their titles.
Various ones of these functions that are invoked by pressing buttons in the Group toolbar 11724, the Document toolbar 11726, and the note toolbar 11728 are further described in the following sections.
Creating a New Group
An operator presses the Create New Group button 13506 in the Group toolbar 11724 in order to create a new group in the group hierarchy displayed in the Group pane 11704. The new group is created as a child group of the group selected in the Group pane 11704.
Consider, for example, the Example console 11902 illustrated in
Editing Group Properties
An operator presses the Show Group Properties button 13508 in the Group toolbar 11724 in order to view and edit the properties of the group selected in the Group pane 11704. Group Viewing And Editing windows 12602 are shown in
It is noted that access to the General Group Properties tab 12606 and the Group Properties Security tab 12604 is limited to operators having sufficiently high access levels with respect to the selected group.
Shared Groups
In an embodiment of the invention, shared groups are graphically depicted in the console using a stacked folders icon 15302 (
Invoking Patent-Centric and Group-Oriented Analysis Functions
An operator presses the Run Reports button 13516 in the Group toolbar 11724 in order to execute methodology reports. These methodology reports are performed by the Analysis modules 416 in the Enterprise server 316 (see
Upon the pressing of the Run Report button 13516, a Report Generator screen 12802 is displayed (
The operator can enter information into the other fields of the report generator screen 12802 in order to define and/or limit the scope of the function that is to be performed. In particular, the operator can specify the number of levels in the group hierarchy to consider in performing the function (specified in field 12804) by entering the appropriate level information into a field 12810. If, for example, the operator enters the value 1 into field 12810, then only the group selected in the Group pane 11704 is considered in performing the selected function. If, instead, the operator enters the value 2 into field 12810, then both the selected group and its immediate child group (one level down from the selected group) are considered in performing the selected function. In the example of
The operator can limit the patents which are to be considered in performing the selected function by patent expiration dates by entering information into fields 12812. In the example of
The operator can also limit the patents which are to be considered in performing the selected function according to the remaining patent terms of the patents. This information is entered into fields 12814. In the example of
Once the operator has defined the function that is to be performed by entering information into the report generator screen 12802, the operator presses the Execute button 12808 in order to execute the selected function.
Adding Documents to a Group
The operator presses an Add a Patent/Document button 13608 in the Document toolbar 11726 in order to add a patent or some other document to the group selected in the Group window 11704. Upon pressing the Add a Patent/Document button 13608, a new Document window 13006 is displayed (
Adding a Document Note
The operator presses the Add a New Patent/Document Note button 13704 in the note toolbar 11728 in order to add a new note to a document. Consider the example shown in
The Note window 12514 includes location information that identifies the location of the text in the document to which the note is linked. This location information is represented by reference numbers 12516 and 12544. The location information 12516 indicates that the note is attached to a portion of U.S. Pat. No. 5,029,013 starting at line 6. The location information 12544 indicates that this portion in U.S. Pat. No. 5,029,013 represents bibliographical information portion (indicated by the symbol B1).
In some embodiments, it is not necessary for the operator to press the Add a New Patent/Document Note button 13704. Instead, the new note is automatically created once the selected pen 12508 is used to highlight the title 12510. Other aspects of the present invention relating to creating and manipulating notes are described in U.S. Pat. No. 5,623,681, U.S. Pat. No. 5,623,679, pending U.S. application Ser. No. 08/341,129, and pending U.S. application Ser. No. 08/590,082, incorporated herein by reference in their entireties.
The Notes window 12514 includes an Unlink button 12534 which, when pressed, operates to unlink the note from the document. The note is then called a floating note. The Notes window 12514 also includes a Contract button 12536 which operates to reduce the area on the display screen which is used to display notes. The Notes window 12514 also includes an Expand button 12538 which operates to increase the amount of space on the display screen which is used to display notes.
As described above, the Notes pane 11708 in the console 12502 lists the notes associated with the selected document in the Document pane 11706, or the selected group in the Group pane 11704. In the example of
Adding a Group Note
The operator presses the Add a New Group Note button 13702 in the Note toolbar 11728 in order to create a new group note for the group selected in the group pane 11704. Upon selection of the Add a New Group Note button 13702, a New Group window 13406 is displayed (
The Notes pane 11708 lists the notes corresponding to the document selected in the Document pane 11706, or the group selected in the Group pane 11704. In the example of
Searching
The operator presses the Search button 13502 in the Group toolbar 11724 in order to perform a search of the data in the databases 316. Upon pressing the Search button 13502, a search screen 12102 is displayed (
A list of the documents identified by operation of the search is displayed in the Document pane 11706. The operator can add these documents to any other group in the group hierarchy (displayed in the Group pane 11704) using well-known drag-and-drop operations. Alternatively, the operator can convert the new group 12204 to a permanent group (pre-defined or user-defined), and maintain these documents in the permanent group 12204 entitled “New Search”.
In an embodiment of the invention, a temporary group is automatically deleted at some time in the future, such as after a timeout or at the conclusion of the session with the enterprise server 314, if not converted to a permanent group before then.
Web Searching
The operation of a web client 304 with regard to searching for data in the databases 316 according to an embodiment of the invention is described in this section. It should be understood, however, that the search capabilities described herein are applicable to all clients 304,306 in various embodiments of the invention. That is, in some embodiments of the invention, all clients 304,306 include at least the capabilities described herein.
In the following, searching at the web clients 304 is described in the context of patent searching. However, the following description applies to searching for all types of documents.
An operator at a web client 304 presses the Search button 13502 in the Group toolbar 11724 in order to access the search capabilities of the present invention. Upon pressing the Search button 13502, a Patent Search screen or window 14002 is displayed (
The operator enters information into the fields of the Patent Search screen 14002 in order to define the parameters of the search. For example, the operator can define the search in terms of patent number, title, inventor, assignee, class, user-defined key words, date of issue, abstract, and/or full patent text by entering search terms into the corresponding fields of the Patent Search screen 140. Also, the operator can select which fields to display in the search results by appropriate selection of the Check Box fields 14004. Further, the operator can order the display or printing of the search results according to a number of factors, such as patent number, assignee, expiration date, number of years remaining in patent term, or score. The score corresponds to the number of hits of the search parameters in a patent. The operator orders the search results by appropriate selection in the Order field 14006. The operator can also specify the number of patents in the search results to display per screen by entering the appropriate information in field 14008.
In the example of
Referring to
The information for each patent also includes an indication of whether or not the patent is in the local repository (i.e., stored in the patent database 614). This is indicated in the column called “In Repository?” In the example of
The operator can view additional information on any of the patents listed in the Search Results screens 14102, 14202, 14302 by selecting the patent (for example, by double-clicking on the patent number in the list of patents). The extent of the information that is displayed for a selected patent depends on whether or not the patent is stored in the patent database 614. If the patent is not stored in the patent database, then patent bibliographic information (retrieved from the patent bibliographic databases 604) is displayed for the selected patent. An example display of such patent bibliographic information for a selected patent is shown in
The display screen 14402 includes patent bibliographic information 14404 on U.S. Pat. No. 5,183,404. Also, in accordance with an embodiment of the invention, the display screen 14402 also includes text corresponding to the abstract 14406 of U.S. Pat. No. 5,183,404. In other words, for patents not stored in the patent database 614, the system of the present invention maintains both patent bibliographic information and the abstract. Such patent bibliographic information and abstract are stored in the patent bibliographic databases 604. (For example, the abstract can be stored in an Abstract database that is keyed to the primary patent table 1222 according to document_ID.)
The operator can elect to display the text of the selected patent by pressing the Text button 14504. In the example of
The operator presses an Image button 14506 to display the images of the selected patent. An example of such a display is shown in
The selected patent as displayed in the display screens of
If the operator wishes to view the bibliography of the selected patent, for example, then the operator presses the Bibliography button 14512. The operator presses the Cross Reference To Related Applications button 14516 to view cross-reference information of the selected patent. The operator presses the Brief Description Of Drawings button 14518 to view the brief description of the drawings section of the selected patent. The operator presses the Detailed Description Of The Invention button 14520 to view the detailed description section of the selected patent. The operator presses the Claims button 14522 to view the claims section of the selected patent.
Preferably, the invention implements such internal hyperlinking using a linked list of nodes, wherein each node corresponds to a section of the selected patent. Specifically, each node includes a link to the corresponding section of the selected patent. When the operator selects one of the Internal Linking buttons 14524, the invention traverses through the linked list corresponding to the selected patent until it finds the node corresponding to the section that the operator wishes to view. The invention then follows the link stored in the node to access the data corresponding to the section that the operator wishes to view. Additional details pertaining to this linked list is described in U.S. Pat. No. 5,623,679, incorporated by reference herein.
The Patent Information display screens in
The selected patent may also be linked to references to other documents that are contained in the selected patent. For example, the selected patent as displayed in
The selected patent may also include links to citations of other publications, as represented by reference number 14530, and citations to related applications, as represented by reference number 14532.
For reference purposes, citations to documents that are linked to the actual documents are called linked citations.
The operator can view the document corresponding to any linked citation by selecting that linked citation. For example,
Referring again to
A citation in a document being displayed is not a linked citation if the corresponding document is not represented in the document bibliographic databases 602 or the document databases 612. Accordingly, in the example of
In other words, whether a citation to a document is linked to the document depends on whether or not the databases 316 store information on that document. If the databases 316 store information on the document, then the citation to the document is linked to the document (i.e., the citation is a linked citation). Otherwise, the citation to the document is not linked to the document (i.e., the citation is not a linked citation).
According to an embodiment of the invention, hyperlinking information is stored in a table in the databases 316. This hyperlinking table stores information pertaining to the links between documents. For a particular document, the hyperlinking table stores information that identifies the links between that particular document and other documents (these other documents being cited in the particular document). More particularly, each entry of this table corresponds to a linked citation, and stores information identifying both ends of the link of the linked citation. Specifically, each entry stores information that identifies a first document and the linked portion in the first document, and also includes information that identifies the object to which the linked portion in the first document is linked. This object may be a second document, for example. In the example of
In an alternate embodiment, when a document is displayed, the document is automatically analyzed to identify and generate a list of all citations to other documents contained in the document. This list is then compared to the information stored in the databases 316. If the databases 316 have stored therein information on a document in the list, then the citation to that document becomes a linked citation. Otherwise, the citation to the document does not become a linked citation.
The invention also allows a document to have user-defined links. In operation, an operator would select a portion of a document being displayed, and then link that portion to some object. That object may be internal to the document (that is, linking a portion of a patent to another portion of the same patent), or external to the document (for example, linking a portion of a patent to another document or to a website). One portion corresponding to a user-defined link can completely or partially overlap with another portion corresponding to a user-defined link.
For example, as represented in
Preferably, information pertaining to user-defined links is stored in a user-defined linking table in the databases 316. Each entry of this table corresponds to a user-defined link, and stores information identifying both ends of the link. Specifically, each entry stores information that identifies the document and the linked portion in the document, and also includes information that identifies the object to which the linked portion in the document is linked.
In practice, when the operator selects a linked citation, the client 304,306 generates a request to the Enterprise server 314 to retrieve information pertaining to the document corresponding to that linked citation (assuming that such information is not already stored in the cache within the client 304,306). In the case of web clients 304, patent-centric URL commands are sent to the Enterprise server 314 (see
Referring again to the Search Results screens in
Still referring to
Referring now to
A Skip Images display screen 14802 is shown in
With regard to the web client 304, pressing the Skip Images button 14704 causes the web browser 808 to generate a patent-centric URL command. This patent-centric URL command represents a request to the Enterprise server 314 to retrieve the first image page of the associated patent (that is, the next patent in the list 14706). Enterprise server 314 responds by returning raw data corresponding to this image page. The translator 804 in the web server 310 converts this raw data to HTML data. The HTML data is sent to the web client 304. The browser 808 in the web client 304 receives this HTML data, and renders the HTML data in order to display the first image page of the patent, as shown by way of example in
An example patent-centric URL command is displayed in field 14804 of the Skim Images display 14802.
The Skim Images feature of the present invention is analogous to a manual search of patents in the shoes of the USPTO Search Room. During such manual searches, practitioners often quickly thumb through the patents in a patent shoe by looking at the first pages of the patents. The Skim Images feature of the present invention enables an operator to quickly electronically scan over the first image pages of the patents in the list 14706, thereby emulating a manual search through the shoes in the PTO Search Room. It should be noted that the images displayed to the user are preferably HTML data rendered by the browser 808.
Importing Data
The operator presses the Import Data button 13510 in the Group toolbar 11724 in order to import data from an external location into the repository 612,602. Upon pressing the Import Data button 13510, an Import Data window 13102 is displayed (
Exporting Data
The operator presses the Export Data button 13512 in the Group toolbar 11724 in order to export data from the repository 612,602 to an external location, such as an external file. Upon pressing the Export Data button 13512, an Export window 13202 is displayed (
Data Presenting and Processing Hyperbolic Trees
As described above, hyperbolic trees can be used for processing and presenting data in the context of the patent citation function. In the following, example uses of hyperbolic trees for data presentation and processing in the context of the present invention are described. First, the hyperbolic tree mechanism is generally described. Next, various functions of the present invention that optionally use hyperbolic trees for data presentation and processing are described.
General Description of Hyperbolic Trees
A hyperbolic tree or hyperbolic browser is a well known “focus+context” technique for visualizing and manipulating large hierarchies, such as trees. A hyperbolic browser assigns more display space to a portion of the tree while still embedding it in the context of the entire tree. The essence of this scheme is to lay out the tree in a uniform way on a hyperbolic plane and map this plane onto a circular display region. Thus, hyperbolic trees support a smooth blending between focus and context, as well as continuous redirection of the focus. Well known procedures exist for manipulating the focus using pointer clicks as well as interactive dragging, and for smoothly animating transitions across such manipulation.
A hyperbolic browser initially displays a tree with its root at the center, but the display can be smoothly transformed to bring other nodes into focus. This is shown in the example of
Additional portions of the hyperbolic tree 17701 can be expanded and displayed in the window 17702 (that is, focus can be redirected to those portions) by traversing to the desired portions in the hyperbolic tree 17701. An operator traverses the hyperbolic tree 17701 using a pointer device, such as a mouse. For example, suppose that the operator wishes to focus the hyperbolic tree 17701 at node 17708. In this case, the operator moves the mouse (represented by icon 17703) and clicks proximate to node 17708. In response, the portion of the hyperbolic tree 17701 proximate to node 17708 is expanded and displayed. This is shown in
With hyperbolic trees, the amount of space available to a node falls off as a continuous function of its distance in the tree from the point in the center. Thus, the context always includes several generations of parents, siblings, and children, making it easier for the user to explore the hierarchy without getting lost.
Hyperbolic trees exploit well known hyperbolic geometry. Hyperbolic geometry is described in a number of publicly available documents, such as Coxeter, Non-Euclidean Geometry, University of Toronto Press, 1965, and Moise, Elemental Geometry from an Advanced Standpoint, Addison-Wesley, 1974. As is well known, the essence of hyperbolic trees is to lay out the hierarchy, such as a tree, on a hyperbolic plane and map this plane onto a circular display region. The hyperbolic plane is a non-Euclidean geometry in which parallel lines diverge away from each other. This leads to the convenient property that the circumference of a circle on the hyperbolic plane grows exponentially with its radius, which means that exponentially more space is available with increasing distance. Thus, trees—which tend to expand exponentially with depth—can be laid out in hyperbolic space in a uniform way, so that the distance (as measured in the hyperbolic geometry) between parents, children, and siblings is approximately the same everywhere in the hierarchy.
While the hyperbolic plane is a mathematical object, it can be mapped in a natural way onto the unit disk, which provides a means for displaying it on an ordinary (Euclidean) display. This mapping displays portions of the plane near the origin using more space than other portions of the plane. Very remote parts of the hyperbolic plane get minuscule amounts of space near the edge of the disk. Translating the tree on the hyperbolic plane provides a mechanism for controlling which portion of the structure receives the most space without compromising the illusion of viewing the entire hyperbolic plane.
Much of the above general description of hyperbolic trees and browsers was taken or adapted from Lamping et al., “A Focus+Context Technique Based on Hyperbolic Geometry for Visualizing Large Hierarchies,” CHI '95 Proceedings Papers, Xerox Palo Alto Research Center, 1995 (including the Appendix entitled “Implementing Hyperbolic Geometry”), incorporated herein by reference in its entirety. In addition to conventional sources, the Lamping et al. document and its Appendix are available on the Internet at www.acm.org/sigchi/chi95/Electronic/documnts/papers/jl_bdy.htm. Hyperbolic trees and browsers are described in a number of additional publicly available documents, such as Hyperbolic Tree Toolkit Application: Programmer's Reference, Version 1.0, Xerox Corporation and InXight Software, Inc., January 1997, which is incorporated herein by reference in its entirety.
Each node in a hyperbolic tree, when being displayed, includes one parent node and zero or more child nodes. The one exception is the root node, which does not have a parent node, but which has zero or more child nodes. For example, node 17706 in
This description of the hyperbolic tree is a general description of the “tree” construct. That is, a tree includes a root node and multiple non-root nodes each having a single parent node and zero or more child nodes.
A graph, such as a directed acyclic graph (DAG), differs from a tree. Like a tree, a DAG includes a root node that does not have any parent nodes, and that has zero or more child nodes. (Generally, a DAG is not limited to a single root, or parentless, node. However, DAGs when used with the present invention either include a single root node, or are made to include a single root node. This is done by creating an artificial root node, and adding to it as children all of the previously parentless nodes.)
Also like a tree, each non-root node in a DAG includes zero or more child nodes. However, unlike trees, each non-root node in a DAG includes one or more parent nodes. An example DAG 17902 is shown in
Trees and graphs (such as DAGs) are well known and are described in many publicly available documents, such as Aho et al., Data Structures and Algorithms, ISBN 0-201-00023-7, 1983.
Many of the modules of the present invention generate data which is optimally represented as a graph, such as a DAG. For example, patent citation data is best represented as a DAG since any given patent can be cited in multiple patents, and can also itself cite multiple patents. Also, claim charts are optimally represented as DAGs since any given dependent claim can depend from multiple parent claims (that is, a multiple dependent claim).
At the same time, the data generated by modules of the present invention can often be effectively represented through use of hyperbolic trees. This is the case, for example, with multi-level patent citation data (as described above). Accordingly, various modules of the present invention enable the operator to display data using hyperbolic trees.
Preferably, the present invention represents data, where appropriate, as a graph, such as a DAG. When an operator elects to display the data using a hyperbolic tree format, the invention does so.
Some well known hyperbolic browser implementations are capable of generating and displaying hyperbolic trees directly from DAGs. These hyperbolic browser implementations conceptually operate by mapping the root node in the DAG to the root node in the hyperbolic tree. Also, non-root nodes in DAG that have a single parent node are directly mapped to corresponding nodes in the hyperbolic tree. These hyperbolic browser implementations conceptually map non-root nodes in the DAG that have multiple parent nodes to multiple nodes in the hyperbolic tree, wherein each of these tree nodes are linked to a single parent node in the hyperbolic tree. This is shown in
When operating with such hyperbolic browser implementations, the invention passes the DAG to the hyperbolic browser. The hyperbolic browser generates and displays a hyperbolic tree directly from the DAG.
Other well known hyperbolic browser implementations are not capable of generating and displaying hyperbolic trees directly from DAGs. When working with such hyperbolic browser implementations, the invention translates or maps the DAG to a tree format. This mapping process is illustrated in
The invention then passes the tree 17904 to the hyperbolic browser. The hyperbolic browser generates and displays a hyperbolic tree from the tree 17904. The process of generating and populating a hyperbolic tree from the tree 17904 will be apparent to persons skilled in the relevant art(s).
In some embodiments, the invention performs this mapping process even when working with a DAG-enabled hyperbolic browser. This may be done for performance reasons. For example, performance may be enhanced by having the invention perform the mapping function, as opposed to the hyperbolic browser performing the mapping function.
Since the invention generates a graph or DAG 17902 to represent data, where appropriate, it is possible to easily display the information in DAG 17902 using other display mechanisms that are DAG-capable or DAG-enabled, or more generally graph-capable or graph-enabled. The scope and spirit of the present invention is intended and adapted to operate with DAG-capable or DAG-enabled display mechanisms, or more generally graph-capable or graph-enabled mechanisms, including those presently existing and those that will be developed in the future.
Various functions of the present invention that optionally use hyperbolic trees to present and process data are described in the following sections.
Patent Citation Tree
According to an embodiment of the present invention, the patent citation module 1004 performs a patent citation tree function (in addition to the functions described above).
As discussed below, the nodes in the patent citation tree 16404 are preferably color coded or otherwise emphasized (by modifying the display properties of the nodes) according to patent ownership or assignee, or some other criteria, such as time (i.e., issue date) or user-selection (this is described below). As a result, the patent citation tree 16404 is very useful when performing clustering analysis and/or bracketing analysis. In fact, the patent clustering/bracketing module 1008 in some embodiments is capable of using hyperbolic trees to represent its data output. Accordingly, the description below of the patent citation module 1004 when performing the patent citation tree function using hyperbolic trees is also applicable to the patent clustering/bracketing module 1008. Additionally, other modules of the invention are capable of presenting their data output using hyperbolic trees. Accordingly, the following description is also applicable to these other modules of the invention.
Patent Citation Tree (Network Client)
The patent citation tree function when being performed by a network client 306 interacting with the enterprise server 314 shall now be described with reference to a flowchart 15702 in
In step 15706, the operator selects a patent from a listing of patents displayed in document pane 16104. The patent selected shall be referred to as the '484 patent. The operator selects the '484 patent using a pointing device, such as a mouse (represented by icon 16110). An indication of this selection of the '484 patent is received by the network client 306.
In step 15708, while the '484 patent is selected, the operator issues a command to perform a citation analysis function. The operator may issue this command by right-clicking (while the mouse is positioned over the '484 patent in the document pane 16104) to bring up a context-sensitive pop-up menu 16202, a portion of which is shown in
In step 15710, the network client 306 presents a dialogue box 16302 (
In step 15712, the network client 306 interacts with the enterprise server 314 as necessary to retrieve information from the databases 316 pertinent to the citation analysis tree function specified by the operator. The manner in which step 15712 is performed is illustrated in a flowchart shown in
In step 15804, the network client 306 sends a request to the enterprise server 314. The network client 306 generates the request in accordance with the enterprise server API discussed above. Accordingly, the request generated by the network client 306 conforms to the enterprise server API. Preferably, the request is made using the ReqAnalysis Citation command (described above). Alternatively, the request can be made using a properly formed ReqFunction command (described above). The request specifies: (1) either a backward citation search or a forward citation search (as indicated by the user in dialogue box 16302); (2) the '484 patent; and (3) the number of levels (as specified by the operator in dialogue box 16302).
In step 15806, the enterprise server 314 processes the request. In particular, the enterprise server 314 accesses the patent table 1222 (
For patent citations of one level, the search is then complete. However, for patent citations of greater than one level, the enterprise server 314 must repeatedly accesses the Patent RefTable 1208. For example, consider abackward patent citation function of two levels. Suppose that the above described operation identified that patents P1 and P2 are cited in the '484 patent. This is the first level. The second level refers to the patents that are cited in patents P1 and P2. Accordingly, the enterprise server 314 must perform the above described operations for each of patents P1 and P2, to identify the patents cited in P1 and P2.
In practice, to enhance performance, a single search command is issued for each level of the citation function. For example, a first search command is issued to identify all patents that cite a patent P1 (for a forward citation function). This is the first level. Suppose that patents P2, P3, and P4 are identified by this first search command. In the second level, a second search command is issued to identify all patents that cite patents P2, P3, and P4. In a similar manner, a single search command is issued for each of the other levels of the citation function being performed.
Further in step 15806, the enterprise server 314 processes the information retrieved from the databases 316 and generates two tables. In particular, the enterprise server 314 generates a parent/child table. An example patent/child Table 18002 is shown in
The enterprise server 314 also creates a patent bibliographic information table. An example patent bibliographic information Table 18202 is shown in
In other embodiments, the client 306 issues two commands, a first command to retrieve the parent/child information, and a second command to retrieve bibliographic information on the parents and children. In such embodiments, the ReqAnalysis Citation function may be configured to optionally return only the parent/child information. Other enterprise server API commands (described above) could be used to retrieve patent bibliographic information.
In step 15808, the enterprise server 314 transfers the patent/child table 18002 and the patent bibliographic information table 18202 to the requesting network client.
Referring again to
In step 15904, the network client 306 initializes the citation analysis DAG 18102. The citation analysis DAG 18102 includes a root node representing the selected patent (that is, the '484 patent), and nodes for each of the other patents (i.e., patents that cite the '484 patent, or that are cited in the '484 patent). In the example of
In step 15906, the network client 306 selects one of the nodes in the citation analysis DAG 18102 for analysis.
In step 15908, the network client 306 generates a link for each parent/child relationship for the selected node, where the selected node is the child. Such parent/child relationship information is obtained from the parent/child Table 18002. For example, assume that node 7 is the selected node. As indicated in the parent/child Table 18002, node 7 (or, equivalently, patent 7) is the child of patent 5 and patent 6. Accordingly, in step 15908, the network client 306 creates a link to node 7 in both node 5 and node 6. The information representing these links is preferably stored in the parent nodes of the selected node to allow navigation of the tree from the root down.
In step 15910, the network client 306 determines whether there are any additional nodes in the citation analysis DAG 18102 that have not yet been processed. If there are such nodes, then control returns to step 15906. Otherwise, the citation analysis DAG 18102 is complete, and control returns to flowchart 15702 in
Referring again to
In step 16004, the network client 306 selects a node of the citation analysis DAG 18102 (it is noted that the root node 18104 corresponding to the '484 patent is not subject to selection). Also, the network client 306 initializes the tree 18302 (an example of which is shown in
In step 16008, the network client 306 selects one of the parents of the selected node from the citation analysis DAG 18102. It is noted that, by definition, the selected node must have at least one parent Assume, for example, that node 7 was selected in step 16004, and node 5 was selected in step 16008.
In step 16010, the network client 306 generates a new node in the tree 18302 being constructed. Specifically, the network client 306 generates node 7A in tree 18302.
In step 16012, the network client generates a link that represents the parent/child relationship between nodes 7A and 5. The information corresponding to this link is stored in tree node 5 of tree 18302.
In step 16014, the network client 306 determines whether the selected node (that is, node 7 in the citation analysis DAG 18102) has any additional parents in the DAG 18102 that have not yet been processed. In the case of the current example, node 7 has a parent, node 6, that has not yet been processed. Accordingly, control returns to step 16008 to process the parent node 6 with respect to the selected node 7. If, in step 16014, the selected node does not have any additional parents in the DAG 18102 to process, then control flows to step 16016.
In step 16016, the network client 306 determines whether there are additional nodes in the citation analysis DAG 18102 to process. If there are additional nodes to process, then control returns to step 16004. Otherwise, construction of tree 18302 is complete, and control returns to flowchart 15702 in
Referring again to
As discussed above, in some embodiments, the invention generates a hyperbolic tree directly from the DAG generated in step 15714. Whether this is possible depends on the capabilities of the hyperbolic browser being used in the client 306, and potentially other issues, such as performance issues. In these embodiments of the invention where the hyperbolic tree is generated directly from the DAG, it is not necessary to perform the above described functions of step 15716.
In step 15718 the network client 306 displays the hyperbolic tree generated in step 15716. An example patent citation hyperbolic tree 16404 corresponding to the '484 patent is shown in
As indicated above, the nodes of the patent citation tree 16404 may be color coded or otherwise emphasized according to some criteria. Examples of such criterions are described below, although the invention is not limited to these examples. The operation of step 15718 in performing this function is represented by a flowchart shown in
In step 17604, based on user command, the network client 306 color codes or otherwise emphasizes and displays the nodes in the patent citation tree 16404 according to ownership and/or assignee (or some other criteria specified by the operator). For example, the nodes corresponding to patents owned by company A may be color coded red, whereas the nodes corresponding to patents owned by company B may be color coded blue. Alternatively, the nodes corresponding to patents owned or licensed by the customer corporate entity may be color coded purple, whereas the nodes owned by any other corporate entity are color coded black.
It is noted that other means for highlighting or emphasizing the nodes in the patent citation tree 16404 (other than color coding) can be used. In fact, any of the display properties of the nodes can be adjusted to reflect the criteria of interest. Such display properties include uppercase, lowercase, typefaces, fonts, underlining, bold, italics, type size, etc.
The enterprise server 314 retrieves ownership and/or assignee information (upon receiving a command from the network client 306 requesting such information) from the assignee table 1201 (
In one embodiment, the assignment information in the assignee Table 1201 reflects any original assignment information on the front page of patents. In some embodiments, the assignee Table 1201 is periodically modified to reflect updated assignment information as recorded in the U.S. Patent Office or other national Patent Offices (in the case of non-U.S. patents).
In other embodiments, such updated assignment information is stored in a separate table (not shown), called the current_assignee table. The original assignment information in the assignee table 1201 is not changed.
In these other embodiments, according to the present invention, the operator can instruct the network client 306 to update the display of the patent citation tree 16404 to reflect such current assignment information using the information in the current_assignee table.
Accordingly, in step 17606, the network client 306 receives a command from the operator to update the patent citation tree 16404 with the current assignee information in the current_assignee table.
In step 17608, the network client 306 sends a request to the enterprise server 314 for updated assignment information. This request, which is in conformance with the enterprise server API, lists the patents represented in the patent citation tree 16404. In accordance with this request, the enterprise server 314 accesses the current_assignee table for any updated assignment information regarding the listed patents. It is noted that not all patents may have updated assignment information. The enterprise server 314 transfers this information back to the requesting network client 306.
In step 17610, the network client 306 adjusts the display properties (such as the color coding) of the nodes in the patent citation tree 16404 to reflect any new assignment information as received from the enterprise server 314. According to an embodiment of the invention, the network client 306 allows the operator to switch back and forth between the original assignment information and the updated assignment information. In other words, upon appropriate operator command, the network client 306 toggles between displaying the patent citation tree 16404 according to the assignment information stored in the assignee Table 1201, and displaying the patent citation tree 16404 according to the updated assignee information in the current_assignee table.
Nodes can also be color coded according to other criteria as selected by the operator. For example, in step 17604, based on user command, the network client 306 color codes or otherwise emphasizes and displays the nodes in the patent citation tree 16404 according to issue date. For example, patents that issued in 1984-1986 are color coded blue, patents that issued in 1986-1988 are color coded red, patents that issued in 1988-1990 are color coded yellow, etc. In a similar manner, the nodes can be color coded according to other time-based criteria, such as filing date, priority date, length of pendency, effective filing date, invention date, critical date, on-sale date, public disclosure date, public use date, etc. Such information is either retrieved from the databases 316, calculated based on information retrieved from the databases 316, or entered by operators. Information entered by an operator on a patent (such as the invention date) is preferably stored in the node that is associated with the patent. Such information is, upon receipt of appropriate user command, referred to when displaying and emphasizing the node.
Operators can also specify the time increment (1984-1986 or 1984-1988, for example), the beginning date to view, the ending date to view, etc.
The invention also allows operators to enter their own user-defined criteria. For example, an operator can specify that patents P1 and P3 should be color coded blue, patents P10 and P21 should be color coded red, etc. Such specification by the operator may be based on information or analysis conducted by the operator. For example, the operator may have previously determined that patents P1 and P3 are unenforceable, and patents P10 and P21 contain claims that are infringed.
In an embodiment, the operator right clicks over a node to display a context sensitive menu. Via this menu, the operator can specify user-defined criteria for displaying the node (i.e., that the node should be color coded blue, or the node should be color coded as an unenforceable patent, where the color for unenforceable patents is defined elsewhere). The operator has the option of entering text that describes the meaning of his criteria, such as “Blue: Patents that are infringed.” This text is displayed in the legend (described below).
Preferably, nodes can be emphasized using any combination of operator-selected criterions. This is done by using different display properties to represent different criterions. For example, color could be used to represent ownership, font could be used to represent issue date, underlining could be used to represent enforceable/unenforceable, etc.
According to an embodiment of the invention, a legend is displayed next to the patent citation tree 16404. This legend specifies the meaning for the colors or other display properties used to highlight the nodes of the patent citation tree 16404. For example, the legend may indicate that blue is for patents owned by IBM, or is for patents issued in 1994-1997, or is for patents indicated by the operator as being infringed.
The present invention enables operators to interact with the data in the patent citation tree 16404. For example, operators can elect to view information regarding any of the patents represented in the patent citation tree 16404. Such operation is represented by steps 15720, 15722, and 15724.
In step 15720, the operator selects one of the patents represented in the patent citation tree 16404. In the example of
In step 15722, the network client 306 retrieves information pertaining to the selected '168 patent.
In step 15724, at a minimum, the network client 306 displays the Abstract and bibliographic information on the '168 patent. This information was preferably transferred to the network client 306 in the patent bibliographic information table 18202 (
If the selected patent (that is, the '168 patent) is in the local repository, then the network client 306 in step 15722 interacts with the enterprise server 314 to download the patent text and/or the patent image of the '168 patent. The network client 306 then displays the patent text and/or patent image as described above (see, for example,
As indicated above, the operator can elect to color code or otherwise adjust the display properties of the nodes in the patent citation tree 16404 according to various criteria. Such criteria includes assignee and ownership information, as described above. Another criteria is patent aging. Specifically, an operator can elect to adjust the display properties of the nodes in the patent citation tree 16404 according to the age of the patents relative to the base patent.
In the example of
Alternatively, gray scales can be used to reflect the age of the patents relative to the base '484 patent. For example, the closer the issue date of a patent is to the issue date of the '484 patent, the darker the gray used, and the farther away the issue date of a patent is to the issue date of the '484 patent, the lighter the gray used.
Alternatively, patent aging can be visualized by displaying in the patent citation tree the root plus any patent that issued within a year of the root (or any other time increment specified by the operator). The tree then grows upon receipt of user command to include patents that issued later. For example, upon receipt of user command, the tree grows to additionally include patents that issued within two years of the root, then three years, four years, five years, etc.
Patent aging visualizations (described here and in other places of this application) are valuable because they represent when patent-related activity occurred with respect to a given technology.
Patent Citation Tree (Web Client)
The operation of the patent citation tree function when performed by a web client 304 interacting with the enterprise server 314 via the web server 310 (
In step 16606, the operator at the web client 304 defines a search to be performed by entering search criteria into a patent search window, such as patent search widow 14002 shown in
In step 16610, the operator selects one of the patents listed in the search results window 14102. In step 16612, the web client 304 interacts with the enterprise server 314 via the web server 310 to retrieve information pertaining to the selected patent, and to display such information (such processing is described above). Preferably, such information is displayed in windows, such as those shown in
In step 16614, the operator at the web client 304 issues a command to perform a patent citation analysis of the patent being displayed. For example, suppose that in step 16612, information regarding an 830 patent was retrieved and displayed in a window 14602 shown in
In step 16616, the web client 304 presents a dialog box 16302 (
In step 16618, the web client 304 interacts with the enterprise server 314 via the web server 310 to retrieve information from the databases 316 pertinent to the citation analysis tree function specified by the operator. The manner in which step 16618 is performed is illustrated in a flowchart shown in
In step 16704, the browser 808 in the web client 304 generates and sends a request to the web server 310 (see
In step 16706, the web server 310 receives the request from the browser 808. The translator 804 in the web server 310 translates the request to a new request that is in conformance with the enterprise server API. This translation function is described above. The web server 310 sends the translated request to the enterprise server 314. In effect, the web server 310 is playing the role of the network client 306.
In step 16708, the enterprise server 314 processes the request. In particular, the enterprise server 314 access the patent table 12222 (
The enterprise server 314 processes the information retrieved from the databases 316 and generates two tables, the parent child table 18002 (
In step 16710, the enterprise server 314 transmits the parent/child table 18002 and the patent bibliographic information table 18202 to the web server 310.
In step 16712, the translator 804 in the web server 310 translates, as necessary, the information received from the enterprise server 314, and forwards the translated information to the web client 304. The translator 804 translates the information from the enterprise server 314 to a format that is compatible with the capabilities and plug-ins associated with the browser 808. This operation shall be further described with reference to
As shown in
The translator 804 in step 16712 translates the information received from the enterprise server 314 to a format that is useable by the hyperbolic tree module 18602. Accordingly, the operation of the translator 804 in this respect is specific to the particular functions and capabilities of the hyperbolic tree module 18602 being used in the web client 304. The browser 808 receives this translated information from the web server 310, and then forwards the translated information to the hyperbolic tree module 18602 for processing. As described below, the hyperbolic tree module 18602 modifies and formats this information from the browser 808, as necessary, and then displays and processes the patent citation hyperbolic tree.
Referring again to
In step 16622, the hyperbolic tree module 18602 maps the citation analysis DAG to a tree where necessary (as described above), and then generates a hyperbolic tree from this tree. The operation of the hyperbolic tree module 18602 when performing step 16622 is similar to the operation of the network client 306 when performing step 15716.
In some embodiments, at least parts of steps 16620 and 16622 are performed by the translator 804 in the web server 310. In particular, the translator 804 generates a citation analysis DAG from the information received from the enterprise server 314, and maps the citation analysis DAG to a tree. The translator 804 may also generate a hyperbolic tree from the tree. The translator 804 forwards the results of its processing (i.e., the translated information referred to above) to the browser 808.
As discussed above, in some embodiments, the invention generates a hyperbolic tree directly from the DAG generated in step 16620. Whether this is possible depends on the capabilities of the hyperbolic tree module 18602 in the web client 304, and potentially other issues, such as performance issues. In these embodiments of the invention where the hyperbolic tree is generated directly from the DAG, it is not necessary to perform the above described functions of step 16622.
In step 16624, the hyperbolic tree module 18602 displays the patent citation information to the operator in a hyperbolic tree format. In other words, in step 16624, the hyperbolic tree module 18602 displays the hyperbolic tree generated in step 16622. The operation of the hyperbolic tree module 18602 when performing step 16624 is similar to the operation of the network client 306 when performing step 15718, wherein at the web client 304, the patent citation tree 16404 is displayed in a window similar to the window 16412 shown in
In step 16626, the operator at the web client 304 selects one of the patents represented in the patent citation tree 16404. Step 16626 is similar to step 15720 (
In step 16628, the web client 304 retrieves information on the patent selected in step 16626. Step 16628 is similar to step 15722 (
In step 16630, the web client 304 displays the retrieved patent information. Step 16630 is similar to step 15724 (
Preferably, the web client 304, when displaying the patent citation tree 16404, color codes or otherwise emphasizes the nodes of the patent citation tree 16404 according to some user selected criteria, such as ownership, assignee, relative age, issue date, filing date, user-defined criteria, etc., as described above.
Additional Patent Citation Visualizations
The present invention includes the capability to display patent citation data in additional formats. For example,
Note that display format 17402 in
Patent Claims Tree
According to an embodiment of the present invention, the analysis modules 416 in the enterprise server 314 include a patent claim tree module 1022 (
The nodes in the patent claims tree 17101 can be color coded or otherwise emphasized (by modifying some display property) according to various criteria, including user-defined criteria. For example, when performing an infringement analysis, the operator can elect to color code claims that are believed to be infringed using one color, and claims that are not believed to be infringed using another color. When conducting a validity analysis, the operator can elect to color code claims that are believed to be valid using one color, and claims that are believed to be invalid using a different color. As discussed below, nodes can also be color coded or emphasized according to whether they correspond to patents or claims, or whether they correspond to independent or dependent claims. Also, as with the patent citation tree (described above), operators can color code according to operator-defined criteria. Other criterions for color coding the claims will be apparent to persons skilled in the relevant art(s).
The patent claims tree function, when performed by either a network client 306 or a web client 304, shall now be described with reference to a flowchart 16802 shown in
In step 16806, the operator selects a patent using any of the mechanisms described herein, such as selecting a patent from a listing of patents displayed in the document pane 16104 of the console 16102 (
In step 16808, information pertaining to the selected patent is retrieved from the databases 316 (as necessary) and displayed using any of the display formats described herein (see, for example,
In step 16810, the operator issues a command to display a patent claims tree for the patent being displayed. The operator may issue this command using any of the mechanisms described herein, such as by selecting a command from the menu bar, selecting a command from a pop-up window, selecting the command from a toolbar, etc.
In step 16812, the client 304/306 retrieves (as necessary) and analyzes the text of the claims section of the patent in order to identify claim dependencies (since it is necessary to analyze the claims, the patent claims tree function according to one embodiment of the invention is only available for those patents in the local repository). The dependency relationship between claims is identified by parsing the claim text of the patent and identifying claim dependency language contained therein (particularly in the claim preambles), such as “the apparatus of claim 1,” “the method of claim 1,” “the method according to claims 3 or 4,” “the system as in one of claims 4-7,” “a product produced according to the method of claim 1,” “a system, comprising,” etc. The dependency between claims is derived by inspection and analysis of these phrases in the preambles of the claims.
In step 16814, the client 304/306 generates a claims dependency DAG. For example,
In step 16904, the client 304/306 initializes the claims dependency DAG 18402. This initial DAG 18402 includes a root node representing the '011 patent, and a node for each claim in the '011 patent.
In step 16906, the client 304/306 selects one of the nodes of the DAG 18402 (or, equivalently, the client 304/306 selects one of the claims of the '011 patent).
In step 16908, if the selected claim is an independent claim, then the client 304/306 creates a link from the root node to the selected node. For example, if claim 1 is the selected claim, then the client 304/306 creates a link between node 18406 to the root node 18408. Information representative of the link is stored in the parent of the selected claim. For example, information representing the link between node 18406 and the root node 18408 is stored in root node 18408.
If the selected claim is a dependent claim, then in step 16908 the client 304/306 creates a link between the selected node and each node (called parent nodes) corresponding to a claim from which the selected claim depends. Information representing these links is stored in the parent nodes. For example, assume that node 18404 corresponding to claim 10 was selected in step 16906. Claim 10 depends from claims 1 and 9, the parent nodes of claim 10. Accordingly, in step 16908, the client 304/306 creates a link from node 18404 to node 18406 and node 18410. The link information is stored in parent nodes 18406 and 18410.
In step 16910, the client 304/306 determines whether there are additional claims in the '011 patent to process. If there are additional claims to process, then control returns to step 16906. Otherwise, construction of the claims dependency DAG 18402 is complete, and control returns to flowchart 16802.
Referring again to
In step 17004, the claims dependency tree 18502 is initialized to include the root node 18504 corresponding to patent '011. Also, the client 304/306 selects a node from the claims dependency DAG 18402 for processing. Preferably, the root node 18408 is not subject to selection (since a corresponding root node 18504 in the claims dependency tree 18502 has already been created). Preferably, nodes in the claims dependency DAG 18402 are selected in ascending order of their corresponding claims. For example, the node corresponding to claim 1 is selected first. The nodes corresponding to claims 2, 3, 4, etc., are then selected. In this manner, it is assured that, in the claims dependency tree 18502, the tree nodes corresponding to a dependent claim's parent claims will exist before the dependent claim is processed.
In step 17008, the client 304/306 selects one of the parents of the selected node. By definition, each node (other than the root node) in the claims dependency DAG 18402 includes at least one parent.
In step 17010, the client 304/306 creates a new node in the claims dependency tree 18502. This new tree node corresponds to the selected node of the claims dependency DAG 18402. Any claim information (such as the text of the claim) is optionally stored in this new tree node.
In step 17012, in the claims dependency tree 18502, the client 304/306 generates a link between the node corresponding to the selected parent, and the new tree node. Information for this link is stored in the selected parent node. For example, assume in step 17004 that node 18404 corresponding to claim 10 was selected, and in step 17008 claim 1 (parent to claim 10) was selected. In step 17012, a link is generated between node 18404A (corresponding to claim 10) and node 18510 (corresponding to claim 1) in the claims dependency tree 18502. The link information is preferably stored in node 18510.
In step 17014, the client 304/306 determines whether the selected node has any additional parents in the claims dependency DAG 18402 that has not yet been processed. If the selected node in the claims dependency DAG 18402 has additional parents, then control returns to step 17008 to process another parent. Otherwise, step 17016 is performed.
In step 17016, the client 304/306 determines whether there are additional nodes in the claims dependency DAG 18402 to process. If there are additional nodes to process, then control returns to step 17004. Otherwise, construction of the claims dependency tree 18502 is complete.
Referring again to
As discussed above, in some embodiments, the invention generates a hyperbolic tree directly from the DAG generated in step 16814. Whether this is possible depends on the capabilities of the hyperbolic browser being used in the client 304/306, and potentially other issues, such as performance issues. In these embodiments of the invention where the hyperbolic tree is generated directly from the DAG, it is not necessary to perform the above described functions of step 16816.
In step 16818, the client 304/306 displays the patent claims tree 17101 generated in step 16816. As indicated above, an example patent claims tree 17101 is shown in
In displaying the patent claims hyperbolic tree 17101 in step 16818, the nodes of the patent claims tree 17101 may be color coded or otherwise emphasized (by modifying display properties) according to a number of criteria, such as node type and/or sub-type. For example, patent nodes may be color coded a first color whereas claim nodes may be color coded a second color. Nodes corresponding to independent claims may be color coded a third color, and nodes corresponding to dependent claims may be color coded a four color. As described above, nodes can also be color coded according to user-defined criteria and user-provided information, such as claims that are being infringed, claims that are invalid, etc.
The present invention enables operators to interact with the data displayed in the patent claims tree 17101. For example, operators can elect to view the text of claims of any of the claims represented in the patent claims tree 17101. Such operation is represented by steps 16820 and 16822.
In step 16820, the operator selects one of the patents in the patent claims tree 17101 using any of the selection mechanisms described above.
In step 16822, the client 304/306 retrieves information on the selected claim, such as the text of the selected claim, and displays the claim text. The invention includes a number of formats for displaying the claim text. For example,
Such user interaction may be based on the node type and subtype. For example, if the user selects a patent node, such as node 17104, then the patent would be displayed (see
Licensing Module
As shown in
Customers use the licensing module 18702 to manage their intellectual property (IP) assets for maximal value through the creative use of licensing. The licensing module 18702 provides the tools a licensor needs to manage its licensing effectively through tracking a variety of objects, including but not limited to out-licenses (i.e., licenses where the corporate entity is the licensor), in-licenses (i.e., licenses where the corporate entity is the licensee), licensing parties (i.e., any parties involved with a license agreement, such as the licensee(s), the licensor(s), license agents, license organizations, attorneys, etc.), royalty statements, royalty payments, etc.
Customers also use the licensing system 18702 to better understand how they are making strategic use of their IP assets and to audit the licensees' contribution to the value of those assets.
As shown in
As shown in
According to some embodiments of the invention, the enterprise server 314 is herein also sometimes referred to as the Intellectual Property Asset Manager™ (IPAM™) server 314.
The database architecture associated with the licensing module 18702 includes a number of databases. As noted above, the standalone embodiment of the licensing module 18702 (shown in
The IPAM-integrated embodiment of the licensing module 18702 (shown in
In an embodiment, the licensing module 18702 is implemented as a two-tier client/server model. In an alternate embodiment, the licensing module 18702 is implemented as a three-tier model using standard middleware technology such as CORBA or COM along with technologies compatible with them, including the appropriate security manager for the application server middleware layer. The invention is not limited to these embodiments. The architecture preferably provides a thin-client C++ component, a secure application domain server, and a secure database server (such as a SQL Server), linking the latter two components with ODBC for maximal portability. The user interface and object model are tightly integrated and use well known component technologies such as ActiveX and DAO. In an embodiment, security relies on defining SQL Server database users with passwords and appropriate privileges on the database objects.
An example thread of operation of the licensing module 18702 shall now be generally described. At initial set up of the licensing module 18702, and periodically thereafter (or as the circumstances dictate), a License Administrator and a System Administrator must perform various set up tasks, such as entering territories, fields of use, and currency conversion intervals.
After initial set up, the customer enters IP business related information, such as but not limited to existing license agreements, new license agreements, and/or related objects, such as but not limited to assets, asset packages, contacts, compensation terms, and so on. Specifically, in an embodiment, the Data Entry Clerk enters assets, and the License Administrator creates asset packages to package assets for licensing. The Data Entry Clerk enters contacts by entering organizations, people, and contact methods. Then the Data Entry Clerk enters the license information. At that point, the License Administrator takes over to modify the license agreement with more complex data that requires an understanding of licensing.
As data grows, the License Administrator begins querying the system interactively in response to questions and issues that arise. He or she will also start generating reports. At some point, an auditor or other interested party will also query and generate reports. The License Administrator then may need to do some maintenance on the agreements, accompanied by occasional maintenance by the IPAM Administrator on objects that require Administrator privileges to remove.
As time goes on, licensees submit royalty statements and payments. The Data Entry Clerk enters these. The License Administrator then allocates the payments to expected revenue and to royalty statement details. This linking enables the Licensing module 18702 to generate meaningful revenue reports.
More generally, the licensing module 18702 enables users to manage, track, interact with, process, analyze, etc., intellectual property (IP) related transactions. In a preferred embodiment, such IP related transactions include the licensing of IP assets, and the management, tracking, interaction with, processing, analysis, etc., of such licensing activities using license agreements, asset packages, royalty statements, payments, etc. However, the invention is not limited to this embodiment. Instead, the invention is intended and adapted to cover the management, tracking, interaction with, processing, analysis, etc., of IP related transactions using any object, vehicles, data, etc., in accordance with the scope and spirit of the functions described herein.
The Licensing module 18702 includes a number of features, including but not limited to the following:
The licensing module 18702 is described in greater detail in the following sections.
User Roles
Generally, the licensing module 18702 involves a number of user roles, including but not limited to the following. The invention is not limited to these functions being performed by the people specified below. In other embodiments, other people in other user roles can perform the following functions.
Generally, the System and Database Administrators have full access to everything in the system. The other users have access granted to them by owners of asset packages or those with write access to security classifications. The different roles above do not imply any particular security access; each user has whatever access they are granted by the Administrator or other users.
Architecture
There are three general functions of the Licensing module 18702: data entry, data exploration, and reports. Underneath the user interface, there is an object model that implements all the different kinds of licensing objects that Licensing module 18702 needs to support data entry, to provide exploration of the database, and to permit generation of effective reports. Licensing module 18702 preferably connects to a SQL Server database server 18740 through ODBC 18738 to provide persistent storage of its data and to support third-party report definitions.
User Interface
The user interface preferably includes the following components.
Licensing System User Interface Module
The licensing system user interface module 18701 is the primary user interface for the licensing related functions of the licensing system 18702 described herein. The licensing system user interface module 18701 interacts with users via the windows and dialogs described herein. Preferably, the licensing system user interface module 18701 is written in Visual C++ and MFC (Microsoft Foundation classes, a well known class library for Visual C++), although the invention is not limited to this implementation.
Licensing System Administrator User Interface Module
The licensing system administrator user interface module 18704 is the user interface to the licensing related administrative functions described herein. The licensing system administrator user interface 18704 is preferably written in Visual C++ and MFC, although the invention is not limited to this implementation.
Data Entry
In an embodiment, operation of the licensing module 18702 is based on license agreements. (The invention is not limited to this embodiment. Specifically, in other embodiments, the licensing module 18702 is based on other IP related transactions, such as assignment agreements, technology transfer agreements, security interests, or any other agreement involving a transaction that includes or relates to an IP asset.)
Generally, license agreements are completely nonstandard in text format, but customers need to track specific, standard information about the agreement: its terms, its duration, its parties, the payments and statements customers receive, etc. They need to explore how their IP assets are generating revenue. They need to be able to license IP assets including patents, trademarks, copyrights, know how, trade secrets, other licenses, etc. Customers need to package multiple assets for licensing through a single license. They need to report on different aspects of their license portfolio. They need to search the document text to identify agreements that they can use as templates for further agreements.
Consequently, the Licensing module 18702 enables users to enter structured data about license agreements, royalty statements, payments (this information is preferably stored in the licensing database 18804). The licensing module 18702 also enables users to enter data about companies and people to which IP assets can be licensed (this information is preferably stored in the licensing database 18804). The licensing module 18702 also enables users to enter IP assets (patents and other types) (this information is preferably stored in the licensing database 18804). This part of the licensing system 18702 can link to the IPAM Server 314 for access to the IP assets and groups it supports. The licensing module 18702 also adds to those IP assets as necessary to round out the range of asset types that customers wish to license: trademarks, copyrights, and trade secrets as well as patents. Generally, information on non-patent assets are stored in the licensing database 18804 or the core database 18808. Information on patent assets are stored in the IPAM database 316 when working in the IPAM integrated mode (
Licensing Reports
Licensing reports are an important feature of the Licensing module 18702. Customers use reports generated by the licensing module 18702 to track the revenue due from licenses, to compare that expected revenue to the actual revenue received, and to evaluate the success of license management in their business units. The invention also supports other reports.
Preferably, the report generation module 18706 is responsible for generating the reports requested by users. The report generation module 18706 generates reports using the data in the licensing related databases, including printing the contents of each major object in the system (Print License, Print Asset, and so on). Preferably, the report generation module 18706 connects to the databases through ODBC 18738 or through the Microsoft SQL Server driver, for example. The report generation module 18706 can be implemented using a commercial report generation product, such as Crystal Reports, although the invention is not limited to that embodiment.
In embodiments where the report generation module 18706 is implemented using a commercial report generation product, a report generator interface 18732 interacts with the report generator 18706 to cause the report generator 18706 to generate reports per user instructions. For example, the generator interface 18732 may interact with the report generator 18706 in a manner consistent with the API (application program interface) of the report generator 18706 to cause the report generator 18706 to access the databases 19208 for appropriate information, and to process and format that information in reports, per user commands.
Data Exploration Module
Strategically, licensing managers will use the Licensing module 18702 to access license data in creative ways.
A strategic use of the licensing system 18702 involves ad-hoc query functions in combination with reports to identify IP assets that are underperforming or outperforming and to cross-reference between license agreements, licensees, royalty terms, royalty statements, and royalty payments. The ad-hoc query facility uses the same user interface that provides data entry facilities in an easy-to-use query-by-example format.
The ad-hoc query facilities also support licensing personnel and auditors in interactive tactical tracking down of issues such as payments due, payments not received, royalty statement details, and errors in data entry.
Object Model
The object model of the Licensing module 18702 represents the transient aspect of the persistent data in the database server. The subsystems of the object model provide interfaces to the various licensing-related objects and higher-level objects that aggregate them for use in the Licensing module 18702. The object model supports a number of subsystems and/or object/data types, including but not limited to the following:
More particularly, the licensing system domain A08 is an object layer called a licensing system domain 18708 that represents a series of subsystems (generally indicated as 18748 in
Each subsystem exports a set of Transaction subclasses, where a transaction is a Database subsystem component that provides support for database transactions. Each transaction subclass represents a transaction use case. Some transaction classes provide methods for generating objects either as new objects or as objects queried from the database. Others provide the ability to update and delete objects from the database. Each use case is a single transaction through the system, and each must execute entirely within a single thread to ensure thread safety. The use cases supported by an embodiment of the invention are described in sections below.
The user interface accesses the transaction subclasses as the primary interfaces. Transactions correspond to the work the user does with those objects (entering new assets, adding payments to a license, and so on). Block diagrams of the subsystems are illustrated in
It is noted that allocation of functions to the subsystems 18748 may vary according to the implementation. Accordingly, the subsystems shown in
Data Access Module
The data access module 18710 provides an interface between system databases 19208 and the modules of the licensing system 18702. Preferably, the data access module 18710 includes the Microsoft Active Data Objects COM component (preferably version 1.5) that provides a SQL interface for accessing various data sources. In this case, it connects to ODBC 18738.
Database Architecture
The database architecture preferably includes a Database Server 18740 (such as a SQL Server or an Oracle server) that preferably manages the persistent data as a set of relational tables. The databases 19208 in the database architecture each preferably includes a number of databases, each containing a well-defined and reusable set of data components. (It is noted that the invention is not limited to this arrangement of data. In other embodiments, the data described herein is stored in database arrangements other than that described below.)
The standalone version of Licensing module 18702 has a stand-in version of the IPAM database 316 (i.e., the Core database 18808) that, in an embodiment, contains only some of the tables in that database that the module uses (for example, group, document, and a few miscellaneous tables). The patent tables in the IPAM Server database 316 also replaces the patent tables (but not non-patent asset tables) in the licensing database 18804 or the core database 18808 for the integrated version of the Licensing module 18702 (
Licensing Module as a Standalone Module or Integrated with IPAM (IPAM Integrated)
As discussed above, in one embodiment the Licensing module 18702 integrates with the IPAM Server 314 through the IPAM database 316, which it accesses directly.
The standalone version of the Licensing module 18702 replaces the IPAM database 316 with a Core database 18808 that emulates the IPAM tables 316 that the Licensing module 18702 uses, including the Group-related tables, the Document table, the IP Document table hierarchy, and the UDD (unique document descriptor) tables. See
With IPAM integration, the Licensing module 18702 has all the patent and UDD (user defined documents) documents available as assets and all groups available for group asset packages from the IPAM database 316. With the standalone version of the Licensing module 18702, the customer must enter patents through data entry screens in the Licensing module 18702 interface (in an embodiment, these are not present when the system is integrated).
Preferably, the Licensing module 18702 integrates with the IPAM security system through the IPAM security broker, a library that is part of the IPAM server technology.
Object Display Window of the User Interface of the Licensing module
Operational Features of the Licensing Module
Operational functions supported by embodiments of the licensing module 18702 are described in detail in the following sections.
Preferably, these functions are implemented by one or more computers operating according to control logic, or software. Such software is preferably written in an object oriented manner. Accordingly, the licensing module 18702 can be said to be an object oriented system.
Use cases are sometimes used to describe the manner in which an object oriented system works. Generally, a use case describes a transaction processed in an object oriented system.
Use cases often include extensions. Extensions are conditional. For example, the enter contact method use case described below extends the enter entity method use case. In other words, under certain conditions when you are entering an entity, you will enter a contact method.
In the following section, the functions supported by embodiments of the licensing module 18702 are described by describing use cases that correspond to these functions. Coding of software to achieve these functions will be readily apparent to persons skilled in the relevant arts, based on the description contained herein, including but not limited to the following description of use cases. In the following, use cases are described as being implemented as procedures, but in practice the functionality of any number of use cases can be achieved through one or more software procedures.
An embodiment of the licensing system 18702 is shown in
The invention also preferably includes a licensing administration module 19301 (
A functional module may “use” another functional module. In other words, in the course of performing its specified function, a functional module may call or invoke the services of another functional module. Alternatively, a functional module may “extend” another functional module. In other words, a functional module may extend the capabilities of another functional modules. In some cases, not all relationships between modules are shown in the figures. The relationships between functional modules are further described in the following sections.
In the following, certain steps are described as being preferably performed by some actors, but in practice and/or in other embodiments, the steps are performed by other actors, including but not limited to those described herein.
General Purpose Use Cases
There are several general-purpose use cases that apply to all users or to generic objects. These are described in the following sections.
Login
The login use case 19402 is diagramed in
The User enters his or her user name and password and any connection string required by the ODBC data source in a login dialog 19502 shown in
Display Help
The display help use case 19602 is diagramed in
The User requests help in a specific context or requests display of the help contents, index, or query preferably using a standard help system, such as the Microsoft Windows help system. The display help module 19304 displays the appropriate help screen by accessing, retrieving, and displaying pertinent information from a help file 19604.
Print Object
The print object use case is diagramed in
The Auditor or License Administrator selects an object and prints the object in a standard print format to a system printer using the print object module 19306.
The operation of the print object module 19306 is further detailed below:
Step 1: The Auditor or License Administrator (the Actor) starts the read-only transaction by selecting an object (license agreement, asset package, entity, royalty statement, or payment), and then selects the Print command.
Step 2: The print object module 19306 displays a Print <Object> dialog, where <Object> is one of the five basic objects from step 1.
Step 3: The Actor sets the printing options, including any printer setup commands, then issues the instruction to print, ending the transaction.
Step 4: The print object module 19306 prints the object.
If the Actor in step 1 selects a License Agreement, the Print License use case extends the print object module 19306.
If the Actor selects an Asset Package, the Print Asset Package module 19310 use case extends the print object module 19306.
If the Actor selects an Entity, the Print Entity module 19308 extends the print object module 19306.
If the Actor selects a Royalty Statement, the Print Statement module 19314 use case extends the print object module 19306.
If the Actor selects a Payment, the Print Payment module 19316 extends the print object module 19306.
Contacts
A Contact is an organization or person (general term “entity”, which also encompasses users and user groups in the security system). People play roles in organizations, and both people and organizations have contact methods (telephone, mail address, and email).
A Contact View 19802 is displayed by selecting the contacts icon 19014 (
Double-clicking on an organization in the explorer view 19804 displays the data modification dialog for organizations. Double-clicking on a person in the people list pane 19806 displays the data modification dialog for people. You can double-click on an empty record or click the New button to create a new organization or person.
The Licensing System Administrator creates, modifies, and/or removes roles from the Licensing Database 18804.
Enter Entity
The enter entity use case 19902 is diagramed in
The Data Entry Clerk enters entity information for people and organizations, including organization levels, people's names, and (optionally) contact methods. The Data Entry Clerk may optionally link a person to an organization with a specific role.
The enter entity use case 19902 is further described below:
Step 1: The Data Entry Clerk begins the transaction.
Step 2: The enter entity module 19318 displays the organizations in the organization pane 19864 and people in the people pane 19806 stored in the licensing database 18804 using the Display Entities module 19322.
Step 3: The Data Entry Clerk takes any of these actions (for example):
Step 4: The enter entity module 19318 displays a data entry form and creates a new entity unique identifier.
Step 5: The Data Entry Clerk enters an optional description for the new organization/person.
Step 6: The Data Entry Clerk commits the transaction.
Step 7: The licensing system 18702 stores the entered entity information in the licensing database 18804 and confirms the commit to the Data Entry Clerk.
There are a number of extensions to the enter entity module 19318.
Enter Contact Method
The enter contact method use case 20002 is diagramed in
This use case extends or is used by another use case, which supplies the unique identifier of an entity. The Data Entry Clerk enters one or more contact methods for that entity.
The enter contact method module 19320 is further described below:
Step 1. The using use case passes in an object identifier for an entity with which to associate a contact method.
Step 2. The Data Entry Clerk chooses one of three types of contact method: telephone, email, or mail address.
Step 3. The enter contact method module 19320 displays an entry form appropriate for the type of contact method selected and generates a unique priority, defaulting it to one more than the last priority entered for methods associated with this entity:
where :Entity_ID is the entity object identifier passed into this use case. Note: The Data Entry Clerk can modify the priorities in the Modify Entity use case.
Step 4. The Data Entry Clerk optionally enters a Description for the contact method and terminates the use case.
Step 5. The enter contact method module 19320 inserts the contact method into the Licensing Database 18804, linking the entity and contact method.
There are a number of extensions with this use case:
Display Entities
The display entities use case 20102 is diagramed in
The Enter Entity module 19318 and Modify Entity module 19328 both use the display entities module 19322 to display organizations and people. The display entities module 19322 displays a tree of organizations and displays all the people in an organization that the Data Entry Clerk selects.
The display entities module 19322 is further described below:
Step 1. The display entities module 19322 displays a list of top level organizations in alphabetical order from the Licensing database 18804 in the organization pane 19804 of the contact view 19802. The display entities module 19322 then displays in the organization pane 19804, for each organization, the hierarchy of organizations that have the top-level organization as a parent.
Step 2. The Data Entry Clerk selects an organization from the organization pane 19804.
Step 3. The display entities module 19322 displays in the people pane 19806 an alphabetical list of all the people in the organization from the Licensing database 18804, preferably displaying the Entity unique identifier, the entity Name, the entity Description, the role Name, and the Start Date and End Date (if any) of the interval during which the person played the particular role in the organization, all preferably ordered by the last name then first name of the person. The user can select to order the data in other ways (this is true whenever data is displayed in the present invention). Note that a person may have different roles in the organization, perhaps at different times. The display entities module 19322 displays the person only once but supplies a list of roles and time periods for the person with multiple roles.
Modify Entity
The modify entity use case 20202 is diagramed in
The Data Entry Clerk interacts with the modify entity use case 20202 to modify entity information for people and organizations, including organization levels, people's names, and contact methods. The Data Entry Clerk may optionally modify the links between a person and their roles in organizations.
The modify entity module 19328 is further described below:
Step 1. The Data Entry Clerk begins the transaction by selecting an appropriate menu option, or pressing an appropriate dialog button.
Step 2. The display entities module 19322 displays a list of top level organizations in alphabetical order from the Licensing database 18804 in the organization pane 19804 of the contact view 19802. The display entities module 19322 then displays, for each organization, the hierarchy of organizations that have the top-level organization as a parent.
Step 3. The Data Entry Clerk selects an organization.
Step 4. The display entities module 19322 displays an alphabetical list of all the people in the organization from the Licensing database 18804 in the people pane 19806.
Step 5. The Data Entry Clerk selects an entity (person or organization) for modification.
Step 6. The modify entity module 19328 displays a data entry form for the appropriate kind of entity.
Step 7. The Data Entry Clerk optionally changes the entity name and/or description in any order.
Step 8. The Data Entry Clerk commits the transaction.
Step 9. The modify entity module 19328 updates the Licensing database 18804 with the modified entity information and confirms the commit to the Data Entry Clerk.
This use case has a number of extensions:
Modify Contact Method
This use case is diagramed in
This use case extends or is used by another use case, which supplies the object identifier for an entity and the priority of the contact method for that entity, which taken together identify the contact method. The Data Entry Clerk can change any of the characteristics of the contact method, which may be a telephone number, a mail address, an email address, etc.
The modify contact method module 19326 is discussed further below:
Step 1. The modify contact method module 19326 accesses a contact method from the licensing database 18804. The modify contact method module 19326 displays the contact method in a dialog.
Step 2. The Data Entry Clerk optionally modifies the Description and details (see Extensions) for the contact method and terminates the use case.
Step 3. The modify contact method module 19326 inserts the contact method into the Licensing database 18804, linking the entity and contact method.
This use case includes the following extensions:
Link Person to Organizational Role
The link person to organization role use case 20402 is diagramed in
This is a use case that extends other use cases when the Data Entry Clerk wants to model a particular person's role in an organization during a given period of time. The extended use case passes in the object identifier for the person and the organization. The Data Entry Clerk selects the role from a list of roles and sets the time period.
This use case is further described below:
Step 1. The extended use case passes in the object identifiers for aperson and an organization.
Step 2. The link person to organization role module 19324 displays a form containing a list of roles ordered by name, displaying the Name and Description for each role, and entry fields for Start and End Dates.
Step 3. The Data Entry Clerk selects a role and enters the Start Date (required) and optionally the End Date.
Step 4. The link person to organization role module 19324 creates a link between the person, the role, and the organization in the Licensing database 18804 as an instance of Organization People and a time period using the Start and End Dates.
This use case has a number of extensions:
Print Entity
The print entity use case 20502 is diagramed in
This use case extends the Print Object use case. The print entity module 19308 prints information on an Entity, including all information in the Licensing database 18804 about the entity, its relationships to other objects, and its contact information.
The operation of this use case is further described below:
Step 1. The Actor via the print entity module 19308 selects an Entity and selects a command to print it.
Step 2. The print entity module 19308 prints a formatted report with the Entity ID, Name, Description, and Named Entity Type (Organization or Person).
Step 3. The print entity module 19308 prints the contact information for the entity in priority order, printing the Priority, Description, and Contact Method Type for each method.
Step 4. The print entity module 19308 prints the Role Name and Know How Description for any Contributor relationship the Entity participates in.
Step 5. The print entity module 19308 prints the Role Name and Agreement Number and Name for any license agreement to which the Entity is a party.
This use case has a number of extensions.
Remove Entity
The remove entity use case 29702 is diagramed in
The operation of this use case is further described below.
Step 1. The License Administrator begins the transaction.
Step 2. The Remove entity module 19394 displays a list of existing entities ordered by name, displaying the name and entity type.
Step 3. The License Administrator selects an entity and removes it. This is allowed only if the entity is not associated with a license (no rows in the Party table for this entity) or has no payments (no rows in the Payment table with Payor_ID=OID) The License Administrator can select and remove multiple entities at once or in sequence. At the end of the process, the License Administrator commits the transaction.
Step 4. The Remove entity module 19394 deletes the entity, removing also the corresponding subclass (Person or Organization), links to Organization for people, name fragments, and contact methods.
Step 5. The Remove entity module 19394 confirms the commit to the License Administrator.
This use case has a number of extensions:
Query Entities
The query entities use case 33002 is diagramed in
Step 1. The query entities module 33004 displays a query form with the name, description, and entity type fields available for specifying a query.
Step 2. The License Administrator enters the search criteria.
Step 3. The query entities module 33004 queries all the entities that meet the query criteria from the Licensing Database 18804. The query entities module 33004 displays the entities, showing the name, description, and type.
Step 4. The License Administrator selects one or more entities for use in the using use case.
Asset Use Cases
An asset is an intellectual property document (for example, patent, copyright, trademark, trade secret, etc.) or an intellectual asset (for example, know how). According to the invention, assets are combined into asset packages, which may be standard (lists of assets), group (reference to an IPAM group, for example, described above), or descriptive (a text describing the assets with language from the license agreement).
Preferably, a group as described above (sometimes herein refer to as an IPAM group) differs from an asset package. When the licensing system 18702 is integrated with the IPAM server 314, it is possible to create a type of an asset package (the IPAM group type) that links to a group and that acquires all of the documents associated with that group. In an embodiment, changes to the contents of the group automatically affect the asset package (in other embodiments, changes to the contents of the group do not automatically affect the asset package). The asset package is said to be linked (where the link is said to be “active”) or associated with the group. But the asset package itself is a separate object from that group.
Linking the package to a license agreement preferably means that the license licenses all of the assets in the package to the licensee, unless the license agreement indicates otherwise.
An asset view 20602 is displayed when the asset packages icon 19016 is pressed (
Selecting an asset package in the asset packages pane 20604 displays the assets in that package in the assets pane 20606. Double-clicking on an asset package in the asset packages pane 20604 displays the asset package modification dialog, while double-clicking on the asset in the asset pane 20606 displays the asset modification dialog. You can enter a new package or asset by double-clicking on an empty record or clicking on the New button. If no package is selected, you create the new asset independently of any package; otherwise, you create the asset in the selected package.
Clicking on a Find tool displays the Find Asset dialog (
Enter Patent
The enter patent use case 20702 is diagramed in
The enter patent use case 20702 enables a Data Entry Clerk to enter information for a patent (U.S. or foreign) asset. The patent can be packaged alone or with other assets into asset packages that can be licensed.
The operation of the enter patent use case 20702 is further described below:
Step 1. The Data Entry Clerk starts a transaction to enter a new patent asset by issuing an appropriate command. This can be done, for example, by selecting New, Patent from the menu bar 19006 (
Step 2. The enter patent module 19330 displays a data entry form called an enter new patent dialog 20902 (
Step 3. The Data Entry Clerk chooses from a list of publishing organizations and document kinds. For example, the Data Entry Clerk can press a down arrow key 20908 (
Step 4. The Data Entry Clerk enters data into the following fields in any order: DocumentNumber, Long Display Name, Patent Type, and Filing Date. Optionally, the user can enter the following fields in any order: Description, Title, Filing Date, Issue Date, and Publication Date. See
Step 5. The Data Entry Clerk commits the transaction by pressing a save button 20910 (
Step 6. The enter patent module 19330 creates an IP Document, a Document, and an object of the appropriate subclass for the patent type in the Core Database 18808. The enter patent module 19330 marks the Document as an IP Document.
This use case has a number of extensions:
Enter Trademark
The enter trademark use case 21202 is diagramed in
The Data Entry Clerk enters information for a trademark asset, including the trademark classes and the kind of trademark (US Federal, State, WIPO, etc.).
The operation of the enter trademark use case 21202 is further described below.
Step 1. The Data Entry Clerk starts a transaction to enter a new trademark asset. This can be done in a number of ways, such as by selecting New, Trademark from the menu bar 19006 (
Step 2. The enter trademark module 19332 displays a data entry form 21302 (
Step 3. The Data Entry Clerk chooses from a list 21402 of publishing organizations (
Step 4. The Data Entry Clerk enters data into the following fields in any order: Doc Kind, Document Number, Long Display Name, and Filing Date. Optionally, the user can enter the following fields in any order: Description, Title, Filing Date, Issue Date, and Publication Date. The Data Entry Clerk enters a set of Trademark Classes from a list of classes. The Data Entry Clerk sets the Security Class from a list of available security classes with Write privilege for the user. See
Step 5. The Data Entry Clerk commits the transaction by pressing a save button 21404.
Step 6. The enter trademark module 19332 creates an IP Document, a Document, an object of class Trademark, and an association object relating the trademark to a series of Trademark Classes in the Licensing Database 18804. The enter trademark module 19332 marks the Document as an IP Document.
At any time, if the Data Entry Clerk presses F1 or the equivalent, the application extends the use case with the Display Help use case.
Enter Copyright
The enter copyright use case 21702 is diagramed in
The operation of the enter copyright use case 21702 is further described below:
Step 1. The Data Entry Clerk starts a transaction to enter a new copyright asset. This can be done in a number of ways, such as by selecting New, Copyright from the menu bar 19006 (
Step 2. The enter copyright module 19334 displays a data entry form 21802 (
Step 3. The Data Entry Clerk chooses from a list of publishing organizations and document kinds. See, for example,
Step 4. The Data Entry Clerk enters data into the following fields in any order: Document Number, Long Display Name, and Filing Date. Optionally, the user can enter the following fields in any order: Description, Title, Filing Date, Issue Date, and Publication Date. The Data Entry Clerk sets the Security Class from a list of available security classes with Write privilege for the user. See
Step 5. The Data Entry Clerk commits the transaction by pressing a save button 21804.
Step 6. The enter copyright module 19334 creates an IP Document, a Document, and an object of class Copyright in the Licensing Database 18804. The enter copyright module 19334 marks the Document as an IP Document.
At any time, if the Data Entry Clerk presses F1 or the equivalent, the application extends the use case with the Display Help use case.
Enter Trade Secret
The enter trade secret use case 22102 is diagramed in
The operation of the enter trade secret use case 22102 is further described below:
Step 1. The Data Entry Clerk starts a transaction to enter a new trade secret asset using any procedure described herein.
Step 2. The enter trade secret module 19336 displays a data entry form for input and generates an object identifier for the new asset.
Step 3. The Data Entry Clerk chooses from a list of publishing organizations and document kinds.
Step 4. The Data Entry Clerk enters data into the following fields in any order: Document Number, Long Display Name, and Filing Date. Optionally, the user can enter the following fields in any order: Description, Title, Filing Date, Issue Date, and Publication Date. The Data Entry Clerk sets the Security Class from a list of available security classes with Write privilege for the user.
Step 5. The Data Entry Clerk commits the transaction.
Step 6. The enter trade secret module 19336 creates an IP Document, a Document, and an object of class Trade Secret in the Licensing Database 18804. The enter trade secret module 19336 marks the Document as a type of know how.
As always, at any time, if the Data Entry Clerk presses F1 or the equivalent, the application extends the use case with the Display Context-Sensitive Help use case.
Enter Know How
The enter know how use case 22202 is diagramed in
The operation of this use case is further described below:
Step 1. The Data Entry Clerk starts a transaction to enter a new know how asset. This can be done in a number of ways, such as by selecting New, Know How from the menu bar 19006 (
Step 2. The enter know how module 19338 displays a data entry form 22302 (
Step 3. The Data Entry Clerk enters various items:
Step 4. The Data Entry Clerk commits the transaction.
Step 5. The enter know how module 19338 creates a Document and an object of class Know How in the Licensing Database 18804. The enter know how module 19338 marks the Document as a Know How.
At any time, if the Data Entry Clerk presses F1 or the equivalent, the application extends the use case with the Display Help use case.
Modify IP Asset
The modify IP asset use case 22402 is diagramed in
Step 1. The License Administrator begins the transaction to modify an IP asset using any of the techniques described herein.
Step 2. The modify IP asset module 19340 uses the Query Assets module 19342 to display a set of assets and to allow the License Administrator to select one for modification.
Step 3. If the License Administrator has Write permission on the selected asset, the IP asset module 19340 displays a form containing, for example, these fields for the asset document: Document Number, Title, Long Display Name, Issue Date, Filing Date, Publication Date, Description, Asset Type (“Disc Switch”), Publishing Organization (Description from Pub Organization class), and Doc Kind (Description from IP Doc Kind class).
Step 4. The License Administrator modifies any of the fields in any order and signals the end of the transaction.
Step 5. The IP asset module 19340 writes the changes to the licensing database 18804 or the core database 18808 and confirms the commit to the License Administrator.
There are a number of extensions of this use case:
Asset Package Use Cases
An asset package includes one or more IP assets. Use cases related to asset packages are described below.
Create IP Asset Package
The create IP asset package use case 22502 is diagramed in
Step 1. The License Administrator begins the transaction to create a new IP asset package. This can be done in a number of ways, such as by selecting New, Asset Package from the menu bar 19006 (
Step 2. The create IP asset package module 19344 displays an asset package dialog 22602 (
Step 3. The create IP asset package module 19344 creates a new package with a new object identifier.
Step 4. The License Administrator enters a Name for the package. Optionally, and in any order, the License Administrator enters the Description and/or the capture period (Start and End timestamps). See
If the Asset/Standard type is selected, then an asset/standard type dialog 22702 is displayed (
If the Package Type is Asset/Standard or Group, the License Administrator can choose to allocate the assets within the package. The create IP asset package module 19344 displays a list of the assets in the package, and the License Administrator enters an Allocation Percent for each asset. See
If the Group type is selected, a group dialog 23002 is displayed (
If the Descriptive type is selected, then a descriptive dialog 23202 is displayed (
Step 5. The create IP asset package module 19344 writes the new asset package to the Licensing Database 18804, making the License Administrator user the owner of the package, then confirms the transaction commit to the License Administrator.
Modify IP Asset Package
The modify IP asset package use case 23402 is diagramed in
Step 1. The License Administrator starts the transaction to edit an IP asset package. This can be done, for example, by selecting the asset packages icon 19016 to display an asset package view 23502. The asset package view 23502 has a package list pane 23504 where asset packages are listed, and an asset list pane 23506 where assets in a selected asset package (selected in the package list pane 23504) are listed.
Step 2. The modify IP asset package module 19346 displays the asset packages in the packages list pane 23504 by querying the Licensing Database 18804, preferably displaying the Name, Description, and/or Package Type preferably in alphabetical order by name. The modify IP asset package module 19346 displays only those packages for which the License Administrator has Read permission or ownership.
Step 3. The License Administrator selects a package in the packages list pane 23504.
Step 4. If the License Administrator has Write permission on the selected package or owns it, the modify IP asset package module 19346 displays a form showing all the fields of the package, including the object identifier, the Package Name, the Description, the capture period (Start and End date/time), and the Package Type. This is similar to the examples shown in
Step 5. The License Administrator changes the Name, Description, Capture Period, Package Type, or other information in any order, then ends the transaction.
Step 6. The modify IP asset package module 19346 updates the Licensing Database 18804 with the changes and confirms the commit to the License Administrator.
This use case has a number of extensions:
Print Asset Package
The print asset package use case 23602 is diagramed in
Step 1. The Actor in the Print Object use case or the Print License Use case selects an Asset Package and prints it.
Step 2. The print asset package module 19310 prints a formatted report with the Start Date, End Date, Name, Description, Package Type, etc. It then prints package-specific information (see Extensions).
Step 3. The print asset package module 19310 prints the Document IDs of the documents and the document-specific information (see Extensions).
This use case has a number of extensions:
Remove IP Asset
The remove IP asset use case 23702 is diagramed in
Step 1. The System administrator begins the transaction.
Step 2. The remove IP asset module 19303 displays a list of all assets (the IP Documents and Know Documents) in the Licensing Database 18804 and Core Database 18808, displaying the Document ID, the Document Type (disc_switch for IP Documents and IA_Kind Description for Know How), the DocumentNumber and Title for IP Documents, ordering by the type and document ID.
Step 3. The Administrator selects one or more assets and removes them.
Step 4. The remove IP asset module 19303 deletes the information from the Licensing and Core databases 18804 and 18808 and moves it to the Recycle Bin (implementation may differ, deferring the actual SQL deletes, and there is no notification of commit to the Administrator).
This use case has a number of extensions:
Remove IP Asset Package
The remove IP asset package use case 23802 is diagramed in
Step 1. The License Administrator begins a transaction.
Step 2. The remove IP asset package module 19348 displays a list of the asset packages to which the user has Read access or which the user owns, displaying the object identifier, the Name, the Description, and the Package Type, ordered by Name.
Step 3. The License Administrator selects one or more asset packages to which the user has Delete access or which the user owns and removes them. The License Administrator then commits the transaction.
Step 4. The remove IP asset package module 19348 removes the persistent asset packages from the Licensing Database 18804 and confirms the operation to the License Administrator. The remove IP asset package module 19348 propagates the delete to the appropriate subclass based on Package_Type (Standard Asset Package, Descriptive Asset Package, Group Asset Package) and to the Secure Object superclass.
This use case has a number of extensions.
Query Assets
The query assets use case 23902 is diagramed in
Step 1. The using use case calls this use case, and the query assets module 19342 displays, for example, a screen that contains these fields for search criteria: Document Number, Title, Long Display Name, Issue Date, Filing Date, Publication Date, Description, Asset Type (“Disc Switch”), Publishing Organization (Description from Pub Organization class), Doc Kind (Description from IP Doc Kind class), and/or any other search fields discussed herein, or conventionally used. See example displays in
Step 2. The License Administrator enters one or more fields of search criteria and submits the query.
Step 3. The query assets module 19342 displays a list of documents 24202 that satisfy the query, displaying the Asset Type, Document Number, and Title (for IP documents) and/or IA Kind and Description (for Know How), and to which the License Administrator has READ access. See
Step 4. The License Administrator may take any number of actions, including one of these actions:
Step 5. The License Administrator ends the use case.
This use case has a number of extensions:
Query Asset Packages
The query asset packages use case 33502 is diagramed in
Step 1. The Actor begins the transaction.
Step 2. The query asset package module 33504 displays a form that allows the Actor to specify a set of search criteria for the query. The main part of the form contains these fields:
Step 3. The Actor enters any of the fields and tells the query asset package module 33504 to execute the query.
Step 4. The query asset package module 33504 concatenates all the conditions with a logical AND, then queries the Licensing Database 18804 using the resulting search condition. The query asset package module 33504 then displays a list of all the asset packages that satisfy the search condition. The query asset package module 33504 displays the Package Name, Description, and Package Type.
Step 5. The Actor ends the transaction.
This use case has a number of extensions:
License Agreements Use Cases
A license agreement is a contract in which an entity, the licensor, licenses intellectual property to another entity, the licensee. There may be a plurality of licensors and/or licensees. In addition to a variety of contract clauses and the links to any number of asset packages, the license agreement in the context of the present invention contains definitions of the parties to the agreement, compensation terms, territorial restrictions, field-of-use (market area) restrictions, and any other terms and/or clauses used in license agreements.
A License Agreements View 24402 (
Double-clicking on the empty row or on the new button in the license agreements view 24402 displays the license creation dialog 24802 (
Selecting a Find tool in this view displays the Find Agreement dialog 24602 (
Enter License Agreement
The enter license agreement use case 24902 is diagramed in
Step 1. The Data Entry Clerk begins the transaction.
Step 2. The enter license agreement module 19350 generates a new object identifier for the license agreement and displays a data entry form 24802 for the new license.
Step 3. The Data Entry Clerk enters data into the structured data fields of the license creation dialog 24802 and links other objects as required:
Step 4. The Data Entry Clerk commits the transaction.
Step 5. The enter license agreement module 19350 creates the License Agreement or Infringement Based Agreement in the Licensing Database 18804. The enter license agreement module 19350 confirms the commit to the Data Entry Clerk.
This use case has a number of extensions:
Link to Part
The link to party use case 25002 is diagramed in
Step 1. The Data Entry Clerk starts the use case with an open transaction containing a license agreement that will link to the entity and role, passing in the object identifier for the license agreement.
Step 2. The link to party module 19356 queries the Licensing database 18804 and displays the names and descriptions of the entities and roles.
Step 3. The Data Entry Clerk selects one entity from the entity list and one role from the role list.
Step 4. The Data Entry Clerk signals the end of the use case.
Step 5. The Licensing Database 18804 creates a Party link using the License Agreement OID, the Entity OID, and the Role OID.
This use case has a number of extensions.
Link to Asset Package
The link to asset package use case 25102 is diagramed in
Step 1. The Data Entry Clerk starts the use case with an open transaction containing a license agreement that will link to the asset packages. The extended use case supplies the object identifier for the agreement.
Step 2. The link to asset package module 19352 displays the names and descriptions of the asset packages in a list ordered by name.
Step 3. The Data Entry Clerk selects one or more packages from the list.
Step 4. The link to asset package module 19352 creates and displays a link between the license agreement and each package the Data Entry Clerk selects and assigns default territorial and field-of-use values. The link to asset package module 19352 sets the default Cross-Licensed flag to false.
Step 5. The Data Entry Clerk adds territorial and field-of-use restrictions to the links using lists of the available territories and fields of use from the Licensing Database 18804. The Data Entry Clerk also sets the Cross-License flag to true if the particular package represents assets licensed by the licensee to the licensor instead of vice versa. The Data Entry Clerk removes unwanted territorial and field-of-use restrictions from the links. The Data Entry Clerk enters any additional limitations in the Limitations field. All of these actions may occur in any order. The Data Entry Clerk signals the end of the use case.
Step 6. The Licensing Database 18804 links the asset packages and the input license agreement and adds links to the required territories and fields of use for each link.
This use case has a number of extensions:
Enter Compensation Term
The enter compensation term use case 25202 is diagramed in
The Enter License Agreement and Modify License Agreement use cases use this one to enter compensation terms to a license agreement in the Licensing Database 18804. The Licensing Administrator or Data Entry Clerk creates a licensing term with the details appropriate to the particular term. AU terms have a description, an amount, and late payment penalties, and perhaps other attributes. Ongoing royalties have a time period and possibly tables of escalating amounts based on number of units/sales plus tables of estimated number of units/sales. Ongoing royalties break down into royalties on units sold, on revenue, or on revenue from sublicense royalties. A minimum guarantee also has a time period and possible escalations. An advance has a due date and may be refundable or not. A fee may be ongoing with a time period or a lump sum fee with a due date.
The operation of this use case is further described below.
Step 1. The using use case passes in the object identifier for the license agreement to which the Data Entry Clerk or License Administrator (the Actor) wants to add compensation terms.
Step 2. The enter compensation term module 19354 displays a list of the current set of compensation terms (if any) for this license, preferably in order of term number, displaying the term Description, the compounding period Description, the Amount with its currency symbol, the Late Payment Interest Rate (if any), and the Term Type.
Step 3. The Actor creates a new term and selects one of the term types (Royalty Per Unit, Royalty Per Sales Amount, Royalty Per Royalty Amount, Minimum Guarantee, Advance, Ongoing Fee, Lump Sum Fee, or Other).
Step 4. The enter compensation term module 19354 displays the term with default values (Amount 0, Currency from the last term or the default currency for the system, interest rate 0, fields for entering a Time Unit Period (see Extensions) with default Time Unit Type of Month, Term Type, Royalty_Per_Sales_Amount). The enter compensation term module 19354 displays a form for the term given the default term type (see Extensions). It displays a choice of several period types and entry fields that differ depending on the period type the user chooses.
Step 5. The Actor enters the standard details for the term and the details for the particular term type (see Extensions), then either repeats from step 3 or ends the use case.
Step 6. The enter compensation term module 19354 inserts the new terms into the Licensing Database 18804. The enter compensation term module 19354 extends the use case with the Create Expected Revenue use case, which computes the expected revenue amounts per period for the existing compensation terms.
This use case has a number of extensions:
Create Expected Revenue
The create expected revenue use case 25302 is diagramed in
The extending use case passes in the compensation term object identifier. The create expected revenue module 19360 queries the compensation term and its components and generates the appropriate payments expected from that term.
Operation of the create expected revenue module 19360 is further described below.
Step 1. The create expected revenue module 19360 queries the Compensation Term in question from the Licensing Database 18804 to get the Amount and subtype of the term.
Step 2. For each period that is part of the structure of the compensation term, the create expected revenue module 19360 creates an Expected License Revenue object in the Licensing Database 18804, giving it a payment number and a due date as well as the expected amount of the payment.
Step 3. The create expected revenue module 19360 iterates through the expected revenues calculated in step 2 to subtract advance payment amounts from expected royalties and to reset Minimum Guarantees to the amount needed to bring the guarantee up to the guaranteed amount.
This use case has a number of extensions:
Modify Compensation Term
The modify compensation term use case 25402 is diagramed in
Step 1. The using use case passes in the object identifier for the license agreement in which the License Administrator wants to change compensation terms.
Step 2. The modify compensation term module 19362 displays a list of the current set of compensation terms for this license in order of term number, displaying the term Description and the Term Type.
Step 3. The License Administrator selects a term for modification.
Step 4. The modify compensation term module 19362 displays the current values. It displays a data entry form for the term given the term type (see Extensions) that display the current values for the selected term.
Step 5. The License Administrator changes any of these values, then ends the use case.
Step 6. The modify compensation term module 19362 updates the term in the Licensing Database 18804.
This use case has a number of extensions:
If the term type is Ongoing Royalty and the Royalty Type is Royalty Per Sales Amount, the Modify compensation term module 19362 displays fields for entering the Percentage, the Net flag (default True), the Estimated Revenue Per Period (default 0), a table for an escalation schedule (Starting Amount, Ending Amount, and Royalty Percentage), and a table for Estimated Revenue (Period Number, Estimated Revenue).
Remove Compensation Term
The remove compensation term use case 25502 is diagramed in
Step 1. The using use case passes in the object identifier for the license agreement in which the License Administrator wants to change compensation terms.
Step 2. The Remove compensation term module 19364 displays a list of the current set of compensation terms for this license in order of term number, displaying the term Description and the Term Type.
Step 3. The License Administrator selects a term to remove.
Step 4. The Remove compensation term module 19364 deletes the information from the Licensing Database and moves it to the Recycle Bin (implementation may differ regarding deferring the actual SQL deletes, and there is no notification of commit to the Administrator).
Query License
The query license use case 25602 is diagramed in
Step 1. The Auditor starts the transaction. This can be accomplished in a number of ways, such as by selecting Tools, Find, License Agreement from the menu bar (
Step 2. The Query license module 19368 displays a query form 25702. (
Step 3. The Auditor enters the search criteria.
Step 4. The Query license module 19368 queries all the licenses that meet the query criteria from the licensing database 18804 and for which the Auditor has Read access. The Query license module 19368 displays the licenses, preferably showing all of the fields in step 2 except for Party Name, Asset Package Name, Territory, and Field of Use, which are extensions. The Query license module 19368 orders the licenses by Agreement ID.
Step 5. The Auditor ends the transaction.
This use case has a number of extensions:
Modify License Agreement
The modify license agreement use case 25802 is diagramed in
Step 1. The License Administrator begins the transaction.
Step 2. The Modify license agreement module 19358 displays the License Agreements in the Licensing Database.
Step 3. The License Administrator chooses a license agreement to modify.
Step 4. If the License Administrator has write permission on the selected document, the Modify license agreement module 19358 displays the license agreement in a data entry form such as that used in the Enter License Agreement use case and shows the current values of all fields. See
Step 5. The License Administrator modifies any of the structured fields and linked objects of the license agreement in any order
Step 6. The License Administrator commits the transaction.
Step 7. The Modify license agreement module 19358 updates the Agreement, License Agreement, and Infr Based Agreement objects in the Licensing Database 18804 and confirms the commit to the License Administrator.
This use case has a number of extensions:
Remove License Agreement
The remove license agreement use case 25902 is diagramed in
Step 1. The License system Administrator begins the transaction.
Step 2. The Remove license agreement module 19305 displays a list of all the licenses in the Licensing Database, displaying the document ID, the Agreement ID, and the Name.
Step 3. The License system Administrator selects one or more license agreements and removes them.
Step 4. The Remove license agreement module 19305 uses the Remove Royalty Statement use case to remove the Royalty Statements with the agreements.
Step 5. The Remove license agreement module 19305 deletes the information from the Licensing database 18804 and moves it to the Recycle Bin (implementation may differ regarding deferring the actual SQL deletes, and there is no notification of commit to the License system Administrator).
This use case has a number of extensions:
Print License
The print license use case 26002 is diagramed in
Step 1. The Actor in the Print Object use case selects a License Agreement and prints it.
Step 2. The Print license module 19312 prints a formatted report with the Document ID, the Agreement ID, the Name, the Description, the Effective Date, the Expiration Date, and the various clause flags as check boxes.
Step 3. The Print license module 19312 prints the parties to the agreement, with name, organization, and primary contact information.
Step 4. The Print license module 19312 prints the compensation terms of the agreement, printing the Term Number, Term Type, and the Description of each term along with the currency symbol and the Amount and any Due Date for the term.
Step 5. The Print license module 19312 prints the Asset Packages for the license using the Print Asset Package use case.
Step 6. The Print license module 19312 prints the Royalty Statements received for the license using the Print Royalty Statement use case.
Step 7. The Print license module 19312 prints the Expected Revenues and the Payments linked to them, printing the Payment Number, Amount, and Due Date for each Revenue and the Payment ID, Receipt Date, Currency Unit Symbol, and Amount Allocated for each Payment.
Administer Territories
The administer territories use case 26102 is diagramed in
Step 1. The System Administrator starts the transaction.
Step 2. The Administer territories module 19309 displays a list of Territories, displaying the Territory ID, Abbreviation (such as EUSA), Full Name (such as East Coast of the United States of America), and Description (such as “the region including all eastern states of the United States of America”).
Step 3. The System Administer takes one of the following actions:
Step 4. The System Administrator ends the transaction.
Step 5. The Administer territories module 19309 commits the changes in the Licensing Database 18804. The Administer territories module 19309 confirms the commit to the System Administrator.
This use case has a number of extensions:
Administer Fields of Use
The administer fields of use case 26202 is diagramed in
Step 1. The System Administrator starts the transaction.
Step 2. The Administer fields of use module 19311 displays a list of Fields of Use, displaying the Field of Use ID, Display Name (for example, “semi”), and Description (for example, “semiconductor applications”).
Step 3. The System Administer takes any of the following actions:
Step 4. The System Administrator ends the transaction.
Step 5. The Administer fields of use module 19311 commits the changes in the Licensing Database 18804. The Administer fields of use module 19311 confirms the commit to the System Administrator.
This use case has a number of extensions:
Display License Agreements
The display license agreements use case 32902 is diagramed in
Step 1. The Actor starts the transaction.
Step 2. The display license agreements module 32904 displays a table of all the License Agreements to which the Actor has read access. Each row of the table corresponds to a License Agreement The columns include the License Agreement ID, the Name, the Description, the Effective Date, the Expiration Date, the Withholding Percentage, and a series of checkbox items: Exclusivity, Assignable, Transferable, Revocable, Confidential, Terminated, Perpetual, Infringement Based, Can Sublicense, Annual Audit, Audit At Licensee Expense, Favored Nation, Improvements, and Grant Back.
Step 3. The Actor ends the transaction.
This use case has a number of extensions:
Enter Adjustment
The enter adjustment use case 33302 is diagramed in
The adjustments modify the revenue stream that compensation terms generate, and the Link Adjustment to Terms use case relates an adjustment to the terms that generate the revenue that it adjusts.
It will be illustrative to consider selected background items. A license agreement structures its revenue stream based on a combination of fees and royalty payments (and possibly some other kinds of compensation). The agreement also contains terms that affect the revenue from these terms, the minimum guarantee and the advance.
A minimum guarantee is an amount of money that the licensor must receive by the end of the guarantee period, usually one year but sometimes quarterly or some other period. If the revenue from certain compensation terms does not add up to this amount, the licensee must make up the difference.
An advance is an amount paid to the licensor by the licensee in advance of revenue (usually royalties). The licensee then subtracts the advance amount from the compensation due until the entire amount of the advance is accounted for. From that point on, the licensee then begins payments to the licensor.
Any given adjustment may cover any number of different compensation terms for the same license. For example, an advance may cover an initial fee and a series of royalty payments. A minimum guarantee could cover two or three different royalty terms but not a maintenance fee.
The operation of this use case is further described below.
Step 1. The using use case passes in the object identifier for the license agreement to which the Data Entry Clerk or License Administrator (the Actor) wants to add adjustments.
Step 2. The enter adjustment module 33302 displays a list of the current set of adjustments for this license in preferably order of term number, displaying the Description, the Amount with its currency symbol, the Due Date, and the Adjustment Type.
Step 3. The Actor creates a new adjustment and selects one of the term types (Minimum Guarantee or Advance).
Step 4. The enter adjustment module 33302 displays the adjustment with default values (Amount 0, Currency from the last term or the default currency for the system, and Due_Date empty). It displays a form for the term given the default term type (see Extensions).
Step 5. The Actor enters the standard details for the adjustment and the details for the particular term type (see Extensions), then either repeats from step 3 or ends the use case.
Step 6. The enter adjustment module 33302 inserts the new terms into the Licensing Database 18804.
This use case has a number of extensions.
Modify Adjustment
The modify adjustment use case 33702 is diagramed in
The Licensing Administrator also modifies the links between adjustments and compensation terms for the license agreement in the Link Adjustment to Terms use case. See the Enter Adjustment use case for background material on adjustments.
The operation of this use case is further described below.
Step 1. The using use case passes in the object identifier for the license agreement in which the License Administrator wants to change adjustments.
Step 2. The modify adjustment module 33704 displays a list of the current set of adjustments for this license in order of term number, displaying the term Description and the Term Type.
Step 3. The License Administrator selects an adjustment for modification.
Step 4. The modify adjustment module 33704 displays the current values for the selected adjustment through a data entry form for the adjustment, including due date, currency, amount, or description.
Step 5. The License Administrator changes any of these values, then ends the use case.
Step 6. The modify adjustment module 33704 updates the adjustment in the Licensing Database 18804.
Link to Adjustment
The link to adjustment use case 33802 is diagramed in
It will be illustrative to consider selected background items. The invention allows one to adjust the revenue stream from a compensation term through advances or minimum guarantees. These are adjustment objects that are part of the license.
The advance is a payment from the licensee to the licensor in anticipation of revenue from the license. When the revenue comes due, the amount from the compensation terms covered by the advance is reduced by the amount of the advance until the revenue accounts for the entire advance.
The minimum guarantee is a floor for revenue during a specific period, usually a year. If the revenue for that period does not come up to the guaranteed amount, the difference becomes due as a separate payment.
Advances and minimum guarantees may apply to only certain compensation terms associated with the license. Linking the compensation terms to the adjustments lets you specify exactly how to adjust the revenue generated from the compensation terms in the Create Expected Revenue use case.
The operation of this use case is further described below.
Step 1. The License Administrator starts the use case with an open transaction containing a compensation term that will link to the adjustments. The extended use case supplies the object identifier for the agreement.
Step 2. The link to adjustment module 33804 displays the types and descriptions of the adjustments for the license that owns the compensation term in a list ordered by adjustment number within the license, displaying any existing links.
Step 3. The License Administrator selects one or more adjustments from the list.
Step 4. The adjustment module 33804 creates and displays a link for each adjustment the License Administrator selects.
Step 5. The Licensing Database 18804 links the adjustments to the compensation term through the Term Adjustment association table.
This use case has a number of extensions.
Remove Compensation Adjustment
The remove compensation adjustment use case 33902 is diagramed in
Step 1. The using use case passes in the object identifier for the license agreement in which the License Administrator wants to change compensation adjustments.
Step 2. The remove compensation adjustment module 33904 displays a list of the current set of compensation adjustments for this license in order of adjustment number, displaying the term Description and the Adjustment Type.
Step 3. The License Administrator selects an adjustment to remove. In an embodiment, the adjustment cannot link to any compensation terms of the license.
Step 4. The remove compensation adjustment module 33904 deletes the information from the Licensing Database 18804 and moves it to the Recycle Bin.
Preferably, if the selected compensation adjustment has any compensation term objects associated with it, the remove compensation adjustment module 33904 refuses to remove the compensation adjustment and instead displays an error message, “Cannot remove this compensation adjustment because there are links to compensation terms of this license.”
Royalty Statements Use Cases
A royalty statement is a document that a licensee submits to a licensor to specify the licensed royalties owed for a given royalty period. A royalty statement includes a number of royalty statement details. Each royalty statement detail lists a product, a number of units sold, an amount of revenue, and a calculated royalty amount.
The Royalty Statements View 26302 contains two panes, a license agreement spreadsheet 26304 and a royalty statement spreadsheet 26306.
Enter Royalty Statement
The enter royalty statement use case 26301 is diagramed in
Step 1. The Data Entry Clerk begins the transaction to enter a new royalty statement. The royalty statement view 26302 (
Step 2. The Data Entry Clerk uses the Query License use case to identify and select the license to which the new royalty statement applies. Alternatively, the Data Entry Clerk can select a license in the license agreement pane 26304 of the royalty statement view 26302.
Step 3. The Enter royalty statement module 19370 creates an object identifier for the new royalty statement that it uses to relate the statement to the queried license agreement and to the statement details. It then links the royalty statement to the queried license.
Step 4. A royalty statement dialog 26402 (
Step 5. In the details tab 26406 (see
Step 6. The Data Entry Clerk commits the transaction.
Step 7. The Enter royalty statement module 19370 inserts the Royalty Statement and its details into the licensing database 18804. The Enter royalty statement module 19370 requests the IPAM Security System 19202 to set the document classification. The enter royalty statement module 19370 confirms the commit to the Data Entry Clerk.
At any time, if the Data Entry Clerk presses F1 or the equivalent, the application extends the use case with the Display Context-Sensitive Help use case.
Modify Royalty Statement
The modify royalty statement use case 26702 is diagramed in
Step 1. The License Administrator begins the transaction.
Step 2. The Modify royalty statement module 19366 displays the licenses to which the License Administrator has read access, displaying the object identifier, the Agreement ID, the Name, and the Description, in a form similar to that shown in
Step 3. The License Administrator selects a license from the license pane 26304.
Step 4. The Modify royalty statement module 19366 displays a list of existing royalty statements attached to the license in the royalty statement pane 26306. The Modify royalty statement module 19366 displays only those royalty statements to which the License Administrator has Read access.
Step 5. The License Administrator selects a royalty statement for modification from the royalty statement pane 26306.
Step 6. If the License Administrator has Write access to the royalty statement, the Modify royalty statement module 19366 displays the current field values in a form similar to that shown in
Step 7. The License Administrator may modify the royalty statement Invoice Number, Due Date, Receipt Date, or the Investigation Window Date in any order.
Step 8. If the details tab 26406 is selected, the Modify royalty statement module 19366 displays the details for the selected royalty statement, displaying the product, the Units Sold, the Currency, and the Revenue.
Step 9. For each detail item on the royalty statement, the License Administrator can modify the name of the product, the number of units sold, or the revenue received and its currency unit, in any order.
Step 10. The License Administrator commits the transaction.
Step 11. The Modify royalty statement module 19366 updates the royalty statement.
Step 12. If the License Administrator updated the time interval for the reporting period, the Modify royalty statement module 19366 creates a new time interval and adds the new period to the Licensing Database 18804 and removes the previous one if it is not linked to any other statements, making the relevant changes to the Time Period extent as well.
Step 13. For each detail modified, the Modify royalty statement module 19366 updates the detail.
Step 14. The Modify royalty statement module 19366 confirms the commit to the License Administrator.
This use case has a number of extensions:
Query Statement
The query statement use case 26802 is diagramed in
Step 1. The Auditor starts the transaction.
Step 2. The Query statement module 19372 displays the licenses to which the Auditor has read access, displaying the object identifier, the Agreement ID, the Name, and the Description in a format similar to that shown in
Step 3. The Auditor selects a license for query of statements.
Step 4. The Query statement module 19372 displays a query form that lets the Auditor enter selection conditions on the set of statements, including object identifier, the reporting period Start and End Dates, the Invoice Number, the Due Date, the Receipt Date, and/or the Investigation Window Date.
Step 5. The Auditor enters query criteria and starts the query.
Step 6. The Query statement module 19372 displays the royalty statements for the license in preferably reverse chronological order to which the Auditor has Read access, displaying the object identifier, the reporting period Start and End Dates, the Invoice Number, the Due Date, the Receipt Date, and the Investigation Window Date.
Step 7. The Auditor selects a statement.
Step 8. The Query statement module 19372 queries all the details of the selected royalty statement from the Licensing Database 18804 and displays them, if any, showing the Product, the Units Sold, the Revenue and its currency unit symbol, and the Royalty Due, in a form similar to that shown in
Step 9. The Auditor selects a detail.
Step 10. The Query statement module 19372 queries all the payment detail allocations from the Licensing Database 18804 and displays the Amount Allocated for each one with a label that allows the Auditor to see it, if any. The Query statement module 19372 displays the Amount Allocated in the currency of the detail, converting it if the currency of the payment is different from the detail currency unit using the Convert Currency use case. The Query statement module 19372 lists the allocations in preferably Receipt Date order.
Step 11. The Auditor ends the transaction.
Remove Royalty Statement
The remove royalty statement use case 26902 is diagramed in
Step 1. The System Administrator begins the transaction.
Step 2. The Remove royalty statement module 19307 displays a list of existing royalty statements.
Step 3. The System Administrator selects one or more royalty statements and removes them.
Step 4. The Remove royalty statement module 19307 deletes the information from the licensing database 18804 moves it to the Recycle Bin (implementation may differ regarding details on deferring the actual SQL deletes, and there is no notification of commit to the System Administrator).
This use case has a number of extensions:
Print Statement
The print statement use case 27002 is diagramed in
Step 1. The Actor in the Print Object use case or the Print License Use case selects a Royalty Statement and prints it.
Step 2. The Print statement module 19314 prints a formatted report with the Start Date, End Date, Agreement Name, Agreement ID, any Invoice Number, the Due Date, the Receipt Date, and/or the Investigation Window Date.
Step 3. The Print statement module 19314 prints the Royalty Statement Details for the statement. Each detail contains the Product Name, Product Description, Units Sold, Revenue, Currency Unit Symbol, and/or Royalty Due.
Step 4. For each detail, the Print statement module 19314 prints any payment allocations, printing the Payment ID, the Receipt Date, any Invoice Number, the Payor Name, the Amount Allocated, the Currency Unit Symbol, the Payment Amount, and/or the Payment Withheld Amount, preferably ordering the list by receipt date of the payment.
Display Royalty Statements
The display royalty statements use case 33402 is diagramed in
Step 1. The Actor starts the transaction.
Step 2. The display royalty statements module 33404 displays a table of all the License Agreements to which the Actor has read access using the Display License Agreements use case.
Step 3. The Actor selects a single license agreement from that table.
Step 4. The display royalty statements module 33404 displays a table of all the Royalty Statements from the Licensing Database 18804 to which the Actor has read access. Each row of the table corresponds to a single Royalty Statement The columns include the Reporting Period's Start Date and End Date, the Invoice Number, the Due Date, the Receipt Date, and the Investigation Window Date.
Step 5. The Actor ends the transaction.
Query Statement
The query statement use case 33102 is diagramed in
Step 1. The Auditor starts the transaction.
Step 2. The query statement module 33104 displays the licenses using the Display Licenses use case.
Step 3. The Auditor selects a license for query.
Step 4. The query statement module 33104 displays a form that lets the Auditor enter any combination of the reporting period Start and End Dates, the Invoice Number, the Due Date, the Receipt Date, and the Investigation Window Date.
Step 5. The Auditor enters values into the query form fields and starts the query.
Step 6. The query statement module 33104 combines the entries into a complete query expression, executes the query in the Licensing Database 18804, then displays the resulting statements in the system that satisfy the query conditions to which the Auditor has read access, ordered by start date.
Step 7. The Auditor selects a statement.
Step 8. The query statement module 33104 queries all the details of the selected royalty statement from the Licensing Database 18804 and displays them in order of Line Number, if any, showing the Product, the Units Sold, the Revenue and its currency unit symbol, and the Royalty Due.
Step 9. The Auditor selects a detail.
Step 10. The query statement module 33104 queries all the payment detail allocations from the Licensing Database 18804 and displays the Amount Allocated for each one with a label that allows the Auditor to see it, if any. The query statement module 33104 displays the Amount Allocated in the currency of the detail, converting it if the currency of the payment is different from the detail currency unit using the Convert Currency use case. The query statement module 33104 lists the allocations in preferably Receipt Date order.
Step 11. The Auditor ends the transaction.
Payment Use Cases
A payment is an amount of money the licensee sends to the licensor based on the amount they owe for fees, royalties, advances, minimum guarantees, and other compensation terms. To produce various reports, the License Administrator must link these payments to expected revenue periods and to royalty statement details.
The Payments View 27102 contains two panes, a license agreement spreadsheet 27104 and a payment spreadsheet 27106. The agreement pane 27104 lets you select a license, and the payment pane 27106 displays the payments for that license. You add and modify payments by double-clicking on a blank row or as existing row, as with all the other views.
Enter Payment
The payment use case 27602 is diagramed in
Step 1. The Data Entry Clerk starts the transaction to enter a new payment.
Step 2. The Enter payment module 19374 displays a list of licenses in the license pane 27104 of the payments view 27102.
Step 3. The Data Entry Clerk selects a license in the license pane 27104 of the payments view 27102.
Step 4. The Enter payment module 19374 displays a list of payments for the license in the payments pane 27106.
Step 5. The Data Entry Clerk signals the desire to add a new payment for the selected license using any procedure described herein.
Step 6. The Enter payment module 19374 displays a form 27202 (
Step 7. In the general tab 27204, the Data Entry Clerk enters the Receipt Date, the Amount received, and the Currency in any order. Optionally, the Data Entry Clerk enters a withheld amount (the part of the total amount of the payment that represents a foreign company's withholding of tax due on the payment), an invoice number (for an invoice needed to release the payment from a foreign tax authority), and any late payment interest amount (part of the total amount of the payment that is a penalty for late payment based on the interest rate in the license agreement), again in any order. The Data Entry Clerk selects a Security Class for the payment. The Data Entry Clerk commits the transaction. Data is not typically entered into the royalty statement details tab 27206 and the expected revenue tab 27208, although these tabs are active and accessible according to an embodiment of the invention.
Step 8. The Enter payment module 19374 creates a persistent payment and a link to the indicated license. The Enter payment module 19374 confirms the committed transaction to the Data Entry Clerk.
At any time, if the Data Entry Clerk presses F1 or the equivalent, the application extends the use case with the Display Help use case.
Modify Payment
The modify payment use case 27702 is diagramed in
Step 1. The License Administrator starts the transaction.
Step 2. The Modify payment module 19376 displays using the payments view 27102 the licenses in the modify payment module 19376 to which the License Administrator has read access, displaying the object identifier, the Agreement ID, the Name, and the Description.
Step 3. The License Administrator selects a license listed in the license agreement pane 27104.
Step 4. The Modify payment module 19376 displays in the payments pane 127106 the payments for the license to which the License Administrator has Read access, displaying the object identifier, the Payor Name, the Security Class, the Currency Symbol, The Amount, the Withheld Amount, the Late Payment Interest Amount, the Receipt Date, and/or the Invoice Number.
Step 5. The License Administrator selects a payment from the payments pane 27106.
Step 6. If the License Administrator can write to the payment, the Modify payment module 19376 displays a form 27202 (
Step 7. The License Administrator optionally modifies any of the fields except for the object identifier and commits the transaction.
Step 8. The Modify payment module 19376 updates the payment in the Licensing Database 18804. The Modify payment module 19376 confirms the committed transaction to the Licensing Administrator.
This use case has a number of extensions:
Link to Expected Revenue
The link to expected revenue use case 27802 is diagramed in
Step 1. The License Administrator initiates the use case from the calling use case, passing in an object identifier for a payment and an object identifier for a license agreement to which the payment applies.
Step 2. The Link to expected revenue module 19378 displays in an estimate pane 27408 of the expected revenue tab 27208 (
Step 3. The License Administrator selects an estimate and enters an allocation amount for it. This can be done by entering an amount in field 27402, or a percentage of the total payment in field 27404. The total payment amount is displayed in field 27406. This step repeats, as necessary.
Step 4. The Link to expected revenue module 19378 stores an allocation amount into the Licensing Database 18804 for each non-zero allocation entered in step 3.
This use case has a number of extensions:
Link to Detail
The link to detail use case 27902 is diagramed in
Step 1. The License Administrator initiates the use case from the calling use case, passing in an object identifier for a payment and an object identifier for a license agreement to which the payment applies.
Step 2. The Link to detail module 19380 displays the royalty statements for the license in the royalty statement details tab 27206 (
Step 3. The License Administrator selects a detail and enters an allocation amount. This can be done by entering an amount (such as in field 27304), or a percentage of the payment total (such as in field 27308). This step repeats as necessary.
Step 4. The License Administrator signals completion.
Step 5. The Link to detail module 19380 creates links between the details and the payment.
This use case includes a number of extensions:
Print Payment
The print payment use case 28002 is diagramed in
Step 1. The Actor in the Print Object use case selects a Payment and issues a command to print it.
Step 2. The Print payment module 19316 prints a formatted report with the Payment ID, the Currency Unit Symbol, the Amount, the Withheld Amount, the Late Payment Interest Amount, the Receipt Date, the Invoice Number, etc.
Step 3. The Print payment module 19316 prints the General Ledger Entries, printing the OL Account Number, the Account Description, the Amount, the Entry Date, and the Entry Type (credit or debit).
Step 4. The Print payment module 19316 prints the allocations of the payment to royalty statement details, including the Royalty Statement Start and End Dates, the Detail Line Number, the Product Name, the Detail Currency Unit Symbol, Detail Royalty Due, and the Amount Allocated.
Step 5. The Print payment module 19316 prints the allocations of the payment to expected revenue, including the License Agreement ID and Name, the Term Number, the Expected Currency Unit, the Expected Amount, the Expected Due Date, and the Amount Allocated.
Remove Payment
The remove payment use case 28102 is diagramed in
Step 1. The System Administrator begins the transaction.
Step 2. The Remove payment module 19313 displays a list of all the payments in the Licensing Database 18804, displaying the Payment ID, the Payor Name, the Receipt Date, and the Amount
Step 3. The System Administrator selects one or more payments and removes them (that is, issues command(s) to remove them).
Step 4. The Remove payment module 19313 deletes the information from the Licensing database 18804 and moves it to the Recycle Bin (implementation may differ regarding deferring the actual SQL deletes, and there is no notification of commit to the System Administrator).
This use case has a number of extensions:
Query Payment
The query payment use case 28202 is diagramed in
Step 1. The Auditor starts the transaction.
Step 2. The Query payment module 19384 displays the licenses to which the Auditor has read access, displaying the object identifier, the Agreement ID, the Name, and the Description.
Step 3. The Auditor selects a license for query of payments.
Step 4. The Query payment module 19384 displays a query form that lets the Auditor enter selection conditions on the set of payments, including object identifier, Payor Name, payment Receipt Date, Amount, Withheld Amount, Late Payment Interest Amount, and/or Invoice Number.
Step 5. The Auditor enters query criteria and starts the query.
Step 6. The Query payment module 19384 displays the payments for the license in preferably reverse chronological order to which the Auditor has Read access, displaying the object identifier, object identifier, Payor Name, payment Receipt Date, Amount, Withheld Amount, Late Payment Interest Amount, and/or Invoice Number.
Step 7. The Auditor selects a payment.
Step 8. The Query payment module 19384 displays a list of General Ledger entries, if any, showing the Entry Type, GL Account Number, Amount, Currency Unit Symbol, and Entry Date. The Query payment module 19384 preferably orders the entries by GL Account Number.
Step 9. The Query payment module 19384 displays a list of Payment Detail Allocations, showing the Royalty Statement Start Date Time and Amount Allocated. The Query payment module 19384 preferably orders the allocations by License Name, Start Date Time, and Line Number.
Step 10. The Query payment module 19384 displays a list of License Payment Allocations, showing the License Name, Payment Number, Expected License Revenue Description and Due Date, and Amount Allocated. The Query payment module 19384 preferably orders the allocations by License OID, Term Number, and Payment Number.
Step 11. The Auditor ends the transaction.
At any time, if the Data Entry Clerk presses F1 or the equivalent, the application extends the use case with the Display Help use case.
Maintain GL Accounts
The maintain GL accounts use case 28302 is diagramed in
Step 1. The License Administrator starts the transaction.
Step 2. The Maintain GL accounts module 19386 displays the list of current GL Accounts, displaying the Account Number and the Description.
Step 3. The License Administrator modifies the set of GL Accounts, performing any of the following actions on the set of accounts:
Step 4. The License Administrator ends the transaction.
Step 5. The Maintain GL accounts module 19386 commits the changes in the Licensing Database 18804. The Maintain GL accounts module 19386 confirms the commit to the License Administrator.
If a GL Account relates to any General Ledger Entries, on modifying the account number, the Maintain GL accounts module 19386 prompts the License Administrator whether to change the account number for the Entries or to cancel the transaction.
Link Payment to Entity
The link payment to entity use case 32702 is diagramed in
It will be illustrate to consider the following scenario. A licensor licenses packages of assets to licensees with a license agreement. The licensees use the assets to produce products that generate revenue. Depending on the license agreement compensation terms, the licensee pays various kinds of payments to the licensor: fees or royalties. These payments constitute a revenue stream to the licensor as a series of payments from the licensee. A single payment may encompass more than one license, so the link between payment and license has a percent allocation that allocates a specific percentage of the payment to a particular license.
The licensor is usually an organization. Often, the licensor is not the business unit or person that ultimately “gets” or recognizes the revenue from a license for accounting purposes. That entity may be an organizational child of the licensor, but not necessarily, and there may be more than one entity that gets revenue from a license. A licensor therefore must have a way to allocate payment revenue from a particular license (a portion of a payment) to one or more named entities (people or organizations).
The operation of this use case is further described below.
Step 1. The link payment to entity module 32704 passes in the object identifier for a license agreement and a payment (a License Payment link).
Step 2. The System displays the current set of links to entities from this license-payment link, displaying the name, description, and entity type for each linked entity.
Step 3. The License Administrator uses the Query Entities use case to display a list of entities. The License Administrator selects a single named entity from the result of the query and links it to the license-payment link. The Query Entity use case returns the object identifier for the entity to this use case.
Step 4. The link payment to entity module 32704 displays a form that lets the license administrator allocate a percentage of the license-payment amount to the entity. It displays a default value of 100% if there are no license payment allocations for this license-payment link or the difference between the sum of existing license payment allocations for this license-payment link and 100%.
Step 5. The link payment to entity module 32704 creates a link between the license-payment and the named entity, inserting a row in the License Payment Allocation table and displaying the new link in the displayed list of links.
Step 6. The License Administrator repeats steps 3-6 or ends the use case and returns to the extending use case.
If the License Administrator wants to remove a given link, he or she selects it in the displayed list of links and tells the System to delete the link. The System then removes the link from the display and schedules the link for deletion from the database (the extending use case is running the transaction). The License Administrator can remove or add any number of links in this use case.
Display Payments
The display payments use case 32802 is diagramed in
Step 1. The Actor starts the transaction.
Step 2. The display payments module 32804 displays a table of all the License Agreements to which the Actor has read access using the Display License Agreements use case.
Step 3. The Actor selects a single license agreement from that table.
Step 4. The display payments module 32804 displays a table of all the Payments from the Licensing Database 18804 to which the Actor has read access. Each row of the table corresponds to a single Payment. The columns include the Payor Name, the Currency Unit Symbol, the Payment Amount, the Late Payment Interest Amount, the Receipt Date, the Invoice Number, and the Payment-to-License Allocation Percent.
Step 5. The Actor ends the transaction.
This use case has a number of extensions:
Time Period Use Cases
The invention supports time period related structures. For example, Royalties and Fees often have a recurring payment. For example, a royalty may be due at the end of every quarter, on every June 15, or something similar. Most license royalties and fees call for monthly, quarterly, or annual payments.
Generally, recurring periods may terminate in one of two ways. A count-limited period has a certain number of periodic payments. For example, you could have a yearly fee due on June 15th for five payments. A date-limited period goes to a certain end date: a royalty paid quarterly on the 15th of the second month of the quarter ending on Feb. 15, 2015.
The beginning interval from the start date to the first recurring date may differ significantly in size from the other dates, as may the period from the last recurring date to an end date for a date-terminated period. For example, you may owe an annual fee every June 15th, with the sequence starting on June 1. The first interval will be 15 days, while the second and onwards will be one year.
In this section, time period use cases are described.
Enter Recurring Time Period
The enter recurring time period use case 33202 is diagramed in
Step 1. The enter recurring time period module 33202 displays a data entry form containing the Time Unit (default Year), the Repetition (default 1), and the Recurring Period Type (default Count Limited).
Step 2. The Actor chooses a Time Unit, a Repetition, and/or a Recurring Period Type.
Step 3. The enter recurring time period module 33202 returns the appropriate object back to the using use case. The enter recurring time period module 33202 sets the Time Period's Time Period Type field to “R” to indicate a recurring period object.
This use case has a number of extensions.
Modify Recurring Time Period
The modify recurring time period use case 33602 is diagramed in
Step 1. The actor passes in the object identifier for a time period to modify (:TimePeriod_ID).
Step 2. The modify recurring time period module 33604 displays a data entry form containing the Time Unit (default Year), the Repetition (default 1), and the Recurring Period Type (default Count Limited), all displaying the current values for the time period the actor passes in (:TimePeriod_ID) queried from the Licensing database 18804.
Step 3. The Actor changes the Time Unit, a Repetition, and/or the Recurring Period Type.
Step 4. The modify recurring time period module 33604 returns the appropriate object back to the using use case.
This use case has a number of extensions.
If the Recurring Period Type is Date Limited, the modify recurring time period module 33604 adds the Date_Limited_Recurring_Period table to the following SQL queries as the <concrete subclass> and displays the End Date field. This controls the number of recurring dates within the whole period by ending the period at a certain date. If the actor changes the Recurring Period Type to Count Limited, the modify recurring time period module 33604 changes to display the Number of Recurrences field and deletes the date-limited row when the transaction completes, replacing it with a new Count_Limited_Recurring_Period row.
Reports Use Cases
Reports are a critical part of the Licensing module 18702. It is through reports that the license administrator and auditor (or any other user) obtain a great amount of useful information from system.
All available reports are listed in a reports pane 28404 of a reports view 28402 (
Preferably, a report engine is used to generate the reports. When the user selects a report, the licensing system 18702 generates one or more commands that collectively encapsulates the user-selected report type and any user-provided parameters. The details of these commands will be apparent to persons skilled in the relevant art(s). These commands are in the language of the report engine. The report engine generates the report pursuant to the commands. In doing so, the report engine accesses data (as indicated in the commands) in the databases discussed herein. In an embodiment, a commercial reporting module is used as the report engine, such as the commercially available Crystal Reports product.
Generate Report
The generate report use case 28502 is diagramed in
Step 1. The Actor begins the transaction to run a report.
Step 2. The Generate report module 19388 constructs a list of available reports, displaying the name and description for the report in the reports view 28402 (
Step 3. The Actor selects a report and requests that it be run, supplying appropriate parameters through a parameter form as requested and required, including the report destination (print or screen or file), ending the transaction.
Step 4. The Generate report module 19388 runs the report and sends it to the indicated destination.
The following are examples of reports: These are presented for illustrative purposes, and the invention is not limited to these examples. The invention is directed to include any reports of interest that can be generated from the information contained in the databases described herein. Implementation of these and other reports will be apparent to persons skilled in the relevant art(s). It is noted that license related reports can be in a plurality of forms, such as those shown in the figures, and in forms including hyperbolic trees (described above).
The Draft License is a report that is in the form of a license agreement document, that is generated by the system based on information in the databases. This draft document can be modified as necessary to produce the actual license agreement document.
Security Use Cases
In an embodiment, Licensing system security includes the security features described above. In other embodiments, Licensing system security includes any combination of the above with one or more other features, such as the following administrative use cases, the ability to assign a security classification in the various document and payment entry and modification use cases, and the ability to change privileges on asset groups.
Administer Entities (Users)
The administer users use case 29402 is diagramed in
Step 1. The System Administrator starts the transaction.
Step 2. The Administer entities module 19315 displays a list of users ordered by name, displaying the User Name, User Full Name, and Password (the password field appears but the actual password does not); there is also a Confirm Password for validating password entry.
Step 3. The System Administer takes one of the following actions:
Step 4. The System Administrator ends the transaction.
Step 5. The Administer entities module 19315 commits the changes in the core database 18808. The Administer entities module 19315 confirms the commit to the System Administrator.
This use case has a number of extensions:
Administer Security Classes
The administer security classes use case 29502 is diagramed in
Step 1. The System Administrator starts the transaction.
Step 2. The Administer security classes module 19317 displays a list of Security Classes, displaying the Security Class ID and Name, and a list of the Entities, displaying the Entity ID and User Name.
Step 3. The System Administer takes one of the following actions:
Step 4. The System Administrator ends the transaction.
Step 5. The Administer security classes module 19317 commits the changes in the Licensing Database 18804. The Administer security classes module 19317 confirms the commit to the System Administrator.
At any time, if the System Administrator presses F1 or the equivalent, the application extends the use case with the Display Help use case.
Grant Permissions
The grant permissions use case 29602 is diagramed in
Step 1. The System Administrator starts the transaction.
Step 2. The Grant permissions module 19319 displays a list of the secure objects to which the System Administrator has access based on their current authentication user name. It gets this from the IPAM Security Subsystem 19202. The Grant permissions module 19319 displays the objects sorted into two groups, asset packages and classifiers, distinguishing them by type (an icon, separate panes, or whatever). The asset packages display the Package OID and the Name. The classifiers display the Security Class OID and the Name.
Step 3. The System Administrator selects a secure object.
Step 4. The Grant permissions module 19319 displays a control that lists available entities ordered by entity type and name, which it gets through the IPAM Security Subsystem 19202.
Step 5. The System Administrator selects one or more entities.
Step 6. The Grant permissions module 19319 displays the current permission settings on the secure objects (Read, Write, Delete), distinguishing settings that are the same for all selected secure objects and entities from those that are different (for example, a greyed check mark).
Step 7. The System Administrator sets the permission flags (Read, Write, Delete) to new values as required, then ends the transaction.
Step 8. The Grant permissions module 19319 passes the changes to the IPAM Security Subsystem 19202, which updates the security tables in the Core Database 18808.
Administer Roles
The administer roles use case 30002 is diagramed in
Step 1. The System Administrator starts the transaction.
Step 2. The Administer roles module 19321 displays a list of Roles, displaying the Role ID, Name, and Description.
Step 3. The System Administer takes one of the following actions:
Step 4. The System Administrator ends the transaction.
Step 5. The Administer roles module 19321 commits the changes in the Licensing database 18804. The Administer roles module 19321 confirms the commit to the System Administrator.
This use case has a number of extensions:
Currency Use Cases
The various monetary amounts in Licensing module 18702 may be in any currency. This can cause problems when payments, royalty statements, and compensation terms list the amounts in different currencies. The Convert Currency use case provides a currency conversion mechanism for the generate report module 19388. This is visible to the user when the user takes an action that needs to operate on amounts in different currencies.
Currency conversion depends on a database of conversion ratios. These ratios vary over time. Depending on the customer's needs, the customer could want to have a different ratio every day, every month, or every year. Or, they could just want a single conversion rate. The Maintain Currency Conversions use case corresponds to a menu entry that lets the License Administrator enter open-ended time intervals and conversion ratios that hold during those intervals.
Convert Currency
The convert currency use case 29802 is diagramed in
Step 1. The using use case passes in the monetary amount, the currency object identifier, and the date of the transaction.
Step 2. The Convert currency module 19390 looks up the currency conversion rate in the licensing database 18804. The conversion rate depends on the date of the transaction, because currency rates fluctuate with time.
Step 3. The Convert currency module 19390 returns the converted amount in dollars.
This use case has a number of extensions:
Maintain Currency Conversions
The maintain currency conversions use case 29902 is diagramed in
The operation of this use case is further described below.
Step 1. The License Administrator begins the transaction.
Step 2. The Maintain currency use case 29902 displays a list of currencies, displaying the Unit Name, Country, and Unit Symbol for the currency:
Step 3. The License Administrator selects a currency or adds a new currency. The License Administrator optionally changes the Unit Name, Country, or Unit Symbol or removes the currency.
Step 4. If the currency is new, the Maintain currency use case 29902 creates a new currency object identifier. The Maintain currency use case 29902 displays the time interval layout of the currency, displaying the Start Date, the Dollar Conversion Rate, and the Description, if any:
Step 5. The License Administrator selects an interval, if there are any.
Step 6. The License Administrator removes the selected interval or changes the Start Date, Dollar Conversion Rate, or Description fields.
Step 7. The License Administrator repeats steps 3-6 or commits the transaction.
Step 8. The Maintain currency use case 29902 inserts any new currencies, updates any changed currencies, and deletes any removed currencies (including any currency intervals). The Maintain currency use case 29902 inserts any new intervals, updates any changed intervals, and deletes any removed intervals. The Maintain currency use case 29902 confirms the commit to the License Administrator.
This use case has an extension. Specifically, if the License Administrator wants to add a new interval to the existing set, the Maintain currency use case 29902 displays the new interval at the bottom of the list of current intervals. The License Administrator enters the Start Date, the Description, and the Dollar Conversion Rate. When the License Administrator selects another interval, the Maintain currency use case 29902 sorts the list and puts the new interval in its proper place in the list ordered by date.
Top Level Operational Examples of the Licensing System
An example thread of operation through the licensing system 18702 shall now be described with reference to a flowchart 30102 in
In the following, the steps are said to be performed by a “user.” Generally, this user can be any person desiring to use the licensing system 18702, including any of the actors described herein. Also, different users can perform different steps.
In step 30104, the user defines entities. These entities will later be assigned to roles, such as licensee and licensor. See, inter alia, the Administer Entity use case.
In step 30106, the user creates IP (intellectual property) assets. This involves entering patent assets if the licensing system 18702 is not integrated with the IPAM database 316. If the licensing system 18702 is integrated with the IPAM database 316, then there is no need to enter patent assets as such patent assets are accessible from the IPAM database 316 (although in some embodiments, the user is allowed to enter patent assets even when the licensing system 18702 is integrated with the IPAM database 316, since, for example, the IPAM database 316 may not include all U.S. and/or foreign patents, reissues, reexaminations, etc.). This step also includes entering trademark assets, entering trade secret assets, entering copyright assets, entering know how assets, etc. See, inter alia, the Enter Patent, Enter Trademark, Enter Copyright, Enter Trade Secret, and Enter Know How use cases.
In step 30108, the user creates asset packages. Each asset package includes IP assets to license. There are three types of asset packages: standard, group, and descriptive. When entering a standard asset package, the user manually selects assets for inclusion into the asset package (this can be done via drag and drop operations, for example). When entering a group asset package, the user selects an IPAM group. The assets in the IPAM group become the contents of the asset package. When entering a descriptive asset package, the user provides a description of the assets being licensed, such as “All patents and patent applications currently existing as of Jun. 18, 1997.” See, inter alia, the Create IP Asset Package use case.
In step 30110, optionally, the user provides a revenue allocation percentage for each asset in an asset package. An asset's revenue allocation percentage within an asset package indicates the degree to which that asset contributed to license revenue attributed to the asset package. For example, if an asset within an asset package has an allocation percentage of 65%, and a license revenue of $100 is attributed to the asset package, then that asset is considered to have been responsible for generating $65 of the $100 license revenue. See, inter alia, the Create IP Asset Package use case.
In step 30112, the user creates a license agreement. See, inter alia, the Enter License Agreement use case. In doing so, the user specifies the parties to the agreement, such as the licensee(s) and the licensor(s). These parties are entities who were defined in step 30106. See, inter alia, the Link to Party use case.
The license agreement is an instrument that operates to license IP assets from the licensor(s) to the licensee(s). According to an embodiment of the invention, the IP assets that are being licensed via the license agreement are specified via asset packages. Specifically, in step 30112, the user identifies one or more asset packages that contain the IP assets that are desired to be licensed via the license agreement. These identified asset packages are linked to the license agreement. See, inter alia, the Link to Asset Package use case.
A license agreement includes a number of terms agreed upon by the parties, such as whether the license is limited to particular territories, whether the license is exclusive or not exclusive, whether the license includes grant back provisions, etc. Importantly, a license also includes compensation terms, which specify the compensation that the licensee pays to the licensor for the benefit of receiving the license to the IP assets contained in the linked asset packages. Accordingly, also in step 30112, the user enters compensation terms for the license. See, inter alia, the Enter Compensation Term use case.
In step 30114, optionally, the user determines the expected revenue of the license agreement. This is preferably done on a per compensation term basis. Specifically, for each compensation term, a schedule of expected future revenue payment(s) is calculated, based on the type and characteristics of the term. For example, if Term1 is a lump sum payment of $100 to be paid on Jan. 1, 2000, then the expected revenue of Term 1 is calculated to be $100 to be received by the licensor on Jan. 1, 2000. If Term2 is an ongoing royalty based on per unit sales, where the royalty rate is $1 per 100 units and the estimated unit sales is 1000 per period (specified via the Enter Compensation Term use case), then the expected revenue of Term2 is calculated to be $10 per period. These expected future revenue payments are displayed in the expected revenue tab 27208 of the payment dialog 27202 (FIG. 272). See, inter alia, the Enter Compensation Term and Create Expected Revenue use cases.
In step 30116, the user receives a royalty statement related to the license from the licensee. Licensees are typically required to send such royalty statements to the licensor, such as on a quarterly basis. The user enters the royalty statement into the system. This includes entering the period to which the royalty statement applies. This also includes entering the details of the royalty statement, where each detail corresponds to a product, the number of units of the product sold during the period, the revenue generated by the sales, and the royalty due. This information is obtained from the royalty statement. See, inter alia, the Enter Royalty Statement use case.
In step 30118, the user receives a license revenue payment related to the license. The user enters the payment into the system. This includes entering the amount of the payment. Optionally, this also includes allocating the payment to terms of the license. See
Optionally, step 30118 also includes allocating the payment to details of royalty statements received by the licensor from the licensee. See
With regard to the operation of step 30118, see, inter alia, the Enter Payment, Modify Payment, Link to Expected Revenue, and Link to Detail use cases.
In step 30120, the user runs reports based on his needs, requirements, interests, etc. Examples of reports supported by the invention include, but are not limited to: compare payments to royalty statement details; compare payments to expected revenue; determine the revenues (payments) attributable to each asset in an asset package; and any other report discussed herein. It is noted that the invention is not limited to the reports discussed herein. Any report, particularly any financial related report, relating to the subject matter discussed herein and/or derivable from the data discussed herein is contemplated by the invention. Implementation of such reports will be apparent to persons skilled in the relevant art(s).
While various embodiments of the present invention have been described above, it should be understood that they have been presented by way of example only, and not limitation. Thus, the breadth and scope of the present invention should not be limited by any of the above-described exemplary embodiments, but should be defined only in accordance with the following claims and their equivalents.
U.S. application Ser. No. 09/545,608, filed Apr. 7, 2000 is a continuation-in-part of U.S. application Ser. No. 08/921,369, filed Aug. 29, 1997, now U.S. Pat. No. 6,339,767, issued Jan. 15, 2002, which is a continuation-in-part of U.S. application Ser. No. 08/867,392, filed Jun. 2, 1997, now U.S. Pat. No. 5,991,751, issued Nov. 23, 1999, each of which is incorporated herein by reference in its entirety. U.S. application Ser. No. 09/545,608, filed Apr. 7, 2000, is a continuation-in-part of U.S. application Ser. No. 09/138,368, filed Aug. 21, 1998, now abandoned, which is a continuation-in-part of U.S. application Ser. No. 08/921,369, filed Aug. 29, 1997, now U.S. Pat. No. 6,339,767, issued Jan. 15, 2002, each of which is incorporated herein by reference in its entirety. U.S. application Ser. No. 09/545,608, filed Apr. 7, 2000, is a continuation-in-part of U.S. application Ser. No. 09/260,079, filed Mar. 2, 1999, now abandoned, which is a continuation-in-part of U.S. application Ser. No. 09/138,368, filed Aug. 21, 1998, now abandoned, which is a continuation-in-part of U.S. application Ser. No. 08/921,369, filed Aug. 29, 1997, now U.S. Pat. No. 6,339,767, issued Jan. 15, 2002, each of which is incorporated herein by reference in its entirety. U.S. application Ser. No. 09/545,608, filed Apr. 7, 2000, is a continuation-in-part of U.S. application Ser. No. 09/057,557, filed Apr. 9, 1998, now U.S. Pat. No. 6,389,434, issued May 14, 2002, which is a continuation of U.S. application Ser. No. 08/632,801, filed Apr. 17, 1996, now U.S. Pat. No. 5,806,079, issued Sep. 8, 1998, which is a continuation-in-part of U.S. application Ser. No. 08/423,676, filed Apr. 18, 1995, now U.S. Pat. No. 5,623,679, issued Apr. 22, 1997, which is continuation-in-part of U.S. application Ser. No. 08/341,129, filed Nov. 18, 1994, now abandoned, which is a continuation-in-part of U.S. application Ser. No. 08/155,752, filed Nov. 19, 1993, now U.S. Pat. No. 5,623,681, issued Apr. 22, 1997, each of which is incorporated by reference herein in its entirety. The present application is related to the following applications and patents, each of which is incorporated herein by reference in its entirety: U.S. application Ser. No. 08/832,971, filed Apr. 4, 1997, now U.S. Pat. No. 5,809,318, issued Sep. 15, 1998; U.S. application Ser. No. 09/058,275, filed Apr. 10, 1998, now U.S. Pat. No. 5,950,214, issued Sep. 7, 1999; U.S. application Ser. No. 08/590,082, filed Jan. 23, 1996, now U.S. Pat. No. 5,754,840, issued May 19, 1998; and U.S. application Ser. No. 08/662,377, filed Jun. 12, 1996, now U.S. Pat. No. 5,799,325, issued Aug. 25, 1998. This application is a continuation of U.S. application Ser. No. 11/178,367, filed Jul. 12, 2005, now U.S. Pat. No. 7,437,471, issued Oct. 14, 2008, which is a continuation of U.S. application Ser. No. 09/545,608, filed Apr. 7, 2000, now U.S. Pat. No. 6,963,920, issued Nov. 8, 2005, which is a non-provisional of Provisional Application No. 60/128,405, filed Apr. 8, 1999, each of which is incorporated herein by reference in its entirety.
Number | Name | Date | Kind |
---|---|---|---|
4205780 | Burns et al. | Jun 1980 | A |
4270182 | Asija | May 1981 | A |
4486857 | Heckel | Dec 1984 | A |
4533910 | Sukonick et al. | Aug 1985 | A |
4555775 | Pike | Nov 1985 | A |
4622545 | Atkinson | Nov 1986 | A |
RE32632 | Atkinson | Mar 1988 | E |
4736308 | Heckel | Apr 1988 | A |
4748618 | Brown et al. | May 1988 | A |
4772882 | Mical | Sep 1988 | A |
4785408 | Britton et al. | Nov 1988 | A |
4788538 | Klein et al. | Nov 1988 | A |
4812834 | Wells | Mar 1989 | A |
4847604 | Doyle | Jul 1989 | A |
4873623 | Lane et al. | Oct 1989 | A |
4884223 | Ingle et al. | Nov 1989 | A |
4899136 | Beard et al. | Feb 1990 | A |
4914732 | Henderson et al. | Apr 1990 | A |
4931783 | Atkinson | Jun 1990 | A |
4935865 | Rowe et al. | Jun 1990 | A |
4939507 | Beard et al. | Jul 1990 | A |
4959769 | Cooper et al. | Sep 1990 | A |
4977455 | Young | Dec 1990 | A |
4985863 | Fujisawa et al. | Jan 1991 | A |
4991087 | Burkowski et al. | Feb 1991 | A |
5008853 | Bly et al. | Apr 1991 | A |
5062060 | Kolnick | Oct 1991 | A |
5072412 | Henderson, Jr. et al. | Dec 1991 | A |
5120944 | Kern et al. | Jun 1992 | A |
5142674 | Barker et al. | Aug 1992 | A |
5148154 | MacKay et al. | Sep 1992 | A |
5155806 | Hoeber et al. | Oct 1992 | A |
5157768 | Hoeber et al. | Oct 1992 | A |
5163104 | Ghosh et al. | Nov 1992 | A |
5222160 | Sakai et al. | Jun 1993 | A |
5228123 | Heckel | Jul 1993 | A |
5237158 | Kern et al. | Aug 1993 | A |
5241671 | Reed et al. | Aug 1993 | A |
5253362 | Nolan et al. | Oct 1993 | A |
RE34476 | Norwood | Dec 1993 | E |
5276616 | Kuga et al. | Jan 1994 | A |
5283894 | Deran | Feb 1994 | A |
5319745 | Vinsonneau et al. | Jun 1994 | A |
5349170 | Kern | Sep 1994 | A |
5392428 | Robins | Feb 1995 | A |
5402336 | Spiegelhoff et al. | Mar 1995 | A |
5404514 | Kageneck et al. | Apr 1995 | A |
5428778 | Brookes | Jun 1995 | A |
5432897 | Tatsumi et al. | Jul 1995 | A |
5440481 | Kostoff et al. | Aug 1995 | A |
5442778 | Pedersen et al. | Aug 1995 | A |
5444615 | Bennett et al. | Aug 1995 | A |
5481666 | Nguyen et al. | Jan 1996 | A |
5511186 | Carhart et al. | Apr 1996 | A |
5519857 | Kato et al. | May 1996 | A |
5537526 | Anderson et al. | Jul 1996 | A |
5544302 | Nguyen | Aug 1996 | A |
5544352 | Egger | Aug 1996 | A |
5550976 | Henderson et al. | Aug 1996 | A |
5551055 | Matheny et al. | Aug 1996 | A |
5557722 | DeRose et al. | Sep 1996 | A |
5557785 | Lacquit et al. | Sep 1996 | A |
5559942 | Gough et al. | Sep 1996 | A |
5568639 | Wilcox et al. | Oct 1996 | A |
5576954 | Driscoll | Nov 1996 | A |
5581686 | Koppolu et al. | Dec 1996 | A |
5583982 | Matheny et al. | Dec 1996 | A |
5584035 | Duggan et al. | Dec 1996 | A |
5592607 | Weber et al. | Jan 1997 | A |
5592608 | Weber et al. | Jan 1997 | A |
5594837 | Noyes | Jan 1997 | A |
5596700 | Darnell et al. | Jan 1997 | A |
5604901 | Kelley et al. | Feb 1997 | A |
5615112 | Liu Sheng et al. | Mar 1997 | A |
5615362 | Jensen et al. | Mar 1997 | A |
5623679 | Rivette et al. | Apr 1997 | A |
5623681 | Rivette et al. | Apr 1997 | A |
5625833 | Levine et al. | Apr 1997 | A |
5628003 | Fujisawa et al. | May 1997 | A |
5630125 | Zellweger | May 1997 | A |
5632031 | Velissaropoulos et al. | May 1997 | A |
5638519 | Haluska | Jun 1997 | A |
5642502 | Driscoll | Jun 1997 | A |
5696963 | Ahn | Dec 1997 | A |
5721910 | Unger et al. | Feb 1998 | A |
5748956 | Lafer et al. | May 1998 | A |
5754840 | Rivette et al. | May 1998 | A |
5757983 | Kawaguchi et al. | May 1998 | A |
5765152 | Erickson | Jun 1998 | A |
5774833 | Newman | Jun 1998 | A |
5794257 | Liu et al. | Aug 1998 | A |
5799325 | Rivette et al. | Aug 1998 | A |
5806079 | Rivette et al. | Sep 1998 | A |
5808615 | Hill et al. | Sep 1998 | A |
5809318 | Rivette et al. | Sep 1998 | A |
5832476 | Tada et al. | Nov 1998 | A |
5845301 | Rivette et al. | Dec 1998 | A |
5848409 | Ahn | Dec 1998 | A |
5860073 | Ferrel et al. | Jan 1999 | A |
5870770 | Wolfe | Feb 1999 | A |
5953528 | Sullivan | Sep 1999 | A |
5991751 | Rivette et al. | Nov 1999 | A |
5999907 | Donner | Dec 1999 | A |
6003033 | Amano et al. | Dec 1999 | A |
6012098 | Bayeh et al. | Jan 2000 | A |
6021426 | Douglis et al. | Feb 2000 | A |
6125391 | Meltzer et al. | Sep 2000 | A |
6226675 | Meltzer et al. | May 2001 | B1 |
6339767 | Rivette et al. | Jan 2002 | B1 |
6343297 | D'Anjou et al. | Jan 2002 | B1 |
6389434 | Rivette et al. | May 2002 | B1 |
6401118 | Thomas | Jun 2002 | B1 |
6501856 | Kuwano et al. | Dec 2002 | B2 |
6507856 | Chen et al. | Jan 2003 | B1 |
6963920 | Hohmann et al. | Nov 2005 | B1 |
7437471 | Hohmann et al. | Oct 2008 | B2 |
20050256965 | Hohmann et al. | Nov 2005 | A1 |
20070078886 | Rivette et al. | Apr 2007 | A1 |
Number | Date | Country |
---|---|---|
0 239 884 | Oct 1987 | EP |
5-135109 | Jun 1993 | JP |
6-231141 | Aug 1994 | JP |
8-221435 | Aug 1996 | JP |
WO 9816890 | Apr 1998 | WO |
WO 9834179 | Aug 1998 | WO |
WO 9844430 | Oct 1998 | WO |
WO 9855945 | Dec 1998 | WO |
Number | Date | Country | |
---|---|---|---|
20070208669 A1 | Sep 2007 | US |
Number | Date | Country | |
---|---|---|---|
60128405 | Apr 1999 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 11178367 | Jul 2005 | US |
Child | 11513360 | US | |
Parent | 09545608 | Apr 2000 | US |
Child | 11178367 | US | |
Parent | 08632801 | Apr 1996 | US |
Child | 09057557 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 08921369 | Aug 1997 | US |
Child | 09545608 | US | |
Parent | 08867392 | Jun 1997 | US |
Child | 08921369 | US | |
Parent | 09138368 | Aug 1998 | US |
Child | 09545608 | US | |
Parent | 08921369 | Aug 1997 | US |
Child | 09138368 | US | |
Parent | 09260079 | Mar 1999 | US |
Child | 09545608 | US | |
Parent | 09138368 | Aug 1998 | US |
Child | 09260079 | US | |
Parent | 09057557 | Apr 1998 | US |
Child | 09545608 | US | |
Parent | 08423676 | Apr 1995 | US |
Child | 08632801 | US | |
Parent | 08341129 | Nov 1994 | US |
Child | 08423676 | US | |
Parent | 08155752 | Nov 1993 | US |
Child | 08341129 | US |