The present invention relates to systems, methods and user interfaces that are utilized in connection with the trading of financial instruments. More particularly, a system for delivering messages to a server through a buffer on a publish/subscribe system. The server may be a live alert system that generates messages, including links that may be used to generate real-time reports when a rule or limit is violated.
Modern financial institutions process and monitor a large volume of trading data, such as orders for financial instruments. Financial instruments include options contracts, futures contracts, options on futures contracts, interest rate products, securities, commodities, equity contracts, etc. Institutions that administer transactions in financial instruments process and store large amounts of trading data every second of the trading day. Moreover, upon executing a trade, processors continually access and distribute market data, which is a subset of trading data.
Financial institutions, such as exchanges, may provide regulatory or market oversight to monitor trade activity. Regulatory or other oversight entities often analyze trading data for compliance with regulations and to ensure market and financial integrity. The analysis of ever increasing amounts of trading data can be a significant burden on regulatory or other oversight entities.
Therefore, there exists a need in the art for automated systems and methods that help regulators and others analyze trading data.
Aspects of the invention overcome at least some of the above problems and limitations by providing systems and methods for delivering a plurality of trading data messages from a match engine to a server. One or more listeners each subscribe to a subset or subsets of the plurality of trading data messages according to a criterion. The criteria may include message source, message content, or intended destination. A buffer receives the subset or subsets of the plurality of trading data messages and stores messages temporarily for some time period. The timer period may be a set duration or be based on the rate of messages received. A server receives the trading data messages stored from the buffer and analyzes the trading data messages.
The server may be a live alert server alerting the regulators and other trading entities when one or more rules or limits are violated. The live alert server receives trade messages and includes computer-executable instructions for comparing trading data to one or more rules. The live alert server generates a rule message when a rule or limit is violated. An email server is configured to receive the rule message and generate an email message that includes a link for generating a report relating to the violated rule or limit.
Of course, the apparatuses, methods and systems disclosed herein may also include other additional elements, steps, computer-executable instructions, or computer-readable data structures. The details of these and other embodiments are set forth in the accompanying drawings and the description below. Other features and advantages will be apparent from the description and drawings, and from the claims.
Aspects of the invention may take physical form in certain parts and steps, embodiments of which will be described in detail in the following description and illustrated in the accompanying drawings that form a part hereof, wherein:
a and 3b illustrates illustrative collections of trading data;
a illustrates yet another illustrative collection of trading data;
b illustrates the structure of an alternative collection of trading data;
Aspects of the embodiments are preferably implemented with computer devices, methods, systems and computer networks for exchange trading information. An exemplary trading network environment for implementing trading systems and methods is shown in
An exchange computer system 100 receives orders and transmits market data related to orders and trades to users. Exchange computer system 100 may be implemented with one or more mainframe, servers, gateways, desktop, handheld and/or other computers. In one embodiment, a computer device uses a 64-bit (or more) processor. A user database 102 includes information identifying traders and other users of exchange computer system 100. Data may include user names and passwords. An account data module 104 may process account information that may be used during trades. A match engine module 106 is included to match bid and offer prices. Match engine module 106 may be implemented with software that executes one or more algorithms for matching bids and offers. A trade database 108 may be included to store information identifying trades and descriptions of trades. In particular, a trade database may store information identifying the time that a trade took place and the contract price. An order book module 110 may be included to compute or otherwise determine current bid and offer prices. A market data module 112 may be included to collect market data and prepare the data for transmission to users. A risk management module 134 may be included to compute and determine a user's risk utilization in relation to the user's defined risk thresholds. An order processing module 136 may be included to decompose delta based and bulk order types for processing by order book module 110 and match engine module 106.
The trading network environment shown in
Computer device 114 is shown directly connected to exchange computer system 100. Exchange computer system 100 and computer device 114 may be connected via a T1 line, a common local area network (LAN) or other mechanism for connecting computer devices. Computer device 114 is shown connected to a radio 132. The user of radio 132 may be a trader or exchange employee. The radio user may transmit orders or other information to a user of computer device 114. The user of computer device 114 may then transmit the trade or other information to exchange computer system 100.
Computer devices 116 and 118 are coupled to a LAN 124. LAN 124 may have one or more of the well-known LAN topologies and may use a variety of different protocols, such as Ethernet. Computers 116 and 118 may communicate with each other and other computers and devices connected to LAN 124. Computers and other devices may be connected to LAN 124 via twisted pair wires, coaxial cable, fiber optics or other media. Alternatively, a wireless personal digital assistant device (PDA) 122 may communicate with LAN 124 or the Internet 126 via radio waves. PDA 122 may also communicate with exchange computer system 100 via a conventional wireless hub 128. As used herein, a PDA includes mobile telephones and other wireless devices that communicate with a network via radio waves.
One or more market makers 130 may maintain a market by providing constant bid and offer prices for a derivative or security to exchange computer system 100. Exchange computer system 100 may also exchange information with other trade engines, such as trade engine 138. One skilled in the art will appreciate that numerous additional computers and systems may be coupled to exchange computer system 100. Such computers and systems may include clearing, regulatory and fee systems.
The operations of computer devices and systems shown in
Of course, numerous additional servers, computers, handheld devices, personal digital assistants, telephones and other devices may also be connected to exchange computer system 100. Moreover, one skilled in the art will appreciate that the topology shown in
In step 210, at least a portion of the data from the trading record received in step 205 is stored on a computer readable medium. As used herein, a computer-readable medium may include, for example, random access memory (RAM), dynamic random access memory (DRAM), flash memory, a hard disk drive, thumb drive, and/or an optical disk (CD ROM, DVD or other optical media). Solid-state memory modules allow for rapid queries due to the lack of moving parts, such as those associated with hard disk drives. The computer-readable medium may be integral with the Exchange Computer System 100 and/or may be associated with one or more modules, such as the match engine module 136.
a illustrates a collection of trading data. As seen in the figure, a memory module 300, such as a RAM or optical disk, may store a plurality of trading records. For example, the trading record stored in step 205 may be visually represented as trading record 305. In step 215, a second trading record may be received. The second trading record may be of a fixed length and have substantially the same information as the first trading record received in step 205. Yet in additional or alternative embodiments, the second trading record may be of a different length than the first trading record, may have additional fields not present in the first record and/or may include additional data not present in the first record. In one embodiment, optional step 225 (explained in more detail below) may be implemented to determine if the trading record comprises more than one field.
In step 220, the second trading record (or a portion thereof) is sequentially stored in relation to the first trading record 305, wherein the data from the second trading record is stored substantially physically adjacent to the data received from the first trading record 305. One of the advantages of locating records close to one another is faster reading times. Existing database systems may have data scattered throughout a memory device. Reading data arranged in this manner is time consuming because the reading process has to skip from one physical location to another physical location. For example, a hard disk drive must physically move a reading head from location to location.
While an exemplary embodiment may not have an index as used in conventional databases, the collection of data as represented by first trading records 305, 310 and 315 can perform row selection at the same speed as an indexed database. Indeed, in some embodiments, eliminating conventional databases indexes results in queries that have the same speed for all columns in the table. Conventional databases typically have an index on every column. This results in deleterious effects on the insertion speed. Conversely, a collection of data organized according to the various embodiments allows for rapid insertion speeds and is particularly useful and advantageous in real-time insertion situations, such as those routinely encountered in the trading industry. Moreover, by providing a collection of data without an associated database-type index, more space is available on the computer readable medium to store data, such as that present in the data of the first trading record and second trading record (305, 310). An increase in data storage may be achieved by eliminating the use of a conventional database-type index. In at least one implementation, the elimination of an index may double the amount of data that may be stored on the computer readable memory.
As one skilled in the art will appreciate, a computer-readable medium may have multiple linked drives and/or modules, where the data is stored in a sequential fashion as described above. The drives and/or modules may be at different physical or remote locations. For example,
As briefly mentioned above, one or more trading records may include multiple fields. Optional step 225 may be implemented to determine if one or more of the trading records includes more than one field. Upon determining that more than one field exists, step 230 may optionally be initiated to parse a first field from one of the trading records. As shown in
In one embodiment, data associated with a first field of a trading record, such as financial instrument data 405a may be stored in a first location on the computer readable medium (step 245). Data associated with other fields of the same record is not stored substantially sequential to financial instrument data 405a, but may be placed on the computer readable memory at a different location (see exemplary embodiment of step 250). Upon receiving another trading record, such as trading record 410, it too may be parsed into a plurality of data associated with different fields. For simplicity,
Other matching fields of different trading records, such as trading records 405 and 410 may also be stored in the same manner. For example, price fields 405b and 410b are stored sequentially wherein price data 410b is substantially sequential to and follows price data 405b. (see also; quantity data 405c and 410c). The data may be stored sequentially as it is received and in at least one embodiment is stored in real time allowing for the fast storage and manipulation of the data without having to construct and update a database-type index. Moreover, while the illustrated computer-readable memory of
b illustrates the structure of an alternative or additional collection of trading data. A computer-readable medium 420 includes a plurality of arrays that contain trading data. Each array includes a particular type of data for a plurality of records. For example, array 2 includes buy/sell, account and firm data for a plurality of trading records and array 4 includes userID and sessionID data. Each record is assigned to a unique row. Section 422, which represents row 0 of array 2 includes 32 bit rows. Bits 0-14 identify the trading firm, bits 15-30 identify the account and bit 31 is used to identify data as corresponding to a buy or a sell. Section 424 illustrates exemplary values for the fields identified in array 2 and section 426 illustrates exemplary values for the fields identified in array 4.
Keys may be used to represent values and facilitate further processing. The keys utilize table based compression to remove gaps in data. Section 428 shows exemplary firm number keys. The firm field in section 422 includes 15 bits, which allows for 32,768 unique keys. The actual firm numbers used may include gaps. For example, section 428 shows that the first firm number used is “28” and the second firm number used is “125.” When assigning keys, the keys may be arranged in sequential order corresponding to the sequential order of the firm numbers to facilitate searching. Section 428 shows that the lowest firm number of “28” is assigned a key value of “0” and the next highest firm number of “125” is assigned a key value of “1.”
Arranging keys in the same order as firm numbers allows for the rapid searching of firm numbers within a specified range. Of course keys for some or all of the additional fields, such as account number, sessionID, userID, price, date and time, may also be arranged in sequential order, alphabetical order or other orders that facilitate searching. When new records are added, keys may be reassigned to ensure that the order of the keys corresponds to the order of the data.
A query on a computer readable medium, such as computer readable mediums having data stored in accordance with several or all of the steps and embodiments discussed in regards to
For example, looking back to
Yet in other embodiments, distinct portions of trading records may be queried and/or a query may be directed to selected portions of trading records. For example, the pending orders may be organized as set forth in
This can be more readily seen when reviewing
The speed at which queries may be performed when trading records are arranged as described above may be taken advantage of for other exchange and trading related activities, such as a match engine.
A trading firm, exchange or other entity may record trading records in a non-indexed collection of data, as described above. The speed at which such a collection may be queried and processed allows such entities to quickly recreate the state of an order book, or portions thereof, for any time period. For example, an initial state of the order book may first be determined and then all of the orders placed at an exchange may be processed in the same manner that they would be processed by an exchange until the desired point in time. For example, graphical user interface 500 (shown in
Graphical user interface 520 represents the state of a order book at some time after the state represented with graphical user interface 500. If we assume that graphical user interface 500 represents the state that existed at 9:00 on Monday morning and graphical user interface 520 represents the state that existed at 2:00 on the following Wednesday, the state represented with graphical user interface 520 may be recreated by starting with the state representing with graphical user interface 500 and processing orders in the sequential non-indexed collection of orders received until 2:00 on Wednesday.
Unlike conventional indexed databases, storing and retrieving trading data according to the disclosed embodiments does not require large quantities of trading data to be executed in batch mode overnight. Indeed, under traditional approaches, large amounts of data could not be adequately analyzed in real-time, thereby preventing many uses of the data. The analysis of the data sequentially stored on the computer readable memory can be continually processed in real-time to monitor activity while new data is being written to the computer readable medium, all without having to create, update, and maintain a space-consuming database index and constant interruption to jump physical locations within the computer readable medium to locate a certain data piece.
Recreating market conditions may be readily accessible by querying methods, for example, as described above. Indeed, the analysis of the data sequentially stored on the computer readable memory can be continually processed in real-time to monitor activity while new data is being written to the computer-readable medium, all without having to create, update, and maintain a space-consuming database index and constant interruption to jump physical locations within the computer readable medium to locate a certain data piece.
A second processor 716 may be configured to periodically check shared memory 714 for new orders. Processor 716 may include a cache memory 718 that includes one or more order books, such as order book 720. The physical locations of pending orders stored in cache memory 718 may correspond to the order in which they were received at the match engine. When a new order is received, the order may be compared to orders that are included in order book 720. The use of two processors 712 and 716 allows for fast operation when matching of trades. In alternative embodiments, the functions performed by processors 712 and 716 may be performed by a single processor and/or by three or more processors. An exemplary processor that may be used is an Intel Itanium II, which contains a 9 MB byte cache memory. Another exemplary processor is the AMD Opteron processor, which utilizes Hypertransport™ technology.
After trades are matched, market data may be generated by processor 716 and then transmitted to shared memory 714. Processor 712 may periodically check shared memory 714 for market data messages. When market data messages are received, processor 712 may format or expand the market data message and then distribute the market data message to trading entities, such as those represented by computer devices 702, 704 and 706. Processor 712 may also distribute other information to trading entities, such as acknowledgement messages.
The speed at which processor 716 may process orders and the low-cost of such processors facilitates the use of redundant components and backup mechanisms. For example a backup processor 722 may include a cache memory 724 that includes an order book 726. Order book 726 may be synchronized with order book 720, such that in the event that processor 716 fails, backup processor 722 may resume matching of trades. A synchronization module 728 may be used to synchronize order books 720 and 726. In one embodiment, processor 716 and backup processor 722 transmit information identifying the states of order books 720 and 726 to synchronization module 728. Synchronization module 728 may then compare the states of the order books and make any adjustments that are necessary.
Match engine 708 may include several different processors that are configured to match a variety of different trades. Shared memory 714 may group new orders such that each of the processors knows which order to process. For example, a first processor may maintain a first order book and match trades against the first order book and a second processor may maintain a second order book for a different financial instrument and match trades for those financial instruments.
Backup processor 722 may be included within match engine 708. Alternatively or in addition, backup processor 722 may be connected to match engine 708 via a local area network or wide-area network. Backup processor 722 may be in a different geographic location than processor 716. For example processor 716 may be located within a first premises and backup processor 722 may be located in a different premises to prevent all processors from failing because of a fire or other event at the first premises. Two or more processors may also be geographically distributed and may be configured to process orders originating from different geographic regions. For example, processor 716 may be located in Chicago and may process orders originating in the United States and a second processor may be located in London in may be configured to process orders originating in that region.
In step 812 the new order is compared to the plurality of pending orders arranged in the non-indexed collection of substantially sequential orders. It is then determined whether the new order matches one of the pending orders in step 814. When the new order does not match one of the pending orders, in step 816 the new order is added to the non-indexed collection of substantially sequential orders. Step 816 may include adding the new order to an existing order book. If the new order does match one of the pending orders, a trade for the matching orders may be executed in step 818. Finally, in step 820 market data may be formatted and distributed.
The match system shown in
In the embodiment shown, match engines 902 and 914 receive orders from input gateway 926 and process those orders in parallel. Match engines 902 and 914 include the same data in order books 912 and 924 and are configured to produce the same results. Output messages from processors 904 and 916 are transmitted to an output gateway 932. Output gateway 932 may be implemented with a computer device configured to route data. In one embodiment, input gateway 926 and output gateway 932 are implemented with the same computer device. Output gateway 932 may include a message memory 934 that stores information identifying messages that have been transmitted by output gateway 932. At least part of the identifying information may be assigned by input gateway 926. The identifying information may be used to make sure that data for an event is only distributed once. For example, input gateway 926 may assign and identification number to a new order and then transmit the order to match engines 902 and 914. Match engines 902 and 914 may process the order in parallel and generate market data messages. The market data messages include the identification number assigned by input gateway 926. When market data messages are received at output gateway 932, output gateway may be configured to search identification numbers stored in message memory 934 to determine if a corresponding market data messages has been transmitted. When a message is received that includes an identification number not stored in message memory 934, the message is distributed to trading entities, such as to computer device 936 via network 938. When a message is received that includes an identification number that is stored in message memory 934, the message may be discarded.
One skilled in the art will appreciate that a variety of different protocols may be used to assign identifying information to data received at input gateway 926 and then filter data at output gateway 932. A new order may be assigned an identification number at input gateway 926 and derivative identification numbers may be assigned to messages associated with that order. For example, a new order may be assigned a 15 digit identification number and an acknowledgment message may be assigned an identification number that consists of the 15 digit identification number followed by a character or number that identifies the type of message. This allows multiple messages associated with a single order to all be assigned unique identification numbers that are related and ensures that match engines 902 and 914 assign the same identification numbers to created messages.
In the event of a failure of one of match engines 902 or 914, output gateway 932 would receive messages from only one match engine and continue to process messages without any failure being apparent to trading entities. In embodiments that include more than two match engines operating in parallel, the failure of one or two match engines would not be apparent to trading entities. Match engines 902 and 914, as well as any additional match engines, may be located in the same location or may be distributed to prevent a fire, network failure or other catastrophic event from halting the operation of all match engines.
The speed at which incoming orders may be processed when pending orders are arranged in a substantially sequential non-indexed collection in the cache memory of a processor allows for the processing of many types of orders. Existing match engine systems limit the type of orders that traders may make. For example, it not practical to process an order that does not have a standard format, such as an order to buy four particular contracts and sell six other contracts, because of the time required to match a single novel order having several legs to several different orders.
With the system described above the processing of orders can be quickly performed, which allows for many types of orders. For example, a trader may enter a nonstandard order that contains multiple legs in different markets. The systems shown in
The speed at which orders may be processed when they are arranged in a substantially sequential non-indexed collection allows one to quickly reconstruct an activity state of an entity across the trading platform and/or reconstruct the state of an order book at any given time. Traders, trading firms and exchange regulatory or enforcement divisions may wish to reconstruct the state of a market for a variety of purposes.
Next, in step 1004, the identification of a first time and a second time after the first time are received. The first and second times may identify a time period over which an activity state of an entity across the trading platform will be reconstructed. For example, if a regulator wanted to determine the profit and loss of a trader between 10:00:21 and 12:31:04 on a given day, the first and second times would be selected accordingly. In step 1006, the non-indexed collection of substantially sequential orders are accessed and a computer device simulates the processing of orders received at a trading platform between the first time and the second time to reconstruct the activity state of an entity across the trading platform. Finally, in step 1008 the activity state is displayed on a graphical user interface. An exemplary graphical user interface is described below. In alternative embodiments activity state data is printed on a report or displayed on a display device in a manner other than a graphical user interface.
In various embodiments, graphical user interface elements allow users to view order book data at different levels. For example, the instruments displayed in column 1206 may be implemented with hyperlinks that link to additional data. Selecting instrument element 1208 may cause computer-executable instructions to generate the graphical user interface shown in
Next, in step 1408, the non-indexed collection of orders is utilized to simulate the processing of orders received between the first time and the second time to reconstruct the state of at least a portion of the order book at the second time. Step 1408 may include processing orders in the same manner as used by the match systems described above and may include identifying information at the second time such as the state of a trader's or firm's order book, the state of a portion of a trader's or firm's order book, the profit and loss state, a net position state of the trader and any other information that may be obtained by simulating the processing of orders that are received between a first time and a second time.
The method shown in
Various alarms may be automatically generated. For example, a predetermined profit/loss condition for a trading entity may result in the generation of an alarm. The alarm may be in the form of an email message, SMS message, computer generated alarm or other type of alarm that may alert a firm, trader, regulator, trading entity or another of a condition.
Different entities may subscribe to messages that are carried along bus 1504. A listener module 1506 monitors messages transmitted along bus 1504 and identifies messages needed by a live alert server 1508. Live alert server 1508 may subscribe to various messages. The subscriptions may be based on message source, message content, intended destination or any other criteria used to identify messages. TIBCO provides exemplary listener modules.
A buffer 1510 receives messages from listener module 1506. Buffer 1510 may match related messages, such as orders and acknowledgement messages. The matched messages may be provided to a memory module 1512. Memory module 1512 may be implemented with a cache memory, such as a processor cache memory and may contain a non-indexed collection of trading messages or records.
Buffer 1510 may also provide trade messages to live alert server 1508. Live alert server 1508 may be configured to analyze trades, orders or combinations. In one embodiment, live alert server 1508 may store aggregate trading records in an aggregate trading records collection 1516 and use the aggregate trading records when analyzing new trades. An alert may be set to alert a regulator, risk manager, trader or someone else when a rule or limit threshold is exceeded. Live alert server 1508 may contain a collection of limits and rules 1514. The exemplary rules provide a maximum quantity of the Acme contracts, a maximum delta value in a maximum number of cancel/replace orders. Additional exemplary thresholds that may be associated with rules or limits include clearing firm limits, position quantities, risk level quantities, order type quantities and other quantities relating to the trading of financial instruments. One skilled in the art will appreciate that a variety of alternative and additional limits and rules may be utilized and in certain embodiments regulators may choose which limits in rules to utilize. Moreover some embodiments may be used to monitor trades and other embodiments may be used to monitor orders and trades.
In operation, live alert server 1508 may receive new trade data for a trader, firm or other entity, add the new trade data to aggregated trading records 1516 and compare the new total to a rule or limit included in limit and rule collection 1514. Live alert server 1508 may then generate a rule message when a rule or limit threshold is exceeded. The rule message may then be transmitted to an email server 1518.
Email server 1518 receives a rule message and generates an email alert message.
When a regulator or other entity selects hyperlink 1602, data is extracted from the hyperlink and used to generate a query that is transmitted to a query server 1522. Query server 1522 may then access data stored in memory module 1512 and/or historical data store 1524 to generate a report that is returned to computer device 1520. For example, if live alert server 1508 determines that a quantity limit for ACME option contracts is exceeded by a trader, live alert server 1508 may initiate the transmission of an email message to an exchange regulator. The email message may include a link that when selected generates a query to provide the quantity total for ACME option contracts for the trader. Query server 1522 may use one or more of the methods described above for generating a report. For example, query server 1522 may simulate the processing of orders received and stored in a non-indexed collection of orders between a first time and a second time to determine a quantity. The report may identify products bought and sold, quantities, exposure, risk, profit and loss and other data relevant to a trading entity.
The example shown in
A web page may be used to monitor activity. A rule message that is generated when a rule or limit threshold is exceeded may result in a web page being generated that includes account activity or any information that would have been included in a report. The web page may be updated periodically, such as once every minute.
In step 1708 it is determined whether or not the predetermined threshold is exceeded. When the predetermined threshold is not exceeded, the process ends in step 1710. One and the predetermined threshold is exceeded, the messages generated in step 1712. The message may include a link for generating a report relating to the aggregated trading record and the at least one limit or rule.
In step 1714 it is determined whether or not the link is selected. When the link is not selected, the process ends in step 1716. A regulator may view the message and determine that follow-up is not necessary and choose to delete or ignore the message. When the link is selected, in step 1718 a trading record query is generated. The trading record query may include information included within that selected link and may be performed at a computer device, mobile terminal, telephone or similar device.
In step 1720, the trading record query may be transmitted to a query server. As shown in
Different entities may subscribe to messages that are carried along bus 1804. A publish and subscribe (pub/sub) system may be used. In one embodiment of a pub/sub system, asynchronous messages are broadcast by publishers without specifying the recipients of the messages. Instead, publishers include information in the message to indicate the class of the message. The class of the message may be based on the topic or subject of the message. Subscribers receive messages according to these classes which are indicated by an attribute in the message. The messages are assigned attributes according to the content of the message or the destination of the message.
A first listener module 1806 is one type of subscriber. Listener module 1806 listens to or monitors bus communications 1804 for a first class of messages indicated by the attribute in the messages. A second listener module 1812 also listens to or monitors communications bus 1804. The second listener module 1812 may identify a second class of message indicated by the attributes in the messages.
A buffering system including buffer 1830 receives the messages from the first listener module 1806 and the second listener module 1812. The buffering system is configured to store the plurality of messages for an amount of time. The amount of time may be set in duration. Examples of set durations are a single trading day or a single trading week. Alternatively, the buffering system may be configured to store the plurality of messages using a first in first out (FIFO) algorithm or circular buffer. In other words, a set number of messages or set total size of messages may determine how long the messages are stored in buffer 1830. The messages are indexed in buffer 1830 by a sequence number.
Before storing the message, the buffering system may wrap the message in a new format including supplementary headers. If the TIBCO system is used, the new format preserves the formatting used by the TIBCO listeners and TIBCO ActiveMatrix Service Bus. The supplementary headers include may include data related to the size of the message, the class or attribute of the message, and the time the message was received by the buffer and/or subscriber.
Buffer 1830 may be implemented as a random access memory (RAM), dynamic random access memory (DRAM), flash memory, a hard disk drive, thumb drive, an optical disk (CD ROM, DVD or other optical media), or a solid-state memory modules. The buffering system may additionally include one or more of a processor, a display, and communication devices.
A database 1820 is coupled to buffer 1830 to receive the plurality of messages. Database 1820 permanently stores the plurality of messages. Database 1820 may be implemented as a random access memory (RAM), dynamic random access memory (DRAM), flash memory, a hard disk drive, thumb drive, an optical disk (CD ROM, DVD or other optical media), or a solid-state memory modules. The buffering system may additionally include one or more of a processor, a display, and communication devices.
An external client device 1808 is in communication with buffer 1830, database 1820, and communications bus 1804. The external client device 1808 may be a subscriber in the publish/subscribe system, as described above. The external client device 1808 may receive one or more classes of message according to the attributes stored in the messages. Live alert server 1508 is one example of an external client device 1808.
Occasionally, the external client device 1808 may not properly receive a message. This may occur if the external client device 1808 malfunctions or experiences down time. More commonly, a message is missed because a network device simply drops a message. The trading engine 1802 identifies that a message was missed when the external client device 1808 to communicate back to the trading engine 1808 that a subsequent message was received out of sequence. Each of the plurality of messages includes a sequence number so that a subscriber can identify when a message is missed. The trading engine 1808 will then retransmit the missed message.
However, the return message creates additional traffic on the communication bus 1804, which compounds the problem because additional messages will not be received by the subscribers. Often, during times of increased market activity a few missed messages will lead to a substantial number of missed messages and a spike in network activity. This series of events may be called a message storm or negative acknowledgement storm.
In order to avoid the congestion of messages, the external client device 1808 generates a request for the missed message that is sent to buffer 1830 or database. If the request is received while the missed message is still stored in buffer 1830, buffer 1830 will provide the stored message to the external client device 1808. If the request is received after the message is no longer stored in buffer 1830, database 1820 provides the stored message to the external client device 1808. Determining whether or not the request is received during the time period comprises indexing the sequence number of the message in the request in the buffer 1830.
The communication bus 1804 may be in communication with a rapid recovery system or storage area network (SAN). The SAN will record all messages from communication bus 1804 in real time as a raw message archive. To recover lost data, the SAN system can play the messages back to the communication bus 1804.
When one the listener modules 1906-1911 misses a message, the buffering system 1930 is configured to store the corresponding message from the corresponding redundant listener modules 1912-1917. The buffering system 1930 may include any number of buffers. For example, the buffering system 1930 may include a number (n) of buffers configured to temporarily stored the messages received from listener modules 1906-1917 and provide the messages to the external client device 1808 upon request.
The messages received from the plurality of listeners are distributed among the buffers according to the modulus (n+1) function performed on data stored in the in the header of the messages. The data used may be the sequence number of the message. For example, if two buffers are used, each would receive every other message regardless of which of listener modules 1906-1917 actually subscribed to that class of messages. If four buffers are used, each would receive every fourth message. The data used may also be an alphanumeric portion of the header, which will produce a more random distribution of messages. For example if the first three characters of the header is data string such as “ABC,” the modulus (n+1) function is performed on the ASCII character codes of A, B, and C added together.
At step 2010, messages are received from the listener modules and stored in a buffer 1830 or buffering system 1930 for a time period (T). At step 2012 the messages are more permanently stored in database 1820. At step 2014, a request is received from the external client device 1808 for missed message, and it is determined whether the missed message still stored in buffer 1830 at step 2016. If no, the message is provided from the buffer 1830 or buffering system 1930 at step 2018, and if yes, the message is provided by the database 1820. Determining whether or not the request is received during the time period comprises indexing the sequence number of the message in the request in the buffer 1830.
As used herein, the phrases “in communication with,” “coupled to” and “coupled with” are defined to mean directly connected to or indirectly connected through one or more intermediate components. Such intermediate components may include both hardware and software based components.
The present invention has been described herein with reference to specific exemplary embodiments thereof. It will be apparent to those skilled in the art that a person understanding this invention may conceive of changes or other embodiments or variations, which utilize the principles of this invention without departing from the broader spirit and scope of the invention as set forth in the appended claims. For example, aspects of the invention may be applied to data collections that are not related to exchanges or trading. All are considered within the sphere, spirit, and scope of the invention.
The present application is a continuation-in-part of application U.S. Ser. No. 12/335,246, filed Dec. 15, 2008 and entitled “Live Alerts,” which is a continuation-in-part application of U.S. Ser. No. 11/696,555, filed Apr. 4, 2007 and entitled “Live Profile,” which is a continuation-in-part application of U.S. Ser. No. 11/276,752, filed Mar. 13, 2006 and entitled “Match System That Uses A Non-Indexed Collection of Orders,” which is a continuation-in-part application of U.S. Ser. No. 11/234,697, filed Sep. 23, 2005 and entitled “Non-Indexed In-Memory Data Storage and Retrieval.” The entire disclosures of all of these applications are hereby incorporated in their entirety by reference herein.
Number | Name | Date | Kind |
---|---|---|---|
5590362 | Baum et al. | Dec 1996 | A |
5719564 | Sears | Feb 1998 | A |
5729742 | Harbinski et al. | Mar 1998 | A |
5845276 | Emerson et al. | Dec 1998 | A |
6205223 | Rao et al. | Mar 2001 | B1 |
6212568 | Miller et al. | Apr 2001 | B1 |
6243719 | Ikuta et al. | Jun 2001 | B1 |
6389510 | Chen et al. | May 2002 | B1 |
6865650 | Morley et al. | Mar 2005 | B1 |
6879987 | Hsieh | Apr 2005 | B2 |
6907422 | Predovic et al. | Jun 2005 | B1 |
6993511 | Himmelstein | Jan 2006 | B2 |
7079023 | Haller | Jul 2006 | B2 |
7716525 | Buchko et al. | May 2010 | B1 |
20020004774 | Defarlo | Jan 2002 | A1 |
20020023077 | Nguyen et al. | Feb 2002 | A1 |
20020040352 | McCormick | Apr 2002 | A1 |
20020055886 | Hinckley | May 2002 | A1 |
20020077962 | Donato et al. | Jun 2002 | A1 |
20020120919 | Aizenbud-Reshef et al. | Aug 2002 | A1 |
20030028506 | Yu et al. | Feb 2003 | A1 |
20030040955 | Anaya et al. | Feb 2003 | A1 |
20030041000 | Zajac et al. | Feb 2003 | A1 |
20030055776 | Samuelson | Mar 2003 | A1 |
20030065709 | Jordan et al. | Apr 2003 | A1 |
20030084028 | Hsieh | May 2003 | A1 |
20030115120 | Kramer et al. | Jun 2003 | A1 |
20030120593 | Bansal et al. | Jun 2003 | A1 |
20030120785 | Young | Jun 2003 | A1 |
20030135556 | Holdsworth | Jul 2003 | A1 |
20030145042 | Berry et al. | Jul 2003 | A1 |
20040001498 | Chen et al. | Jan 2004 | A1 |
20040044609 | Moore | Mar 2004 | A1 |
20040098663 | Rey et al. | May 2004 | A1 |
20040107123 | Haffner et al. | Jun 2004 | A1 |
20040205439 | Carmeli et al. | Oct 2004 | A1 |
20040254993 | Mamas | Dec 2004 | A1 |
20050021843 | Duigenan et al. | Jan 2005 | A1 |
20050086295 | Cunningham et al. | Apr 2005 | A1 |
20050128943 | Gibbs et al. | Jun 2005 | A1 |
20050256931 | Follmeg et al. | Nov 2005 | A1 |
20050273499 | Goodman et al. | Dec 2005 | A1 |
20050283353 | Billingsley et al. | Dec 2005 | A1 |
20060013367 | Sawyer et al. | Jan 2006 | A1 |
20060036448 | Haynie et al. | Feb 2006 | A1 |
20060047666 | Bedi et al. | Mar 2006 | A1 |
20060053425 | Berkman et al. | Mar 2006 | A1 |
20060085507 | Zhao et al. | Apr 2006 | A1 |
20060146999 | Thompson et al. | Jul 2006 | A1 |
20060224668 | Ginis | Oct 2006 | A1 |
20060224683 | Briscoe et al. | Oct 2006 | A1 |
20060242371 | Shono et al. | Oct 2006 | A1 |
20060248143 | Collison et al. | Nov 2006 | A1 |
20070014302 | Vincent | Jan 2007 | A1 |
20070025351 | Cohen | Feb 2007 | A1 |
20070073634 | Meacham et al. | Mar 2007 | A1 |
20070073804 | Allman et al. | Mar 2007 | A1 |
20070192230 | Meacham et al. | Aug 2007 | A1 |
20070192706 | Bruce et al. | Aug 2007 | A1 |
20070198397 | McGinley et al. | Aug 2007 | A1 |
20070198629 | Ganguly et al. | Aug 2007 | A1 |
20070276956 | Dorai et al. | Nov 2007 | A1 |
20080005294 | Morris | Jan 2008 | A1 |
20080103854 | Adam et al. | May 2008 | A1 |
20090138572 | Banks et al. | May 2009 | A1 |
20090299914 | Moran et al. | Dec 2009 | A1 |
20100023587 | Fletcher et al. | Jan 2010 | A1 |
Number | Date | Country |
---|---|---|
2006042066 | Apr 2006 | WO |
2008073009 | Jun 2008 | WO |
Number | Date | Country | |
---|---|---|---|
20090299914 A1 | Dec 2009 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 12335246 | Dec 2008 | US |
Child | 12536994 | US | |
Parent | 11696555 | Apr 2007 | US |
Child | 12335246 | US | |
Parent | 11276752 | Mar 2006 | US |
Child | 11696555 | US | |
Parent | 11234697 | Sep 2005 | US |
Child | 11276752 | US |