The present disclosure generally relates to techniques for exploring large data sets, for example, as related to market instruments.
The approaches described in this section are approaches that could be pursued, but not necessarily approaches that have been previously conceived or pursued. Therefore, unless otherwise indicated, it should not be assumed that any of the approaches described in this section qualify as prior art merely by virtue of their inclusion in this section.
Data processing systems can be programmed to facilitate analysis of a universe of data items. A universe of data items refers to a large collection of data items. An example of such a universe may be a large collection of market instruments. In many instances, the amount of raw data about data items can be massive and dynamically increasing all the time. Under some approaches, an analyst relies on empirical knowledge and cumbersome spreadsheets to analyze markets and instruments. Under some other approaches, markets and instruments are modeled as multi-variable stochastic, predictive systems. In all these approaches, however, what has been captured is often over-simplified and relatively static. These approaches cannot keep up with new variable and new trends appearing in the markets, and therefore can hardly yield reliable insights for future performance of the markets and instruments. These shortcomings are made worse, as these approaches typically provide little support for a user to flexibly model the markets, to promptly react to new trends, and to timely test new hypotheses.
The present disclosure is directed to a programmatic object model that facilitates analysis of universes of data items.
A first claim of the disclosure is an object model that facilitates performing financial analysis and that includes certain zero-order objects or building blocks that lend themselves particularly well to doing financial analysis. The object model comprises a universe of data items, relationships between the data items, higher-order objects generated based on one or more data items in the universe, higher-order objects generated based on other objects, and auxiliary entities related to the universe of data items.
A second claim is that some of the building blocks are “zero-order”, in that they cannot be decomposed into other building blocks. Examples of zero-order building blocks are time series, metrics, and financial instruments. A time series is an object that represents time-dependent information. A metric building block represents a type of data transformation; for example, a metric defines a function that receives an instrument as input and produces a time series as output. A financial instrument building block represents any market entity that is traded or otherwise of interest, such as an equity, a currency, or a bond.
A third claim is that some of the building blocks can be decomposed into other building blocks. Examples include a date set, index, portfolio, strategy, instrument group, and regression. For example, a date set comprises time values that satisfy one or more selection criteria; an instrument group comprises one or more instruments selected from a universe of instruments using a filter chain; an index indicates a collective value of one or more instruments; a regression transforms one or more first time series into a predicted time series and compares the predicted time series with a second time series; a portfolio comprises zero or more time series each of which represents an instrument, a particular date set, and one or more trades that refer to times represented in the particular date set; a strategy comprises a date set that represents a time period and a statement block that can be executed to determines one or more trades of the instrument.
Additional claims of the disclosure relate to how the foregoing higher-order building blocks can be decomposed into the zero-order building blocks. For example, an index comprises an instrument group and a metric and a date set; an instrument group comprises filters; and a filter can be a set of instruments and a metric.
In embodiments where data items are instruments (in equity, currency and bonds), zero-order objects may refer to instruments, economic indexes, time series and meta data associated with instruments, and other information that are cataloged and stored in a database for the purpose of being analyzed by the data analysis system.
Other embodiments may comprise a system and one or more machine-readable storage media operable to provide the foregoing graphical user interface and/or to perform or cause the performance of the foregoing computer-implemented methods.
In the following description, for the purposes of explanation, numerous specific details are set forth in order to provide a thorough understanding of the present invention. It will be apparent, however, that the present invention may be practiced without these specific details. In other instances, well-known structures and devices are shown in block diagram form in order to avoid unnecessarily obscuring the present invention.
In this disclosure the following terms have the following meanings:
Data item: a zero-order object that can be described by a number of properties and/or metrics.
Higher-order objects: the term “higher-order objects” refers to objects that can be built directly or indirectly on top of zero-order objects such as instruments.
Metric: a type of transformation. The metric performs the type of transformation specified, e.g., using the instrument as input, and produces the time series. In some embodiments, the identifier for the object and the token for the type of transformation are separated by a suitable delimiter such as a period.
Object model: a model that comprises a universe of data items, relationships between the data items, higher-order objects generated based on one or more data items in the universe, higher-order objects generated based on other objects, and auxiliary entities related to the universe of data items.
Ontological relationships: structural relationships existing among zero-order objects (such as economic indexes, instruments, etc.). The instruments can be classified based on ontological relationships, thereby forming a hierarchy on which the object model can be further built. In some embodiments, this hierarchy may comprise one or more economic indexes, which is not specifically tied to an instrument.
Time series: a type of objects which are used in the object model to represent time-dependent information.
Universe of data items: a large collection of data items, typically everything known to a particular system.
Zero-order objects: leaf nodes in the object model. In embodiments where data items are instruments (in equity, currency and bonds), zero-order objects may refer to instruments, economic indexes, time series and meta data associated with instruments, and other information that are cataloged and stored in a database for the purpose of being analyzed by the data analysis system.
In the embodiment illustrated in
In some embodiments, GUI logic 122 is omitted. For example, in one embodiment, client 120 may comprise an application program or process that issues one or more function calls or application programming interface (API) calls to application server 102 to obtain information resulting from, to provide input to, and to execute along with application server 102, the processes or one or more steps thereof as described herein. For example, client 120 may request and obtain a representation of zero-order objects such as instruments, higher-order objects such as date sets, indexes, instrument groups, etc., higher-order objects, and other constructs as described herein using a programmatic interface, and then the client may use, process, log, store, or otherwise interact with the received data according to local logic. Client 120 may also interact with application server 102 to provide input, definition, editing instructions, expressions related to one or more objects or constructs as described herein using a programmatic interface, and then the application server 102 may use, process, log, store, or otherwise interact with the received input according to application server logic.
Application server 102 may be implemented as a special-purpose computer system having the logical elements shown in
When executed by one or more processors of the computer system, logic in application server 102 is operable to explore the universe of data items according to the techniques described herein. In one embodiment, application server 102 may be implemented in a Java Virtual Machine (JVM) that is executing in a distributed or non-distributed computer system. In other embodiments, application server 102 may be implemented as a combination of programming instructions written in any programming language (e.g. C++ or Visual Basic) and hardware components (e.g. memory, CPU time) that have been allocated for executing the program instructions.
In an embodiment, application server 102 comprises repository access logic 110 and data exploring logic 104. Repository access logic 110 may comprise a set of program instructions which, when executed by one or more processors, are operable to access and retrieve data from data repository 112. For example, repository access logic 110 may be a database client or an Open Database Connectivity (ODBC) client that supports calls to a database server that manages data repository 112. Data repository 112 may be any type of structured storage for storing data including, but not limited to, relational or object-oriented databases, data warehouses, directories, data files, and any other structured data storage.
In the embodiment illustrated in
In an embodiment, input receiver 106 is a set of program instructions which, when executed by one or more processors, are operable to receive input from a client.
Evaluation module 108 is a set of program instructions that implement logic to create, modify, delete and store objects that are associated with the universe of data items, evaluate these objects when instructed to do so by data analysis system 100, provide the evaluation results to a client. Evaluation results of one or more objects may also be rendered by GUI logic 122 on display 120.
3.1 Instruments
An instrument is an object that represents any market traded financial entity or product of interest, such as a stock (equity), bond, currency, or fund.
3.2 Metrics
A metric is a transformation (or function) that receives one type of data (e.g., an object such as an instrument) and returns another type (e.g., another object such as a time series). A metric may perform any form of specified processing, specified computation, related operations such as database queries, network communications and data storing. For example, a metric may receive a particular instrument as input and return a time series of the particular instrument's volume. A metric may also receive one time series for an instrument and return the value of the instrument on a given day. A metric may optionally receive parameters at runtime that influence the execution of logic implemented in the metric. An example of a parameter that can be inputted into a metric to influence the execution of a metric may be a number of days to show a moving average price for MSFT where the metric calculates the moving average price.
Objects that are of a higher order than a zero order can be built using metrics. The input objects and the output objects can be zero-order or higher-order in any combination.
The data changes over time. Therefore, if a metric is evaluated at two different times, it may produce different outputs. Alternatively, output objects from one or more of these metrics may be pre-computed/evaluated and stored/cached beforehand. In some embodiments, parameters may be provided to a metric to specify whether a cached object of a metric should be used as input, or whether the output of a metric should be cached or stored.
3.3 Time Series
A time series is a programmatic object that represents time-dependent information in any of several forms, including a series of discrete dates or a sequence of time-related values. Where an object model contains a large amount of time-dependent information, many time series may be created in the process of evaluating objects in the object model. For example, an instrument may have a trading history that indicates its values over a period of time. From this trading history (e.g., raw trading data), one or more time series may be created to represent time-dependent information, in any desired resolution (for example, in a time scale of years, months, weeks, days, hours, minutes, seconds).
In some embodiments, a time series may comprise a set of numeric values and a separate set of time values, wherein each numeric value has a corresponding time value in the set of time values. Each such numeric value represents a value of a certain entity at each corresponding time value in the set of time values. For example, a time series may be used to represent market values of an instrument. The above-mentioned “value of a certain entity” may be a particular market value at the closing of a trading day. In this example, the time series may comprise a set of long or double values, each of which represents a market value at the closing of a corresponding day as indicated by a time value in a separate set of time values. The time series further comprises the separate set of time values representing the closings of all corresponding days, for which market values of the instruments are included in the set of long or double values.
A time series may also be used to represent values of an entity for time values that meet certain criteria. For example, a time series may be used to represent market values for an instrument when the instrument is traded to higher prices, when the instrument is traded to lower prices, when the volatility of the instrument exceeds a certain limit, when the volatility of the instrument stays below a certain limit, or a derivative of other time series. Furthermore, the values of an entity are not limited to market values of an instrument. For example, the values of an entity, as represented by a time series, may comprise analytical values of historical volatility of two instruments.
In some embodiments, a time series associated with an instrument may be accessed by an expression containing an identifier (e.g., the identifier “GOOG” to indicate the equity instrument for Google, Inc.) for another object such as an instrument and a token (e.g., a textual name such as “HVOL” representing historical volatility of an instrument) for a type of transformation. In the present example where the time series is accessed by the expression “GOOG.HVOL”, the metric identified by the token (e.g., “HVOL”) receives the identifier for the instrument (e.g., “GOOG”) as input and transforms raw trading data of the instrument (i.e., “GOOG”) into a time series as an output object. This time series, for example, may represent time-dependent information of volatility of the instrument “GOOG” in all recorded trading days.
A time series such as described above may be further transformed along with other parameters into another output object.
A time series can not only represent time-dependent information for zero-order objects such as instruments, but may also represent time-dependent information for any higher-order objects in the object model.
In some embodiments, a time series may be used to represent time-dependent information that is not related to another object. For example, a set of time values from a calendar, e.g., all week days, all work days, all Mondays, or the second days of months, may be transformed by a metric into a time series. Such a time series may be viewed as an object per se as it is independent of another object such as an instrument. In some embodiments, the time series may be accessed within a global scope, by any other objects, without naming any other object such as an instrument. In some embodiments, a time series may comprise a set of time values (e.g., all Mondays) without including a separate set of numeric values representing values of an entity that may be associated with another object such as an instrument.
In some embodiments, time series may be pre-computed (evaluated) and stored/cached.
4.1 Date Set
A date set comprises a set of time values that satisfy one or more selection criteria. As used herein, the term “time value” may include date and/or time of day information at various resolutions, for example, from multiple years to sub-seconds. For example, a date set may be all trading days when the “GOOG” stock trades up. A date set may also have an explicit start time value for the set, for example, Jan. 1, 2006; thus, the date set excludes all time values that are before the explicit start time value. Similarly, a date set may also have an explicit end time value; thus, the date set excludes all time values that are after the explicit end time value.
A date set may also take an implicit start time value, where an explicit start time value is not specified. For example, a date set that comprises all days when the “GOOG” stock trades up may have an implicit start time value when the “GOOD” stock was first publicly traded. Similarly, a date set may also take an implicit end time value, where an explicit end time value is not specified. For example, a date set that comprises all days when the “ENE” stock was available for trades may have an implicit end time value when the “ENE” stock was terminated from public trading from the New York Stock Exchange.
One of several object creation mechanisms may be used to create higher-order objects such as date sets. One object creation mechanism is a metric. This metric may take a first input that specifies a time series. This time series is generally a set of date/value pairs. The date set metric also may take a second input that specifies one or more criteria. For example, the one or more criteria as specified in the second input may specify a range. The resulting date set will then contain all the dates as indicated by the time series that are within the specified range.
Another object creation mechanism to create a higher-order object such as a date set is to directly use a programming language such as JAVA. The user may supply programming language code to the system 100, which may be compiled, interpreted or otherwise executed by the system 100 to create a date set. Extension mechanisms such as Java reflection may be used to add code segments or objects to the system so that the object creation mechanisms can be dynamically extended.
Yet another object creation mechanism to create a higher-order object such as a date set is to interact with a user interface. For example, tools or widgets may be provided in or through a graphical user interface and may interact with the user for the purpose of creating a date set.
In various embodiments, these and other object creation mechanisms, or a combination thereof, may be used to create various higher-order objects.
A date set may or may not be related to any other object. For example, as shown in
For a generated date set, the user may provide a token in the form of a string to this date set in a text input box 204. Subsequently, this date set may be used in combination with other objects. In an embodiment, any of all the entities that are involved in specifying, creating and outputting a new date set may be stored in a machine-readable storage medium. In addition, the new date set may also be stored or cached in such a medium.
4.2 Index
An index indicates a collective value of one or more instruments as a function of time over a set of time values. A collective value is any type of aggregate value of the one or more instruments. The collective value may be of a market value type such as a total monetary value of the one or more instruments traded at public exchanges, or of an analytical value type such as a numeric value indicating volatility of the trading price for the one or more instruments, as a function of time over the set of time values.
For the purpose of illustration only, the one or more instruments included in the index may comprise the “GOOG”, “YHOO”, and “MSFT” stocks. Hence, the index may be an aggregate market value of these stocks, as a function of time over all trading days since Jan. 1, 2007. A market value is an aggregation of values of all assets included in the portfolio at a corresponding time value in the set of time values. The market value may be measured (e.g., denominated) in a reference currency such as the U.S. dollar. For example, a value of an asset such as an instrument may be a trading price of that instrument at the closing of a particular trading day. A value of the reference currency may be its trading value as denominated in the reference currency. A value of a currency that is not the reference currency may also be measured in the reference currency through an exchange rate.
An index may have a start time value, for example, Jan. 1, 2007; thus, the index does not track the collective value before the start time value. Similarly, an index may also have an end time value; thus, the index does not track the collective value after the end time value. The start time value and/or the end time value may be explicit or implicit.
To create an index, any of the object creation mechanisms may be used. An object creation mechanism may take a first input that specifies one or more time series for the one or more instruments. For example, these time series as specified in the first input may represent trading prices for the “GOOG”, “YHOO”, and “MSFT” stocks on all trading days when the stocks are publicly traded. The object creation mechanism also may take a second input that specifies a date set. In some embodiments, the date set as specified in the second input may specify a set of days for which a collective value of the one or more instruments should be tracked. For example, the date set may comprise a set of last five trading days of each quarter since Jan. 1, 2007. The object creation mechanism may comprise logic to compute the collective value of the one or more instruments as specified in the first input over the set of time values as specified in the second input. The object creation mechanism may create and output an index in the form of a new time series. Each numeric value in the set of longs or doubles indicates the collective value of the “GOOG”, “YHOO”, and “MSFT” stocks at a time value (e.g., a day) in the set of last five trading days of each quarter since Jan. 1, 2007.
The user may provide a token in the form of a string to name the index so that the definition or computed value of the index can be subsequently referenced as a named object in combination with other objects. In an embodiment, any of all the entities that are involved in specifying, creating and outputting a new index may be stored or cached in a machine-readable storage medium. In addition, the definition of new index may also be stored or cached in such a medium.
4.3 Instrument Group
An instrument group comprises one or more instruments selected from a universe of instruments using a filter chain that is created from zero or more set operations and one or more filter links. For example, an instrument group may comprise all the stocks in the S&P Index (“SPX”) that are in the technology sector. Another example of instrument group may be all the stocks in the financial sector of the S&P Index that have low PE ratios.
To create an instrument group, an object creation mechanism may be used. This mechanism may take a first input that specifies the zero or more set operations. For example, a set operation of “intersection” may be specified as the first input. The object creation mechanism also may take a second input that specifies the one or more filter links. For the purpose of illustration only, such a filter link may be a criterion that any selected stock must belong to the bucket of lowest 10% among an input set of instruments. In some embodiments, graphical user interface 200 of client 120 may be used to create an instrument group, as shown in
The object creation mechanism may comprise logic to create a filter chain by evaluating each filter link in the filter chain, combining the filter link into the filter chain based on the set operation specified, and generate the instrument group that comprises the one or more instruments. In the present example, where the filter link is created using an u-tile diagram. the object creation mechanism may create and output an instrument group that comprises a set of instruments that are in the bottom 10% of PE ratios as indicated in
The user may provide a token in the form of a string to name the instrument group. For example, this instrument group as illustrated in
In an embodiment, any of all the entities that are involved in specifying, creating and outputting a new instrument group may be stored or cached in a machine-readable storage medium. In addition, the new instrument group may also be stored or cached in such a medium.
4.4 Portfolio
A portfolio indicates a market value of included assets as a function of time over a set of time values. A portfolio may comprise a start time value from which the market value of the portfolio is to be tracked. A portfolio may optionally comprise an end time value after which the market value of the portfolio is no longer tracked. The set of assets included in the portfolio at any given time value may comprise a variable number of instruments. The set of assets may optionally include a certain amount in various currencies (including currency equivalents).
To create a portfolio, an object creation mechanism may be used. This mechanism may take a first input that specifies zero or more time series for the zero or more instruments. For example, these time series as specified in the first input may represent trading prices for the “GOOG”, “YHOO”, and “MSFT” stocks on all trading days when the stocks are publicly traded. In some embodiments, the object creation mechanism may use weight factors to determine how much of each of these instruments is to be hold in the portfolio at each time value of a time period starting from the start time value. The object creation mechanism also takes a second input that specifies a date set. In some embodiments, the date set as specified in the second input specifies a set of time values (e.g., the preceding time period) for which a market value of the portfolio should be computed. For example, the date set may comprise a set of all trading days since Jan. 1, 2007. The object creation mechanism may further take a third input that specifies the one or more trades over the set of time values as specified in the second input. Each trade may specify an instrument, a buy-or-sell indication, a time of trading, and a quantity. The object creation mechanism may comprise logic to execute, or to simulate execution of, trades as specified in the third input and to compute the market value of the portfolio over the set of time values as specified in the second input, thereby giving rise to a new portfolio object. Any other metric may be applied to the new portfolio object to extract information. In addition, the portfolio object may be used to create another higher-order object. In the present example, the associated set of time values to which the long or double values are mapped is the set of time values specified in the second input. For example, each numeric value in the set of longs or doubles indicates a collective market value of all assets in the portfolio at a time value in the set of all trading days since Jan. 1, 2007.
The user may provide a token in the form of a string to name the portfolio so that a subsequent reference can be made to the token in an expression that involves other objects.
In an embodiment, any of all the entities that are involved in specifying, creating and outputting a new portfolio may be stored or cached in a machine-readable storage medium. In addition, the new portfolio may also be stored or cached in such a medium.
4.5 Strategy
A strategy, as illustrated in
The time period may be represented by a date set that comprises a starting time value corresponding to the beginning of the time period and optionally an end time value corresponding to the end of the time period.
In some embodiments, a strategy comprises an initial collection of assets at the beginning of the time period. In a particular embodiment, this initial collection of assets may comprise only a starting net asset value (212 of
To create a strategy, an object creation mechanism may be used. This object creation mechanism may take a first input that specifies a particular date set. Comprising a start time value and optionally an end time value as previously described, the particular date set represents a time period where trades may be generated and executed. For example, the date set may be all trading days from Jan. 1, 2006 to now. Alternatively, the date set may be all trading days when the “GOOG” stock trades up.
The object creation mechanism may take a second input that specifies a statement block, which when executed generates one or more trades. Each trade may specify an instrument, a-buy-or-sell indication, a time of trading, and a quantity. For the purpose of illustration, the statement block may be displayed in a content pane 214 on graphical user interface 200 in
The user may provide a token in the form of a string to name the strategy. For example, the strategy in
In an embodiment, any of all the entities that are involved in specifying, creating and outputting a new strategy may be stored or cached in a machine-readable storage medium. In addition, the new strategy may also be stored or cached in such a medium.
A user may interact with graphical user interface 200 to test a trading strategy. For example, a statement block may be supplied (e.g., pasted) into content pane 214 of
For the purpose of illustration only, the statement block that is to be executed by a strategy (object) may comprise one or more rules that can be used to determine the one or more trades, as illustrated below:
This statement block as indicated in its comment section implements a trading strategy with rules of buying 100 units in SPX if SPX moves below its lower Bollinger band, selling 100 units if SPX moves above its upper Bollinger band, and exiting the position in SPX if SPX returns to its moving average.
4.6 Regression
A regression, as illustrated in
To create a regression, an object creation mechanism may be used. This object creation mechanism may take a first input that specifies one or more first time series representing independent variables in a regression analysis. For example, the one or more first time series may be ones that are associated with objects like “Exxon Mobil Corp”, “WTI CRUDE FUTURE (1st month generic)”, and “S&P 500 INDEX” in the object model, as indicated in 218 of
The user may provide a token in the form of a string to name the regression. Subsequently, this regression may be used in combination with other objects through a reference to its token.
In an embodiment, any of all the entities that are involved in specifying, creating and outputting a new regression may be stored or cached in a machine-readable storage medium. In addition, the new regression may also be stored or cached in such a medium.
A user may define an arbitrarily complex object that is built on top of other objects. For example, liquidity and risk models may be built as a multi-level object on top of an instrument group, a portfolio, several indexes, a date set, etc. Similarly, an index may be built on top of other higher-order objects.
In some embodiments, a higher-order object may be represented as a tree. The leaf nodes of the tree are zero-order objects such as instruments. The tree may additionally and/or optionally contain non-leaf nodes. The non-leaf nodes are higher-order objects. In other words, a higher-order object may be built from building blocks. These building blocks may be zero-order or higher-order objects. For example, when an index is built from an instrument group, the instrument group also may be built from a combination of other higher-order and zero-order objects.
Any of several object creation mechanisms may be selected by a user for the purpose of creating a higher-order object. Definitions for the higher-order objects may be generated by the object creation mechanism and saved in the system. A definition may be defined and evaluated at two different times. The results of evaluation of a definition may change as underlying data changes. These results may be saved in cache or in permanent storage.
In some embodiments, types of objects in the object model may be implemented as classes in an object-oriented language such as JAVA®, thus allowing easy incorporation of various properties of one object into another.
In accordance with an embodiment of the present invention, an input mechanism is provided for a user to enter expressions to the data analysis system for the purpose of instructing the data analysis system to create, modify, delete, evaluate, or save various objects and components in the object model. Here, the term “input mechanism” includes either a command line interaction mechanism or a graphic-user-interface based interaction mechanism, or a combination of the preceding two. In other embodiments, an input mechanism is not used and objects may be specified programmatically or at runtime using other mechanisms.
An expression may comprise one or more tokens separated by delimiter characters such as a period, parentheses, a comma, quotation marks, etc. Each token may refer to an economic index, an instrument, a metric, an input object, an output object, a parameter, a time series, a higher-order-object, or any higher-order object in the object model.
An expression may be evaluated with a certain order. For example, in a particular embodiment, the expression may be evaluated according to a precedence ordering among operators. Additionally and/or optionally, certain optimization logic may be used to determine whether any tokens in an expression can be evaluated in parallel.
Custom metrics and user-defined classes and objects can be provided to (or plugged into) the system and be immediately made available for use. In certain embodiments, a modeling language may be used to define custom metric objects. For example, a user may specify at a command line interface for creating a new type of object and provides to the data analysis system a token for this new type of object. The new type of object, for example, may be a new metric. However, a modeling language is not required, and the embodiments that show use of a modeling language herein are provided merely to illustrate clear examples. Thus, in one alternative, Javan objects and instance variables may be used to define custom metric objects programmatically without using a modeling language to define the objects and instance variables.
As illustrated in
The data analysis system may immediately make available this new type of object (e.g., a new function “avgvol( )”) to all users of the system. The users simply specify the token associated with the new type of object in subsequent expressions. As shown in
In this manner, new types of objects and new types of expressions can be continuously added to the data analysis system, which causes the object model to evolve over the time. For example, a user may continuously define new hypotheses as new object types or as new instances of existing object types and timely test the new hypotheses in a rapidly changing market. Evaluations of some of these hypotheses may be saved or cached along with the definitions for the hypotheses. These hypotheses can also be recalled, re-studied, and reused by way of suitable tokens at a later time.
In block 304, the data analysis system 100 determines, based on one or more input objects, the one or more time series. For example, input object may be the calendar and the set of criteria, a part of which is displayed in 202 of
In block 306, the data analysis system 100 applies the metric using the one or more time series, thereby generating a particular value for the output object. For example, the metric may be used by the data analysis system 100 to transform the time series that represents the calendar into a date set in the form of a time series comprising time values satisfying the set of criteria.
In block 308, the data analysis system 100 store, in memory, one of the metric and the particular value for the output object. In some embodiments, any of other objects, time series, and parameters may also be stored. For example, the user may specify a name for the date set in 204 of
For the purpose of this invention, other objects including the higher-order objects and the higher-order objects described above may also be created in a similar manner. For example, this example process can be repeated to produce higher-order objects based on time series determined from higher-order objects or zero-order objects. In this manner, higher-order objects may be built on top of higher-order objects in the object model.
Data analysis according to the techniques described herein is not limited to any particular tool or any particular type of analysis. Thus, the examples of data analysis provided herein are to be regarded in an illustrative rather than a restrictive sense.
Computer system 400 may be coupled via bus 402 to a display 412, such as a cathode ray tube (CRT), for displaying information to a computer user. An input device 414, including alphanumeric and other keys, is coupled to bus 402 for communicating information and command selections to processor 404. Another type of user input device is cursor control 416, such as a mouse, a trackball, or cursor direction keys for communicating direction information and command selections to processor 404 and for controlling cursor movement on display 412. This input device typically has two degrees of freedom in two axes, a first axis (e.g., x) and a second axis (e.g., y), that allows the device to specify positions in a plane.
The invention is related to the use of computer system 400 for implementing the techniques described herein. According to one embodiment of the invention, those techniques are performed by computer system 400 in response to processor 404 executing one or more sequences of one or more instructions contained in main memory 406. Such instructions may be read into main memory 406 from another machine-readable medium, such as storage device 410. Execution of the sequences of instructions contained in main memory 406 causes processor 404 to perform the process steps described herein. In alternative embodiments, hard-wired circuitry may be used in place of or in combination with software instructions to implement the invention. Thus, embodiments of the invention are not limited to any specific combination of hardware circuitry and software.
The term “machine-readable medium” as used herein refers to any medium that participates in providing data that causes a machine to operate in a specific fashion. In an embodiment implemented using computer system 400, various machine-readable media are involved, for example, in providing instructions to processor 404 for execution. Such a medium may take many forms, including but not limited to, non-volatile media, volatile media, and transmission media. Non-volatile media includes, for example, optical or magnetic disks, such as storage device 410. Volatile media includes dynamic memory, such as main memory 406. Transmission media includes coaxial cables, copper wire and fiber optics, including the wires that comprise bus 402. Transmission media can also take the form of acoustic or light waves, such as those generated during radio wave and infrared data communications. All such media must be tangible to enable the instructions carried by the media to be detected by a physical mechanism that reads the instructions into a machine.
Common forms of machine-readable media include, for example, a floppy disk, a flexible disk, hard disk, magnetic tape, or any other magnetic medium, a CD-ROM, any other optical medium, punch cards, paper tape, any other physical medium with patterns of holes, a RAM, a PROM, and EPROM, a FLASH-EPROM, any other memory chip or cartridge, a carrier wave as described hereinafter, or any other medium from which a computer can read.
Various forms of machine-readable media may be involved in carrying one or more sequences of one or more instructions to processor 404 for execution. For example, the instructions may initially be carried on a magnetic disk of a remote computer. The remote computer can load the instructions into its dynamic memory and send the instructions over a telephone line using a modem. A modem local to computer system 400 can receive the data on the telephone line and use an infrared transmitter to convert the data to an infrared signal. An infrared detector can receive the data carried in the infrared signal and appropriate circuitry can place the data on bus 402. Bus 402 carries the data to main memory 406, from which processor 404 retrieves and executes the instructions. The instructions received by main memory 406 may optionally be stored on storage device 410 either before or after execution by processor 404.
Computer system 400 also includes a communication interface 418 coupled to bus 402. Communication interface 418 provides a two-way data communication coupling to a network link 420 that is connected to a local network 422. For example, communication interface 418 may be an integrated services digital network (ISDN) card or a modem to provide a data communication connection to a corresponding type of telephone line. As another example, communication interface 418 may be a local area network (LAN) card to provide a data communication connection to a compatible LAN. Wireless links may also be implemented. In any such implementation, communication interface 418 sends and receives electrical, electromagnetic or optical signals that carry digital data streams representing various types of information.
Network link 420 typically provides data communication through one or more networks to other data devices. For example, network link 420 may provide a connection through local network 422 to a host computer 424 or to data equipment operated by an Internet Service Provider (ISP) 426. ISP 426 in turn provides data communication services through the worldwide packet data communication network now commonly referred to as the “Internet” 428. Local network 422 and Internet 428 both use electrical, electromagnetic or optical signals that carry digital data streams. The signals through the various networks and the signals on network link 420 and through communication interface 418, which carry the digital data to and from computer system 400, are exemplary forms of carrier waves transporting the information.
Computer system 400 can send messages and receive data, including program code, through the network(s), network link 420 and communication interface 418. In the Internet example, a server 430 might transmit a requested code for an application program through Internet 428, ISP 426, local network 422 and communication interface 418.
The received code may be executed by processor 404 as it is received, and/or stored in storage device 410, or other non-volatile storage for later execution. In this manner, computer system 400 may obtain application code in the form of a carrier wave.
In the foregoing specification, embodiments of the invention have been described with reference to numerous specific details that may vary from implementation to implementation. Thus, the sole and exclusive indicator of what is the invention, and is intended by the applicants to be the invention, is the set of claims that issue from this application, in the specific form in which such claims issue, including any subsequent correction. Any definitions expressly set forth herein for terms contained in such claims shall govern the meaning of such terms as used in the claims. Hence, no limitation, element, property, feature, advantage or attribute that is not expressly recited in a claim should limit the scope of such claim in any way. The specification and drawings are, accordingly, to be regarded in an illustrative rather than a restrictive sense.
This application claims the benefit of priority to and is a divisional of application Ser. No. 12/210,947, filed Sep. 15, 2008 now abandoned; the entire contents of which are hereby incorporated by reference for all purposes as if fully set forth herein.
Number | Name | Date | Kind |
---|---|---|---|
5412769 | Maruoka et al. | May 1995 | A |
5414838 | Kolton et al. | May 1995 | A |
5444819 | Negishi | Aug 1995 | A |
5454104 | Steidlmayer et al. | Sep 1995 | A |
5819238 | Fernholz | Oct 1998 | A |
5872973 | Mitchell et al. | Feb 1999 | A |
6012042 | Black et al. | Jan 2000 | A |
6065026 | Cornelia et al. | May 2000 | A |
6072942 | Stockwell et al. | Jun 2000 | A |
6104401 | Parsons | Aug 2000 | A |
6161098 | Wallman | Dec 2000 | A |
6189005 | Chakrabarti et al. | Feb 2001 | B1 |
6289338 | Stoffel et al. | Sep 2001 | B1 |
6313833 | Knight | Nov 2001 | B1 |
6349315 | Sonoyama et al. | Feb 2002 | B1 |
6496817 | Whang et al. | Dec 2002 | B1 |
6513019 | Lewis | Jan 2003 | B2 |
6532449 | Goertzel et al. | Mar 2003 | B1 |
6640231 | Andersen et al. | Oct 2003 | B1 |
6662202 | Krusche et al. | Dec 2003 | B1 |
6748481 | Parry et al. | Jun 2004 | B1 |
6801201 | Escher | Oct 2004 | B2 |
6876981 | Berckmans | Apr 2005 | B1 |
6907426 | Hellerstein et al. | Jun 2005 | B2 |
6920453 | Mannila et al. | Jul 2005 | B2 |
7043449 | Li et al. | May 2006 | B1 |
7086028 | Davis et al. | Aug 2006 | B1 |
7111231 | Huck et al. | Sep 2006 | B1 |
7133409 | Willardson | Nov 2006 | B1 |
7181423 | Blanchard et al. | Feb 2007 | B2 |
7185065 | Holtzman et al. | Feb 2007 | B1 |
7213030 | Jenkins | May 2007 | B1 |
7216299 | Knight | May 2007 | B2 |
7237192 | Stephenson et al. | Jun 2007 | B1 |
7240330 | Fairweather | Jul 2007 | B2 |
7246090 | Thomas | Jul 2007 | B1 |
7356504 | Müller | Apr 2008 | B2 |
7401038 | Masuda | Jul 2008 | B2 |
7403921 | Tanpoco et al. | Jul 2008 | B2 |
7403922 | Lewis et al. | Jul 2008 | B1 |
7437728 | Stackhouse et al. | Oct 2008 | B2 |
7441182 | Beilinson et al. | Oct 2008 | B2 |
7469238 | Satchwell | Dec 2008 | B2 |
7533069 | Fairweather | May 2009 | B2 |
7542934 | Markel | Jun 2009 | B2 |
7587352 | Arnott | Sep 2009 | B2 |
7590582 | Dunne | Sep 2009 | B2 |
7620582 | Masuda | Nov 2009 | B2 |
7630931 | Rachev et al. | Dec 2009 | B1 |
7657478 | De Diego | Feb 2010 | B2 |
7685042 | Monroe et al. | Mar 2010 | B1 |
7685083 | Fairweather | Mar 2010 | B2 |
7716227 | Hao et al. | May 2010 | B1 |
7725728 | Ama et al. | May 2010 | B2 |
7835966 | Satchwell | Nov 2010 | B2 |
7848995 | Dalal | Dec 2010 | B2 |
8010507 | Poston et al. | Aug 2011 | B2 |
8036971 | Aymeloglu et al. | Oct 2011 | B2 |
8041714 | Aymeloglu et al. | Oct 2011 | B2 |
8046283 | Burns | Oct 2011 | B2 |
8112425 | Baum et al. | Feb 2012 | B2 |
8230333 | Decherd et al. | Jul 2012 | B2 |
8280880 | Aymeloglu et al. | Oct 2012 | B1 |
8301464 | Cave et al. | Oct 2012 | B1 |
8326727 | Aymeloglu et al. | Dec 2012 | B2 |
8484115 | Aymeloglu et al. | Jul 2013 | B2 |
8484549 | Burr et al. | Jul 2013 | B2 |
8494941 | Aymeloglu et al. | Jul 2013 | B2 |
8909656 | Kumar et al. | Dec 2014 | B2 |
8938686 | Erenrich et al. | Jan 2015 | B1 |
20010011243 | Dembo et al. | Aug 2001 | A1 |
20020007329 | Alcaly et al. | Jan 2002 | A1 |
20020007331 | Lo et al. | Jan 2002 | A1 |
20020026404 | Thompson | Feb 2002 | A1 |
20020030701 | Knight | Mar 2002 | A1 |
20020059126 | Ricciardi | May 2002 | A1 |
20020087570 | Jacquez et al. | Jul 2002 | A1 |
20020099870 | Miller et al. | Jul 2002 | A1 |
20020138383 | Rhee | Sep 2002 | A1 |
20020147671 | Sloan et al. | Oct 2002 | A1 |
20020156812 | Krasnoiarov et al. | Oct 2002 | A1 |
20030009392 | Perkowski | Jan 2003 | A1 |
20030009399 | Boerner | Jan 2003 | A1 |
20030065605 | Gatto | Apr 2003 | A1 |
20030065606 | Satchwell | Apr 2003 | A1 |
20030065607 | Satchwell | Apr 2003 | A1 |
20030078827 | Hoffman | Apr 2003 | A1 |
20030130996 | Bayerl et al. | Jul 2003 | A1 |
20030144868 | MacIntyre et al. | Jul 2003 | A1 |
20030163352 | Surpin et al. | Aug 2003 | A1 |
20030172021 | Huang | Sep 2003 | A1 |
20030172053 | Fairweather | Sep 2003 | A1 |
20030182177 | Gallagher | Sep 2003 | A1 |
20030184588 | Lee | Oct 2003 | A1 |
20030187761 | Olsen et al. | Oct 2003 | A1 |
20040133500 | Thompson et al. | Jul 2004 | A1 |
20040153418 | Hanweck | Aug 2004 | A1 |
20040193599 | Liu et al. | Sep 2004 | A1 |
20050060712 | Miller et al. | Mar 2005 | A1 |
20050060713 | Miller et al. | Mar 2005 | A1 |
20050075962 | Dunne | Apr 2005 | A1 |
20050075966 | Duka | Apr 2005 | A1 |
20050090911 | Ingargiola et al. | Apr 2005 | A1 |
20050108001 | Aarskog | May 2005 | A1 |
20050171881 | Ghassemieh et al. | Aug 2005 | A1 |
20050182709 | Belcsak et al. | Aug 2005 | A1 |
20050256703 | Markel | Nov 2005 | A1 |
20050262004 | Sakata et al. | Nov 2005 | A1 |
20050262057 | Lesh et al. | Nov 2005 | A1 |
20060020398 | Vernon et al. | Jan 2006 | A1 |
20060052984 | Nakadate et al. | Mar 2006 | A1 |
20060053097 | King et al. | Mar 2006 | A1 |
20060059072 | Boglaev | Mar 2006 | A1 |
20060064181 | Kato | Mar 2006 | A1 |
20060116943 | Willain | Jun 2006 | A1 |
20060136513 | Ngo et al. | Jun 2006 | A1 |
20060149596 | Surpin et al. | Jul 2006 | A1 |
20060218405 | Ama et al. | Sep 2006 | A1 |
20060224356 | Castelli et al. | Oct 2006 | A1 |
20060235786 | DiSalvo | Oct 2006 | A1 |
20060241974 | Chao et al. | Oct 2006 | A1 |
20060265311 | Dean et al. | Nov 2006 | A1 |
20060265397 | Bryan et al. | Nov 2006 | A1 |
20070055598 | Arnott et al. | Mar 2007 | A1 |
20070055599 | Arnott | Mar 2007 | A1 |
20070067233 | Dalal | Mar 2007 | A1 |
20070091868 | Hollman et al. | Apr 2007 | A1 |
20070112714 | Fairweather | May 2007 | A1 |
20070118527 | Winje et al. | May 2007 | A1 |
20070136115 | Doganaksoy et al. | Jun 2007 | A1 |
20070168269 | Chuo | Jul 2007 | A1 |
20070168270 | De Diego Arozamena et al. | Jul 2007 | A1 |
20070168871 | Jenkins | Jul 2007 | A1 |
20070219882 | May | Sep 2007 | A1 |
20070226617 | Traub et al. | Sep 2007 | A1 |
20070282951 | Selimis et al. | Dec 2007 | A1 |
20080015920 | Fawls et al. | Jan 2008 | A1 |
20080040250 | Salter | Feb 2008 | A1 |
20080046803 | Beauchamp et al. | Feb 2008 | A1 |
20080172607 | Baer | Jul 2008 | A1 |
20080183639 | DiSalvo | Jul 2008 | A1 |
20080195417 | Surpin et al. | Aug 2008 | A1 |
20080208820 | Usey et al. | Aug 2008 | A1 |
20080215546 | Baum et al. | Sep 2008 | A1 |
20080249957 | Masuyama et al. | Oct 2008 | A1 |
20080263468 | Cappione et al. | Oct 2008 | A1 |
20080288306 | MacIntyre et al. | Nov 2008 | A1 |
20080288471 | Wu et al. | Nov 2008 | A1 |
20080313243 | Poston et al. | Dec 2008 | A1 |
20090006271 | Crowder | Jan 2009 | A1 |
20090031401 | Cudich et al. | Jan 2009 | A1 |
20090094166 | Aymeloglu et al. | Apr 2009 | A1 |
20090106308 | Killian et al. | Apr 2009 | A1 |
20090112678 | Luzardo | Apr 2009 | A1 |
20090112922 | Barinaga | Apr 2009 | A1 |
20090138307 | Belcsak et al. | May 2009 | A1 |
20090172511 | Decherd et al. | Jul 2009 | A1 |
20090193050 | Olson | Jul 2009 | A1 |
20090313250 | Folting et al. | Dec 2009 | A1 |
20090319418 | Herz | Dec 2009 | A1 |
20090327157 | Dunne | Dec 2009 | A1 |
20100057600 | Johansen et al. | Mar 2010 | A1 |
20100070426 | Aymeloglu et al. | Mar 2010 | A1 |
20100070489 | Aymeloglu et al. | Mar 2010 | A1 |
20100070844 | Aymeloglu et al. | Mar 2010 | A1 |
20100205108 | Mun | Aug 2010 | A1 |
20100283787 | Hamedi et al. | Nov 2010 | A1 |
20100312530 | Capriotti | Dec 2010 | A1 |
20100325581 | Finkelstein et al. | Dec 2010 | A1 |
20110179042 | Aymeloglu et al. | Jul 2011 | A1 |
20110218934 | Elser | Sep 2011 | A1 |
20120030140 | Aymeloglu et al. | Feb 2012 | A1 |
20120144335 | Abeln et al. | Jun 2012 | A1 |
20120221553 | Wittmer et al. | Aug 2012 | A1 |
20120221580 | Barney | Aug 2012 | A1 |
20130073377 | Heath | Mar 2013 | A1 |
20130290161 | Aymeloglu et al. | Oct 2013 | A1 |
20130293553 | Burr et al. | Nov 2013 | A1 |
20140279865 | Kumar | Sep 2014 | A1 |
Number | Date | Country |
---|---|---|
1109116 | Jun 2001 | EP |
1146649 | Oct 2001 | EP |
WO 2008121499 | Oct 2008 | WO |
WO 2009042548 | Apr 2009 | WO |
WO 2010030915 | Mar 2010 | WO |
WO 2010030946 | Mar 2010 | WO |
WO 2010030949 | Mar 2010 | WO |
Entry |
---|
Devanbu et al., “Authentic Third-Party Data Publication”, http://seclab.cs.ucdavis.edu/˜devanbu/authdbpub.pdf, 19 pages, dated 2000. |
U.S. Appl. No. 12/210,947, filed Sep. 15, 2008, Office Action, mailed Jul. 1, 2013. |
“A First Look: Predicting Market Demand for Food Retail using a Huff Analysis,” TRF Policy Solutions, Jul. 2012, pp. 30. |
Azad, Khalid, “A Visual Guide to Version Control,” <http://betterexplained.com/articles/a-visual-guide-to-version-control/>, Sep. 27, 2007 in 11 pages. |
Beverley, Bill, “Windows Tips & Tricks,” <http://alamopc.org/pcalamode/columns/beverley/bb0301.shtml>, Mar. 2001 in 5 pages. |
Bradbard, Matthew, “Technical Analysis Applied,” <http://partners.futuresource.com/fastbreak/2007/0905.htm>, Sep. 5, 2007, pp. 6. |
Breierova et al., “An Introduction to Sensitivity Analysis,” Publsihed by Massachusetts Institute of Technology, Cambridge, MA, Oct. 2001, pp. 67. |
Dramowicz, Ela, “Retail Trade Area Analysis Using the Huff Model,” Directions Magazine, Jul. 2, 2005 in 10 pages, http://www.directionsmag.com/articles/retail-trade-area-analysis-using-the-huff-mode1/123411. |
Griffith, Daniel A., “A Generalized Huff Model,” Geographical Analysis, Apr. 1982, vol. 14, No. 2, pp. 135-144. |
Hibbert et al., “Prediction of Shopping Behavior Using a Huff Model Within a GIS Framework,” Healthy Eating in Context, Mar. 18, 2011, pp. 16. |
Huff et al., “Calibrating the Huff Model Using ArcGIS Business Analyst,” ESRI, Sep. 2008, pp. 33. |
Huff, David L., “Parameter Estimation in the Huff Model,” ESRI, ArcUser, Oct.-Dec. 2003, pp. 34-36. |
Liu, Tianshun, “Combining GIS and the Huff Model to Analyze Suitable Locations for a New Asian Supermarket in the Minneapolis and St. Paul, Minnesota USA,” Papers in Resource Analysis, 2012, vol. 14, pp. 8. |
Microsoft, “How Word Creates and Recovers the AutoRecover files,” <http://support.microsoft.com/kb/107686>, Article ID: 107686, printed Feb. 11, 2010 in 3 pages. |
Microsoft, “Introduction to Versioning,” <http://office.microsoft.com/en-us/sharepointtechnolgy/HA010021576.aspx?mode=print>, 2007 in 3 pages. |
Microsoft, “Managing Versions and Checking Documents In and Out (Windows SharePoint Services 2.0),” <http://technet.microsoft.com/en-us/library/cc287876.aspx>, Aug. 22, 2005 in 2 pages. |
Schwieger, V., “Sensitivity Analysis as a General Tool for Model Optimisation-Examples for Trajectory Estimation,” 3rd IAG/12th FIG Symposium, Baden, Germany, May 22-24, 2006, Published by IAG, 2006, pp. 10. |
Schwieger, V., “Variance-Based Sensitivity Analysis for Model Evaluation in Engineering Surveys,” INGEO 2004 and FIG Regional Central and Eastern European Conference on Engineering Surveying, Nov. 11-13, 2004, Published by INGEO, Bratislava, Slovakia, 2004, pp. 10. |
Traichal et al., “Forecastable Default Risk Premia and Innovations,” Journal of Economics and Finance, Fall 1999, vol. 23, No. 3, pp. 214-225. |
UMBC CMSC 341 Introduction to Trees dated Aug. 3, 2007. |
YAHOO, <http://web.archive.org/web/20020124161606/http://finance.yahoo.com/q?s=%5eIXIC&d=c . . .> printed Mar. 6, 2012 in 2 pages. |
Official Communication for New Zealand Patent Application No. 628840 dated Aug. 28, 2014. |
Definition “Identify” downloaded Jan. 22, 2015, 1 page. |
Definition “Overlay” downloaded Jan. 22, 2015, 1 page. |
Official Communication for New Zealand Patent Application No. 622513 dated Apr. 3, 2014. |
W. Dreyer et al., “An Object-Oriented Data Model for a Time Series Management System,” IEEE 1994, pp. 10 pages. |
G. Mentzas et al., “An Architecture for Intelligent Assistance in the Forecasting Process,” Proceedings of the 28th Annual Hawaii International Conference on System Sciences, 1995, 10 pages. |
Notification of International Search Report and Written Opinion, PCT/US2009/056738, Applicant: Palantir Technologies, Inc., dated Mar. 29, 2010, 11 pages. |
Current Claims, PCT/US2009/056738, 11 pages. |
Number | Date | Country | |
---|---|---|---|
20110179042 A1 | Jul 2011 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 12210947 | Sep 2008 | US |
Child | 13079690 | US |