The amount of data available for making business and personal decisions has grown rapidly as networking and other communications media have enabled access to large stores of information. To make use of this information, a class of workers, called “information workers” has developed. Information workers are tasked with developing analysis techniques that can be applied to data so that the data can be presented in a way that supports informed decision making.
In some instances, information workers use documents to capture information and knowledge about analysis of that data. Such documents may be of different types. For example, a word processing document may be primarily organized according to paragraphs or sections. Though, a word processing document may include objects, such as tables. In contrast, a spreadsheet document may be organized as a table with rows and columns of cells. Each cell may contain text or numbers. In some instances, cells contain formulas that can compute a value based on values in other cells or other spreadsheets.
These documents can incorporate “visualizations.” A visualization may be a graphical object linked to a data set. Values in the data set may control the appearance of visual characteristics of the graphical object when it is rendered on a graphical user interface. Charts are one example of visualizations. For example, the EXCEL spreadsheet program allows a chart to be linked to data in cells of the spreadsheet such that the data is displayed graphically as an embedded object in the spreadsheet.
In some instances, the visualization may be interactive. The visualization may include a control that a user may manipulate to change some aspect of a data set associated with the interactive visualization. A slider is one example of an interactive visualization. The slider may be positioned based on a value in the data set. By interacting through the graphical user interface with the slider, the user may specify a new value for that value in the data set.
Regardless of the specific format of the document, once created, it may be distributed to others who may use it for analyzing data and making decisions. For example, an information worker may create a spreadsheet that captures knowledge about running a department in a large company. The spreadsheet may be distributed to managers of various departments, who may then enter data into cells of the spreadsheet. Each manager may then gain insights related to their department by viewing graphs that have been incorporated into the spreadsheet by the information worker. As one example, managers may view a chart showing profitability of their departments.
The usefulness of documents for capturing and distributing knowledge may be expanded by providing novel techniques for authoring the document. The document may be defined as a plurality of entities interconnected by edges. Multiple types of entities may be represented in the document, but entities of any type may be interconnected through edges. These entities, for example, may represent a source of external data, a visualization, interactivity of a visualization, or an analytic.
By providing a common framework to represent such disparate entities, bindings may be specified between different types of entities such that, for example, a source of data may be bound to an analytic, a visualization and/or interactivity of a visualization. Moreover, by providing a common framework, a common data schema may be used across multiple types of entities.
A document authoring tool may be provided to receive user inputs defining an interactive document. In the document, entities and edges may be interconnected to form a directed acyclic graph. Accordingly, as user input is received, the document authoring tool may verify that the graph resulting after each user input is processed to modify the graph maintains the acyclic nature of the graph.
Once the document is defined, it may be published so that it may be used by parties interested in applying the knowledge captured in the document. Publishing the document may entail converting the edges defining links between data outputs and data inputs of entities into computer executable code that causes data to flow between computer-executable instructions representing transforms associated with at least a portion of the entities. For entities that represent data sources, publishing the document may entail providing computer-executable instructions that acquire data from the source.
Publishing the document may entail one or more manipulations to improve the efficiency of operation of the document. Some manipulations may relate to ordering the operations to reduce the total amount of computation required to generate a result based on user interaction with the document. Such manipulations may entail reordering entities in the graph, inserting entities or removing entities to reduce the amount of processing required to achieve a result that matches a result achieved with the document before manipulation.
Alternatively or additionally, the manipulations may relate to the manner in which the document is partitioned for distribution in a tiered computer system. The document may be partitioned and different partitions may be formatted for execution on different computing devices. The partitioning may be performed to improve efficiency of operation in the deployed environment. Such partitioning may entail assigning portions of the document to partitions based on criteria such as processing power available on a computing device to execute each partition or based on available network bandwidth between those computing devices.
The foregoing is non-limiting summary of features the invention. It should be appreciated that the forgoing features may be used singly or in any suitable combination.
The accompanying drawings are not intended to be drawn to scale. In the drawings, each identical or nearly identical component that is illustrated in various figures is represented by a like numeral. For purposes of clarity, not every component may be labeled in every drawing. In the drawings:
The inventors have recognized and appreciated that a novel approach to representing an interactive document as a directed acyclic graph of nodes and edges may facilitate the authoring and distribution of complex documents. Entities of multiple types may be incorporated in the document to provide the capability to capture knowledge about data analysis. Yet, a relatively small feature set needs be supported by a document authoring tool.
In some embodiments, the tool allows a user to define entities that represent external data, visualizations, interactivity of visualizations and analytics, including analytical patterns. The tool supports data schemas of arbitrary complexity, which may be used by any of the entities. Moreover, the tool supports edges interconnecting any types of entities, including those representing data sources, analytics, visualizations, and interactivity. In some embodiments, this relatively limited set of functionality is adequate to represent complex analytical operations and to support complex interactions between a user and the document.
Such a representation leads to efficiencies in distributing the document. The graph may be manipulated to improve the efficiency with which results are generated as a user interacts with the document. Improvements may be achieved, for example, by reordering the entities in the graph, inserting additional entities, removing entities or modifying entities, so long as the overall result is not changed. As an example, if an entity that performs a transformation resulting in condensing a data set is preceded by an entity including a complex transformation applied to the entire data set, substantial computation may be performed on data in the set that does not ultimately affect an output. In this scenario, the preceding entity may be modified so as to apply the transformation to only the portion of the data set output after the subsequent transformation.
Alternatively or additionally, efficiencies may be achieved based on the manner in which the document is partitioned to execute on multiple computing devices when the document is published. For example, the graph may be partitioned such that portions of the functions of the document are performed on a user device while other portions of the functions are performed on one or more servers “in the cloud.” The graph may be partitioned such that entities involving user inputs and outputs are assigned to a partition assigned to a user device. Other entities, which may be associated with transformations that require substantial computation, may be assigned to servers to which the user device is networked. The specific server to which a partition is assigned may depend on factors that enhance efficiency, such as availability of a data source providing data that is input to the transformation.
Computing device 105 may have the capability to communicate over any suitable wired or wireless communications medium to a server 106. The communication between computing device 105 and server 106 may be over computer network(s) 108, which may be any suitable number or type of telecommunications networks, such as the Internet, a corporate intranet, or cellular networks. Server 106 may be implemented using any suitable computing architecture, and may configured with any suitable operating system, such as variants of the WINDOWS® Operating System developed by MICROSOFT® Corporation. Moreover, while server 106 is illustrated in
In the embodiment of
In the embodiment illustrated, data 110 may store information representing a document under development by user 102. Accordingly, as a user interacts with the data analysis system, the document authoring tool may store as data 110 a representation of the document.
As this model of an interactive document is built, server 106 may generate information depicting the document in a format suitable for display in a graphical user interface. The information generated by server 106 may be sent over computer network(s) 108 and be displayed on a display of computing device 105. A display may be any suitable display, including an LCD or CRT display, and may be either internal or external to computing device 105.
The entities are interconnected via edges, with an edge connecting two entities and indicating a data flow between these entities. Some entities may have both an input and an output, while others may have no inputs and an output or an input and no output. For example, an analytic may be represented as an entity that includes a transformation between an input and an output. A data source, however, may have no inputs but may provide an output supplying data from the source. For example, when the data source comprises a table, an output may be a collection of rows. If the table is nested, the output rows may themselves be columns that include tables. An entity representing a visualization has an input comprising data to be visually represented and suitable supplemental information and no output. As a result, the document may also represent a binding between data and one or more of an analytic, a visualization and/or interactivity of a visualization. Edges may connect any entities, including entities of different types.
Each of entities 206 and 208 may be referred to as an analytic. The analytic entities perform transformation of the data and are therefore shown as associated with respective transforms 210 and 212. These entities may transform data input by applying analytic logic to the data input and generating an output result based on the data input having been operated upon. The transformations define a functional relationship between an input and an output of an entity. The analytics may include rules, equations, constraints, expressions as well as complex data structures, such as nested data, or combinations thereof.
A transform defines operations that may be performed on data received as one or more inputs to generate output(s) provided to other entities. For example, the transform may comprise a calculation on data. Accordingly, the entities that perform operations on the data have both one or more inputs and one or more outputs. The operations may include calculations, transformations, evaluation of equations, or application of constraints or rules and any other suitable operations.
The interactive document 200 is shown to include another entity 214 associated with a transform 216. The entity 214 is connected via an edge 215 with the entity 206 and via an edge 217 with the entity 208. Thus, the entity 214 may receive data from entities 206 and 208 and transform the data in accordance with operations defined in the transform 216.
Some of the entities represented in an interactive document may have an input but no output. Examples of such entities are shown as an entity 218 and an entity 220. These entities may be, for example, visualizations that only accept inputs (e.g., data to be visually represented and supplemental information) but do not generate any data outputs. Accordingly, as shown in
The interactive document 200 in
In some scenarios, entities may be interactive visualizations which are therefore referred to as visualizations with interactivity. Such visualizations may receive user input indicating a change in a way the visualization is to be presented. In response to a suitable input, the appearance of the visualization may change. An interactive slider provides an example of such a visualization. Though, any other suitable visualizations with interactivity may be substituted. Data linked to an interactive visualization may also change in response to a user input. Such a data change may be modeled as an entity with an output.
In the example of
Because the graph formed by entities and edges in accordance with some embodiments is acyclic, to avoid a cycle in the data flow, the visualization 300 may be represented as two separate entities, 308 and 310 shown in
In contrast, entity 310 represents the portion of interactive visualization 300 that produces output in response to a user input. Output edge 309 represents the data that is output. The manner in which the data output by entity 310 is used in the interactive document depends on how output edge 309 is connected to other entities in the document.
This representation of a visualization with interactivity as two separate entities allows maintaining the acyclic nature of the graph.
The positions of slider controls 350A and 350B may be used in any suitable way. In this example, the controls 350A and 350B may collectively form a slider that specifies filter criteria on a data set. For example, in this scenario, the positioning of slider controls 350A and 350B may define a range of data values to be filtered from the data set for further processing. Accordingly, the results of user input manipulating slider controls 350A and 350B may also be represented as an output of an entity associated with visualization 300.
In some embodiments, other types of entities may be represented using two separate entities. For example, a data source or data sink, which may, in some embodiments, receive data to be updated, may be similarly represented as two entities. One of such entities may have no output but only an input through which data updates are received, whereas another entity may have an input receiving a query (e.g., a set of query parameters) and an output supplying the results of the query. The output from that entity of the two separate entities representing an updatable data source or data sink may be supplied in the same form as output provided by data sources or sinks that are not updated and may therefore be referred to as invariable.
Regardless of the specific functions represented by each of the entities in a document, each of the entities may be associated with a function performed on data. Ultimately, when the interactive document is published and used, each of the entities may be associated with computer executable instructions that perform those functions. The association between an entity and computer executable instructions may be achieved in any suitable way. In some embodiments, as part of authoring a document, a user may provide input that specifies the computer executable instructions. The user input, for example, may be source code in a high-level programming language such that the computer executable instructions associated with an entity may be entered by a user as the user authors a document. Though, in other embodiments, entities may be predefined such that the computer executable instructions that perform functions of an entity when a document containing that entity is published are predefined. Entities, for example, may be predefined by other users or software vendors, and an authoring tool may present to a user a library of such entities. For example, in visualization 300 (
Though,
In some embodiments, a common framework is provided to represent disparate entities of different types. The common framework allows using a common data schema across multiple types of entities.
An authoring tool may enable the user to define entities of any type in an interactive document in a simplified and intuitive manner, using a standardized form provided by the data schema. Different elements, sub-elements, suitable functions and other types of information defining an entity may be created using the data schema.
By combining entities of different types, a user may represent both simple documents of the type that can be generated using current data processing software applications. For example, a conventional spreadsheet containing rows and columns of cells, each potentially containing a value, may be represented in a document in the form of
In addition, a document in the format specified in
Similarly, a conventional word processing document may be represented in the format illustrated in
As with the case of a spreadsheet document, representing a document in the form of
Further, representing a document as an interconnected graph of entities facilitates use of the document in environments that expand beyond a traditional computing environment in which spreadsheet programs and word processing programs were initially developed. As one example, a document created as depicted in
Accordingly, an interactive document may be published so that a user may utilize the document. The publishing may involve converting, with a computerized tool, a graph formed by entities represented in the interactive document into executable components configured for execution on a computing device. That conversion may be performed using techniques as are known in the art for compiling or interpreting computer executable instructions in a higher level programming language. For example, computer executable instructions associated with the entities may be combined into an executable version of a program based on the manner in which those entities are specified as connected through edges in the document. As part of the conversion process, the computerized tool may insert further computer executable instructions that control the ordering of the execution of the computer executable instructions associated with each of the entities and the flow of data between those entities. For example, computer programming techniques that result in data being queried from a data source may be incorporated in the executable document. Additionally, as part of publication, references to specific computing devices that may interact to execute the document may also be partially or fully resolved. For example, in scenarios in which an entity depicting a data source represents data that may be obtained by querying a server, publishing the document may include inserting information such that upon execution of the document an appropriate query will be sent to the appropriate server. Programming languages that support such functions are known in the art, such that known techniques for configuring computer executable instructions for execution in a specific hardware environment may be used as part of the publication process. Accordingly, it should be appreciated that the specific techniques used in publishing the document are not critical to the invention.
In some embodiments, the graph may be modified to improve execution as it is published. Such modifications may be based on criteria indicative of efficient execution. Such criteria may include time required to complete an operation, amount of network bandwidth consumed, or interference with other operations, for example. The graph may be partitioned into two or more partitions. The partitioning may be based on a processing power available on a user device, memory capacity and availability and capability of other computing devices (e.g., a graphics processing unit, etc.).
In some embodiments, the interactive document, in the form of the executable components, may be deployed on a suitable deployment environment. The deployment environment may be indicated in any suitable manner. For example, a user input may be received identifying the deployment environment. Though, other ways of identifying the deployment environment may be substituted.
A deployment environment may comprise multiple computing devices that have different properties making the devices suitable for different purposes. For example, some of the devices, such as servers, may be capable of performing multiple computationally intensive operations. Such devices may handle a large volume of processing operations. Other devices in the deployment environment may be more suited for handling multiple data access operations. These devices may be associated with one or more databases that may be accessed frequently. The deployment environment may comprise any other devices.
A published interactive document may be presented to a user on a user interface of a user device. The user interface may allow the user to view and interact with the document. In some embodiments, such user device may have a limited processing power that does not allow the device to perform multiple computationally intensive operations or multiple data access operations. The device may also have a limited data storage capacity. However, one or more entities represented in the interactive document may perform multiple computationally intensive operations. For example, an entity may be a transformation that requires substantial computation. Other entities may, such as those associated with data sources, may require or multiple data access operations. In this scenario, efficient execution may be achieved by implementing portions of the document that directly control interaction with the user on the user device. To achieve more efficient execution, other portions of the document, such as those involving extensive computation or data manipulation may be performed on other computing devices to which the user device is linked in the computing environment.
Accordingly, execution of one or more entities in the interactive document converted into respective executable components may be partitioned among different computing devices in the deployment environment, depending on suitability and availability of the devices to execute the components. The graph may be partitioned into a plurality of partitions based on properties of computing devices in the deployment environment. The document authoring tool may partition the graph automatically, without user intervention. Alternatively or additionally, in some embodiments, the graph may be partitioned based on suitable user input.
Different partitions may be assigned to execute on different devices, based on computing capabilities of the devices. The graph representing the document may be partitioned such that portions of the functions of the document are performed on the user device while other portions of the functions are performed on one or more servers “in the cloud.” Thus, a partition may be defined for execution on the user device, based on computing capabilities of the user device. Also, one or more partitions for execution on a network server may be defined, which may be implemented based on bandwidth of a network connection between the network server and a data source. The partitioning of the document to execute on multiple computing devices when the interactive document is published may improve efficiency of the execution of the document.
The device 502 may provide a user interface 504 through which the user 102 may view and interact with the interactive document. The graph may be partitioned into multiple partitions to execute on different devices in the deployment environment 500.
In the example illustrated, a portion 506 of the document comprising entities involving user inputs and outputs may be assigned to a partition assigned to the user device 502. That partition may be assigned to the user device 502 based on computing capabilities of the user device 502 or other properties of the user device.
The device 502 may communicate wirelessly or otherwise with multiple devices in a deployment environment. For example, the device 502 may communicate, via an access point 508, with a router 510. The router 510 may connect the device 502 to one or more other computing devices “in the cloud.” For example, the router 510 may allow the device 502 to communicate, via a network 514, with servers 516 and 518. The network may be any suitable network. However, this connection may be a relatively low bandwidth connection such that portion 506 is generated from a portion of a graph representing an interactive document that is selected to exclude any entities that access external sources of data.
Different partitions of the document may be assigned to different computing devices “in the cloud,” based on computing capabilities of the devices. In
In some embodiments, the server 516 may provide functionality of an external service. In some embodiments, one or more of such entities may be identified that have transforms executable by an external service. When a graph is converted into the executable components, one or more of the components may execute instructions placing a call on the external service.
A portion 519 of the interactive document comprising one or more entities (e.g., transformations) that require substantial computation may be assigned to the server 518 that has processing power sufficient for execution of multiple computationally intensive operations. The executable components deployed to the multiple computing devices may therefore operate “in the cloud” where they can exchange data in accordance with the data flow defined in the graph. It should be appreciated that each of the servers 516 and 518 may encompass multiple computing devices as embodiments of the inventions are not limited to a particular architecture of the deployment environment.
A specific server to which a partition is assigned may depend on factors that enhance efficiency, such as availability of a data source providing data that is input to the transformation. Also, a partitioning decision may depend on a proximity of one or more computing devices to which partition(s) are assigned to the user device. Any other suitable factors may be taken into consideration. Moreover, the partitioning of the document may be changed at any suitable time based on changing network conditions.
In some embodiments, reordering entities in the graph comprises reordering an entity having a transform that implements a filter to precede an entity having a transform that implements a computation. The reordering may be based on computational complexity of the filter and the computation.
As shown in
Because sort and filter operations are commutative operations, switching their order produces the same output with a different complexity. Accordingly, depending on complexity of sort and filter operations represented by transforms 605 and 607, respectively, the entities in the graph 600 may be reordered by switching the order of the entities 604 and 606. The resulting graph 601 is shown in
As an example, the entity 602 may represent a data source including a listing of real estate properties each associated with a particular zip code. The listing may comprise, for example, n rows. In accordance with the graph 600, the sort transform 605 may be first applied to the zip codes, a result of which may be n rows sorted by the zip codes. The filter transform 607 may then be applied to filter out all zip codes outside of a certain mile range. The result of this operation provided as an output of the entity 606 may be data comprising m rows, where m≦n.
For example, if the data output by the entity 602 comprises n rows where N=10,000,000, the sort transform 605 may order the n rows in the worst case with a complexity of O(n*log(N)) (70,000,000). The filter transform 607 then removes some of the n rows with a O(n) complexity. Because the sort operation has been first applied to the data, the filter operation can be performed with an O(log(n)) complexity, in which case a sequential read to extract the relevant rows takes O(m) time. The overall complexity of the graph 600 will be O(n*log(n))*(complexity of the sort operation)+O(log(n))*(complexity of the filter operation)+O(m).
Because sort and filter operations are commutative operations, switching their order produces the same output with a different complexity. Thus, in the graph 601 shown in
Based on the complexity of the filter operation represented by the filter transform 607 and the complexity of the sort operation represented by the sort transform 605, an order of the entities 604 and 606 as shown in
In some embodiments, modifying a graph corresponding to an interactive document may involve inserting an entity in the graph.
As shown in
When the new column is calculated, all of the columns of the data and the new columns may be presented on a user interface. The entity 706 may be a visualization that visually displays the data. As an example, the data may be represented on a map showing all properties and their luxury indexes. However, only a limited number of columns may be used to show the real estate properties and their respective luxury indexes. For example, only a latitude, longitude and a luxury index of a real estate property may be used to display this property and its luxury index on the map. Accordingly, one or more of the columns from the data provided by the data source entity 702 may be dropped, leaving only the columns that are required to calculate the column showing the luxury index and the columns used to display the properties on the map. As shown in
In some embodiments, modifications of a graph may comprise partitioning the graph for distribution in a tiered computer system. The tier splitting may involve partitioning the graph into portions to be executed on different devices, such as different servers, or a user device, etc. The partitioning may be performed based on a number of suitable factors. For example, computing capabilities of the devices to which partitions are assigned may be utilized.
In some embodiments, a computerized tool for converting the graph into one or more executable components, such as, for example, a document authoring tool, prior to the converting the graph into the executable components, may manipulate the graph for efficiency purposes. Each of the executable components may be configured to execute on a device from the multiple devices in the deployment environment, with some of the components configured to execute on the user device, which may be a mobile computing device. The deployment environment may comprise multiple different computing devices. For example, the deployment environment may comprise may comprise a user device through which the user interacts with the graph and one or more other devices capable of executing the executable components.
The graph may be manipulated to improve a value of at least one metric indicative of user interaction with the interactive document in the deployment environment. The metric may comprise bandwidth in a communication link to a user device mobile computing device used during interaction with the interactive document by the user of the mobile computing device. The metric may also comprise processing power consumed on the mobile computing device during interaction with the interactive document by the user of the mobile computing device.
As shown in
Next, in accordance with the data flow indicated in the graph 800, the entity 806 may apply the filter transform 807 to filer out properties that are not in a list including certain zip codes. The resulting data may be sorted using the sort transform 809 of the entity 808. The sort transform 809 may sort the data based on the luxury index column calculated by the entity 804. Finally, another filter transform, transform 811 of the entity 810, may be applied to the sorted data to keep a certain number of the rows in the data (e.g., the top five rows) and filter out the rest. These top rows therefore comprise real estate properties with the highest luxury indexes. The data that is output from the entity 810 comprising real estate properties at certain location(s) that have highest luxury indexes may be input to the entity 812. The entity 812 may be a visualization that displays a certain number (as determined by the filter transform 811) the real estate properties with the highest luxury indexes on a map.
The graph 800 shown in
A computerized tool may identify an entity in the graph that has a transform that receives as input static values. When such entity is identified, it may be replaced with an entity representing pre-computed static values. Alternatively, the entity that pre-computes the static values may be added to the graph. In the example illustrated in
Similarly to the insertion of a new entity to a graph shown in
When the document is published, the graph is converted into executable components each configured to be executed on a computing device. The graph may be partitioned by defining two or more partitions assigned to execute on different devices. The partitioning may be based on computing capabilities of a user device and other devices.
As indicated above, the data output by the entity 802 may comprise a large number of real estate properties. For example, 10,000,000 properties may be listed. Accordingly, computation of the luxury index and further processing of the data may require substantial processing power. As shown in
The results of the processing may be presented to the user using the entity 812 which may be assigned to a different partition 818 that is assigned to execute on the user device. The partition 818 may be assigned to the user device based on impoving a value of one or more suitable metrics indicative of user interaction with the interactive document. Such metrics may include bandwidth in a communication link to the user device used during interaction with the interactive document by the user of the device, processing power consumed on the user device during interaction with the interactive document by the user and any other suitable metrics. The tier splitting as shown in
In some embodiments, one or more entities may be assigned to a partitions assigned to execute on the user device. For example, it may be efficient to execute entities that receive user input or that are close in the graph to the entities that receive user input. Such entities may be a visualization, control, interactivity of a visualization, etc.
In
To ensure the responsiveness of execution of the entity 810, it may now be more efficient to execute this entity on the user device. Because the entity 820 receives user input, it is efficient to assign this entity to execute on the user device as well. Accordingly, as shown in
It should be appreciated that any other suitable modifications of the graph may be performed as well. For example, an entity suitable for receiving user input indicating different formulas to perform a calculation column using the transform 805 may be added. In this case, this additional entity, along with the entity 805, may be added to the partition 818 configured for execution on the user device.
Next, at block 904, user input defining an entity represented in the interactive document may be received. The entity may be defined, for example, by assigning values to elements of the schema. The user may operate a user device having a user interface that receives user input indicative of defining an entity. Any suitable entity of any type may be defined, non-limiting examples of which include a source of external data, a visualization, interactivity of a visualization, an analytic, or a binding between data and at least one of an analytic, a visualization and/or interactivity of a visualization. The entity may also comprise a table or a nested table.
In an interactive document, an entity is connected to at least one other entity via a directed edge indicating a data flow between these entities. Accordingly, at block 906, the tool may receive user input defining one or more edges connecting the entity defined at block 904 and other entities in the graph. If the entity defined at block 904 is the first entity to be defined in the interactive document, at least one other entity may need to be defined before an edge may be defined that connects these entities in the graph.
In embodiments described herein, the graph is a directed acyclic graph. Accordingly, as user input defining an entity and an edge connecting the entity to another entity is received, the document authoring tool may verify that the edges interconnect the entities in an acyclic graph. Thus, process 900 may branch at decision block 908, depending on whether the document authoring tool verifies that, as a result of the user input received at block 906, the acyclic nature of the graph is maintained.
If it is determined at block 908 that the acyclic nature of the graph is violated (i.e., a cycle is the graph is created), the process 900 may branch to block 909, where a respective error is reported in a suitable manner. For example, a message in a visual, audio or other form may be provided to the user to inform the user that the acyclic nature of the graph is violated. It should be appreciated that even though process 900 is shown to end at block 909, the process may be iterative. Accordingly, user input may be received indicating removal of the entity and/or an edge which, if inserted into the graph, would violate the graph's acyclic nature. The process 900 may then return to block 906 where user input defining another entity may be received.
When it is determined at block 908 that the acyclic nature of the graph is maintained, the process 900 may branch to block 910 where it may be determined whether the entity defined at block 904 is an interactive visualization. If this is the case, the entity may be decomposed at block 912 into two entities—one having only an input and no outputs and another having only an output and no inputs. An example of such decomposition of an entity is shown in connection with
Alternatively, when it is determined at block 910 that the entity defined at block 904 is not an interactive visualization, process 900 may also continue to block 914. At block 914, one or more entities and edges defined at blocks 904, 908 and, in some cases, decomposed into input and output entities at block 912, may be added to the graph.
Next, at decision block 916, it may be determined whether more entities are to be represented in the interactive document. This may be determined in any suitable way. For example, the document authoring tool may prompt the user, via the user interface, to specify whether one or more additional entities are to be defined in the graph. Other ways of determining whether more entities are to be defined may be substituted.
When it is determined, at decision block 916, that no other entities are to be defined, process 900 may end. However, when it is determined, at decision block 916, that other entities will be defined, the process may return to block 904 where user input may be received defining such one or more entities, as shown in
In some embodiments, the graph built as described above, may be modified to improve efficiency of execution of the graph. Additionally or alternatively, the graph may be modified to improve efficiency of operation of the interactive document. In the latter scenarios, the graph may be modified based on operations performed by transforms in the graph and their computational complexity, a volume of data that flows between entities in the graph or a frequency of refreshing the data (e.g., updated once a day or every minute). Further, a level of interactivity of the document may be taken into consideration. If an entity has a transform that receives as input static values that do not change at a time of execution of the interactive document, such entity may be replaced with or supplemented with another entity that pre-computes the static values.
Next, the graph may be modified to achieve greater efficiency of operation of the interactive document, as measured by improvement in any one or more metrics. Any suitable modifications to the graph may be effected in any suitable order. In the example illustrated, at block 1006, the document authoring tool may remove one or more entities from the graph. The removal of the entities may involve merging at least two entities. At block 1008, two or more entities in the graph may be reordered. An example of reordering of the entities is shown in
Process 1012 may determine, at decision block 1012, whether any additional modification of the graph may be implemented to effect more changes to the graph. This may be performed by analyzing the graph and determining whether any additional changes may improve efficiency of operation of the document. If more changes are possible, the process 1000 may return to block 1006 where one or more entities may then be removed, the entities may be reordered or added. It should be appreciated that only a portion of the processing at blocks 1006-1010 may be performed on a graph.
If it is determined, at decision block 1012, that no additional changes to the graph may be effected to improve efficiency of operation of the document, process 1000 may end.
In some embodiments, the graph converted into executable components may be modified based on criteria indicative of efficiency of execution. Such modifications may involve partitioning the graph into two or more partitions based on criteria associated with computing devices available to execute the components. A deployment environment in which the partitions may be executed by comprise different types of devices having different computing capabilities and other properties. The partitions may be assigned to executed on different devices in the deployment environment.
At block 1102, the document authoring tool may receive user input defining a deployment environment. The user input may be received in any suitable manner and with respect to any suitable deployment environment. For example, a user interface of a user device may allow the user to indicate the deployment environment using a suitable control.
Next, at block 1104, two or more partitions may be defined for execution on the user device and one or more devices “in the cloud.” The partitions may be defined based on a number of factors. For example, the partitions may be defined based on computing capabilities of the user device and other devices in the deployment environment. Entities within the graph may be assigned to different partitions. At block 1106, process 1100 may identify in the graph one or more transforms that are executable by an external service. The external service may be a server or other suitable computing device. Such transform(s) may be converted into executable components that place a call to the external service.
The process 1100 may then continue to block 1108 where each partition may be encoded for execution on a computing resource to which the partition is assigned. In particular, entities assigned to the partition may be converted into executable components configured to executed on the computing resource.
Next, at block 1110, data push and pull instructions may be incorporated into the graph, defining a way in which entities having an input receive data through the input. The data pull and push modes are manifested at edges of the graph defining a data flow between entities in the graph.
An entity in the graph having an input may operate either in the data pull mode or in the data push mode. In the data pull mode, the entity may request data to be received at the entity's input from its predecessor entity in the graph. The request for data in the pull mode may be defined as a function call or in any suitable manner.
In the data push mode, the entity may be “pushed” data without an explicit request from that entity. The data may be pushed into an entity in number of ways. For example, a suitable interactive element (e.g., a control or other element) capable of receiving user input indicative of “pushing” the data may be presented on a user interface. An example of such entity comprises a visualization with an interaction.
It should be appreciated that processing shown at blocks at
Some embodiments are operational with numerous other general purpose or special purpose computing system environments or configurations. Examples of well known computing systems, environments, and/or configurations that may be suitable for use with the invention include, but are not limited to, personal computers, server computers, hand-held or laptop devices, multiprocessor systems, microprocessor-based systems, set top boxes, programmable consumer electronics, network PCs, minicomputers, mainframe computers, distributed computing environments that include any of the above systems or devices, and the like.
The embodiments may be described in the general context of computer-executable instructions, such as program modules, being executed by a computer. Generally, program modules include routines, programs, objects, components, data structures, etc. that perform particular tasks or implement particular abstract data types. The invention may also be practiced in distributed computing environments where tasks are performed by remote processing devices that are linked through a communications network. In a distributed computing environment, program modules may be located in both local and remote computer storage media including memory storage devices.
With reference to
Computer 1210 typically includes a variety of computer readable media. The system memory 1230 includes computer storage media in the form of volatile and/or nonvolatile memory such as read only memory (ROM) 1231 and random access memory (RAM) 1232. A basic input/output system 1233 (BIOS), containing the basic routines that help to transfer information between elements within computer 1210, such as during start-up, is typically stored in ROM 1231. RAM 1232 typically contains data and/or program modules that are immediately accessible to and/or presently being operated on by processing unit 1220. By way of example, and not limitation,
The computer 1210 may also include other removable/non-removable, volatile/nonvolatile computer storage media. By way of example only,
The drives and their associated computer storage media discussed above and illustrated in
The computer 1210 may operate in a networked environment using logical connections to one or more remote computers, such as a remote computer 1280. The remote computer 1280 may be a personal computer, a server, a router, a network PC, a peer device or other common network node, and typically includes many or all of the elements described above relative to the computer 1210, although only a memory storage device 1281 has been illustrated in
When used in a LAN networking environment, the computer 1210 is connected to the LAN 1271 through a network interface or adapter 1270. When used in a WAN networking environment, the computer 1210 typically includes a modem 1272 or other means for establishing communications over the WAN 1273, such as the Internet. The modem 1272, which may be internal or external, may be connected to the system bus 1221 via the user input interface 1260, or other appropriate mechanism. In a networked environment, program modules depicted relative to the computer 1210, or portions thereof, may be stored in the remote memory storage device. By way of example, and not limitation,
Having thus described several aspects of at least one embodiment of this invention, it is to be appreciated that various alterations, modifications, and improvements will readily occur to those skilled in the art.
Such alterations, modifications, and improvements are intended to be part of this disclosure, and are intended to be within the spirit and scope of the invention. Accordingly, the foregoing description and drawings are by way of example only.
The above-described embodiments of the present invention can be implemented in any of numerous ways. For example, the embodiments may be implemented using hardware, software or a combination thereof. When implemented in software, the software code can be executed on any suitable processor or collection of processors, whether provided in a single computer or distributed among multiple computers. Such processors may be implemented as integrated circuits, with one or more processors in an integrated circuit component. Though, a processor may be implemented using circuitry in any suitable format.
Further, it should be appreciated that a computer may be embodied in any of a number of forms, such as a rack-mounted computer, a desktop computer, a laptop computer, or a tablet computer. Additionally, a computer may be embedded in a device not generally regarded as a computer but with suitable processing capabilities, including a Personal Digital Assistant (PDA), a smart phone or any other suitable portable or fixed electronic device.
Also, a computer may have one or more input and output devices. These devices can be used, among other things, to present a user interface. Examples of output devices that can be used to provide a user interface include printers or display screens for visual presentation of output and speakers or other sound generating devices for audible presentation of output. Examples of input devices that can be used for a user interface include keyboards, and pointing devices, such as mice, touch pads, and digitizing tablets. As another example, a computer may receive input information through speech recognition or in other audible format.
Such computers may be interconnected by one or more networks in any suitable form, including as a local area network or a wide area network, such as an enterprise network or the Internet. Such networks may be based on any suitable technology and may operate according to any suitable protocol and may include wireless networks, wired networks or fiber optic networks.
Also, the various methods or processes outlined herein may be coded as software that is executable on one or more processors that employ any one of a variety of operating systems or platforms. Additionally, such software may be written using any of a number of suitable programming languages and/or programming or scripting tools, and also may be compiled as executable machine language code or intermediate code that is executed on a framework or virtual machine.
In this respect, the invention may be embodied as a computer readable storage medium (or multiple computer readable media) (e.g., a computer memory, one or more floppy discs, compact discs (CD), optical discs, digital video disks (DVD), magnetic tapes, flash memories, circuit configurations in Field Programmable Gate Arrays or other semiconductor devices, or other non-transitory, tangible computer storage medium) encoded with one or more programs that, when executed on one or more computers or other processors, perform methods that implement the various embodiments of the invention discussed above. The computer readable storage medium or media can be transportable, such that the program or programs stored thereon can be loaded onto one or more different computers or other processors to implement various aspects of the present invention as discussed above. As used herein, the term “non-transitory computer-readable storage medium” encompasses only a computer-readable medium that can be considered to be a manufacture (i.e., article of manufacture) or a machine. Alternatively or additionally, the invention may be embodied as a computer readable medium other than a computer-readable storage medium, such as a propagating signal.
The terms “program” or “software” are used herein in a generic sense to refer to any type of computer code or set of computer-executable instructions that can be employed to program a computer or other processor to implement various aspects of the present invention as discussed above. Additionally, it should be appreciated that according to one aspect of this embodiment, one or more computer programs that when executed perform methods of the present invention need not reside on a single computer or processor, but may be distributed in a modular fashion amongst a number of different computers or processors to implement various aspects of the present invention.
Computer-executable instructions may be in many forms, such as program modules, executed by one or more computers or other devices. Generally, program modules include routines, programs, objects, components, data structures, etc. that perform particular tasks or implement particular abstract data types. Typically the functionality of the program modules may be combined or distributed as desired in various embodiments.
Also, data structures may be stored in computer-readable media in any suitable form. For simplicity of illustration, data structures may be shown to have fields that are related through location in the data structure. Such relationships may likewise be achieved by assigning storage for the fields with locations in a computer-readable medium that conveys relationship between the fields. However, any suitable mechanism may be used to establish a relationship between information in fields of a data structure, including through the use of pointers, tags or other mechanisms that establish relationship between data elements.
Various aspects of the present invention may be used alone, in combination, or in a variety of arrangements not specifically discussed in the embodiments described in the foregoing and is therefore not limited in its application to the details and arrangement of components set forth in the foregoing description or illustrated in the drawings. For example, aspects described in one embodiment may be combined in any manner with aspects described in other embodiments.
Also, the invention may be embodied as a method, of which an example has been provided. The acts performed as part of the method may be ordered in any suitable way. Accordingly, embodiments may be constructed in which acts are performed in an order different than illustrated, which may include performing some acts simultaneously, even though shown as sequential acts in illustrative embodiments.
Use of ordinal terms such as “first,” “second,” “third,” etc., in the claims to modify a claim element does not by itself connote any priority, precedence, or order of one claim element over another or the temporal order in which acts of a method are performed, but are used merely as labels to distinguish one claim element having a certain name from another element having a same name (but for use of the ordinal term) to distinguish the claim elements.
Also, the phraseology and terminology used herein is for the purpose of description and should not be regarded as limiting. The use of “including,” “comprising,” or “having,” “containing,” “involving,” and variations thereof herein, is meant to encompass the items listed thereafter and equivalents thereof as well as additional items.
Number | Name | Date | Kind |
---|---|---|---|
4633430 | Cooper | Dec 1986 | A |
5669007 | Tateishi | Sep 1997 | A |
6691100 | Alavi et al. | Feb 2004 | B1 |
6865720 | Otani et al. | Mar 2005 | B1 |
6931589 | Baltsan et al. | Aug 2005 | B2 |
7028306 | Boloker et al. | Apr 2006 | B2 |
7263663 | Ballard et al. | Aug 2007 | B2 |
7315861 | Seibel et al. | Jan 2008 | B2 |
7343585 | Lau et al. | Mar 2008 | B1 |
7349947 | Slage et al. | Mar 2008 | B1 |
7440902 | Greenstein et al. | Oct 2008 | B2 |
7506243 | Kotler et al. | Mar 2009 | B2 |
7603620 | Erol et al. | Oct 2009 | B2 |
7752314 | Trevor et al. | Jul 2010 | B2 |
7752536 | Megiddo et al. | Jul 2010 | B2 |
7802230 | Mendicino et al. | Sep 2010 | B1 |
7900111 | Kim et al. | Mar 2011 | B1 |
7908186 | Gabelmann et al. | Mar 2011 | B2 |
8135655 | Oaten et al. | Mar 2012 | B2 |
8332772 | Janzen et al. | Dec 2012 | B2 |
8473473 | Wang et al. | Jun 2013 | B2 |
8589172 | Alonso et al. | Nov 2013 | B2 |
8635211 | Jiang et al. | Jan 2014 | B2 |
20010047372 | Gorelik et al. | Nov 2001 | A1 |
20020065673 | Rooke | May 2002 | A1 |
20020066782 | Swaminathan et al. | Jun 2002 | A1 |
20020091609 | Markowski | Jul 2002 | A1 |
20020169658 | Adler | Nov 2002 | A1 |
20020191199 | Imada et al. | Dec 2002 | A1 |
20030041104 | Wingard et al. | Feb 2003 | A1 |
20030144868 | MacIntyre et al. | Jul 2003 | A1 |
20040015481 | Zinda | Jan 2004 | A1 |
20040098358 | Roediger | May 2004 | A1 |
20040153992 | Molina-Moreno et al. | Aug 2004 | A1 |
20040162842 | Ono et al. | Aug 2004 | A1 |
20040181519 | Anwar | Sep 2004 | A1 |
20050004911 | Goldberg et al. | Jan 2005 | A1 |
20050043961 | Torres et al. | Feb 2005 | A1 |
20050187809 | Falkenhainer | Aug 2005 | A1 |
20050231392 | Meehan et al. | Oct 2005 | A1 |
20060037019 | Austin et al. | Feb 2006 | A1 |
20060074882 | Scherer et al. | Apr 2006 | A1 |
20060080400 | Guha | Apr 2006 | A1 |
20070038657 | Denton et al. | Feb 2007 | A1 |
20070046664 | Raspl et al. | Mar 2007 | A1 |
20070061711 | Bodin et al. | Mar 2007 | A1 |
20070112714 | Fairweather | May 2007 | A1 |
20070124285 | Wright et al. | May 2007 | A1 |
20070136326 | McClement et al. | Jun 2007 | A1 |
20070179941 | Huang et al. | Aug 2007 | A1 |
20070185746 | Chieu et al. | Aug 2007 | A1 |
20070250764 | Jiang et al. | Oct 2007 | A1 |
20070265995 | Remington et al. | Nov 2007 | A1 |
20070294614 | Jacquin et al. | Dec 2007 | A1 |
20080040346 | Aggarwal et al. | Feb 2008 | A1 |
20080058969 | Nixon et al. | Mar 2008 | A1 |
20080178083 | Bergman et al. | Jul 2008 | A1 |
20080183710 | Serjeantson et al. | Jul 2008 | A1 |
20080184140 | Koerner | Jul 2008 | A1 |
20080189438 | Zimmerer et al. | Aug 2008 | A1 |
20080195930 | Tolle | Aug 2008 | A1 |
20080209314 | Sylthe et al. | Aug 2008 | A1 |
20080215559 | Fontoura et al. | Sep 2008 | A1 |
20080238925 | Meehan et al. | Oct 2008 | A1 |
20080271127 | Naibo et al. | Oct 2008 | A1 |
20080288889 | Hunt et al. | Nov 2008 | A1 |
20080294996 | Hunt et al. | Nov 2008 | A1 |
20080306981 | Jiang et al. | Dec 2008 | A1 |
20080307334 | Chaudhri et al. | Dec 2008 | A1 |
20080319829 | Hunt et al. | Dec 2008 | A1 |
20090037363 | Kozlov et al. | Feb 2009 | A1 |
20090049422 | Hage et al. | Feb 2009 | A1 |
20090094674 | Schwartz et al. | Apr 2009 | A1 |
20090100360 | Janzen et al. | Apr 2009 | A1 |
20090100407 | Bouillet et al. | Apr 2009 | A1 |
20090125553 | Dickinson | May 2009 | A1 |
20090172024 | Hsu et al. | Jul 2009 | A1 |
20090172773 | Moore | Jul 2009 | A1 |
20090216758 | Tuttle et al. | Aug 2009 | A1 |
20090225082 | Hargrove et al. | Sep 2009 | A1 |
20090254971 | Herz et al. | Oct 2009 | A1 |
20090287814 | Robertson et al. | Nov 2009 | A1 |
20090300544 | Psenka et al. | Dec 2009 | A1 |
20090312992 | Chen et al. | Dec 2009 | A1 |
20090322739 | Rubin et al. | Dec 2009 | A1 |
20090327878 | Grandison et al. | Dec 2009 | A1 |
20100070448 | Omoigui | Mar 2010 | A1 |
20100088258 | Oaten et al. | Apr 2010 | A1 |
20100100561 | Cooper et al. | Apr 2010 | A1 |
20100106853 | Kashiyama et al. | Apr 2010 | A1 |
20100131255 | Beckman et al. | May 2010 | A1 |
20100179951 | McPhail | Jul 2010 | A1 |
20100198697 | Brown et al. | Aug 2010 | A1 |
20100205178 | Bush et al. | Aug 2010 | A1 |
20100241620 | Manister et al. | Sep 2010 | A1 |
20100287459 | Mital et al. | Nov 2010 | A1 |
20110029636 | Smyth et al. | Feb 2011 | A1 |
20110093430 | B'Far et al. | Apr 2011 | A1 |
20110131253 | Peukert et al. | Jun 2011 | A1 |
20110179020 | Ozzie et al. | Jul 2011 | A1 |
20110231385 | Wang et al. | Sep 2011 | A1 |
20110295795 | Venkatasubramanian et al. | Dec 2011 | A1 |
20110295853 | Li et al. | Dec 2011 | A1 |
20120158643 | Mital et al. | Jun 2012 | A1 |
20120158644 | Mital et al. | Jun 2012 | A1 |
20120158732 | Mital et al. | Jun 2012 | A1 |
20120158754 | Mital et al. | Jun 2012 | A1 |
20120159312 | Mital et al. | Jun 2012 | A1 |
20120159465 | Mital et al. | Jun 2012 | A1 |
Entry |
---|
“How to Customize Ubuntu into your own custom distribution,” Retrieved at <<http://www.linuxquestions.org/questions/ubuntu-63/how-to-customize-ubuntu-into-your-own-custom-distribution-663412/>>, Aug. 17, 2008, 10 pages. |
“LeoStatistic—building histogram, curve fit, multivariate regression, data modeling software,” Retrieved at <<http://www.leokrut.com/leostatistic.html>> Retrieved Date Sep. 21, 2010, pp. 1-6. |
“Publishing applications to market place,” Retrieved at <<https://help.creator.zoho.com/Publishing-applications-to-market-place.html>>, Retrieved Date Nov. 26, 2010, pp. 1-5. |
“Quella Business Intelligence Package,” Retrieved at <<http://www.shareit.com/product.html?cookies=1&productid=300100398&affiliateid=2000122751>>, 1 page. |
“Square your search results with Google Squared,” Retrieved at <<http://googleblog.blogspot.com/2009/06/square-your-search-results-with-google.html>>, Jun. 2009, pp. 1-4. |
“User Customization,” Retrieved at <<http://docstore.mik.ua/orelly/perl3/tk/ch16—01.htm>>, Retrieved Date Nov. 26, 2010, pp. 1-4. |
“Windows Azure and Cloud Computing,” Retrieved at <<http://oakleafblog.blogspot.com/2010/09/windows-azure-and-cloud-computing-posts—09.html>>, Sep. 9, 2010, pp. 1-68. |
Ayachit et al., “Customizing ParaView,” Retrieved at <<http://www.itk.org/Wiki/images/7/77/Branding—paper.pdf>>, Oct. 2009, 3 pages. |
Banerjee, Atanu, “The 2007 Microsoft Office System and Other Platform Technologies for Building Composite Applications,” Retrieved at <<http://msdn.microsoft.com/en-us/library/bb220802.aspx>>, Dec. 2006, 14 pages. |
Biddick, Michael, “Six Questions to Ask Before Buying End-to-End APM,” Retrieved at <<http://www.networkcomputing.com/end-to-end-apm/6-questions-to-ask-before-buying-end-to-end-apm.php>>, Jun. 21, 2010, pp. 1-9. |
Collins, J., “Using Innovation in Technology to Create New Business Models,” Retrieved at <<http://www.theshiftonline.com/?p=666>>, Oct. 25, 2010, 3 pages. |
Delaney, A., “Direct Data Feed Services,” Retrieved at <<http://www.a-teamgroup.com/?dl—id=7460&dl—cm=on&dl—la=0&dl—ls=0>>, Jun. 2010, 8 pages. |
Janeiro, et al., “Improving the Development of Service-Based Applications Through Service Annotations,” Retrieved at <<http://www.rn.inf.tu-dresden.de/uploads/Publikationen/AnnotationPaperWWW-Internet2009.pdf>>, 2009, 8 pages. |
Johnson, et al., “Building ETL Processes for Business Intelligence Solutions,” Retrieved at <<http://www.ca.com/files/whitepapers/ca-erwin-building-etl-processes-sql-wp-us-en.pdf>>, Jul. 10, 2008, 6 pages. |
McNee et al., “Creating Auction Ads for Marketplaces,” Retrieved at <<http://e-articles.info/e/a/title/Creating-Auction-Ads-for-Marketplaces/>>, Apr. 2007, pp. 1-2. |
Mostarda et al., “MU: an hybrid language for Web Mashups,” Retrieved at <<http://em-up.googlecode.com/svn/wiki/papers/www2009.pdf>>, 2009, 10 pages. |
Nagel, Nick, “Enterprise Data Modeling Using XML Schema,” Retrieved at <<http://citeseerx.ist.psu.edu/viewdoc/download?doi=10.1.1.135.6120&rep=rep1&type=pdf>>, 2007, 30 pages. |
Ravindran, Karthik, “Integrating LOB Systems with the Microsoft Office System,” Retrieved at <<http://msdn.microsoft.com/en-us/library/bb896607.aspx>>Nov. 2007, pp. 1-18. |
Spillner et al., “Flexible Human Service Interfaces,” Retrieved at <<http://citeseerx.ist.psu.edu/viewdoc/download?doi=10.1.1.70.7734&rep=rep1&type=pdf>>, 2007, 7 pages. |
White, Colin J., “IBM enterprise analytics for the intelligent e-business,” Retrieved at <<http://sysdoc.doors.ch/IBM/bi.pdf>>, Sep. 2001, 34 pages. |
“Document Processing System”, Published on: Nov. 16, 2007, Available at: http://www.wolfram.com/products/mathematica/analysis/content/DocumentProcessingSystems.html. |
“Introduction to the XML Pipeline Definition Language (XPL)”, Retrieved on: Sep. 16, 2010, Available at: http://www.orbeon.com/orbeon/doc/reference-xpl-pipelines. |
“Optimizing Forms Processing”, Retrieved on: Sep. 16, 2010, Available at: http://www.movetonow.com/content/optimizing forms—processing. |
Frisch, et al., “Streaming XML Transformations Using Term Rewriting”, In Plan—X—Programming Language Technologies for XML, Jan. 20, 2007, 13 Pages. |
Gardarin, et al., “XML-based Components for Federating Multiple Heterogeneous Data Sources”, In Proceedings of the 18th International Conference on Conceptual Modeling, Nov. 15, 1999, 14 Pages. |
Jelinek, et al., “XML Visualization Using Tree Rewriting”, In Proceedings of the 20th Spring Conference on Computer Graphics, Apr. 22, 2004, pp. 65-72. |
Page, Sam, “XSL Pipeline Processing”, Published on: Jul. 2, 2007, Available at: http://www.usingxml.com/Transforms/XslPipelines. |
“Non-Final Office Action Issued in U.S. Appl. No. 12/971,685”, Mailed Date: Jul. 13, 2012, Filed Date: Dec. 17, 2010, 9 Pages. |
“Non-Final Office Action Issued in U.S. Appl. No. 12/971,685”, Mailed Date: Apr. 24, 2014, Filed Date: Dec. 17, 2010, 15 Pages. |
“Final Office Action Issued in U.S. Appl. No. 12/971,685”, Mailed Date: Oct. 11, 2012, Filed Date: Dec. 17, 2010, 16 Pages. |
“Non-final Office Action Issued in U.S. Appl. No. 12/971,638”, Mailed Date: Aug. 30, 2012, Filed Date: Dec. 17, 2010, 18 Pages. |
“Non-final Office Action Issued in U.S. Appl. No. 12/971,725”, Mailed Date: Aug. 21, 2012, Filed Date: Dec. 17, 2010, 10 Pages. |
“Final Office Action Issued in U.S. Appl. No. 12/971,725”, Mailed Date: May 1, 2013, Filed Date: Dec. 17, 2010, 14 Pages. |
“Non-final Office Action Issued in U.S. Appl. No. 12/971,782”, Mailed Date: Jul. 13, 2012, Filed Date: Dec. 17, 2010, 7 Pages. |
“Final Office Action Issued in U.S. Appl. No. 12/971,782”, Mailed Date: Jan. 31, 2013, Filed Date: Dec. 17, 2010, 10 Pages. |
“Final Office Action Issued in U.S. Appl. No. 12/971,462”, Mailed Date: Sep. 18, 2013, Filed Date: Dec. 17, 2010, 24 Pages. |
“Non-final Office Action Issued in U.S. Appl. No. 12/971,462”, Mailed Date: Mar. 21, 2013, Filed Date: Dec. 17, 2010, 21 Pages. |
“Non-Final Office Action Issued in U.S. Appl. No. 12/972,205”, Mailed Date: Nov. 26, 2012, Filed Date: Dec. 17, 2010, 32 Pages. |
“Final Office Action Issued in U.S. Appl. No. 12/972,205”, Mailed Date: Jun. 7, 2013, Filed Date: Dec. 17, 2010, 35 Pages. |
“Final Office Action Issued in U.S. Appl. No. 12/971,638”, Mailed Date: Feb. 25, 2014, Filed Date: Dec. 17, 2010, 11 Pages. |
“Non-final Office Action Issued in U.S. Appl. No. 12/971,725”, Mailed Date: Jun. 23, 2014, Filed Date: Dec. 17, 2010, 18 Pages. |
“Non-final Office Action Issued in U.S. Appl. No. 12/971,782”, Mailed Date: Apr. 10, 2014, Filed Date: Dec. 17, 2010, 10 Pages. |
“Document Processing System”—Published Date: Nov. 16, 2007; http://www.wolfram.com/products/mathematica/analysis/content/DocumentProcessingSystems.html. |
“Introduction to the XML Pipeline Definition Language (XPL)”—Retrieved Date: Sep. 15, 2010; http://www.orbeon.com/orbeon/doc/reference-xpl-pipelines. |
“Optimizing forms processing”—Retrieved Date: Sep. 15, 2010; http://www.movetonow.com/content/optimizing—forms—processing. |
Frisch, A. et al. “Streaming XML transformations using term rewriting”—Published Date: 2007; http://pauillac.inria.fr/˜frisch/xstream/long.pdf. |
Gardarin, G. et al. “XML-based Components for Federating Multiple Heterogeneous Data Sources” Lecture Notes in Computer Science—Published Date: 1999; http://dntt.free.fr/publi/er1999.pdf. |
Jelinek, J. et al. “XML Visualization Using Tree Rewriting”—Published Date: 2004; http://mummy.intranet.gr/includes/docs/Conferences/—02—XMLvisualization-Jelinek-SCCG04.pdf. |
Page, S. “XSL Pipeline Processing”—Published Date: Jul. 2, 2007; http://www.usingxml.com/Transforms/XslPipelines. |
Number | Date | Country | |
---|---|---|---|
20120159333 A1 | Jun 2012 | US |