This disclosure relates to modeling real world events. More particularly, this disclosure relates to a system and data model for collecting information about commodity trading.
Manufacturing businesses typically require raw materials to produce products. Sometimes these raw materials are obtained through a commodity market. Other business may not directly trade in commodity raw materials, but may watch commodity trading to obtain information to make business decisions. It may thus be important to track commodity trading information.
The description that follows includes illustrative systems, methods, techniques, instruction sequences, and computing machine program products of illustrative embodiments. In the following description, for purposes of explanation, numerous specific details are set forth in order to provide an understanding of various embodiments of the inventive subject matter. It will be evident, however, to those skilled in the art that embodiments of the inventive subject matter may be practiced without these specific details. In general, well-known instruction instances, protocols, structures, and techniques have not been shown in detail.
Once raw materials 108 are obtained, production 110 may product goods 112 that are sold by a business. Often, there are fixed (or reasonably fixed) production costs, goods are sold at a fixed price, but raw materials can fluctuate, depending on what is happening in the commodities market 104. To minimize business risk, many companies have departments that track purchases, market variations, and so forth. These departments rely on information regarding the company and/or market activities. In
The data model 200 may include a plurality of objects (e.g., physical commodity object 202, contract specification object 206, etc.). In this disclosure, object means a location in storage (memory, disk, etc.) having a value and referenced by an identifier. Objects may be a variable, function, or a data structure, such as a data table or other structure. It may also refer to a particular instance of an object class.
The data model 200 may include physical commodity object 202. The physical commodity object 202 may comprise a plurality of data fields to represent the underlying commodity that is traded. For example, the fields may comprise a physical commodity name (e.g., the name of the physical commodity used in the object), a physical commodity description, and a physical commodity unit of measure. The physical commodity name may be created and/or modified by a user and/or may be selected from a drop down list or some combination thereof. The physical commodity name may be used in the system to refer to the underlying commodity. The physical commodity description may contain text, other descriptive information, or combinations thereof. The physical commodity unit of measure may be a unit of measure used to trade the commodity, such as tons, barrels, metric tons, and so forth.
The data model 200 may also include a market identifier object 204. The market identifier object 204 may comprise one or more data fields to represent a commodity market. Commodity markets have Market Identifier Codes (MIC) that uniquely identify them. These MIC are published in the ISO 10383 standard. For example, the London Metal Exchange has the MIC of XLME and the CME Globex has the MIC of GLBX. Additional fields may include a description field containing text, other descriptive information, or combinations thereof, a country field containing an identifier of the country where the commodity market is located, a city field containing an identifier of the city where the market is located, a status field containing status information such as active, inactive, etc. to identify the status of the market, a URL for the market, the trading platform (electronic, open outcry, etc.), and so forth.
The data model may also include a contract specification object 206. A contract specification object 206 may include a plurality of fields that identify information from a derivative contract specification. A derivative contract specification identifies the terms of the transaction. Depending on the type of derivative contract specification, it may include such information such as the underlying commodity, the grade of the underlying commodity, the product symbol, the market the derivative contract applies to, the hours of the market, the contract unit or lot size (e.g., the quantity of the commodity to be traded, the option to be purchased, and so forth), the currency units for price quotation (e.g., US dollars, US dollars and cents), clearable currencies (e.g., what currencies are acceptable for settling the contract), minimum price fluctuation per unit (e.g., the “tick size” or quantized change of price such as $10.00 US, $0.50 US, and so forth), the last trading day (e.g., last day for trading a particular contract), the settlement type (e.g., physical), location of settlement, delivery terms (location, time period, and so forth), and other information. A contract specification object 206 may include data fields to capture some or all of this information. Some data in the derivative contract specification like contract size, or quotation unit of measure are time dependent, and can be changed by an exchange from time to time.
It should be noted that a derivative contract specification is particular to a given market or set of markets. Thus, the information in a particular derivative contract specification may not only depend on the type of derivative contract specification, but also on the commodity market and the underlying commodity. In accordance with this, the data fields of a particular contract specification object 206 may vary somewhat by the commodity market, the type of derivative contract specification, the underlying commodity, or combinations thereof.
A given market has a plurality of derivative contract specifications for a plurality of commodities. A given derivative contract specification may apply to a plurality of markets. A given commodity may be traded according to a plurality of derivative contract specifications. Thus, the data model 200 may account for these possibilities. A single physical commodity object 202 may be associated with multiple contract specification objects 206 as indicated by the 1:n relationship link 216. A single contract specification object 206 may be associated with multiple market identifier objects 204 and a single market identifier object 204 may be associated with multiple contract specification objects 206 as indicated by the n:m relationship link 218.
Relationships between a physical commodity object 202, a contract specification object 206 and a market identifier object 204 may uniquely define a particular commodity traded at a particular market according to a particular derivative contract specification. Thus, such a combination may be used to track information about a particular commodity traded at a particular market according to a particular derivative contract specification.
In some embodiments, the data model 200 of
Additionally, in some embodiments the commodity object hierarchy may be a bit more detailed if desired with a generic commodity object 210 representing the general commodity (oil, copper, wheat, etc.) and a real commodity object 212 representing a specific commodity (such as a particular grade of oil, copper, wheat, etc.) as represented by the 1:n relationship link 224. The real commodity object 212 may then be associated in a 1:n type of relationship 222 with a pricing location object 208 (e.g., multiple commodities at a particular pricing location). Since a real commodity object 212 may represent a particular grade of commodity, it is similar (or has similar information to) a contract specification object 206. Thus, there may be an effective logical (rather than actual) link between a real commodity object 212 and a contract specification object 206 as indicated by the logical n:m relationship link 226.
Since the particular grade of commodity is represented in the contract specification object 206 when coupled with a physical commodity object 202, the physical commodity object 202 is effectively a generic commodity and for those embodiments that use a generic commodity object 210, a 1:1 relationship 228 may exist between a physical commodity object 202 and a generic commodity 210.
Finally commodity objects may be collected into a physical commodity group object 214. A given commodity may belong to multiple groups and a given group may have multiple commodities. Thus, an n:m relationship link 230 may exist between a physical object 202 and a physical commodity group object 214. This creates an effective logical (rather than actual) link between a physical commodity group object 214 and a generic commodity object 210 as indicated by logical n:m relationship link 232.
In one embodiment, pricing location object 208, real commodity object 212 and generic object 210 may comprise existing data models of the embodiment and the relationship links between them and physical commodity object 202, contract specification object 206 and market identifier object 204 may represent integration of an existing data model with a new data model comprising physical commodity object 202, contract specification object 206 and market identifier object 204. In other embodiments, there may be no existing data model and desired commodity and market information may be represented by a data model comprising physical commodity object 202, contract specification object 206 and market identifier object 204.
Table 1 below may represent, for example, some information associated with a derivative contract specification for crude oil traded on the CME Globex market that may be obtained from a web page containing the appropriate derivative contract specification. The information is not meant to be exhaustive, simply illustrative, so actual derivative contracts may have either more or less information accordingly.
From this table (perhaps included in a web page), key information may be extracted, such as the commodity (crude oil), a description (light sweet crude oil), a product symbol (CL), a market (CME Globex), the contract unit (1,000 barrels), price quotation currency (dollars and cents per barrel), the “tic” size ($0.01 per barrel), special rules, such as limits on price fluctuation ($10.00 per barrel), the type of settlement (physical), and various delivery information. Such information may be placed in the appropriate data objects of data model 314.
By way of example, an appropriate physical commodity object 308 may be created and appropriate fields such as a physical commodity name (crude oil), a physical commodity description (light sweet crude oil), and a physical commodity unit of measure (barrel) may be populated. An appropriate contract specification object 310 may also be created and appropriate fields, such as the underlying commodity (crude oil), the grade of the underlying commodity (light sweet crude oil), the product symbol (CL), the market the derivative contract applies to (CME Globex), the lot size (1,000 barrels), the currency units for price quotation (US dollars and cents), tic size ($0.01 per barrel), the settlement type (physical), delivery terms (location, time period, and so forth) may be populated. Note that fields such as the underlying commodity and commodity grade may not reside in the contract specification object 310, but may be part of the physical commodity object 308 and a link may be established between the two objects (310, 308) to define that information.
Thus, by obtaining information 316 such as derivative contract specifications from network 318, the information may be parsed and appropriate data objects may be created and fields in those data objects populated in an automated fashion as indicated by arrow 320.
Rather than automatically creating and populating appropriate data objects, information may be entered from the retrieved information 316 through an appropriate user interface 300. An appropriate user interface 300 may take a variety of forms, but such an interface may typically have a plurality of regions 302, 304, 306 where information may be displayed, entered, and/or combinations thereof. As information is entered, appropriate data objects may be created and fields populated as indicated by arrow 324. To the extent that information already exists in the system, it need not be reentered, simply retrieved and/or linked to. As an example, if a market identifier object has already been crated for CME Globex, the object may simply be linked to in an appropriate manner.
Combinations of the automatic creation/population and user interface approaches may also be used. This is indicated by arrow 322. As an example, suppose appropriate physical commodity object 308 and market identifier object 312 already exist. Also suppose that a derivative contract specification for the commodity described in physical commodity object 308 from the market described in market identifier object 312 is retrieved as information 316. Further suppose that parsing the retrieved information 316 identified the commodity associated with the physical commodity object 308 and the market associated with market identifier object 312. The information in these objects (308, 312) may be retrieved and placed in the appropriate locations in use interface 300 to “pre-populate” the user interface 300 with information that already exists in the system. Furthermore, other information retrieved from the derivative contract specification may be populated into user interface 300 to aid in entry of the appropriate information.
Region 402 may comprise a title, such as a window title. If the user interface 400 is used to display or enter information about a derivative contract specification, the title may be something like “Display Derivate Contract Specification.”
Region 404 may comprise a plurality of icons, text labels, and/or combinations thereof that indicate various actions a user may take. Representative actions may include functions like “create” to create a new derivative contract specification, “save” to save the information into the appropriate object(s), “copy” to copy the information to a different location, etc.
Region 406 may comprise a plurality of fields that identify the contract specification object such as a derivative contract specification identifier field to identify the contract specification object, a description field containing a description of the derivative contract, a derivative category field containing the type of derivative contract (such as futures, option, etc.), a status field containing the status of the contract specification object (e.g., released, etc.). In one embodiment, region 406 may be continuously displayed even if other regions of the user interface change when, for example, a new tab is selected as described below. However, this may not be reflected in all embodiments.
Region 408 may comprise a plurality of tab controls that cause different regions containing different fields to be displayed in the area underneath the tabs. One tab may be highlighted, brought to the front, and/or otherwise distinguished from the other tabs to indicate which tab is being displayed in the remainder of the regions of the display. In one embodiment, the tabs may contain basic data, derivative details, periods, and administration. Some of these are described in conjunction with other figures below. When the basic data tab is selected, region 410, 412, 414, 416, 418 and/or combinations thereof may be displayed. Each region may contain a title indicating the information displayed in the region.
Region 410 may contain general data, such as a filed containing a product symbol and a URL for the contract specification. Labels and/or descriptive text may also be displayed, along with a title indicating the data in the region.
Region 412 may contain information about the physical commodity such as a physical commodity name (e.g., the name of the physical commodity used in a physical commodity object in the system), a physical commodity unit of measure and/or combinations thereof. Labels and/or descriptive text may also be displayed, along with a title indicating the data in the region.
Region 414 may contain information related the determination method associated with the derivative contract specification. Each market has rules for derivative contract determination such as when the commodity can be traded according to the contract, the contract period, the settlement period, the quotation period, etc. The information in the region 414 may be used by a market data management system to calculate this information. In an example embodiment, region 414 may include the market rules to be used in the period determination (e.g., London Metal Exchange, CME Globex, etc.), the security identifier determination (e.g., manual input or with pattern YYYYMMDD), the prompt date calendar to be used (e.g., the calendar used by the London Metal Exchange), the logic to be used for the expiration date (e.g., the last trading day or the last quotation date), the logic to be used for the reporting date (e.g., the last trading day, the last contact date), and/or combinations thereof. Labels and/or descriptive text may also be displayed, along with a title indicating the data in the region.
Region 416 may contain market identifier code information, such as the market identifier code of a selected market identifier object(s) (since multiple market identifier objects may be linked to a single contract specification object according to a data model like model 314 of
Region 418 may contain a field related to archiving market data such as a retention period field indicating the time frame for which market data should be retained in the system. Labels and/or descriptive text may also be displayed, along with a title indicating the data in the region.
Region 502 may be substantially similar to region 402 of
Region 504 may be substantially similar to region 404 of
Region 506 may be substantially similar to region 406 of
Region 508 may be substantially similar to region 408 of
Region 510 may comprise one or more fields and/or descriptive text (labels, etc.) such as a field to indicate a date from which the derivative contract is valid. Other information may also be displayed, if desired.
Region 512 may comprise an area where a title is displayed and one or more fields, labels, and/or other descriptive text or combinations thereof displayed to indicate the contract size such as the contract quantity and/or unit of measure. For example, the contract size of the crude oil of Table 1 above is 1,000 barrels. The contract size and unit of measure will depend on the commodity of the contract. As another example, a contract for metal, such as copper or aluminum may have a unit of measure of tons, metric tons, etc. with a contract size of 25 tons, metric tons or however the contract is specified. The unit of measure may also be pulled from (or congruent with) another field, such as that specified in region 412 of
Region 514 may comprise an area where a title is displayed and one or more fields, labels, and/or other descriptive text or combinations thereof displayed to indicate quotation information of the derivative contract specification. For example, fields, labels and/or other descriptive text may comprise currency, to indicate the currency (such as US Dollars, Japanese Yen, etc.) of the derivative contract specification, the currency unit (such as US Dollars, US Dollars and Cents, etc.) of the quotation, the unit of measure for the quotation (e.g., Ton, Barrel, etc.), the Commodity Pricing Engine (CPE) unit of measure (such as Ton Copper or Barrel Oil, etc.), and decimal places to indicate how many decimal places should be tracked for the quotation (e.g., 6, 2, etc.)
Region 516 may comprise an area where a title is displayed and one or more fields, labels, and/or other descriptive text or combinations thereof displayed to indicate the tick information of the derivative contract specification. For example, fields, labels, descriptive text, and/or combinations thereof may comprise the market identifier code for the market, the tic size, the currency unit, the tick value and the currency of the tick value. Information in these fields, labels, descriptive text, etc. may come from, or be congruent with, other places, such as region 514, or regions of
Region 602 may be substantially similar to region 402 of
Region 604 may be substantially similar to region 404 of
Region 606 may be substantially similar to region 406 of
Region 608 may be substantially similar to region 408 of
Region 610 may comprise one or more fields and/or descriptive text (labels, etc.) such as a field to indicate a date from which the period should be started. These fields and/or descriptive text may be congruent with other information in other places, such as region 510 of
Region 612 may comprise an area where a title is displayed and one or more fields, labels, and/or other descriptive text or combinations thereof displayed to indicate periods of the derivative contract specification. These fields, labels, and/or other descriptive text or combinations thereof may be displayed as individual fields or as a table with appropriate columns/rows. The region 612 may also comprise various icons, text labels, and/or combinations thereof illustrating table tools to invoke underlying functionality that can be performed on a table such as sorting, filtering, printing, inserting rows and/or columns, deleting rows and/or columns, and so forth. Table 2 below represents an example table that may be displayed in region 612.
The fields of Table 2 include a key date, a description of the key date, what type of period it is, when the start and end dates of the period are. Note that these fields may be calculated or determined from information entered elsewhere. A key date is a date in combination with a derivative contract specification that identifies, for example, individual futures with a defined last trading and settlement date in a market. Each exchange may have its way of calculating these type of period dates. It may also be that different commodities may influence the dates and the way the dates are calculated. It may further be that a derivative contract specification may influence the dates and the way the dates are calculated. Thus, information such as that entered in region 414 of
Other tabs in Regions 608 of
The pricing information may be extracted by a price extraction module 722 adapted to take in the data feed 708 and extract from the data feed information that corresponds with the physical commodity objects 724, contract specification objects 726, and market identifier objects 728 active in the system. As previously mentioned, the combination of a commodity 702, a market 704 and a derivative contract specification 706 uniquely specifies the terms and price of a commodity. Thus, the relationships between commodities represented physical commodity objects 724, the markets represented in market identifier objects 728 and the derivative contract specifications represented in contract specification objects 728 identify the information that should be extracted from data feed 708. Pricing information about the commodity may be extracted from a data feed 708 and the information captured in an appropriate data object or combination of data objects. The price may be captured as part of an existing object (e.g., a commodity object 724, a market identifier object 728, a contract specification object 726, and/or combinations thereof), or the price may be captured as part of a separate pricing object 730 and relationships between other objects may be made. In one example, the pricing object may have a 1:1 relationship with a combination of a physical commodity object 724, a contract specification object 726 and a market identifier object 728.
Pricing object 730 may comprise a plurality of data fields to identify the price of a commodity traded at a market according to a derivative contract specification. Thus, the pricing object 730 may comprise such fields as price date, price time, price type (e.g., the type of pricing information such as the spot price, etc.), the key date, the time to maturity, the quotation price, the currency of the quotation price, the quantity of the quotation price, and so forth. Time to maturity is the amount of time left until the settlement data of a future, for example, is reached. Time to maturity may be expressed in years, months or days. The pricing object may contain fields for many such quotations.
The method used by price extraction module 722 to extract information from data feed 708 may comprise a plurality of operations. One operation may identify information related to a commodity traded at a market according to a derivative contract specification. Other operation may locate within the system 700, information matching the commodity, the market and the derivative contract specification such as by identifying a contract specification object 726. Alternatively, locating information matching the commodity, the market and the derivative contract specification may be accomplished by identifying a relationship between a contract specification object 726 and another object, such as a physical commodity object 724, a market identifier object 728 or combinations thereof. Another operation may be to extract desired price information from the data feed 708 and place it in an appropriate object or combination of objects, such as pricing object 730 and/or physical commodity object 724, contract specification object 726, market identifier object 728, or combinations thereof.
As alternative to capturing information from data feed 708, market data management system 700 may allow manual entry of pricing information. A user may obtain price information 710 via various mechanisms or in a variety of formats. The market data management system 700 may then present an appropriate user interface, such as price user interface 720 and allow the user to enter the pricing information. Price user interface 720 may pull information from a variety of sources, such as physical commodity object 724, contract specification object 726, market identifier object 728, pricing object 730, and/or combinations thereof and present known information to the user. Appropriate objects and other information may be selected by the user from the user interface so that the information can be retrieved. For example, the user may be presented with a dialog allowing a user to identify a contract specification object 726 and information may then be retrieved from related objects in some embodiments. Additionally, or alternatively, the pricing user interface may include fields, labels and/or other descriptive text to allow a user to enter appropriate pricing information, such as price type, price date, price time, key date, time to maturity, etc. Note that date and time fields may include a starting and ending date, if desired.
Although not shown, market data management system 700 may also have a user interface to present commodity prices. As with the user interfaces of
As an alternative to capturing information from a data feed or manual data entry, market data management system 700 may import pricing information from a document 714 containing pricing information. For example, all the appropriate information may be collected into a spreadsheet and the spreadsheet document imported into the system as shown by arrow 716.
Price extraction module 718 may be adapted to extract information from a spreadsheet and place it in appropriate data object(s). Price extraction module 718 may be the same as, or different from price extraction module 722. The method used by price extraction module 718 to extract and import price information may comprise a plurality of operations. One operation may identify information related to a commodity traded at a market according to a derivative contract specification by parsing the input file. Other operation may locate within the system 700, information matching the commodity, the market and the derivative contract specification such as by identifying a contract specification object 726. Alternatively, locating information matching the commodity, the market and the derivative contract specification may be accomplished by identifying a relationship between a contract specification object 726 and another object, such as a physical commodity object 724, a market identifier object 728 or combinations thereof. Another operation may be to extract desired price information from the pricing document 714 and place it in an appropriate object or combination of objects, such as pricing object 730 and/or physical commodity object 724, contract specification object 726, market identifier object 728, or combinations thereof.
As will be appreciated by one skilled in the art, aspects of the present disclosure may be illustrated and described herein in any of a number of patentable classes or context including any new and useful process, machine, manufacture, or composition of matter, or any new and useful improvement thereof. Accordingly, aspects of the present disclosure may be implemented entirely hardware, entirely software (including firmware, resident software, micro-code, etc.) or combining software and hardware implementation that may all generally be referred to herein as a “circuit,” “module,” “component,” or “system.” Furthermore, aspects of the present disclosure may take the form of a computer program product embodied in one or more computer readable media having computer readable program code embodied thereon.
In addition to being sold or licensed via traditional channels, embodiments may also, for example, be deployed by Software-as-a-Service (SaaS), Application Service Provider (ASP), or utility computing providers. The computer may be a server computer, a personal computer (PC), a tablet PC, a set-top box (STB), a personal digital assistant (PDA), cellular telephone, or any processing device capable of executing a set of instructions 824 (sequential or otherwise) that specify actions to be taken by that device. Further, while only a single computer is illustrated, the term “computer” shall also be taken to include any collection of computers that individually or jointly execute a set (or multiple sets) of instructions 824 to perform any one or more of the methodologies discussed herein.
The example computer processing system 800 includes a processor 802 (e.g., a central processing unit (CPU), a graphics processing unit (GPU), advanced processing unit (APU) or some combination thereof), a main memory 804 and static memory 806, which may communicate with each other via a bus 808. The computer processing system 800 may further include a graphics display 810 (e.g., a plasma display, a liquid crystal display (LCD) or a cathode ray tube (CRT) or other display). The processing system 800 may also include an alphanumeric input device 812 (e.g., a keyboard), a user interface (UI) navigation device 814 (e.g., a mouse, touch screen, or the like), a storage unit 816, a signal generation device 818 (e.g., a speaker), and/or a network interface device 820.
The storage unit 816 includes machine-readable medium 822 on which is stored one or more sets of data structures and instructions 824 (e.g., software) embodying or utilized by any one or more of the methodologies or functions described herein. The instructions 824 may also reside, completely or at least partially, within the main memory 804 and/or within the processor 802 during execution thereof by the computer processing system 800, with the main memory 804 and the processor 802 also constituting computer-readable, tangible media.
The instructions 824 may be transmitted or received over a network 826 via a network interface device 820 utilizing any one of a number of well-known transfer protocols (e.g., HTTP).
While the machine-readable medium 822 is shown in an example embodiment to be a single medium, the term “machine-readable medium” should be taken to include a single medium or multiple media (e.g., a centralized or distributed database, and/or associated caches and servers) that store the one or more sets of instructions 824. The term “machine-readable medium” shall also be taken to include any medium that is capable of storing, encoding or carrying a set of instructions 824 for execution by the computer and that cause the computer to perform any one or more of the methodologies of the present application, or that is capable of storing, encoding or carrying data structures utilized by or associated with such a set of instructions 824. The term “machine-readable medium” shall accordingly be taken to include, but not be limited to, solid-state memories, and optical and magnetic media. The term “machine-readable storage medium” does not include signals or other intangible mechanisms. Such intangible media will be referred to as “machine-readable signal media.” The term “machine-readable media” will encompass both “machine-readable storage media” and “machine-readable signal media.”
While various implementations and exploitations are described, it will be understood that these embodiments are illustrative and that the scope of the claims is not limited to them. In general, techniques for maintaining consistency between data structures may be implemented with facilities consistent with any hardware system or hardware systems defined herein. Many variations, modifications, additions, and improvements are possible.
While the embodiments are described with reference to various implementations and exploitations, it will be understood that these embodiments are illustrative, and that the scope of claims provided below is not limited to the embodiments described herein. In general, the techniques described herein may be implemented with facilities consistent with any hardware system or hardware systems defined herein. Many variations, modifications, additions, and improvements are possible.
The term “computer readable medium” is used generally to refer to media embodied as non-transitory subject matter, such as main memory, secondary memory, removable storage, hard disks, flash memory, disk drive memory, CD-ROM and other forms of persistent memory. It should be noted that program storage devices, as may be used to describe storage devices containing executable computer code for operating various methods, should not be construed to cover transitory subject matter, such as carrier waves or signals. “Program storage devices” and “computer-readable medium” are terms used generally to refer to media such as main memory, secondary memory, removable storage disks, hard disk drives, and other tangible storage devices or components.
Plural instances may be provided for components, modules, operations, or structures described herein as a single instance. Finally, boundaries between various components, modules, operations, and data stores are somewhat arbitrary, and particular operations are illustrated in the context of specific illustrative configurations. Other allocations of functionality are envisioned and may fall within the scope of the claims. In general, structures and functionality presented as separate components in the exemplary configurations may be implemented as a combined structure, module, or component. Similarly, structures and functionality presented as a single module or component may be implemented as separate modules or components. These and other variations, modifications, additions, and improvements fall within the scope of the claims and their equivalents.