WO2003012586A2 - Systems and methods for facilitating agreement generation and negotiation via an agreement modeling system - Google Patents
Systems and methods for facilitating agreement generation and negotiation via an agreement modeling system Download PDFInfo
- Publication number
- WO2003012586A2 WO2003012586A2 PCT/US2002/023898 US0223898W WO03012586A2 WO 2003012586 A2 WO2003012586 A2 WO 2003012586A2 US 0223898 W US0223898 W US 0223898W WO 03012586 A2 WO03012586 A2 WO 03012586A2
- Authority
- WO
- WIPO (PCT)
- Prior art keywords
- agreement
- party
- document
- counter
- information
- Prior art date
Links
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06Q—INFORMATION AND COMMUNICATION TECHNOLOGY [ICT] SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES; SYSTEMS OR METHODS SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES, NOT OTHERWISE PROVIDED FOR
- G06Q40/00—Finance; Insurance; Tax strategies; Processing of corporate or income taxes
- G06Q40/02—Banking, e.g. interest calculation or account maintenance
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F40/00—Handling natural language data
- G06F40/10—Text processing
- G06F40/166—Editing, e.g. inserting or deleting
Definitions
- the present invention relates to agreements between parties.
- the present invention relates to systems and methods to facilitate generation and/or negotiation of an agreement document via an agreement modeling system.
- an agreement between a party and a counter-party is manually defined by the parties. That is, one or both of the parties manually select a type of document that appropriately reflects the substance of the agreement (e.g. , a particular type of contract) and/or agreement terms to be included in the document (e.g., contract clauses). The parties also manually generate and distribute the document for signature.
- a type of document that appropriately reflects the substance of the agreement (e.g. , a particular type of contract) and/or agreement terms to be included in the document (e.g., contract clauses).
- the parties also manually generate and distribute the document for signature.
- the manual definition and generation of an agreement can be a time consuming and error-prone process, especially when a large number of potential document types and/or potential agreement terms can be associated with the agreement.
- particular parties or localities may require different document types and/or agreement terms.
- the parties must carefully consider the substance of the agreement in order to select the appropriate document type and/or agreement terms.
- a transaction agreement associated with a number of different financial instruments (e.g., swaps and options) and financial products (e.g., equities and commodities).
- financial instruments e.g., swaps and options
- financial products e.g., equities and commodities
- different combinations of financial instruments and financial products may call for different document types and/or agreement terms.
- several different entities within a party e.g., a bank's taxation department and legal department
- a single relationship between two parties may require that a number of different documents be generated, exchanged, and executed.
- a master contract, a schedule to the master contract, a supporting document (e.g., a power of attorney), and a cover letter may all need to be generated.
- Manually generating and exchanging such sets of documents may be a difficult process, especially when different types of agreements require different combinations of documents.
- the present invention introduces systems and methods to facilitate generation and/or negotiation of an agreement document via an agreement modeling system.
- agreement information associated with an agreement between a party and a counter-party is determined.
- An agreement document is generated in accordance with the agreement information, and it is arranged for the agreement document to be received by the party and/or the counterparty.
- Another embodiment is directed to a computer-implemented method of facilitating generation of an agreement document associated with a financial transaction agreement between a party and a counter-party.
- agreement information is received from a user associated with the party, the agreement information including (i) a counter-party communication address and (ii) information about a financial instrument and/or a financial product associated with the financial transaction agreement.
- the agreement document is generated in accordance with the agreement information and a covered products matrix.
- the agreement document is then automatically transmitted to the counter-party via the counter-party communication address.
- contract information is determined.
- a first contract document and a second contract document are then generated in accordance with the contract information.
- at least one of the following are determined: (i) an agreement scope, (ii) a document scope, (iii) a fact set scope, and (iv) a work flow scope.
- the determined scope is placed in a scope stack, and the scope stack is evaluated via an evaluation engine to produce a result in accordance with at least one of (i) a rule, (ii) an action, and (iii) an expression.
- a contract document is then generated in accordance with the result.
- a user defines agreement information associated with an agreement between a party and a counter-party.
- the user also defines a communication address to which an agreement document will be automatically transmitted.
- One embodiment comprises: means for determining agreement infonnation; means for generating an agreement document in accordance with the agreement information; and means for arranging for the agreement document to be received by a party and/or a counter-party.
- Another embodiment comprises: means for receiving agreement information from a user associated with a party, the agreement information including (i) a counterparty communication address, and (ii) information about a financial instrument and/or a financial product associated with a financial transaction agreement; means for generating an agreement document in accordance with the agreement information and a covered products matrix; and means for automatically transmitting the agreement document to the counter-party via the counter-party communication address.
- Another embodiment comprises means for determining contract information; means for generating a first contract document in accordance with the contract information; and means for generating a second contract document in accordance with the contract information.
- Still another embodiment comprises, means for determining at least one of: (i) an agreement scope, (ii) a document scope, (iii) a fact set scope, and (iv) a work flow scope; means for placing the determined scope in a scope stack; means for evaluating the scope stack via an evaluation engine to produce a result in accordance with at least one of (i) a rule, (ii) an action, and (iii) an expression; and means for generating a contract document in accordance with the result.
- Yet another embodiment comprises: means for defining agreement information associated with an agreement between a party and a counter-party; and means for defining a communication address to which an agreement document will be automatically transmitted.
- FIG. 1 is a block diagram overview of an agreement modeling system according to an embodiment of the present invention.
- FIG. 2 is a flow chart of a method according to some embodiments of the present invention.
- FIG. 3 is a block diagram overview of an agreement modeling system according to another embodiment of the present invention.
- FIG. 4 is a client-server diagram overview of an agreement modeling system according to some embodiments of the present invention.
- FIG. 5 is a more detailed diagram of an agreement modeling system according to an embodiment of the present invention.
- FIG. 6 is an information architecture overview associated with an agreement modeling system according to some embodiments of the present invention.
- FIG. 7 is a flow chart of a method for generating a plurality of contract documents according to some embodiments of the present invention.
- FIG. 8 illustrates various representations of agreement modeling system infonnation according to an embodiment of the present invention.
- FIG. 9 is a flow chart of an agreement modeling system method according to some embodiments of the present invention.
- FIG. 10 is a block diagram of an agreement modeling system controller according to an embodiment of the present invention.
- FIG. 11 is a tabular representation of a portion of an agreement information database according to an embodiment of the present invention.
- FIG. 12 is a flow chart of a method for generating an agreement document in accordance with a covered products matrix according to some embodiments of the present invention.
- FIG. 13 illustrates an example of a covered products matrix according to an embodiment of the present invention.
- FIG. 14 illustrates another example of a covered products matrix according to an embodiment of the present invention.
- FIG. 15 is a flow chart of a method for generating a contract using a scope stack according some embodiments of the present invention.
- FIGS. 16A and 16B are block diagrams of agreement modeling system functions, applications, and interactions according to some embodiments of the present invention.
- FIG. 17 is a block diagram of an evaluation engine according to some embodiments of the present invention.
- FIG. 18 illustrates a number of scope stacks according to an embodiment of the present invention.
- FIG. 19 illustrates fact namespaces, fact set contexts, and scopes according to some embodiments of the present invention.
- FIG. 20 is a block diagram of agreement creation interactions according to some embodiments of the present invention.
- FIG. 21 is a block diagram of document creation interactions according to some embodiments of the present invention.
- FIG. 22 is a flow chart of a method performed by a user according some embodiments of the present invention.
- FIGS. 23 through 25 illustrate client displays associated with an agreement according to an embodiment of the present invention. DETAILED DESCRIPTION
- Embodiments of the present invention are associated with systems and methods to facilitate generation and/or negotiation of an agreement document • associated with an "agreement" between a party and a counter-party.
- an agreement may refer to any arrangement between the parties.
- An agreement may be, for example, a legal contract defining a set of rights that exist between the parties, such as an INTERNATIONAL SWAP DEALERS ASSOCIATION® (ISDA®) master agreement associated with financial instruments and products.
- ISDA® INTERNATIONAL SWAP DEALERS ASSOCIATION®
- a single agreement may be associated with more than two parties (e.g., three parties may enter into a legal contract).
- an agreement may or may not be legally binding (e.g., an agreement may simply reflect an informal understanding between parties).
- party and “counter-party” can refer to any entity associated with an agreement.
- a party may be, for example, a business, a business entity (e.g., a department within a business), or a person.
- FIG. 1 is a block diagram of an agreement modeling system 100 according to an embodiment of the present invention.
- an agreement modeling system controller 1000 may interact with a client device 10 and a counter-party device 15. For example, a user may input information associated with a transaction agreement via the client device 10. The client device 10 may then transmit appropriate information to the agreement modeling system controller 1000, which in turn may store and/or interpret the information. The agreement modeling system controller 1000 may also generate one or more contract documents as appropriate and arrange for those documents to be transmitted to the counter-party device 15 (e.g., via an electronic mail message after approval by the user).
- FIG. 2 is a flow chart of a method according to some embodiments of the present invention.
- the flow charts in FIG. 2 and the other figures described herein do not imply a fixed order to the steps, and embodiments of the present invention can be practiced in any order that is practicable.
- the method shown in FIG. 2 may be performed, for example, by the agreement modeling system controller 1000.
- agreement information is determined. For example, a user may input information via the client device 10 indicating one or more financial products that will be associated with a contract. The agreement modeling system controller 1000 may then determine an appropriate contract type based on those financial products.
- an agreement document is generated.
- the agreement modeling system controller 1000 may generate a word processing file (e.g., a MICROSOFT WORD® file) based on the determined agreement information.
- a word processing file e.g., a MICROSOFT WORD® file
- the agreement modeling system controller 1000 may automatically transmit a word processing file to the client device 10 or the counter-party device 15 (e.g., by publishing the document via a secure Web page).
- FIG. 3 is a block diagram overview of an agreement modeling system 300 according to another embodiment of the present invention.
- the agreement modeling system controller 1000 communicates with the client device 10 and the counter-party device 1.5.
- devices such as the agreement modeling system controller 1000, the client device 10, and the counter-party device 15
- a communication network 20 such as a Local Area Network (LAN), a Metropolitan Area Network (MAN), a Wide Area Network (WAN), a proprietary network, a Public Switched Telephone Network (PSTN), a Wireless Application Protocol (WAP) network, a wireless LAN (e.g., in accordance with the Institute of Electrical and Electronics Engineers 802.11 standard), a
- LAN Local Area Network
- MAN Metropolitan Area Network
- WAN Wide Area Network
- PSTN Public Switched Telephone Network
- WAP Wireless Application Protocol
- wireless LAN e.g., in accordance with the Institute of Electrical and Electronics Engineers 802.11 standard
- a wireless LAN e.g., in accordance with the Institute of Electrical and Electronics Engineers
- the term "communications" can refer to wired and/or wireless communications as appropriate.
- the devices shown in FIG. 3 need not be in constant communication.
- the agreement modeling system controller 1000 may communicate with a client device 10 and/or a counter-part device 15 on an as-needed or periodic basis.
- agreement modeling system controller 1000 may be included in the agreement modeling system 300.
- client devices 10, counter-party devices 15, or any other device described herein may be included in the agreement modeling system 300 according to embodiments of the present invention.
- the agreement modeling system controller 1000, the client device 10, and the counter-party device 15 may be any devices capable of performing the various functions described herein.
- a client device 10 or a counter-party device 15 may be, for example: a Personal Computer (PC), a portable computing device (e.g., a laptop computer), a Personal Digital Assistant (PDA), or a dedicated agreement modeling system 300 terminal.
- a client device 10 or a counter-party device 15 may be associated with a full-blown workstation application or a thin-client browser-based application.
- a user enters information associated with an agreement (e.g., information associated with an agreement type, an agreement term, and/or an agreement fact) via the client device 10.
- the agreement may be, for example, associated with financial transactions between a party and a counter-party.
- the user may enter information about the party, the counter-party (e.g. , a name and communication address associated with the counter-party device 15), and/or the financial transactions via the client device 10 (e.g., by selecting a number of different financial instruments that will be involved in transactions between the parties).
- Information associated with the agreement may then be transmitted from the client device 10 to the agreement modeling system controller 1000 via the communication network 20, and the agreement modeling system controller 1000 may process the information to generate one or more agreement documents.
- the agreement modeling system 1000 also communicates with one or more satellite systems, such as a business system 30, a legal system 40, a compliance system 50, a credit system 60, a treasury system 70, and/or an operations system 80 to facilitate definition and/or generation of the agreement documents.
- the agreement modeling system controller 1000 may review information provided by the user and determine that an agreement requires approval via a credit system 60.
- the agreement modeling system controller 1000 may communicate with the client device 10, the counter-party device 15, and one or more satellite systems via a single communication network or via multiple communication networks.
- the agreement modeling system controller 1000 may determine information associated with an agreement using a covered product matrix (as described in detail with respect to FIGS. 12 through 14), a pre-stored default transaction term (e.g., representing industry "best practices"), and/or information received from a "legacy" agreement system.
- a covered product matrix as described in detail with respect to FIGS. 12 through 14
- a pre-stored default transaction term e.g., representing industry "best practices”
- a user also provides a communication address to which an agreement document should be transmitted.
- the communication address may be, for example, an electronic mail address (e.g., associated with the counter-party device 15 or the legal system 40), an Internet address, a Uniform Resource Locator (URL) address, or a telephone number (e.g., associated with a facsimile machine).
- the agreement modeling system controller 1000 may then automatically transmit the agreement document to the communication address once the document is generated and/or approved.
- an agreement document is transmitted to a number of different devices (e.g., to the credit system 60, the treasury system 70, and the counter-party device 15) in either a parallel or sequential fashion (e.g., the document may be forwarded after a satellite system approves the agreement document or provides additional information).
- a number of different devices e.g., to the credit system 60, the treasury system 70, and the counter-party device 15
- the document may be forwarded after a satellite system approves the agreement document or provides additional information.
- the agreement modeling system controller 1000 may generate and/or transmit either a final agreement document or a preliminary agreement document.
- the agreement modeling system controller 1000 may also receive revisions to the document (e.g., from the client device 10, a satellite device, or even the counter-party device 15).
- the agreement modeling system controller 1000 may then reconcile the revised preliminary agreement document and the preliminary agreement document (e.g., by searching for changes and seeking the appropriate approval) and generate a final agreement document in accordance with this reconciliation.
- FIG. 4 is a client-server diagram overview of an agreement modeling system
- a database server 1002 communicates with a number of middle-tier servers 1004.
- each middle-tier server 1004 communicates with one or more client devices 12.
- the database server 1002 may include (or communicate with) an agreement modeling system database, such as a database that stores agreement information.
- the database server 1002 may also include Java and Structured Query Language (SQL) stored procedures along with User Defined Functions (UDFs).
- SQL Structured Query Language
- UDFs User Defined Functions
- the database server 1002 can act as a "back-end" to the agreement modeling system 400 and manage user connections (e.g., by invoking stored procedures in and out, validating client logons, establishing client access rights, and/or maintaining a list of connected clients).
- the database server 1002 may also perform concurrency management (e.g.
- the database server 1002 may manage Extensible Markup Language (XML) and Application Program Interface (API) information (e.g., by managing special Java XML API entry point stored procedures, interpreting incoming XML streams, performing appropriate XML operations, returning appropriate response XML packets, and/or retrieving agreement information using XML streams).
- XML Extensible Markup Language
- API Application Program Interface
- the middle-tier servers 1004 may comprise, for example, SILNERSTREAM® or WEBLOGIC® servers that manage user connections (e.g., via special login and logout servlet interfaces and/or by establishing logins and logouts with the database server 1002).
- the middle-tier servers 1004 may also perform session management (e.g., by handling timeouts and disconnects and notifying the database server 1002 when a client device 12 has timed-out or disconnects) and/or manage database connections (e.g., by optimizing and pooling database connections and providing XML user and session identification packets associated with XML packets sent to the database server 1002).
- the middle-tier servers 1004 may also perform XML API management (e.g., using a special XML API servlet interface that serves as a pass- through for XML packets sent to the database server 1002 via calls to a Java stored procedure).
- a client device 12 may, for example, control user functionality (e.g., by supporting applicable user interactions).
- the client device 12 may also perform session management (e.g., by providing user login and logout capability, managing a physical connection including a connection status notification to a user, and issuing a logout when appropriate) and manage XML API interactions (e.g. , by interacting with an XML API back-end via correctly formed XML packets, and/or managing incoming XML API response packets returned from XML API calls).
- This hierarchical arrangement (e.g., having a client tier, a middle tier, and a database tier) may let a significant number of client devices 12 access and utilize the database server 1002.
- FIG. 5 is a more detailed diagram of an agreement modeling system 500 according to one embodiment of the present invention.
- a database server 1006 communipates with a middle-tier server 1008.
- the middle-tier server 1008 communicates with a client device 14.
- the database server 1006 may, for example, provide support for an API via stored procedures and UDFs.
- the database server 1006 may also manage persistence of agreement information and API states for the agreement modeling system 500 in a database.
- the middle-tier server 1008 may communicate with the database server 1006 via a number of server-side language managers, such as an agreement and/or a utility language manager.
- the server-side language managers may, for example, implement interfaces similar to those provided on the client side to provide specific API functionality. These managers may be registered with an execution manager indicating supported interfaces. Instances of the server-side language managers may be instantiated to service incoming API method calls. The managers may also provide implementation of the API method calls by interacting directly with the agreement database via stored procedure calls.
- the server-side language managers may communicate with the execution manager via a server-side base language manager that routes method calls and provides implementation of common API methods.
- the execution manager may exchange information with a communication manager associated with the client device 14 via a Hyper-Text Transfer Protocol (HTTP) connection.
- HTTP Hyper-Text Transfer Protocol
- the execution manager may be delegated to by middle-tier servlets that process HTTP requests and responses.
- the execution manager may also handle all incoming API "method calls" and interact with the service-side base language manager to service those calls.
- the execution manager may be responsible for the registration of server-side language managers, / "de-serializing" XML method call packets, routing methods to the appropriate registered server-side language manager, "serializing" return values or errors into XML packets, and/or forwarding return values or errors back to the client device via an HTTP response.
- the communication manager in the client device 14 interacts with a client-side base language manager and the middle-tier servlets.
- the communication manager is responsible for managing the connection with the server, the invocation of method calls by passing a stream to the server, the receiving return values or errors back as a stream, and/or propagating up return values or errors to the language manager layer. Both synchronous and asynchronous method calls may be supported at this layer.
- the client-side base language manager may define a base class from which extended client-side language managers are derived. Common functionality may be implemented in the base class, including a standard set of API method calls.
- the client-side base language manager may also be responsible for interacting with the communication manager to process method calls forwarded by derived client-side language managers.
- the client side base language manager communicates with a number of client- side language managers, such as an agreement and/or a utility language manager.
- the client-side language managers may implement interfaces providing specific API functionality to the client device 14.
- the API methods in the client application may be called like any other local method.
- the derived client-side language managers may be responsible for serializing method calls into XML packets and/or interacting with the client-side base language manager to process the call.
- agreement In order to define an agreement, the facts that are associated with the agreement need to be captured.
- different agreements may not be equal in terms of data content, and thus a flexible database design (e.g., capable of capturing a variety of data while maintaining relative data context) may be required to allow for effective and reliable agreement definition, generation, and/or utilization (e.g. , via agreement information data queries).
- FIG. 6 is an information architecture overview associated with one such embodiment of the present invention.
- the information architecture is associated with a hierarchical view of agreement information.
- an agreement 602 is viewed as a set of related documents 604.
- Each document 604 comprises one or more fact sets 606, and each fact set 606 includes a number of related facts 608 (e.g., single pieces of information).
- the information architecture may apply structure to infonnation through the constructive use of well- known fact sets 606 and data definitions that are applied to facts 608, and taken together, data context may be maintained.
- the agreement 602 is associated with an "original" document instance containing facts 608 that define the agreement 602 upon creation. As additional information is created (e.g., the original agreement 602 is amended), additional documents 604 may be added to define the facts 608 that apply at particular points in time.
- a document 604 may be created that "overrides" existing facts 608 in an agreement 602 for a specified period of time and/or that adds new facts 608 that extend existing facts 608. In either case, the added document 604 may now be considered to determine a complete set of agreement facts 608 (e.g., via an agreement modeling system query).
- documents 604 may be categorized according to a single document type name and any number of document type facts that further refine the documents classification.
- the document type name may indicate a basic category of agreement types (e.g., a financial instrument swap agreement or an over-the-counter financial instrument agreement) and the document type fact (or facts) may further categorize a document's relationship to an agreement (e.g., a credit support annex or an amendment to an existing agreement 602).
- a document 604 contains instances of fact sets 606, and a fact 608 may belong to an instance of a fact set 606.
- Fact set definitions may exist outside of any agreement, and their definition and fact content may be described via an agreement modeling language.
- a fact 608 may be associated with a party name, a party address, a term date, a country of origin, an indication of governing law (e.g., "Delaware law applies to all transactions associated with this agreement"), or any other information associated with an agreement.
- a fact set 606 may comprise, for example, a counter-party fact set including a counter-party name and address. Note that fact sets 606 can be single-instance or multi-instance.
- a fact 608 belonging to a fact set 606 may be related to the other facts 608 in that fact set 606.
- a multi-instance fact set 606 enables the repeated instantiation of the same set of facts 608, typically with different values being associated with the different instantiated facts 608.
- An instance of a multi-instance fact 606 set is analogous to a row of data in a conventional database table, and the facts 608 are analogous to columns. Note, however, that the table is not statically defined - rather it is dynamically defined via the agreement modeling language.
- a fact 608 in the agreement modeling system may have pre-defined attributes that describe the fact's nature and meaning.
- each fact 608 may have an associated data type that defines a set of potential values and/or data input behavior.
- a fact 608 may be considered "internal” or "external,” and external facts may map to information in other databases (i.e. external databases).
- other attributes may be applied to facts 608 to help to define context.
- FIG. 7 is a flow chart of a method for generating a plurality of contract documents according to some embodiments of the present invention.
- contract information is determined.
- the contract information may represent, for example, an agreement type, a document type, fact sets, and/or facts.
- a first contract document is generated in accordance with the agreement information.
- a second contract document is generated at 706.
- the agreement modeling system controller 1000 may also arrange for the first and/or second contract documents to be received by appropriate parties (e.g. , the first contract document may be transmitted to a first counter-party communication address and both contract documents may be transmitted to a second counter-party communication address).
- FIG. 8 illustrates various representations of agreement modeling system information according to an embodiment of the present invention.
- agreement information may be stored via an extensible agreement modeling system language.
- an XML or Standard Generalized Markup Language (SGML) data format may be used to store information as follows:
- Such an approach may let the system model dynamic information (e.g., document and fact set information) and facilitate communication of dynamic agreement information between a client and a server.
- the implementation may be technology neutral (e.g., the information may be provided to or accessed by a number of different technologies).
- facts may be associated with attribute information, such as a data name, a data prompt, a data type, a security attribute, and/or a display attribute.
- MASTER” id "2" ...>, which in turn may be rendered by an agreement application display engine (e.g., via a document list pane and/or an active document information pane).
- ⁇ Document spec "ORIGINAL
- FIG. 9 is a flow chart of a method according to some embodiments of the present invention.
- information associated with an agreement is gathered.
- the agreement modeling system controller 1000 may gather information associated with a financial transaction agreement between a party and a counter-party via one or more client devices 10 and/or satellite systems.
- a request for a new agreement may be generated by a satellite system, such as the business system 30, the credit system 60, and/or the treasury system 70.
- a user associated with the business system 30 may populate a new agreement request form via a Web-based interface provided by the agreement modeling system 1000.
- the new agreement request form may include, for example, a set of "required” information, such as: a name of a sales person covering an account, a selected entity master (e.g., via a drop-down list of party entities that the counter-party is contemplating doing business with), a business desk (e.g., an indication of "Fixed Income,” “Equity,” or “Commodities" which may be automatically generated based on a user identifier), a counter-party legal name (e.g.
- contact information of a person with whom documentation will be exchanged e.g., a name, a phone number, and/or a facsimile number
- one or more products to be traded e.g., associated with a covered products matrix
- an indication of whether or not the agreement is bilateral e.g., two-way agreements may require special processing via the treasury system 70
- an anticipated trade date an indication of whether or not the agreement will be used as a marketing tool.
- the new agreement request form may also include information that will be required when appropriate (e.g. , based on the particular agreement being requested), such as a type of agreement (e.g., selected from a drop-down list) and/or an investment advisor.
- the new agreement request form may also include optional infonnation, such as an electronic mail address associated with the counter-party.
- some information may be selected by a user via a drop- down list (e.g., a counter-party name or identifier).
- the desired information may not be present in the drop-down list (e.g., when a new counter-party is desired).
- a user may be asked to complete another form (e.g., a new counter-party request form) or he or she may simply enter the information manually (e.g., via free form text).
- one or more satellite systems may be involved in this process (e.g. , the compliance system 50 may approve new counterparties).
- the agreement modeling system controller 1000 determines if a new agreement is actually required at 904. For example, the agreement modeling system controller 1000 may execute a query to ensure that there are no other existing agreements in place and return the results of the query to the user (e.g., by indicating that "there are existing agreements that cover this request"). If no new agreement is required at 904 (e.g., an appropriate existing agreement is found by the agreement modeling system controller 1000), one or more amendments to the existing agreement may be facilitated at 906. For example, the agreement modeling system controller 1000 or the compliance system 50 may determine that an existing agreement can be used to cover a transaction by broadening a compliance covered products scope term in the existing agreement.
- an electronic mail message may be transmitted to the legal system 40 asking if the agreement scope can be broadened accordingly.
- the legal system 40 may then indicate to the business system 30 that the transaction can be covered under the existing agreement.
- the legal system 40 may instead indicate that a new agreement is required.
- the new agreement request form is processed by the agreement modeling system controller 1000.
- the processing of the new agreement request form also involves one or more satellite systems.
- the compliance system 50 may receive the request via an automated workflow and provide information as required.
- the compliance system 50 may advise the legal system 40 as to the types of products the counter-party is authorized to trade, and with which party entity the counter-party may trade these products.
- the compliance system 50 may need to access information about the agreement, such as the counter-party name or identifier, a master agreement type, a current status of the master agreement type, a date of agreement, a document identifier, an investment advisor, and/or a security agreement type.
- information about the agreement such as the counter-party name or identifier, a master agreement type, a current status of the master agreement type, a date of agreement, a document identifier, an investment advisor, and/or a security agreement type.
- the compliance system 50 may define facts for the agreement, such as: a compliance officer name responsible for the account, a party entity approved for the business, a covered products matrix indicating the authorized products the counter-party can or can't trade, and/or one or more supporting authority documents.
- the form may be forwarded to the credit system 60 (e.g., if the agreement is associated with a risk transaction) to provide still more information.
- information may include, for example, collateral terms such as: a credit officer name responsible for the account, terms of a collateral agreement (e.g., bilateral, party post, or counter-party post), an independent amount (e.g., an initial margin percentage or dollar amount associated with notional amount), a threshold amount (e.g., a trigger value associated with a specified dollar amount or a ratings table), a minimum transfer amount, a rounding amount, and/or a base currency.
- collateral terms such as: a credit officer name responsible for the account, terms of a collateral agreement (e.g., bilateral, party post, or counter-party post), an independent amount (e.g., an initial margin percentage or dollar amount associated with notional amount), a threshold amount (e.g., a trigger value associated with a specified dollar amount or a ratings table), a minimum transfer amount, a rounding amount, and/
- the credit system 60 may also provide non-collateral terms, such as: default information (e.g., bankruptcy information'or credit event upon merger information), a cross acceleration threshold amount for the counter-party, and/or one or more credit-related additional termination events (e.g., adequate assurance, amendment of constituent documents, break clause, credit rating downgrade, decline in partners capital, governmental moratorium on debt declared, investment advisor event, material adverse change, modification to guaranty, net asset value information, ownership maintenance, redemption of notes, termination of trust under trust agreement, termination rights linked to separate agreement, transactions not covered by guaranty and/or guarantor, or withdrawal of general partners or key employees).
- default information e.g., bankruptcy information'or credit event upon merger information
- a cross acceleration threshold amount for the counter-party e.g., a cross acceleration threshold amount for the counter-party
- one or more credit- related additional termination events e.g., adequate assurance, amendment of constituent documents, break clause, credit rating downgrade, decline in partners capital, governmental moratorium on
- the credit system 60 may also indicate one or more credit support documents referenced under the agreement, such as: a comfort letter, a deed poll guarantee, an indemnity agreement, a Keepwell agreement, a letter of commitment, a letter of credit, a security trust deed, a senior facility agreement, a supplemental trust deed, a support agreement, and/or a swap surety bond/insurance policy.
- a comfort letter such as: a comfort letter, a deed poll guarantee, an indemnity agreement, a Keepwell agreement, a letter of commitment, a letter of credit, a security trust deed, a senior facility agreement, a supplemental trust deed, a support agreement, and/or a swap surety bond/insurance policy.
- the treasury system 70 may provide information associated with bilateral agreements, such as an indication of approval, a threshold amount, a notional amount, eligible collateral types (e.g., United States Treasury bills, highly liquid pools, AAA bonds, residuals, commercial paper, investment grade corporate instruments, preferred stock, municipals, emerging market debt, Brady bonds, high yields, non-distressed issues, distressed issues, bank debt, par, whole loans, residential, commercial, and/or short-tenn mortgage backed bank notes), equities (e.g., United States or United Kingdom listed equities, foreign convertibles-investment grade, foreign convertibles-high yield, listed mutual funds, rights and warrants, or options), commodities (e.g., metals or energy), interest paid on cash collateral, base currency on cash, tri-party custodial relationships, notification time, amendments to transfer provision (e.g., after approval by the legal system 40).
- eligible collateral types e.g., United States Treasury bills, highly liquid pools, AAA bonds, residuals, commercial paper, investment grade corporate
- the processing of multiple new agreement request forms may be prioritized (e.g., based on a date on which a request was made, a date associated with a pending trade, or a number of requests in a queue for a given business area).
- an agreement document is generated by the agreement modeling system controller 1000 at 908.
- the agreement modeling system controller 1000 may use a rule set to route the new agreement request form to an appropriate functional group within the legal system 40 based on a product type and/or a party entity.
- an agreement type (e.g., an ISDA® master agreement schedule, a club letter, or a credit support annex in accordance with New York law) may be determined based on one or more rules by the legal system 40 or the business system 30.
- a user has the ability to override an agreement type chosen by the system.
- the legal system 40 can access the generated agreement on-line to review the agreement's structure and to make revisions, if required.
- the legal system 40 may also prepare the agreement for transmission. If desired, the legal system 40 may be prevented from changing or over-riding data that was originally provided via the new agreement request form.
- the agreement modeling system controller 1000 may then automatically create the agreement document along with, according to one embodiment, one or more supporting documents (e.g., a power of attorney, a legal opinion, a pre-executed request guarantee, and/or a cover letter).
- the user or the agreement modeling system controller 1000 then transmits the agreement document or documents to the counter-party at 910.
- a user may manually print hard copies of the agreement to send via a delivery service (e.g., FED EX®).
- the agreement modeling system controller 1000 automatically sends a facsimile or an electronic message attachment of the agreement document in an unalterable format (e.g., a "pdf file) to the counterparty.
- agreement information (e.g., an agreement document) is transfened to the counter-party in a medium that allows the counter- party to alter the contents of the agreement to reflect agreement terms desired by the counter-party.
- the altered agreement content can then be automatically extracted from the medium by the agreement modeling system controller 1000 and the differences may be transmitted to the appropriate functional areas to move a negotiation forward. Examples of such an appropriate medium include a
- MICROSOFT WORD® file an ADOBE® "pdf file
- information delivered to the counter-party via a Web page e.g., in HTML or XML format.
- the agreement modeling system controller 1000 determines that an agreement will not be automatically generated and/or transmitted. This may be the case, for example, when a data field in the new agreement request form requires a change (e.g., a name change or a policy change). Similarly, it may be determined that a counter-party form of the agreement will be used, that supervisory review is required (e.g., based on a functional group associated with the agreement), or that the business system 30 has asked that the generation or transmission be postponed.
- a change e.g., a name change or a policy change.
- the counter-party may the respond to the draft agreement (e.g., altering a MICROSOFT WORD® or ADOBE® file to indicate an adjusted agreement term).
- the counter-party returns a hard copy of an altered agreement.
- the hard copy may be scanned and stored via an Optical Character Recognition (OCR) application.
- OCR Optical Character Recognition
- the counter-party may instead contact the party via telephone to verbally confirm the terms of the agreement or advise of any discrepancies between the counter-party's view and party's view of the agreement.
- the agreement modeling system controller 1000 may store the name of the person who called and the time, date, and substance of the conversation. Any changes proposed by the counter-party are then reviewed at 912. For example, discrepancies may be determined and routed to the appropriate party entities for reconciliation (e.g., by routing the information to an appropriate information owner based on a functional group or a document type).
- the system waits for approval by the party at 916. If the changes proposed by the counter-party do require further negotiation at 914, negotiations continue until the differences are resolved at 918.
- a final document is generated at 920 and transmitted to the appropriate parties for execution at 922.
- two hard copies of a fully negotiated ISDA® schedule and boiler-plate may be printed and forwarded to the counter-party for signature.
- a cover letter with instructions to the counter-party may be automatically generated along with any required tax documents.
- the counter-party can then return the signed agreement via hard copy, electronic mail, facsimile, a URL, or any other agreed upon medium for document exchange.
- the counter-party may also provide any supporting documentation (e.g., a power of attorney).
- the date that the agreement was executed may be recorded by the agreement modeling system controller 1000 along with, for example, a date on which the agreement is effective (which may or may not be the same as the execution date). Any subsequent amendments to the agreement may then be made at 906. Note that the agreement modeling system controller 1000 extends the same capabilities of automatic document negotiation and generation (described herein) with respect to an amendment to an existing agreement.
- FIG. 10 illustrates an agreement modeling system controller 1000 that is descriptive of the devices shown, for example, in FIGS. 1 and 3 according to some embodiments of the present invention.
- the agreement modeling system controller 1000 comprises a processor 1010, such as one or more INTEL® Pentium® processors, coupled to a communication device 1020 configured to communicate via a communication network (not shown in FIG. 10).
- the communication device 1020 may be used to communicate, for example, with one or more client devices 10 and/or satellite devices.
- the processor 1010 is also in communication with an input device 1040.
- the input device 1040 may comprise, for example, a keyboard, a mouse or other pointing device, a microphone, knob or a switch, an IR port, a docking station, and/or a touch screen.
- Such an input device 1040 may be used, for example, to enter infonnation (e.g., agreement information).
- the processor 1010 is also in communication with an output device 1050.
- the output device 1050 may comprise, for example, a display (e.g., a display screen), a speaker, and/or a printer.
- the output device 1050 may be used, for example, output agreement information (e.g., a final version of an agreement to be executed).
- the processor 1010 is also in communication with a storage device 1030.
- the storage device 1030 may comprise any appropriate information storage device, including combinations of magnetic storage devices (e.g., magnetic tape and hard disk drives), optical storage devices, and/or semiconductor memory devices such as Random Access Memory (RAM) devices and Read Only Memory (ROM) devices.
- the storage device 1030 stores a program 1015 for controlling the processor
- the processor 1010 performs instructions of the program 1015, and thereby operates in accordance with the present invention. For example, the processor 1010 may determine agreement information associated with an agreement between a party and a counter-party. The processor 1010 may also generate an agreement document in accordance with the agreement information, and arrange for the agreement document to be received by the party and/or the counter-party (e.g., by automatically transmitting the agreement document to a counter-party device 15).
- the processor 1010 receives agreement information from a user, the agreement information including (i) a counter-party communication address and (ii) information about a financial instrument and/or a financial product associated with a financial transaction agreement.
- the processor 1010 then generates an agreement document in accordance with the agreement information and a covered products matrix.
- the processor 1010 also automatically transmits the agreement document to the counter-party via the counter-party communication address.
- the processor 1010 determines contract information and generates a first contract document and a second contract document in accordance with the contract information.
- the storage device 1030 also stores an agreement information database 1100.
- the illustration and accompanying description of this database is exemplary, and any number of other database arrangements could be employed besides those suggested by the figure.
- a table represents the agreement information database 1100 according to one embodiment of the present invention.
- the table includes entries identifying agreements that have been (or are being) generated by the agreement modeling system controller 1000.
- the table also defines 1102, 1104, 1106 for each of the entries.
- the table defines an agreement identifier 1102, an agreement type 1104, and a counter-party communication address 1106.
- the information in the agreement information database 1100 may be created and updated, for example, by the agreement modeling system controller 1000, a client device 10, a satellite device, and/or a counter-party device 15.
- the agreement identifier 1102 may be, for example, an alphanumeric code associated with an agreement between a party and a counter-party.
- the agreement type 1104 describes the agreement.
- the agreement may be an original master agreement or an amendment to an existing master agreement.
- the agreement information database 1100 also stores a counter-party communication address 1106 for each agreement. After an agreement is generated, the agreement modeling system controller 1000 may transmit the appropriate documents via the counter-party communication address 1106. Note that a counter- party communication address 1106 may not be defined (e.g., the documents will be manually sent to the counter-party) or more than one counter-party communication address 1106 may be defined (e.g., a document may be broadcast to a number of communication addresses associated with the counter-party). According to another embodiment, one or more communication addresses associated with ttie party are also stored in the agreement information database 1100. Agreement Modeling System Covered Products Matrix
- FIG. 12 is a flow chart of a method for generating an agreement document in accordance with a covered products matrix according to some embodiments of the present invention.
- the method may be performed, for example, by the agreement modeling system controller 1000 and may be associated with a transaction agreement defining a plurality of product types (e.g., a number of different financial products) and/or instruments (e.g., a number of different financial instruments).
- product types e.g., a number of different financial products
- instruments e.g., a number of different financial instruments
- agreement infonnation is received from a user.
- the agreement modeling system controller 1000 may receive agreement information from a client device 10, including a counter-party communication address and an indication of a set of financial instruments and/or products that will be associated with an agreement.
- an agreement document is generated based on the plurality of product types (or instruments) and a "covered products matrix.”
- the phrase "covered products matrix” may refer to, for example, any stored indication of transaction instruments (e.g., swaps, options, and forwards) and product types (e.g., stocks, bonds, and credit derivatives) in connection with a particular agreement. Note that the stored information does not necessarily need to be in the form of a matrix or an array.
- the agreement document (or documents) generated at 1204 may be associated with, for example, a set of rights between the party and the counter-party, a legal contract, a product type, a monetary amount, and/or a transaction instrument.
- the agreement type comprises a document type name (e.g., an ISDA® master agreement type) and one or more document type facts (e.g., further characterizing the document type).
- an agreement may be associated with a number of different financial products.
- an agreement may be associated with an equity instrument (e.g., a stock or index instrument), a fixed income instrument (e.g., a bond, a bank loan, or a credit derivative), and/or a commodity instrument (e.g., a precious metals instrument or a wheat commodity instrument).
- an equity instrument e.g., a stock or index instrument
- a fixed income instrument e.g., a bond, a bank loan, or a credit derivative
- a commodity instrument e.g., a precious metals instrument or a wheat commodity instrument.
- the agreement may further be associated with one or more financial instruments (e.g., a wanant or a buy-call option).
- a user may indicate that a particular agreement is going to be associated with (i) buy and sell options for gold commodities and (ii) swaps for silver commodities (i.e., as indicated as "Y" in FIG. 13). Based on this information, an appropriate agreement type may be determined by the agreement modeling system controller 1000.
- the agreement modeling system controller 1000 may determine one or more agreement terms between the party and the counter-party in accordance with an agreement type. For example, the agreement modeling system controller 1000 may determine a number of default agreement terms (e.g., default credit limits) associated with a particular agreement type. In general, the agreement term may be associated with, for example, a right between the party and the counter-party, a legal contract tenn, a product type, a monetary amount, and/or a transaction instrument.
- a number of default agreement terms e.g., default credit limits
- the agreement term may be associated with, for example, a right between the party and the counter-party, a legal contract tenn, a product type, a monetary amount, and/or a transaction instrument.
- the agreement is associated with (i) swaps and options for metal commodities and (ii) options for energy commodities. Based on these parameters, the agreement modeling system controller 1000 may determine an appropriate agreement type and populate a document with appropriate terms and parameters for these types of transactions.
- the covered product matrix may be associated with any number of product types, such as equity products, stock products, index products, fixed income products, bond products, bank loan products, whole loan products, interest rate products, credit derivative products, commodity products, metal products, energy products, agriculture products, and/or any other type of product.
- the covered product matrix may be associated with any number of transaction instruments, such as swap instruments, option instruments, buy instruments, sell instruments, call instruments, put instruments, forward instruments, pre-paid forward instruments, spot instruments, repurchase agreement instruments, loan instruments, warrant instruments, a contract for differences instrument, and/or any other type of instrument.
- the covered products matrix may indicate when a particular financial instrument is approved (or disapproved) with respect to an agreement between a party and a counter-party. Also note that the covered products matrix may indicate if either of these items are "under investigation” (e.g., approval or disapproval is pending) or "not contemplated” (e.g., by the party or the counter-party). Similarly, the covered products matrix may indicate compliance authorization information, default infonnation, party or counter-party information, legal information, and/or master agreement information.
- the agreement document may be generated at 1204 by defining one or more agreement terms based on pre-stored default transaction terms (e.g., "best practices" transaction terms).
- the agreement tenn may also be automatically determined by defining the agreement term based on information receive from a user (e.g., via a client device 10) or a legacy agreement system.
- the agreement term is also based on information received from a satellite system.
- the agreement tenn may be based on input received from a business system 30, a legal system 40, a compliance system 50, a credit system 60, a treasury system 70, and/or an operations system 80.
- the covered products matrix may set the scope of a particular agreement between a party and a counter-party.
- an individual covered products matrix may exist for each "entity pair" (e.g., a party - counter-party pair) or even an "entity triplet" (e.g., a party - counter-party - investment advisor triplet).
- entity pair e.g., a party - counter-party pair
- entity triplet e.g., a party - counter-party - investment advisor triplet
- a covered products matrix may exist for each agreement, and there may be multiple covered product matrices for a single entity pair or triplet. In this case, the agreement modeling system controller 1000 may ensure that this does not result in over-lapping coverage.
- the agreement modeling system controller 1000 when the compliance system 50 indicates an authorized scope, the agreement modeling system controller 1000 defaults certain products to "no" based on a pre-defined rule. For example, if a new authorized scope entry is created for a particular counter-party, the agreement modeling system controller 1000 may default all foreign exchange products to "no" since the compliance system 50 does not typically approve foreign exchange products with that particular counter-party. According to one embodiment, an operator may override these defaults determinations.
- the compliance system 50 may mark appropriate products with a "yes,” indicating that those products may be traded with the counter-party.
- the compliance system 50 may also have the ability to mark products with a "no” (indicating disapproval) or "in progress” indicating that the product is in the process of being considered. All other boxes may remain blank indicating that the product has not been (and is not being) considered.
- the agreement modeling system controller 1000 uses a default document scope if the agreement type in question is always limited to a certain subset of products. A user may also over-ride these default values.
- an "approved scope" layer that captures the products for which legal system 40 would like to use a given master agreement.
- the legal system 40 may define for each master agreement a set of trades for which that master agreement should be used. This set of trades may be a subset of the document scope, and the document scope may therefore be defined before the approved scope. According to one embodiment, the approved scope is limited to a subset of the authorized scope and would typically fall within the document scope.
- the agreement document may be automatically transmitted to the counter-party via the counter party communication address.
- the agreement document may be automatically transmitted to a counter- paily facsimile machine after being viewed and approved by a user (e.g. , after the terms of the agreement have been negotiated as described herein).
- the agreement document is instead published via a secure Web site so that it may be accessed by the counter-party.
- a URL address and/or a password may be transmitted to the user or to the counter-party.
- FIG. 15 is a flow chart of a method for generating a contract using a scope stack according some embodiments of the present invention.
- an agreement scope, a document scope, a fact set scope, and/or a work flow scope are determined.
- the detennined scope is placed in a scope stack.
- a set of agreement/document creation rules may be evaluated based on the information in the scope stack, and the scope stack may be evaluated via an evaluation engine to generate a result at 1506.
- a contract is generated in accordance with this result.
- FIGS. 16A and 16B are block diagrams of agreement modeling system functions, applications, and interactions according to some embodiments of the present invention.
- FIG. 16A presents an engine-level overview of the client device 10 and the agreement modeling system controller 1000 according to one embodiment.
- the client device 10 includes a display engine 1 02 that may be used to exchange information with a user (e.g., by receiving information from and displaying information to the user).
- the display engine 1920 may comprise, for example, a typical WINDOWS® style Multi-Document Interface (MDI) application. Such an application may simultaneously display one or more agreements.
- MDI WINDOWS® style Multi-Document Interface
- Some examples of user displays that may be processed by the display engine 1902 are described herein with respect to FIGS. 23 through 25.
- the agreement modeling system controller 1000 includes an administrator 1910 and an agreement engine 1920 described in detail with respect to FIG. 16B.
- the agreement modeling system controller 1000 also includes an evaluation engine 2040 and a creation engine 2030 described in detail with respect to FIGS. 17 through 21.
- the agreement modeling system controller 1000 may include a fact engine 1904 to process facts and fact sets as required.
- FIG. 16B illustrates the operation of the administrator 1910 and the agreement editor 1920.
- the administrator 1910 may be used to create an agreement template, 1 including templates for various documents associated with that type of agreement.
- the agreement template may include an original document template, a schedule document template, a CSA document template, and/or an amendment document template.
- the agreement editor 1920 may be used to create an agreement instance based on the agreement template.
- the agreement instance may, for example, include instances of one or more document templates (e.g., an original document instance, a schedule document instance, a CSA document instance, and/or an amendment document instance). Both the agreement template and the agreement instance may be stored in an agreement modeling system database 1930 for future use.
- FIG. 17 is a block diagram of the evaluation engine 2040 according to some embodiments of the present invention.
- the evaluation engine 2040 allows for the dynamic evaluation and performance of rules, expression, and actions at runtime.
- a "rule” may be a type of expression that returns a Boolean value (i. e. , "true” or “false") to control the agreement modeling system 300.
- An "expression” may be a more generalized computation that returns an arbitrary string.
- An “action” may be a specialized expression that contains one or more functions that are evaluated by the evaluation engine 2040 to perform a specific task (e.g., to send an electronic mail message, perform a batch update, or add a log entry). Using these three types of computations, the evaluation engine 2040 may be employed on both the client and server sides to meet a broad range of requirements.
- the evaluation engine 2040 is comprised of two major components: the scope stack 1700 and the expression evaluator 2042.
- the scope stack 1700 may contain the entire set of variables (e.g., facts) that are available to the expression evaluator 2042 at any point in time. During operation, the scope stack 1700 may change to reflect the current state of accessible facts available to the expression evaluator 2042.
- the expression evaluator 2042 is the actual engine that parses a supplied rule/expression, perfonns callbacks to the scope stack 1700 to resolve fact references, and computes the range of operations in the expression (expressed via operators and functions) to return a final result.
- a call to the evaluation engine 2040 returns a result that is a string, such as:
- Successess or “failure” in the case of an action to indicate the result of the performed action; or an arbitrary string result in the case of an expression (depending on the specific context when the expression is evaluated).
- the inputs to the evaluation engine 2040 are a set of scopes and one or more rules/expressions.
- the scope stack 1700 may be initialized by pushing one or more scopes onto the stack 1700.
- the scope stack 1700 will be searched in a top-down order when asked to resolve an instance of a fact (i.e., the last scope pushed onto the stack 1700 will be the first scope that is searched). If no instance is found by the time the bottom of the scope stack 1700 is reached, a special exception may be returned.
- an instance of the evaluation engine 2040 may be called an unbounded number of times to evaluate rules and/or expressions (and to perfonn actions). According to one embodiment, there is no restriction on the types (or sequence) of the rules, expressions, and actions that are performed by an instance of the evaluation engine 2040. Typically, an instance of the evaluation engine 2040 will be created to perform a broad range of operations given the same initialized scope. Note that a single instance can have a different set of scopes pushed on to (or popped off of) the scope stack 1700 in between calls to the expression evaluator 2042.
- an agreement scope may contain facts, defined by a set of wizard fact sets, that are used to create an agreement - including related fact sets (e.g., fact sets nested via "button” and "list” data types). This set of wizard fact sets is collectively called the "agreement wizard.”
- an agreement wizard is not re-entrant. That is, once an agreement wizard's set of facts have been answered, they are static for the life of the agreement (and, as a result, the one-and-only agreement scope may always be active).
- a "document scope” may contain a set of facts that are defined by a document's primary fact set, as identified as an attribute of the associated document type.
- a document has one, and only one, primary fact set. There may be only one active document scope at any point in time, which is defined by the cmrent document instance's primary fact set.
- a "fact set scope” may contain a set of facts that are defined by the current fact set. Note that there may be more than one fact set scope active (e.g., when a nested fact set has been invoked by pressing a button generated by a button data type or by invoking an instance of a multi-instance fact set associated with a list data type).
- a "workflow scope” may contain a special set of facts that are defined by a fact set populated with relevant in formation associated with the current set of workflow operations being performed.
- This scope may be independent of other scopes and may be either the only scope on the scope stake 1700 or the top-most scope (i.e., the last scope placed on the stack).
- the scope stack 1700 must contain at least one of these scopes before being used to evaluate a rule/expression.
- the agreement scope may always at the bottom of the scope stack 1700. If it exists, a one-and-only document scope may come next on the scope stack 1700 (i.e., immediately on top of the agreement scope). Finally, one or more fact set scopes can exist at the top of the scope stack 1700.
- the 18 illustrates a number of scope stacks 1702, 1704, 1706, 1708 according to an embodiment of the present invention (e.g., depicting a number of scope hierarchies in the scope stack 1700 for an instance of the evaluation engine 2040 at a single point in time).
- the first example 1702 illustrates the scope stack 1700 containing the minimum agreement scope.
- the document scope constructed from the document's primary fact set is then pushed onto the stack (e.g., as in the second example 1704).
- the appropriate fact set scope is pushed onto the stack (e.g., as in the third example 1706).
- the fourth example 1708 illustrates the possible existence of a workflow scope on top of all of the other scopes - the deepest nesting that can occur on the scope stack 1700 according to this embodiment.
- a "root node fact set” is a fact set that does not have any other fact set as a parent - it is only owned by the document in which it is contained.
- a "child fact set” is any fact set that is a dependent on a root node fact set (e.g. , a fact set associated with a button or a list).
- a "fact namespace" exists within each fact scope.
- a fact that belongs to a root node fact set may be immediately accessible in a scope's namespace.
- a fact in a child fact set (and a fact in a multi-instance fact set) may not be immediately accessible. Instead, these facts may be accessed via fact accessor functions available within the expression evaluator 2042.
- each instance of a fact set has a coreesponding "fact set context."
- a fact set context contains all of the fact names and fact values defined by an instance of a fact set, plus a linkage to all child (dependent) fact set contexts.
- root node fact set contexts are also stacked within the scope. As with scopes, the order on the stacked fact set contexts determines the search order when resolving references to fact names within a specific scope 1700.
- FIG. 19 illustrates fact namespaces, fact set contexts, and scopes according to some embodiments of the present invention.
- the stacking of fact set contexts and linkage to child fact set contexts are illustrated.
- there is one root node fact set for each fact set defined as a wizard page e.g., all of the fact sets directly accessible via the wizard's next and back buttons.
- the order of the agreement scope's root node fact set contexts is the reverse of the order that the wizard pages occur in the wizard. That is, the first wizard fact set context is on the bottom of the scope stack 1710 (within the agreement scope) and the last wizard fact set context is at the top of the scope stack 1710 (within the agreement scope).
- the FactSetThree is the first wizard fact set page and FactSetOne is the last wizard fact set page.
- the FactSetThree is the first wizard fact set page and FactSetOne is the last wizard fact set page.
- the fact set context for each instance (see FactSetThree in FIG. 19).
- the facts in the first instance of a multi-instance root node fact set are directly accessible without the use of fact accessor functions.
- the accessibility to facts may be described in a vertical or horizontal fashion as depicted in FIG. 19.
- all vertically stacked fact contexts within all of the vertically stacked fact scopes defines all of the facts that are directly accessible during a search.
- the search occurs from the top-down (i.e., starting with the top-most fact set context in the top-most fact scope and ending with the bottom-most fact set context within the bottom-most fact scope).
- access to any facts that exist within non-root node fact sets e.g., child fact sets
- facts may be referenced via two names in a given namespace. One is the "unqualified” fact name and the second is the "fully qualified" fact name.
- the unqualified fact name is the case-insensitive fact name itself.
- the fully qualified fact name is the FactSefName:FactName concatenated together with a colon separator. Note that other separators may also be used (e.g., a ".” or a "$").
- Fact accessor functions allow systematic access to child fact sets and instances of multi-instance fact sets, in addition to providing a range of general access functions to any fact and fact set instance. These functions may be available for use in any rule or expression.
- Boolean FactExists( ⁇ Fact>, ⁇ Value>) - returns "true” if an instance of the named ⁇ Fact> exists anywhere on the scope stack 1700 (including nested children and all multi-instance fact sets) with the assigned ⁇ Nalue>.
- ⁇ Value> may be an arbitrary expression itself that results in a string.
- Boolean FactExists ( ⁇ ChildFact>, ⁇ ChildValue>, ⁇ ParentFact>, ⁇ ParentValue>) - returns "true” if an instance of the named ⁇ ChildFact> exists anywhere on the scope stack 1700 (including nested children and all multi- instance fact sets) with the assigned ⁇ ChildValue> when its ⁇ ParentFact> has the assigned ⁇ ParentValue>.
- the values for both child and parent may be arbitrary expressions that result in a string.
- Boolean FactSetExists( ⁇ Fact set>) - returns "true” if an instance of the named ⁇ Fact set> exists anywhere on the scope stack 1700 (including nested children and all multi-instance fact sets).
- agreement modeling system may be rules- driven, using a range of rules and expressions to control the system's behavior, such as: applies rules; fact default value expressions; fact default attribute expressions; enabled rules; multi-instance fact set name expressions; multi-instance fact set primary key expressions; multi-instance document name expressions; security access rules; workflow rules; and workflow actions.
- rules such as: applies rules; fact default value expressions; fact default attribute expressions; enabled rules; multi-instance fact set name expressions; multi-instance fact set primary key expressions; multi-instance document name expressions; security access rules; workflow rules; and workflow actions.
- a number of database tables associated with agreement modeling define a potential set of components (e.g., an agreement type, a document type, a fact set, or a fact) that apply in a given context.
- the inclusion of facts into fact sets, fact sets into documents, documents into agreements, and which agreement type applies given a specific context may be controlled via applies rules.
- Applies rules are expressions that are constructed and evaluated based upon the facts available in the system.
- zero or more applies rules can be associated with any individual component (with the default being zero).
- the lack of any applies rules being associated with a component implies the automatic inclusion of the component in any context. If one or more applies rules exist, then any one of the rules must be "true” (e.g., an OR condition against each of the rules) in order to include the component in a specific context.
- a default value expression and default attribute expression may be associated with each specific applies rule. If an applies rale is "true,” then the other two expressions (if they exist) are evaluated and the results applied to the fact.
- the evaluation of "fact default value” and “fact default attribute” expressions may occur at the server, and the agreement and/or document scopes may be on scope stack 1700 when this evaluation occurs.
- the default value and default attribute expressions may be expressions that compute default value(s) to be assigned to a fact and the default attribute to be set for an instance of a fact.
- the evaluation of "enabled" rules may occur at the client and/or a server, and the agreement, document, and/or fact set scopes may be on scope stack 1700 when this evaluation occurs.
- the fact set is required to provide an appropriate multi- instance name expression by which its name is derived for display in the instance list within the editor client.
- this name is assembled from the values of facts within the fact set via a concatenation of fact set fact values as dictated by the multi- instance name expression.
- the multi-instance fact set name expression is special in that it may contain a mixture of list box column-heading formatting infonnation in addition to the individual expressions required to compute each column's contents for that instance.
- each instance of a multi-instance fact set can require that its name is unique, thereby enforcing the notion of a primary key as described by the multi- instance fact set name expression.
- the unique attribute applied to a multi-instance fact set is enforced by the editor upon completion of the dialog associated with the instance. The editor may compare cunent instance names with the currently computed instance name to prevent duplicates.
- the evaluation of the "multi-instance document name" expressions may occur at the client, and the agreement and/or document scopes may be on scope stack 1700 when this evaluation occurs.
- a document attribute provides an appropriate multi-instance name expression by which its document name is derived for display in the multi-document instance list within a multi-document tab.
- the evaluation of the "security access" rules may occur at the server, and the agreement scope may be on scope stack 1700 when this evaluation occurs. Because agreements are dynamically constructed based upon a rule set that is evaluated at runtime, a security model that dictates access to agreements/documents must also be rules based. For example, agreements may be formed based upon answers to questions that appear via a wizard fact set.
- the answers to the questions may indicate which agreements can be potentially formed by the rules associated with the agreement types. Without knowing which answers the user will select (or without even knowing the questions that will be asked), a rule set may be put into place ahead of time that ensures that a user's set of potential agreements does not change.
- a security table contains zero or more entries per security group that specifies access rights to the set of agreements and documents that a user is allowed to access (i.e., given that the user is a member of the group). Each table entry may partition access into specific create, delete, and implied update rights. An optional access expression may also be associated with each table entry. According to one embodiment, the access rights are automatically applied when an access expression does not exist. If an access expression exists associated with the table entry, then the expression must evaluate to "true" for the set of access rights to apply.
- the evaluation of the "workflow” rules may regulate the performance of workflow actions throughout the system.
- the evaluation of the "workflow” actions may occur at the server, and the agreement scope maybe on scope stack 1700 when this evaluation occurs.
- a workflow action expression may be specified associated with every applies rule in the system to enable execution of the workflow action (expressed as a function in the evaluator) provided the applies rule is "true.”
- the agreement modeling system also enables extension of a set of workflow actions via a Java method that expands the base set of functions available in the evaluation engine 2040.
- a generalized mechanism to define a workflow wizard enabling population of values by a user may be provided.
- FIG. 20 is a block diagram of agreement creation interactions according to some embodiments of the present invention.
- the creation engine 2030 may manufacture new agreements and documents.
- the creation engine 2030 may exist in the database backend 2020 and niay comprise a creation processor 2050 and an instance of the evaluation engine 2040 (e.g., that extends from the evaluation engine 2040 object in the Java/object sense).
- the creation engine 2030 may service two types of create operations: a create agreement operation and a create document operation.
- a successful create agreement operation results in a new agreement including one or more associated required documents.
- a successful create document(s) operation results in the creation of one (or more) new documents associated with an existing agreement.
- An instance of the creation engine 2030 is manufactured to service each create operation (note that the create functionality may be exposed via Java Stored Procedures).
- the create agreement operation may be invoked from the agreement editor 1920 upon a completion of an agreement wizard as follows.
- the agreement wizard may be selected via a "file - new" menu item, followed by selection of submenu items that allow selection of a specific agreement wizard.
- the content of each agreement wizard may be defined by one or more agreement wizard fact sets.
- the agreement wizard is completed by activating a "finish" button on one of the wizard pages. When the "finish" button is activated, all of the combined agreement wizard fact sets are communicated to the database backed 2020, in the form of an XML document describing the fact set content, via a middle-tier 2010.
- the middle-tier 2010 simply passes the stream through to the database/backend 2020.
- an instance of the creation engine 2030 is instantiated.
- an instance of the evaluation engine 2040 is created and initialized with an agreement scope that contains all of the facts defined in the wizard fact sets passed from the agreement editor 1920.
- the creation processor 2050 determines the appropriate agreement to be created (via "applies rules"). If an appropriate agreement is found, it is determined if the user has the appropriate rights to create all required documents associated with the agreement (via "security rules"). If the user has appropriate rights, then the agreement is created by systematically creating the required documents associated with the agreement, conditionally populating each document's content with the fact sets and facts that are included through the applies rules analysis. In addition, default values and attributes may be assigned to facts populated into documents.
- the creation processor 2050 may use a series of stored procedure calls that operate directly on the agreement, document, and fact set or fact instance tables populating instance data into the tables as the intermediate result of rules and expression evaluations.
- a set of well-defined stored procedures may accommodate the entire agreement creation process.
- the immediate return value for the create agreement operation from the database/backend 2020 to the middle-tier 2010 may simply comprise signal of success or failure. If the creation of the agreement failed, then the middle-tier 2010 returns an appropriate Java exception to the agreement editor 1920.
- the middle-tier 2010 may orchestrate call(s) back to the database/backend 2020 to make it appear as if the agreement editor 1920 had called an "open agreement" operation. That is, an entire XML stream representing the opening of the newly created agreement may be returned.
- FIG. 21 is a block diagram of document creation interactions according to some embodiments of the present invention.
- the create documents operation may be invoked from the agreement editor 1920 when an "add" button is activated via a multi-document tab and one of the listed document types are selected.
- a multi-document list box may display all instances of existing documents that are associated with that tab (e.g., documents may be associated with a tab based on a document type's document group membership).
- the agreement editor 1920 may first call a method that returns an array of (partially loaded) objects that are used to populate an "add document” selection dialog associated with the "add” button.
- a corresponding stored procedure may form the list of document types based on a specific user and/or agreement.
- the agreement editor 1920 Upon the selection of a document type from the "add document” list, the agreement editor 1920 sends the selected document type information to the database backed 2020 via a middle-tier 2010 API call.
- An instance of the creation engine 2030 is then instantiated by the database/backend 2020.
- an instance of the evaluation engine 2040 is created and initialized with the agreement scope that is applicable for the active agreement.
- the agreement scope is passed as an XML stream by the agreement editor 1920 which has the scope loaded for the active agreement.
- the scope is instead loaded from a database 2060.
- the creation processor 2050 conditionally populates the document's content with the fact sets and facts that are included through an "applies rules" analysis. In addition, default values and attributes are assigned to each fact based upon “value and attribute expressions.”
- the instance of the creation engine 2030 may be associated with a create agreement operation or a create document operation. In either case, the appropriate agreement scope may be initialized on the associated evaluation engine 2040.
- a series of stored procedure calls by the creation processor 2050 may operate directly on the document and fact set - fact instance tables populating instance data into the tables as the result of the rules and expressions evaluations.
- a set of well-defined stored procedures may accommodate the entire agreement, document, fact set, and/or fact creation process.
- security tables and views may be calculated.
- the availability of the document scope enables applies rules, value expressions, and attribute expressions to be written that are generally more localized to a document's context. With the document scope included, rules and expressions can be written that do not need to rely solely on agreement level attributes to drive the creation process.
- the intermediate return value from the create document operation from the database/backend 2020 to the middle-tier 2010 may simply be a signal of success or failure. If the creation of the document failed, then the middle-tier 2010 returns an appropriate Java exception to the agreement editor 1920. Upon successful creation of a document, the middle-tier 2010 (prior to returning information to the agreement editor 1920) may orchestrates call(s) back to the database/backend 2020 to make it appear as if the agreement editor 1920 had called an update document operation. That is, an entire XML stream representing the newly created document may be returned.
- FIG. 22 is a flow chart of a method performed by a user according some embodiments of the present invention.
- the user arranges for agreement information to be transmitted from the client device 10 to the agreement modeling system controller 1000.
- the user may select a number of financial instruments and/or financial products via the client device 10.
- the user defines a communication address to which an agreement document will be transmitted (e.g., a communication address associated with a counter-party device 15).
- the communication address maybe, for example, entered by the user or selected from a list of potential communication addresses.
- the communication address may be a counter-party communication address
- the communication address may also be associated with a different party, a particular device, and/or the user (e.g., an electronic mail address associated with a legal department).
- the user defines a number of different communication addresses to which an agreement document will be transmitted.
- the communication address is instead defined by the agreement modeling system controller 1000 and transmitted to the user (or to the counter-party). For example, the agreement modeling system controller 1000 may generate and transmit a URL address and password that can be used to access an agreement document.
- FIGS. 23 through 25 illustrate client displays associated with an agreement according to an embodiment of the present invention.
- the system may be document-centric in the display of agreement information., and that a new agreement may be created via a special wizard "fact set" that asks questions and receives answers (fact values) that are used by the fact engine's rules-based wizard to determine the agreement type, documents, fact sets, and facts that are populated in the agreement.
- FIG. 23 illustrates a display 2300 when no agreement is loaded into the application. A user selects an existing agreement from a search dialog that is associated with the "file ... open agreement" menu item.
- FIG. 24 illustrates a display 2400 after an agreement has been loaded.
- Each agreement instance in the MDI display frame contains a set of display tabs that are dynamically generated according to a set of document groups that are defined for the agreement.
- Each document group has one or more documents that are members of the group and whose contents will be displayed on the relative document group tab.
- FIG. 24 illustrates the layout of a general "agreement data" single-document group tab. Note that a consistent display space may be organized around the current document and active fact set. For example, a tab associated with a single-document display may divide the display 2400 into a left and right pane.
- the cunent document's name (“LCA Today") is displayed at the top of the left-pane.
- the left-pane list box contains the set of fact sets that are defined for the cunent document (e.g., "agreement data,” "counter-party data,” “credit support,” and “cross acceleration”).
- the right-pane contains the contents for the actively selected fact set within the cunent document.
- the name of the active fact set (e.g., "agreement data”) may be displayed in the top of the right-pane.
- FIG. 25 illustrates a display 2500 when an agreement has been loaded, and the display 2500 is associated with a multi-instance fact set display (i.e., "counter-party data").
- the right-pane is divided into two areas.
- the top area includes a list box of instances of the active fact set.
- the display entry in the list box is formed by an expression associated with the fact set.
- the bottom portion of the right-pane display area indicates the facts that comprise the fact set which may be displayed in linear order (as with the single-instance display space).
- one of the facts displayed is a counter-party communication address 2502 (i.e.,
- the user may enter (or select) a counter-party communication address 2502 to which a generated agreement document will be transmitted.
- an agreement modeling system controller 1000 that facilitates generation and/or negotiation of an agreement document. According to other embodiments, however, some or all of these functions are instead performed by other devices. For example, multiple devices may communicate with each other to perform the functions described herein without the use of a "controller" (e.g., a peer-to-peer model maybe used). Moreover, many of the devices illustrated in FIG. 3 (including some or all of the satellite systems) may be inco ⁇ orated in a single device. In addition, many of the embodiments described herein are directed to financial transaction agreements. However, the present invention is applicable to may other types of agreements as well (e.g., contracts with a governmental authority).
Landscapes
- Engineering & Computer Science (AREA)
- Business, Economics & Management (AREA)
- Theoretical Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Finance (AREA)
- Accounting & Taxation (AREA)
- Physics & Mathematics (AREA)
- General Health & Medical Sciences (AREA)
- Economics (AREA)
- Health & Medical Sciences (AREA)
- Computational Linguistics (AREA)
- Audiology, Speech & Language Pathology (AREA)
- Artificial Intelligence (AREA)
- Development Economics (AREA)
- General Engineering & Computer Science (AREA)
- Marketing (AREA)
- Strategic Management (AREA)
- Technology Law (AREA)
- General Business, Economics & Management (AREA)
- Information Transfer Between Computers (AREA)
- Financial Or Insurance-Related Operations Such As Payment And Settlement (AREA)
Abstract
Description
Claims
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
AU2002322709A AU2002322709A1 (en) | 2001-07-27 | 2002-07-29 | Systems and methods for facilitating agreement generation and negotiation via an agreement modeling system |
Applications Claiming Priority (4)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US09/916,881 US20030023539A1 (en) | 2001-07-27 | 2001-07-27 | Systems and methods for facilitating agreement definition via an agreement modeling system |
US09/916,881 | 2001-07-27 | ||
US09/929,184 | 2001-08-14 | ||
US09/929,184 US7720729B2 (en) | 2001-07-27 | 2001-08-14 | Systems and methods for facilitating agreement generation and negotiation via an agreement modeling system |
Publications (3)
Publication Number | Publication Date |
---|---|
WO2003012586A2 true WO2003012586A2 (en) | 2003-02-13 |
WO2003012586A8 WO2003012586A8 (en) | 2004-05-21 |
WO2003012586A3 WO2003012586A3 (en) | 2004-07-22 |
Family
ID=27129708
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
PCT/US2002/023898 WO2003012586A2 (en) | 2001-07-27 | 2002-07-29 | Systems and methods for facilitating agreement generation and negotiation via an agreement modeling system |
Country Status (1)
Country | Link |
---|---|
WO (1) | WO2003012586A2 (en) |
Cited By (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US7945500B2 (en) | 2007-04-09 | 2011-05-17 | Pricelock, Inc. | System and method for providing an insurance premium for price protection |
US7945501B2 (en) | 2007-04-09 | 2011-05-17 | Pricelock, Inc. | System and method for constraining depletion amount in a defined time frame |
US8019694B2 (en) | 2007-02-12 | 2011-09-13 | Pricelock, Inc. | System and method for estimating forward retail commodity price within a geographic boundary |
US8156022B2 (en) | 2007-02-12 | 2012-04-10 | Pricelock, Inc. | Method and system for providing price protection for commodity purchasing through price protection contracts |
US8160952B1 (en) | 2008-02-12 | 2012-04-17 | Pricelock, Inc. | Method and system for providing price protection related to the purchase of a commodity |
Citations (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US5970479A (en) * | 1992-05-29 | 1999-10-19 | Swychco Infrastructure Services Pty. Ltd. | Methods and apparatus relating to the formulation and trading of risk management contracts |
US6125391A (en) * | 1998-10-16 | 2000-09-26 | Commerce One, Inc. | Market makers using documents for commerce in trading partner networks |
-
2002
- 2002-07-29 WO PCT/US2002/023898 patent/WO2003012586A2/en not_active Application Discontinuation
Patent Citations (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US5970479A (en) * | 1992-05-29 | 1999-10-19 | Swychco Infrastructure Services Pty. Ltd. | Methods and apparatus relating to the formulation and trading of risk management contracts |
US6125391A (en) * | 1998-10-16 | 2000-09-26 | Commerce One, Inc. | Market makers using documents for commerce in trading partner networks |
Cited By (8)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US8019694B2 (en) | 2007-02-12 | 2011-09-13 | Pricelock, Inc. | System and method for estimating forward retail commodity price within a geographic boundary |
US8156022B2 (en) | 2007-02-12 | 2012-04-10 | Pricelock, Inc. | Method and system for providing price protection for commodity purchasing through price protection contracts |
US8538795B2 (en) | 2007-02-12 | 2013-09-17 | Pricelock, Inc. | System and method of determining a retail commodity price within a geographic boundary |
US7945500B2 (en) | 2007-04-09 | 2011-05-17 | Pricelock, Inc. | System and method for providing an insurance premium for price protection |
US7945501B2 (en) | 2007-04-09 | 2011-05-17 | Pricelock, Inc. | System and method for constraining depletion amount in a defined time frame |
US8065218B2 (en) | 2007-04-09 | 2011-11-22 | Pricelock, Inc. | System and method for providing an insurance premium for price protection |
US8086517B2 (en) | 2007-04-09 | 2011-12-27 | Pricelock, Inc. | System and method for constraining depletion amount in a defined time frame |
US8160952B1 (en) | 2008-02-12 | 2012-04-17 | Pricelock, Inc. | Method and system for providing price protection related to the purchase of a commodity |
Also Published As
Publication number | Publication date |
---|---|
WO2003012586A8 (en) | 2004-05-21 |
WO2003012586A3 (en) | 2004-07-22 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US7720729B2 (en) | Systems and methods for facilitating agreement generation and negotiation via an agreement modeling system | |
US10923912B2 (en) | Electronic trading confirmation system | |
US20200143475A1 (en) | System and method for conducting web-based financial transactions in capital markets | |
US7970694B2 (en) | Method and system for executing trades in a user preferred security | |
US6772146B2 (en) | Website for financial information | |
US6317727B1 (en) | Systems, methods and computer program products for monitoring credit risks in electronic trading systems | |
US10387952B1 (en) | System and method for conducting web-based financial transactions in capital markets | |
US6996540B1 (en) | Systems for switch auctions utilizing risk position portfolios of a plurality of traders | |
US20020138389A1 (en) | Browser interface and network based financial service system | |
US20020116317A1 (en) | Systems and methods for reverse auction of financial instruments | |
US20060190383A1 (en) | Systems for risk portfolio management | |
US20050187866A1 (en) | Method and system for executing financial transactions via a communication medium | |
US20020007335A1 (en) | Method and system for a network-based securities marketplace | |
US20010037287A1 (en) | Method and apparatus for an advanced speech recognition portal for a mortgage loan management system | |
US20080270283A1 (en) | Electronic trading data integration and protection system | |
US20020178099A1 (en) | Methods and systems for managing a portfolio of securities | |
JP2004530977A (en) | Query processing method and system requiring cooperative access to distributed database | |
US8682767B2 (en) | System and method for accessing and displaying data relating to financial securities | |
EP1267288A1 (en) | Online creation and management of enterprises | |
WO2003012586A2 (en) | Systems and methods for facilitating agreement generation and negotiation via an agreement modeling system | |
WO2003012584A2 (en) | Systems and methods for facilitating use of agreement information via an agreement modeling system | |
WO2002031740A2 (en) | Method and apparatus for processing financing application | |
WO2001044974A2 (en) | Analyzing input data streams using user criteria | |
KR20020061338A (en) | IT infra system, and method for applying tax using the same |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
AK | Designated states |
Kind code of ref document: A2 Designated state(s): AE AG AL AM AT AU AZ BA BB BG BR BY BZ CA CH CN CO CR CU CZ DE DK DM DZ EE ES FI GB GD GE GH GM HR HU ID IL IN IS JP KE KG KP KR KZ LC LK LR LS LT LU LV MA MD MG MK MN MW MX MZ NO NZ PL PT RO RU SD SE SG SI SK SL TJ TM TR TT TZ UA UG US UZ VN YU ZA ZW Kind code of ref document: A2 Designated state(s): AE AG AL AM AT AU AZ BA BB BG BY BZ CA CH CN CO CR CU CZ DE DM DZ EE ES FI GB GD GE GH GM HU ID IL IN IS JP KE KG KP KR KZ LK LR LS LT LU LV MA MD MG MK MW MX MZ NO NZ PL PT RO RU SD SG SI SK SL TJ TM TR TT TZ UA UG UZ VN YU ZA |
|
AL | Designated countries for regional patents |
Kind code of ref document: A2 Designated state(s): GH GM KE LS MW MZ SD SL SZ TZ UG ZW AM AZ BY KG KZ MD RU TJ TM AT BE CH CY DE DK ES FI FR GB GR IE IT LU MC NL PT SE TR BF BJ CF CG CI CM GA GN GW ML MR NE SN TD TG Kind code of ref document: A2 Designated state(s): GH GM KE LS MW MZ SD SL SZ UG ZW AM AZ BY KG KZ MD TJ TM AT BE CH CY DE DK ES FR GB GR IE IT LU MC NL PT SE TR BF BJ CF CG CI CM GA GN GW ML NE SN TD TG |
|
121 | Ep: the epo has been informed by wipo that ep was designated in this application | ||
CFP | Corrected version of a pamphlet front page | ||
CR1 | Correction of entry in section i |
Free format text: IN PCT GAZETTE 07/2003 UNDER (81) DELETE "US"; AS A CONSEQUENCE REPLACE "(71) APPLICANT (FOR ALL DESIGNATED STATES EXCEPT US)" BY "(71) APPLICANT" AND REPLACE "(72) INVENTORS; AND (75) INVENTORS/APPLICANTS (FOR US ONLY)" BY "(72) INVENTORS"; DUE TO LATE TRANSMITTAL BY THE RECEIVING OFFICE |
|
REG | Reference to national code |
Ref country code: DE Ref legal event code: 8642 |
|
122 | Ep: pct application non-entry in european phase | ||
NENP | Non-entry into the national phase in: |
Ref country code: JP |
|
WWW | Wipo information: withdrawn in national office |
Country of ref document: JP |