This application relates to data management.
The amount of data that can be processed and stored by one or more computers has grown multi-fold over the last few years. The explosive growth in the data managed and processed by computers can be witnessed in application areas such as web servers, e-commerce servers, financial databases, multimedia content servers, and so on.
The present document describes techniques for managing data items, or groups of data items, such that data items can be modified while maintaining data hierarchy and inter-dependency.
In one aspect, techniques are provided for managing changes to information by storing information as a plurality of objects, each object having a plurality of states, maintaining one or more temporal histories for each object based on the plurality of states of the object at a plurality of time instances, determining, for each state of the object, whether the state is a user of another state of the object or another object, receiving a request to change the information, and selectively changing, responsive to the request, at least one state of at least one of the plurality of objects. When it is determined that the at least one state is the user of another state, then the changing is further responsive to changes in the another state.
The details of above aspects and their implementations are set forth in the accompanying drawings, the description and the claims.
Information often, but not always, changes over a period of time. For example, 1950 baseball champion team may not change, but the record for most hits in a baseball game will change over a period of time. Similarly, in software code development scenario, some files, e.g., source code or header files, may not change over the life time of the software, but some other files may change over a period of time to add new features or to perform bug fixes and so on.
Data used in many application may have interdependencies. For example, in one hypothetical example, System A may maintain and use earth-moon information (e.g., rise/set times, location, tides, etc.) while another System B may maintain earth-moon-satellite information. In this scenario, the changes to the Earth and moon data in System A may have an impact on System B, while changes to satellite data in System B may have no impact on System A. Therefore, certain information from System A may be a “resource” for certain information in System B, while that information in System B may be called to have a “user” relationship to some information in System A.
In applications where complex interdependencies exist among data items with data items being modified, there to not presently exist any solutions to effectively track and manage these interdependencies and changes to information. Tools that provide version tracking (e.g., source code revision control system, or RCS), techniques for tracking changes to Word documents, etc. provide “special purpose” suffer from numerous limitations and are not ubiquitously applicable. For example. Word files can track changes from a previous version, but do not track changes to changes. Similarly, Word files do not track changes from interdependencies, e.g., one Word file changing due to changes in another Word file. Similarly, while RCS can tie together changes to one source file with changes to another source file through the use of a Makefile, RCS does not make a downstream file (a “user”) aware of changes to a “resource” file.
The communication network 2904 can be a suitable network, such as a wired or wireless network, e.g., the Internet, Ethernet, wireless cellular network such as 3G, Long Term Evolution (LTE) network, WiMax, etc. In various embodiments, the client computer 2902 may be a computer, a smartphone, a tablet device, using a suitable operating system. The server 2906 may include a processor, instruction memory and a suitable operating system. The database 2908 may be implemented using storage such as hard drive, flash memory, etc. In various embodiments, the server 2906 and the database 2908 may be implemented on the same hardware platform (e.g., sharing the same power source) or may comprises two different platforms connected over a local connection such as an SCSI interface.
Headings are used in this document only for clarity of explanation and do not in any way limit the scope of the disclosed technology.
1. Introduction
Some building blocks of QEI and the real world problem it addresses are briefly discussed in Section 1. Section 2 goes systematically over the concepts underlying QEI's functionality and design; it ends with 2.6 which is a roadmap for the rest of the paper: metadata representation (Section 3), provided operations (Section 4), and finally the requirements QEI imposes on data (Section 5).
1.1 A Platform for Open Data
A current trend is the increased pace of change in the structure of data. Different from the speed of accumulation of data of a certain kind, this results in a need to adapt database representations and code more frequently.
Dynamic data structures are difficult to handle. When the structure is static, one can build a specialized system, which can be robust and efficient, with a good user interface. However the very same qualities make it difficult to upgrade, presenting a tradeoff between the advantages of specialization and the length of release cycles. This creates a problem for dynamic businesses like finance, where the upgrade cycle cannot be shortened enough. It is common to see stop-gap solutions, especially spreadsheets. However, in the long run scalability and reliability are desired, and new systems are built. Development and transition costs are high.
One approach to dynamism is modularity, which consists of breaking down information into stand-alone pieces, perhaps with dependencies. This allows individual pieces, i.e. modules, to evolve at their own pace, and distribute the problem among firms and teams. Modularity is ubiquitous in software development, mechanical design, even mathematics; beyond a certain complexity, any problem requires building blocks.
Standardization helps modularity tremendously, as it draws the boundaries between pieces, and creates competition to produce them. Dynamism is opposite: because problems are less set, standards are not established yet. Trying things out is necessary, sometimes requiring substantial integration efforts.
Being able to keep track of versions becomes a desirable feature. This observation predates computers: whiteprints and then cheaper blueprints started to be used at the turn of the 20th century for designs, and currently version control systems are widely used, from software development, industrial design to documents. There are numerous benefits: freedom to try knowing reverting is easy, combining work done by multiple individuals, locate problems, observe the evolution of an idea etc. Without version control, the world of design today would be inconceivable.
One reason an equivalent of open source software development for the realm of data does not exists may be because currently there is no system capable of solving the complexities of systematically maintaining versions of data. The problem is more complex than software version control (SVC), for a number of reasons:
QEI is an innovative solution to the problem of, among others, managing versions of what can be called hierarchical data, modules of data characterized by user/resource relationships. A user module needs resource modules to function, while the latter function independently of their users, of which there can be many or none.
QEI enables building a platform for modular data, with the following desiderata:
1.2 The QE Platform (QEP)
QEP distinguishes between producers and consumers of data. A related concept is that of mutable and immutable data; all data is initially mutable, but at some point it is frozen and becomes immutable. Immutable data cannot be edited directly, but a mutable copy can be made (A similar process is used in file version control. A file committed into a repository is immutable, while a working copy is mutable). Consumers of data only have access to immutable data.
QEP is a distributed platform composed of QE Zones, physically similar but residing on different servers, potentially at different firms. Zones can obtain immutable data from each other, either individual items or as time series (similar to a subscription). Mutable data cannot be seen in another zone, and thus whoever needs to interact with mutable data should have access to that particular zone.
Project X produces data in Python, and resides on a machine with access to the SQL Server. The machine should also have QEI Python installed, the interface between QEI application code and QEI Core. QEI Core can be given commands through QE Python, or directly via stored procedures. The same goes for Y/Java. For simplicity the diagram assumes the Daemon, QEI Java and the Java projects also reside on the same machine (Application code can be split on multiple machines for load balancing, and the Daemon keeps track on which machine a project is located on to route requests.). The QEI Core is a schema on the SQL Server, augmented with C++ code, called the metadata schema (From a user's perspective the schema is a regular one. However, given complexity it is necessary to use a high-level language the SQL server accepts. MySQL allows C++ user-defined functions, and Oracle Java stored procedures; both can be called from SQL without knowledge of how they were implemented). The metadata schema provides IDs for projects X and Y; the project schemas have foreign keys constraining IDs to those provided by QEI. The metadata schema provides stored procedures for a variety of QEI operations.
The projects provide two special items of code (LLF and Hooks are discussed together with the rest of the application code requirements in Section 5.).
LLF Low-level functionality consists of two stored procedures for each type of data implemented (kind in QEI parlance), that perform duplication and deletion. Besides a number of roles inside QEI, they also support the inter-zone subscription mechanism. They should be stored procedures for reasons of efficiency and portability of code across programming languages.
Hooks These are high level functions (e.g. written in Python for Project X), that are involved in the process of constructing, freezing and evolving data.
Arrows represent calls; blue ones are possible initiated requests, which can be made by either users or the Daemon. Suppose Project X is related to a utility company, and a meter reading has to be inputted manually every month. Here is a simplified sequence of the steps that would get triggered (Likely more than one hook will be involved.):
One observation is that moving code from language interfaces to stored procedures saves implementing logic repeatedly across programming languages, and gains efficiency. The language interfaces cannot be moved entirely into the database server, as they need to call hooks, which is not possible from the SQL Server. Moving the hooks into SQL is not practical, due to their complexity; it is not reasonable to ask developers to write them in anything but a high-level language. The division between LLF and hooks presents a tradeoff between efficiency and ease of programming, and the LLFs chosen are those crucial for efficiency and the zone subscription mechanism. As their implementation is often boilerplate, this is acceptable (A Python framework can automate writing the LLFs using metaclass programming techniques.).
Throughout this paper QEI will mean QEI Core together with the QEI language interfaces. The discussion of the latter has a Python bias, but all of QEI consists of generic programming techniques, and can be implemented in any high-level language that provides SQL access.
1.3 Challenges
As disclosed above, there are three principal difficulties facing such a system. The first is that when combining groups of objects, each individually correct, the result can be inconsistent, as resources can conflict. QEI uses an original approach and relies on the notion of batch editing.
The second is keeping track of historical relationships in the presence of multiple versions. The first step is associating validity intervals to data items (Section 2.1), at the end of which actions need to be taken (Working with temporal objects only is a limitation of QEI. For example, a code repository's history in a revision control system contains forks and merges, and thus it is not a linear succession. Modeling evolution patterns and rules for combing them is possible, but a discussion is beyond the scope here.). To guarantee deterministic behavior, validity intervals of resources are required to at least include those of users. Furthermore, time-driven object updates are reduced to calls to the next( ) hook, with the issue of choosing resource continuations from among multiple versions handled by again by batch editing (see Sections 2.5 and 5.2.2). This allows both manual and automatic generation of histories, the latter being useful for any realistic size system. This feature can be used to implement a daemon. Adding some elements to the metadata schema (Section metadata) may be desirable.
Finally, managing dependencies on code an execution platform is relies on the fact that they fit very well the user/resource model. This allows QEI to remain simple, as the development framework can address the issue in a language specific way (Building a project in Python is very different from C++.). This results in a relatively simple metadata schema and requirements for application code, which are both language-independent, albeit with a Python flavor. Code and execution platforms can be made 1st class citizens, and data migrations triggered by code upgrades represented naturally.
2. QEI Concepts
QEI uses batch editing augmented with time information as an approach to managing versions of data. This section describes the concepts involved, and introduces terminology used throughout the rest of the sections.
Most of this paper is intended to be readable in isolation, by combing the concept discussion with design details, by the exception being the μ and ρ batch functions, and the related batch updating algorithm.
2.1 Objects and States
Information is organized into objects, each having a multitude of states. An object is something that is unique within a “reality” at a given point in time. As our physical (macroscopic) world is composed of evolving objects, there are many examples; e.g. store inventory can be an object, as it is not possible for two different inventories to be correct at one point in time. Multiple states for an object can model its history, i.e. how it evolved over time, as well as keep track of unrelated versions as needed by work in progress, differences of opinion etc.
While many evolution patterns are possible, QEI works with temporal objects, whose history is a sequence of states. Time is modeled as a discrete integer interval T (T=[−231, 231−1]⊆Z) for the prototype), and states are associated a validity interval [b,e)⊆T. Thus the history of an object consists of a sequence of states {xn} with en=bn+1. To represent object histories, a state can have a state in the same object assigned as its parent. More that one state can share a parent, i.e. a state can have multiple descendants, representing forking histories, however, a state can have at most one parent.
States provide trails for changes of objects. To limit trails to what is relevant, states are divided into frozen and pending (also referred to as immutable and mutable). A frozen state can no longer be changed, and will be remembered indefinitely (unless a trimming operation is performed, see Section 4.3 item 3a). A pending copy can be modified, with intermediate information irreversibly lost.
Pending states are organized into separate batches, each batch B characterized by a point in time tB∈T. A batch is a candidate for a “correct reality” at tB; in particular, an object cannot appear twice in a batch. When pending information is finalized, a batch is frozen. Importantly, new states can only be created within a batch. The batch is a central QEI concept, and disclosed in more detail in Section 2.4, which describe its database representation.
QEI distinguishes between creating states as a result of evolution, i.e. normal changes to the object due to the passage of time, and amendment, potentially allowing arbitrary changes. What constitutes evolution is defined by application logic (via the next( ) method, see 2.5 below, and Section 5.2.2). QEI automates evolutions, making possible data management systems in the familiar sense, i.e. they “just run” without the user being concerned with objects, states, validity intervals etc.
2.2 User/Resource Relationships
A fundamental concept of QEI is that of a user/resource relationship between two states. This is easiest described by an example.
Consider a simplified inventory consisting of 2 fresh fish and 2 lightbulbs. This can be modeled by 5 states: i for the inventory, ƒ1,ƒ2 for the fish, and l1,l2 for the lightbulbs. While the inventory items can be described absent the inventory, a correct description of the inventory relies on the items. One could say that ƒ1,ƒ2,l1,l2 are resources of i, while i is a user of ƒ1,ƒ2,l1,l2, and denote this relationship by ⊆, e.g. ƒ1⊆i.
Resources can be either direct, as in the above case, or indirect i.e. resources of resources. For example, a resource of a bulb could be its manufacturer, which would become an indirect resource of the inventory. QEI tracks of direct resources using the concept of dependency (Section 3.3), and infers indirect ones.
Implementations may impose a number of restrictions on user/resource relationships:
With the above example, suppose fresh fish are good for a week after being caught, while lightbulbs have infinite shelf life. The validity intervals and addition to inventory for each item could be:
One possible evolution of the inventory is i1, . . . , i6, with the following validity intervals and items:
The inventory changes both because transactions (receive and sell) and expirations of resources, for example the transition i4→i5 is at the end of ƒ1.
2.3 Kinds
A special kind of user/resource relationship is between code and data. Every state has a kind state associated with it, representing what kind of data it is. Two typical cases are the class of an instance, and the metaclass of a class. For Python, the kind of x is type(x). QEI provides two objects, each with one unique state that cannot be duplicated or changed, having full lifespan ([−∞,+∞]). They are:
Pythons-like relationships hold: kind(QeiKind)=kind(QeiState)=QeiKind and QeiKind is derived from QeiState.
A kind can have different representations in multiple programming languages. Code objects such as projects or modules can also be modeled as states; the QE Framework has a notion of QE Project, which once loaded become QEI states.
Kinds enable the state retrieval approach of Section 4.1
2.4 Batch Specification
A batch is a way to combine states and reconcile resource incompatibilities. Given a time-point t∈T, a batch B at t is a set of states which is:
Completeness makes batches stand-alone sets of data, i.e. necessary dependencies are included. As seen above (Section 2.3), code can itself is data, in which case a complete set of data is functional.
Condition 3 means no conflicts are allowed among data resources. Two items of data that use different versions of a common resource cannot coexist in a batch. To combine them, a choice of preferred version of the common resource should be made, and one or both of the items be suitably modified.
While in principle batches can be enumerated, it is not practical even for small cases. QEI uses a more flexible batch description, from which the actual batch is automatically computed.
To see why there is an issue, consider the case of two objects X={x} and Y={y, y′} with y⊆x. Starting with an empty batch B=Ø, add x. As B is complete, y is added as well, thus B={x,y}. Now, to “use” y′ in the batch, it is not clear how this operation should be handled, as no batch can contain both x and y′. If x, y′∈B′, for some batch B′, as y⊆x, by completeness y∈B′, hence B′∩Y contains at least two elements, contradicting realism.
QEI resolves this situation using the notion of equivalent states. Two states of the same object are said to be equivalent (written s≃s′) if they are identical except for allowing the replacement one or more resources with states from their respective objects. In the above example, a clone of x′ of x can be created, and the resource y replaced with y′. B′={x′, y′} is a correct batch, and x≃x′.
Importantly, the batch description remembers that x and y′ are the desired states of the batch, while x′ is a utility state, called an autoclone. Should a user change mind and want y to be used again, the batch reverts to B={x,y}.
This process requires that states have a duplication mechanism (Section 5.1.3) and that resources can be replaced (Section 5.1.1). The central role played by batches in QEI makes these requirements useful (except for built-in states, e.g. QeiKind, Section 2.3).
This process requires that states have a duplication mechanism (Section 5.1.3) and that resources can be replaced (Section 5.1.1). The central role played by batches in QEI makes these requirements useful (except for built-in states, e.g. QeiKind, Section 2.3).
A batch description consists of:
The models do not need to be compatible, providing a “mix-and-match” approach to combining states into batches. The above example is represented by a set of generators G={X,Y}, and models mX=x,mY=y or mX=x,mY=y′.
A batch is computed by reconciling the models, starting with the generators. The resulting batch entries are called resolutions, and they satisfy the following:
(A) and (B) simply state that resolutions form a batch. It is important to remember that models are part of the batch's description, while the resolutions are its entries.
(C) prohibits QEI from guessing; if an object is needed, a model should be specified. Even if the object were to contain a unique state, using it automatically is incorrect, as new states can be created for reasons independent of the batch in question. (D) limits the changes made to models to resource replacement within the resource's object. Resource replacement is reversible, so no information is lost.
Conditions (E) and (F) insure the batch consists of as few objects as possible. Consider the case of three objects X={x}, Y={y}, Z={z}, with z⊆x,z⊆y. Starting with G={X,Y}, the batch consists of {x, y, z}. If X is no longer to be a generator, the batch becomes {y,z}, as z is still needed. However, for G=Ø, one can get B=Ø.
This is practically important, as it makes adding an object to a batch reversible. To highlight the importance, consider managing installed software. Often one item of software requires other items to be installed, which can be represented as user/resource relationships. X, Y and Z above can represent items X and Y which need Z to function, while Z is not of interest in its own right (it is not a generator). Ideally Z should be kept only if at least one of X or Y is installed, but typically removing Z is left for the human to remember.
To compute a batch, three tasks need to be performed:
While a batch can be computed from its description by relatively simple algorithms, it is computationally expensive, and QEI uses an incremental algorithm instead. It is considerably more technical, but the efficiency gains are substantial.
2.5 Advancement
As mentioned above, QEI distinguishes between evolution of data and arbitrary edits. Evolving data is created by advancements, the process of generating a descendant state at the end of the validity interval of the parent. The basic idea is that if the parent is known, and the continuations of all resources of the parent are also known, there is enough information to construct the descendant. The process does need to be deterministic; manual input can be required, or recovering data from remote sources.
With the store example of Section 2.2, selling products and ordering items from suppliers represent evolution. Such logic would be put in the next( ) method of the classes modeling the inventory, fish and lightbulb concepts, which QEI assumes every application class provided to perform descendant construction (see also 5.2.2).
To see the difference between evolution and amendment, consider how and accounting mistake should be treated. If the desired effect is restating the books from the point when the mistake occurred, it will not constitute evolution. If on the other hand the next( ) method of inventories allows inputting corrections, it becomes business-as-usual, and hence evolution.
To simplify writing next( ) methods and also provide automation, QEI takes on the responsibility determining what resources next( ) should assume for the new state. To see why this is a concern, recall that for a resource y⊆x, [bx,ex)⊆[by,ey) and hence ey≥ex. Looking to extend x beyond ex, the continuation of y at ex can be y itself if ey>ex, or a descendant of y, if ex=ey. With multiple versions present, there is no guarantee at y has a unique descendant, and therefore advancing x may require a choice. Furthermore, is possible the resource continuation choices are incompatible, i.e. there are conflicts among their own resources.
To address these issues, QEI performs advancement within a batch, into which the desired continuations are added (using Section 4.2 item (2e)), either manually or automatically. If this step succeeds, the chosen continuations are known to be compatible. This is followed by calling next( ), which receives the resource continuations as arguments.
The conditions for the advancement of a state x into a batch B are the following:
2.5.1 Merge Advance
As mentioned above, next( ) is not deterministic, and it may involve manual input. This can create difficulties when correcting histories of states, as advance may require duplicating data input work.
Suppose daily temperatures are collected at certain locations. This can be modeled by two classes, Location and Reading. An instance of reading might consist of temperature, time and location, while Location might have coords and stationManager. A dependency readingLocation can tell QEI each instance of Reading has an instance of Location as a resource.
A sequence of readings at the same location represents an object, with each reading having the prior reading as a parent. Regarding successive observations as a history allows implementing correctly historical measures, e.g. “change-from-prior”. The validity interval of Reading can enforce data collection, and Reading.next( ) can request the observed temperature as input. Location instances will likely have long validity intervals, as changes are infrequent.
Suppose now that after collecting a year of daily observations at a location, an implementation determines that the station manager was replaced six months ago, and would like to correct the data. Just using advancement, this is possible but labor intensive and error prone. The steps, based on the batch operations listed in Section 4.2, are:
If next( ) is not deterministic, amending a parent is not easy. As both the new parent, and the state itself contain useful information, any automatic solution should use both. There is no universal answer, and aggregating the two should be part of the application logic.
QEI addresses this problem via its merge feature, a variation of advancement that uses non-deterministic information from a merge source, an additional state of the object valid at the advance time. The optional argument mergeSource in next( ), None by default, conveys that a merge is in progress (see Section 5.2.2 item 4).
Many practical cases can be covered by two basic approaches:
In the above example, both Reading and Location can be pure input states
Using the merge feature, the amendment Step 2 above is automated (forking, i.e. Step 1, stays the same). Additionally, given code is a state and a resource of data, new functionality can be added when the amendment is done, postponing writing merge code until needed.
2.5.2 Automating Advance and Merge
It is not practical to do all advances and merges manually. However, automation runs into the problem of choosing resources. QEI uses the notion of natural descendant to provide a way to automate most advances and merges.
A state x can have a unique natural descendant n(x), and it is required x is the parent of n(x), and ex=bn(x). This allows advancing all the resources of a state “in-bulk”, using and producing only natural descendants. The results can be iterated upon, doing multiple time intervals with one command.
Natural descendants should not be confused with correct histories, as any parent/descendant relationship can be checked by validation; they are simply preferred choices. A sequence of natural descendants can be thought of as “published data”.
The exact algorithm is described in Section 10.2 items 2c and 2d. Natural descendants can handle multiple branches of versions, and only “fork points” should be treated manually. The example below should give some intuition for the interaction between natural descendants and advance/merge.
Let X and Y be two objects with states x0⊆y0 having b=bx
Implementations may fork the object X at 20. For that purpose implementations may create a batch B at 20, put x20 into it, modify x20 into x′20, and freeze B. Implementations can do a natural advance starting with x′20, which does not have a natural descendant, and obtain e.g. x′21, . . . , x′50; the validity intervals may or may not be the same as for xi, but for simplicity it could be assumed to be the same. The reason for stopping at 50 is that perhaps due to the changes in x′20, next( ) fails for x′50. Thus, n(x′i)=x′i+1, i=20, . . . , 49, and thus have constructed two separate branches of natural descendants for X.
Implementations may update Fusing iterated natural merges. There is a manual step involved, to create the head of a new Y branch. Create a batch, B′ also at 20, add x′20 to it first, then add y20 to it using put with ADAPT flag. This will create a state y′20∈B′ with x′20⊆y′20 After freezing B′, an implementation can perform an iterated natural merge on y′20 with y21 as the merger source. The result will be a sequence y′21, y′22, . . . .
It is worth noting what happens at t=51. x′50 does not have a natural descendant; a 50 merge-advance will be attempted, using x51 as a merge source. If that succeeds, the x′ and y′ branches are extended beyond 51.
If desirable, y′20 can be designated the natural successor of y19 (Section 4.3 items 2b 20 and 2a). Any state that uses the Y sequence and does a natural advance will see this as a smooth transition, which does not break automation (see comment in Section 4.3 2(c)i).
Designating y′20=n(y19) can cause a conflict. Suppose another object Z has a state z0 valid on [0,1), which has both x0 and y0 as direct resources. If an implementation performs a natural advance of z0, it encounter a problem at t=20. Because, x′20⊆y′20=n(y19) and x20=n(x19), and thus the natural descendants of the resources of z19 cannot be combined in a batch at t=20, and natural advance will fail.
The conflict is real, as implementations may have given contradictory instructions as to how to advance, by saying the natural descendants of x0 and y0 should be both followed. This would not be the case if only y0 was a direct resource of z0, with x0 an indirect resource; in that case the advance instructions are to follow the natural descendants of y0, whatever they may come with. The stopping condition in Section 4.3 2(c)i may be used to avoid involving x20
2.5.3 Controlled Resources
While the requirement that the user/resource graph is acyclic is fundamental to QEI, there are cases when it is necessary that a user modifies a resource while there are both pending. The user/resource graph is still acyclic from a validation standpoint, but from a construction standpoint the resource also depends on the user. Consequently, it may be impossible to change the resource without involving the user. Such a relationship is called a controlled resource.
To understand the necessity, consider the following two application classes:
Power Consists of three fields a, n and b, and validation requires an=b. It also has a calculate( ) method, which sets b=an.
PowerLink Has two fields of type Power, called from and to. Validation requires that from.b=to.a, linking the output of from to the input of to. It also has a method calculate( ), which sets to.a:=from.b and then calls to.calculate( ).
Let now x,y be states of kind Power, and l a state of kind PowerLink, with l.from=x and l.to=y. As an example, assume x.n=2, x.a=2 and y.n=3. The only valid combination is x.b=y.a=4 and y.b=64.
This setup only makes sense if l and y are pending simultaneously, y pending implies l is pending, but the converse is not required. However, without y pending, l being pending is useless, as there is no way to correct it if validation fails.
QEI represents this relationship as y being a controlled resource of l. Controlled resources are taken into account when freezing a batch, with two consequences:
When creating new versions of frozen states that have a non-NULL cycle ID, looking at other states that share the same cycle ID may or may not be necessary. In the above example, y and l form a cycle, and both depend on x. If an implementation starts to edit y.a:=4.1 to see the effect y.b=68.921, irrespective of how y.a was arrived at initially, the relation to l is irrelevant.
On the other hand, suppose a version xx of x is created in a batch B with xx.a:=3, and xx.calculate( ) is run. Next l is added to B using the ADAPT flag, which creates a pending version of ll of l, and brings its resource y into B. Validation now fails, as x.b=9 and y.a=4. Calling ll.calculate( ) also fails, as ll's controlled resource y is not pending. Looking at the cycle of l shows editing y in B is necessary. Once a copy yy of y is created, ll.calculate( ) works and computes yy.b=729.
Automated advance and merge using natural descendants can be used once a correct alternate state is constructed, as all states in the cycle will advance simultaneously, given (2a) above. Controlled resources place an additional burden on the forking process (mitigated by storing the cycle ID), but not on automation. Nonetheless, they should be used only when absolutely necessary. A typical case is implementing spreadsheet-like features, where the nature of cycles is not known when the code is developed, but only at run-time.
Every kind is required provide controlled resources via the controlled( ) method, which is part of low-level functionality (see 5.1.3, item 3c).
2.6 QEI Road Map
As previewed in the introduction, QEI functionality (aside from renaming states and objects, Section 4.3 item 1) can be divided into two categories:
(I) Working with states at a fixed time-point, provided by the batch operations of Section 4.2. Some functionalities include:
(II) Working with histories. Creating descendant states comes in two flavors:
As a part of managing histories, set_intervals (Section 4.2 item 1g) determines validity intervals when based on those of resources. The batch time can be changed with set_time (Section 4.2 item 1c).
Finally, detach and kill are the sole means of reducing the database.
Each category each impose requirements on data:
(I) (a) On states:
(b) On relationships:
(II) (a) Retrieval. To work with any application logic, states need to be recoverable from their ID.
These requirements are met by imposing some constraints on application data (Section 5), and storing the necessary metadata. The imports, kind, inheritance, dependency and resource_change tables, together with state.kind_id (
The batch, counts, for_update and account tables support (I), with the exception of the counts.crossleft and batch.t_at columns. Additionally, state.rescount is an optimization feature for batch updating. The remaining portions of the metadata schema support (II).
3. The Metadata Schema
The metadata schema enables the QEI operations (Section 4). Application data is stored separately in application schema, which the metadata schema links with in three ways:
This separation allows QEI to function without knowledge of application schema.
3.1 Overview of Tables
The metadata schema can be seen in
3.2 The State Table
Given the concept of state represents all data in QEI, the state table is central to its functioning, as can be seen by the number of foreign keys tied to state_id, directly or indirectly. The column descriptions are:
The user/resource relationships discussed in Section 2.2 have a 2-tier representation:
Each dependency corresponds to a specific pair of columns in one table. The columns of the dependency table are:
An example of delete is a container which allows deleting its entries by simply removing the line corresponding to the relationship in the database.
This column is used by the delete operation of Section 4.2, item 2f.
Dependencies are inherited. If (A,B) and (C,D) appear in the inheritance table, a dependency for A→C will apply to B→D.
Based on the dependency table, the resources of any state s can be obtained algorithmically, without using application code:
3.4 Monitoring Resources
The correctness of a batch depends on the models' resources. Dependencies declared in the dependency table are monitored by triggers, which log changes in the resource_change table. Its columns are:
The table resource_change is a temporary table, and changes cannot be committed if it is not empty (see 3.6).
INSERT, DELETE and UPDATE are created by running the dependency_triggers stored procedure of the metadata schema when an application schema is added to QEI, consolidating the actions that need to be taken on account of the dependencies of the table. For this reason, tables in application schemas containing dependencies cannot have triggers (see 5.1.1). The triggers generates a +1 signal for INSERT, −1 for DELETE, and one or both for UPDATE, (changing a resource causes one user count to decrease and another to increase).
3.5 Batch Representation
Batches are represented by one line in the batch table, and a set of lines in the counts table, one for each object of the batch, (an object can have only one state in a batch, Sections 2 and 2.4).
The columns of batch are:
According to batch properties, only resolutions can be resources, and given put requires choices (Section 4.2 item 2e), it is better not done automatically. However, if multiple operations are consolidated (Section 3.6.1), it can be useful to suspend this check. One example is to create and assign an object one go.
True is always temporary, thus one connection's choice does not affect others.
The batch description and resolutions are stored in the counts table:
3.5.1 Batch Updating
Batch updating is at the core of batch editing, as all batch operations perform this function, either upon completion or delayed, as in the case of consolidation (see 3.6.1). It is implemented as a stored procedure update(batch_id). Its effect is emptying out the resource_change and for_update entries for the batch, updating μ and ρ, eliminating obsolete objects, recomputing resolutions, and adjusting resolutions to insure consistency. The user/resource relationship graph is checked to be acyclic.
Being able to implement update( ) as a stored procedure is the main reason all kinds have duplicate and delete stored procedures rather than hooks, (see steps 4g and 6 below, and 5.1.3). Due to the complexity of the algorithm, a pure SQL implementation is difficult, and high-level code residing on the database server is the better option, e.g. MySQL C++ user-defined functions or Oracle Java stored procedures.
The columns of for_update are as follows:
Many of the operations described below in Section 4.2 are expressed in terms of producing inputs for update( ).
3.5.2 The Update( ) Algorithm
The algorithm used by update is incremental, as potentially very large batches need to be updated after small changes.
The propagation scheme is implemented as a directed graph routine propagate( ). The inputs are:
The routine returns the graph of vertices touched in the propagation process. For each vertex old and new values of ƒ are returned, allowing to compute the ƒ-signal of the vertex x as ϵ(x,ƒnew (x))−ϵ(x, ƒold(x)).
propagate( ) is run twice, once for μ and once for ρ.
The steps of the update algorithm are as follows:
1. Un-pin objects with deltaP −1. This step is done first to allow un-pinned model to be replaced in the same pass.
2. Recompute μ:
This step detects if models are missing, e.g. there is no model for a resource of a generator object's model, and can raise an exception.
3. Recompute ρ:
4. Update the counts table:
5. Adjust the resources of pending resolutions (keep in mind pending models are always resolutions). Done for:
6. Delete obsolete states. These are:
This step requires each kind to have a delete stored procedure.
3.5.3 The Batch.crossleft Column
batch.crossleft supports make_head and make_descendant for pending states (Section 4.2 items 4b, 4a), by storing a potential parent, which is always a frozen state.
For a frozen state x, the crossleft is defined as:
For a pending state, the crossleft is NULL except for the following cases:
As states represent intervals of time when the object was constant, a descendant y of a state x with bx<by<ex represents a fork. The state x at by−1 has two successors: the constant one, i.e. x at by, and y at by.
Make_head and make_descendant toggle the parent between crossleft and NULL.
3.6 Concurrency
Resource monitoring imposes some restrictions on concurrent access:
(A) Batch updates should be done sequentially. This is enforced by a SELECT . . . FOR UPDATE on the batch table.
Necessary because the effects of update( ) on the counts table cannot be anticipated. One example is cycle detection: two changes, working from the same data in parallel, can each be OK, but together produce cycles. This cannot be detected unless each update finishes before the next one is started.
(B) Committing a connection requires empty resource change and for_update tables.
Necessary because update( ) should eventually be run, and it can fail (e.g. cycles are detected); in that case changes to states should be rolled back.
(C) Changing resources require a state lock. This is acquired by a SELECT . . . FOR UPDATE on the kind's main table.
Necessary because monitoring differences on parallel process produces incorrect results. Suppose a variable x starts with the value 1, and two processes P and Q, working in parallel from the base value, change x to 2 and 3 respectively, with Q committing last. The end result is x=3, with Δx=2. However ΔxP=1, ΔxQ=2, hence ΔxP+ΔxQ=3≠Δx. This applies to a batch, for example:
The above restrictions result in the following typical sequence of actions:
With locking done via SQL, deadlock detection is the responsibility of the database management system.
3.6.1 Consolidation
For a framework, it make sense to have batches operate in two modes:
Automatic updates are simpler, but less efficient. Besides requiring an extra task, consolidating has the disadvantage that incorrect steps are not detected until the end. Consolidation is preferable for multiple operations with upodate( ) unlikely to fail, e.g. constructing large arrays of states.
4. QEI Functionality
This section describes, inter alia, the functionality of QEI, and gives some implementation details, including for state retrieval mechanism, used for any operation that cannot be carried out using metadata alone, and then list individual operations.
Batches (Section 2.4) are used for most operations that create new states, the exceptions being Section 4.3 item (1); item (2c) and (2d) rely on their batch counterparts.
4.1 The Retrieval Sequence
All the information of a state is accessible from its id. Its kind can be recovered from the state table, and the name of the state's main table read from kind.main_table. The kind bases are in inheritance, and hence all dependencies.
Constructing actual instances of application classes is programming-language specific. For Python, the sequence is:
The format of the imports table is flexible, and columns could be added to support other programming languages.
Batch Operations
1. Managing Batches:
The implementation relies on the well-known Tarjan's algorithm, whose output is summarized in Section 6.1. This is necessary to compute intervals that satisfy:
The steps of the operation are the following:
The elements of an SCC are either all pending or all frozen.
If controlled resources are not used, the graph is acyclic and enumerating the graph increasingly suffices; Tarjan's algorithm is not needed.
2. Batch composition: These operations allow choosing which objects appear in the batch and with what model. They all require running update( ) (Section 3.5.1), and thus their output are entries in the for_update table.
With the exception of put, all operations result in exactly one line in for_update, with obvious significance. They can implemented as stored procedures.
Creating the state itself is the responsibility of the application code (Section 5.2.1).
EXACT Fail if there exists a model conflict, i.e. if the object of a resource of toAdd is already in the batch with a different model.
FORCE If there is a conflict between the resources of to Add and existing models, replace the models with the resources of toAdd.
ADAPT If there is a conflict between the resources of toAdd and existing models in the batch, use the existing models.
The above options can be combined to “mix-and-match” existing states. The result is not guaranteed to be correct; further changes can be made either manually or using application logic.
The implementation uses a queuing algorithm to process to Add and its resources top-down. As the user/resource graph is acyclic, the set of resources can be listed such that every user appears before any of its resources. The stopping condition is determined by putFlag.
Processing the queue gives a set of models to be added to the batch's description, each resulting in a line in for_update. toAdd will have a non-zero entry in the delta_g column, determined by the generator flag.
(f) delete: Remove pending state to_delete from all its users, and delete it. The potentially cascading effect on users is determined by the on_delete flags of the dependencies involved (Section 3.3). As frozen states have frozen resources, only pending states are affected.
The first step is to construct a graph of users, with edges between users and resources. The graph's edges store the dependencies relating the two states, taking into account that a state can be a resource of another in more than one way, either because of multiple dependencies among kinds, or because of multiple occurrences within the same dependency.
A vertex is marked DELETE if it has a resource in the graph already marked DELETE, and the dependency's flag is cascade, and marked KEEP otherwise. If marked DELETE, the vertex′ users are added to the graph.
A vertex′ status can be changed from KEEP to DELETE, if it is reached again by via a cascade dependency. For clarity, if x is a resource of y via two dependencies that have restrict and cascade flags, deleting x succeeds; cascade takes precedence.
Once the graph is complete, the vertices are iterated over with users occurring before resources (possible as the graph is acyclic). Each vertex is processed according to how it is marked:
KEEP: All incoming edges come from expanded vertices, and only DELETE vertices are expanded, therefore no cascade incoming edges are possible. There are now two possibilities:
(FAIL) At least one incoming edge contains a restrict dependency. To_delete cannot be deleted due to restrict dependencies.
(ADJUST) All incoming edges contain only setNull or delete dependencies. The user/resource relationships are eliminated by changing the dependencies' tables, and the incoming edges are deleted from the graph.
This step leads adds the requirement that the data allows this changes (Section 2.6, item I(b)iii).
DELETE: As users are processed first, the vertex has no outgoing edges (no users), insured by the (ADJUST) case above. The state's object is added to the for_update table, with −1 in the delta_g column. All incoming edges, and the vertex itself, are deleted from the graph.
The algorithm finishes when all vertices have been processed.
The delete operation can be implemented as a store procedure, with the usual caveat of complexity.
3. State editing: These operations directly modify the counts table, and do not require batch updating. They take the state and user accounts as arguments.
SQL-style read/write locks can be implemented, but require deadlock detection. All three can be implemented as stored procedures.
4. Evolving states:
While advance cannot be a stored procedure, as next( ) is implemented in a high-level language, it is possible for Step 4(c)i, the more complex part.
4.3 Frozen State Operations
As frozen states to not change, the operations consist of generation of descendant states and maintenance.
1. Up-keeping:
2. Automated state construction: Automatic advance and merge are done via the natural descendant mechanism (see Section 2.5.2).
As an observation, controlled resources allow next( ) to modify pending resources. This does not affect natural_advance, but affects future amendments (see 2.5.3).
The algorithm is the same as above, with the difference that in Step 2(c)v, a merge source is provided to the batch function merge. For a given y, the merge source my is the unique (in)direct resource of m (or m′) in y's object. If one does not exist, the special value NOT_FOUND is used (see also 5.2.2).
natural_advance and natural_merge can be iterated using the return value to advance multiple periods.
3. Trimming the database: While frozen states cannot be changed, they can be permanently discarded:
5. Requirements for Application Data
1. Database representation: Application data is stored in database schema, which link to the metadata schema. The restrictions are discussed in Section 5.1.
2. Low-level functionality: Every kind implements delete and duplicate as stored procedures (Section 5.1.3).
3. Hooks: These are high-level programming language calls that are provided to QEI to support the process of creating states. They are:
4. Constraints on application logic: Kind-specific logic, including constructors, is implemented in a high-level programming language, for which a QEI Development framework has been provided. The limitations are discussed in Section 5.2.
5.1 Schema Requirements
For a specific programming language, kinds correspond to application classes. Application class data can reside in multiple tables, but every kind has a unique main table whose lines are in 1-1 correspondence with the states of that kind. The name of this preferred table is stored in the main_table column of the kind table in the metadata schema. In this main table, the primary key is a column named id of type UNSIGNED BIGINT(20); ids are supplied by the framework (see 5.2.1 below).
Duplication (5.1.3 below) has some consequences for UNIQUE indices. This is a basic choice: if versions of states are needed, UNIQUE indices are analyzed early on.
5.1.1 Dependencies
User/resource relationship among states are modeled by dependencies, stored in the meta-data schema table dependency (Section 3.3). Entries should be added into dependency table via SQL, either manually or automated. The graph of dependencies among kinds can have cycles.
The dependency's table in the application schema is assumed to fully describe the relationship, and replacing all occurrences of a resource should be allowed, and amount to replacing the resource. This is a core requirement by the batch update mechanism (see 2.4 and 3.5.1). The resulting object can be invalid, and this will be caught by validation, run when the batch is frozen, or manually. Tables with dependencies may not have triggers, as they are generated automatically to monitor resource changes.
5.1.2 Inheritance
Inheritance is a fundamental relationship among kinds, stored in the inheritance table. Bases are considered resources of the derived class; in particular if a batch contains a kind, it will also contain all its bases, (recall kinds are states). Multiple inheritance is possible but always virtual. This fits the Python model, but cannot represent C++-style non-virtual multiple inheritance. If the data should be accessed from Java, multiple inheritance should not be used.
The hierarchy of main tables mirrors the kind hierarchy. Entries in the main tables of kind bases share the id of the most derived instance, and as result they are not homogeneous by kind.
The following two rules are followed:
5.1.3 Low-level functionality
QEI requires the following to be implemented as stored procedures:
Separating delete and duplicate because of hooks is due to the complexity of updating batches This allows batch updating (see 3.5.1) to reside in the database server, and be used by all programming languages; the efficiency gains are substantial. They also tend to be boilerplate, therefore a framework can automatically generate them in a majority of cases. An additional benefit is that zone subscription becomes automatic.
5.2 Application Logic
Application logic that constructs or modifies pending states uses batches; batches cannot be mixed (see 2.4). Therefore, such methods should receive the batch, database connection and user account among their arguments, const methods, such as the hooks validate( ) and controlled( ) below, should not make modifications, even if they have enough information to do so.
Such methods should accept the batch, database connection and user account as argu-ments, along with other information needed.
The programmer should be cognizant of the need to update batches after resources change. Committing the connection requires resource_change and for_update to be empty. As batch updates are time consuming, consolidation is possible (see 3.6.1).
To change any state, it should be pending and reserved for edit by the correct user account. This can be checked using touch, which should also be run whenever a change is done that does not change the state's entry in the kind's main table. These are gentlemen's agreements, with no enforcement mechanism; a framework can provide a more rigorous interface for a specific programming language. In general, assigned resources should be resolutions of the batch. In consolidation mode (see 3.6.1) that is not always possible, e.g. when assigning a state of a newly created object. Assigning non-resolutions is prohibited by default, and enforced by triggers.
5.2.1 Creating New States
Object construction is treated differently form state duplication, as it typically requires information that is only available in a high-level programming language. Creating a new object is a two step process:
A development framework can simplify the task by providing factory-like functionality.
5.2.2 The Next( ) Method
The advancement mechanism (Sections 2.5 and 2.5.1) requires each kind to provide a next( ) method, which models behavior at the end of the validity interval. Normal maintenance of data should be captured here, including manual inputs. next( ) does not need to be deterministic.
The arguments for advancement at time t are:
mergeSource should be used as a source of previous manual inputs, or any other information not found in either the parent or the continuations. This functionality should be designed based on the need for amendments (see 2.5.1).
The return should be the descendant, as a resolution in the batch, or the special value END. If it is impossible to construct a state correctly, there are two options:
Next can use of controlled resources. These are resources that should be pending when next( ) is run (see 2.5.3). Using controlled resources in next( ) should be coordinated with controlled( ). If consolidating (Section 3.6.1), update( ) should be run.
5.2.3 Conceptual Considerations
Underlying the QEI approach is the assumption that the user/resource graph is acyclic. This needs to be considered early on in the design, when determining what should be QEI states. The general rule of thumb is that if a subcomponent of some data can function on its own, and can be potentially used in more than one place, it should be a state. The smaller states are, the more likely cycles are to appear.
Another consideration are the limitations on concurrency discussed in Section 3.6. The issues raised are not new, as it primarily concerns long operations that use numerous resources, hence raising the risks of waits and deadlocks. One question application design needs to answer is the role of batches. Batches are necessary when several users need to cooperate on data that has not been frozen yet, which should not be too common in the operation of large systems. Except within an individual batch, no concurrency issues arise, as different batches only share frozen states.
6. Example Algorithms
6.1 The Output of Tarjan's Algoritm
For a directed graph (X,E),E⊆X×X, a strongly connected component is a subset C⊆X such that for all x,y∈C, y is reachable from x. Let the set of SCCs of X be denoted by
Tarjan's algorithm takes a list of pairs (vertex,[endpoints]) computes a list of SCCs, each a list of vertices, together with the list of outgoing Ē-edges, as indices in the result list.
For example, from [(1,[2]), (2,[1]), (3,[4]), (4,[1,3])] representing X={1,2,3,4}, E={(1,2), (2,1), (3,4), (4,3), (4,1)}, the result of the Tarjan's algorithm is [([1,2], [ ]), ([3,4], [1])], i.e.
Managing Atemporal Hierarchical Data
The present document also presents techniques for managing data items which are linked by user/resource relationships. In some embodiments, the conflicts may be managed by grouping data items into objects, defined to be sets of mutually exclusive data items. The data items of an object are called states. An intuitive representation is that in any realistic situation, only one state of an object can be true.
The notion of batch, a complete and conflict-free set of data items, is introduced. A way of constructing batches out of conflicting items is described, based on batch descriptions consisting of generator objects and model states.
An non-commutative monoid action on the set of batch descriptions is defined, which captures a set of operations sufficient to manage batches in practice. For the acyclic case, an algorithm for recomputing a batch after changes induced by the action is given, making large batches practical. Associativity allows operations to be consolidated prior to recalculation.
7. Batch Editing
7.1 Introduction
Data items can be related in many ways. Groups defined by subsets, shared characteristics, and proximity according to metrics are just a few. Hierarchical data may refer to sets of items related by binary relationships between users and resources, modeled as a directed graph with items as vertices, and arrows going from resources to users. The assumption is that a user's functionality depends on its resources; conversely, a resource can be used by many items, but its own functioning does not depend on being used.
Some embodiments may manage dynamic hierarchical data, and provide tools for a modular approach to data. For data of any kind, beyond a certain level of complexity the importance of keeping track of versions is well established, and hierarchical data is no different. This documents presents various approaches, collectively called batch editing, for modifying and combining hierarchical data items, while keeping track of versions.
When working with versions of objects, such as code files or industrial designs, their use can be broken down into two categories. The first, which is referred to as primary functionality, requires choosing one version for each object. For example, a building ultimately has one design, as does a software application. The second is historical functionality, in which different versions are related. An item's history may be time-driven, or simply abstract, such as a document's versions. Batch editing is concerned with primary functionality. Thus it is applicable to objects without history, or once a point in history is fixed.
Terminology-wise, an object's versions are referred to as its states; for primary functionality, in any realistic context only one state of the object can be correct. Embodiments may distinguish between immutable and mutable states. A familiar example are files checked into a version control system being immutable, with working copies mutable. All the (in)direct resources of an immutable state may be assumed to be immutable; as the behavior of a state depends on that of its resources, it cannot be otherwise guaranteed deterministic.
Here are a few examples of hierarchical data:
An important issue with respect to hierarchical data is whether to allow cycles in the user/resource graph or not. All items in a cycle are both users and resources to each other, which is not intuitive. However, any directed graph can be reduced to an acyclic one by regarding each maximal cycle as a node; if most of the complexity is retained, user/resource concepts are relevant. The issue is continuum rather than a binary choice.
While the batch editing make senses in general (Propositions 7, 8 and 9), efficient computations are difficulties when cycles are present; the incremental algorithms of Section 9 may not work. Together with other rationales, such as data modularity and validation, acyclic relationships may be the better paradigm if keeping track of versions is a concern. Many practical examples, including the ones mentioned above, are indeed naturally acyclic. Section 7.3.2 further discloses such examples.
7.2 Batch Operations
When relationships are present, it does not make sense to edit states in isolation. Implementations may consider which users will be affected, and perhaps adjust resources. The cornerstone of the approach is the concept of batch, defined as set of states that is both complete and consistent. Completeness means that if a state is in the batch, then all its resources are as well. Consistency means that no object can have multiple states within a batch, eliminating “out of sync” issues. Any mutable state belongs to a unique batch, and thus editing is constrained to batches.
Any set of batch operations must include adding and deleting states. However, working with relationships complicates matters. An added state is accompanied by resources, which may conflict with existing states. Deleting is not straightforward either, as used states cannot be removed. Even immediately reverting an add operation raises issues.
The reader is familiar with these difficulties. When installing software, it is easy to prompt the user to install or upgrade components, but no checks are made for conflicts with existing software. Uninstalling does not revert these side-effects, as it is not known what actions have been done since, and downgrading is often not supported. Human intervention is required, and problems often occur.
To address these concerns, implementations may construct batches out of two types of data (Definition 3 and Proposition 7):
An advantage is that IN/AUTO designations and model replacements are generally reversible.
Here is a possible set of batch operations:
1. There are three flavors of adding a state x to a batch:
All mark x's object IN.
2. Edit pperations:
3. IN/AUTO designation:
4. A model lock. The force command destroys mutable states that conflict with the new state. To prevent accidental loss, models can be locked against replacement:
Both commands can be done manually too.
To see these commands work, refer to
1. Diagram (b): Add y. No conflicts with an empty batch.
2. Diagram (c): Open y. As y is frozen, a mutable clone is created, and becomes Y's model.
3. Diagram (c): Add a. Fails as y is an indirect resource of a, and conflicts with y′.
4. Diagram (d): Adapt a. This step is an example of how resource conflicts are resolved. No batch can contain both a and y′; completeness requires y, which conflicts with y′. Copies a′, q′ of a, q, are created, with q′ a resource of a′, and y′ a resource of q′. a′ and q′ are not mutable, and a,q are still models for A,Q. Refer to a′,c′ auto-clones, which the diagrams show in blue, with their models circled in red (e.g., 202). For clarity, it is the auto-clone that belongs to the batch, not its model.
Not being mutable, auto-clones contain no information; if no longer needed, they are discarded automatically. Application logic can produce different results, as their resources are different. A related situation is attempting to change the version of the required components for some software; it may or may not work.
5. Diagram (d): Force i. This fails, as Step 2 pinned y′ as Y's model.
6. Diagram (d): Unpin y′.
7. Diagram (e): Force i. y′ is replaced with y as a model, y′ is now a mutable state without a batch, and is discarded, hence the need for pin/unpin.
8. Diagram (f): Open y again. The users of y must be switched to y′, therefore clones are generated for a, q, i; they remain models and are shown again in red.
9. Diagram (g): Open i.
10. Diagram (h): Modify the stock index i1 to no longer include stock Z. Z is AUTO, and is dropped.
11. Diagram (i): Save i′. This freezes i′ and its mutable or auto-clone resources, in this case y′.
12. Diagram (j): Drop i′. As i′ is not in use, the drop operation is available.
13. Diagram (k): Open a. The generated state a′ is set as the model for A. Though initially the same, a no longer plays a role in the batch.
14. Diagram (l): Modify account a by deleting the position Q. Q is no longer in use, and was never marked IN, hence is deleted, y′ behaves differently, as the add operation at Step 1 marked Y IN.
15. Diagram (m): Save a′, a becomes immutable.
16. Diagram (n): Dropping or marking A AUTO are equivalent, as there are no users of A.
17. Diagram (o): Drop Y.
Notice the last two steps are performed on the object, not the state. The IN/AUTO designation is per-object, not state; otherwise model replacement does not work.
Implementation-wise, the above operations can be expressed in terms of three elementary operations:
Adding operations compute a set of models to replace, different by flavor (see Proposition 9), and combine it with a object IN designation, open consists of creating a copy state, a model replacement, and setting one pin flag. The sole effect of IN, AUTO, drop, pin and unpin is changing one flag. Finally, save changes the pins of states it freezes.
The implementation of the elementary operations (without the pin flag) is discussed in Section 8.2, in terms of monoid actions. For the reader not familiar with modern algebra, the practical consequence is that operations can be consolidated, allowing bulk processing of batch updates.
7.3 Requirements on Data
Requirements can be divided into data manipulation needed by the batch mechanics, and the more conceptual requirement that user/relationship graph does not have cycles.
7.3.1 Data Manipulation
As it can be seen from the above steps, for the approach to work the data must provide the following:
If a database is used, it is preferable that these operations are implemented as stored procedures. This allows the batch functionality to reside in the database server, and therefore be available in any programming language.
As the algorithms are a bit complex, implementing them in SQL is not easy. However, most database management systems allow high level language code to reside on the server, e.g. MySQL's C++ user-defined functions, and Oracle's Java stored procedures.
7.3.2 Representing Data with Acyclic Relationships
Besides using the algorithms in Section 9, there are a number of benefits to working with acyclic graphs:
Nonetheless, data modeling concepts include bidirectional relationships, and they suit many applications. There is no contradiction; our view is that if keeping versions is important, resolving cycles is useful. In many cases it can be done.
Consider the example a transfer t from account x to account y. Each account needs to know the transactions booked for it, and its balance cannot be validated without knowing all relevant transactions. On the other hand t cannot be specified (and validated) without knowing its “from” and “to” accounts, and the user interface might require navigating from t to x and y. It appears bi-directional relationships are needed.
Applying 2) above to treat cycles as one state does not work. Given interconnections between accounts and transactions, the result is one state comprising all accounts and all transactions. The solution lies in better understanding the data, and finding an acyclic representation.
The first observation is that a transfer does not need to know everything about an account, such as other payments, as the routing information suffices. Two states iy, iy, representing the routing information, can be assigned as resources to x and y. t can use ix,iy, and in turn be used by x,y, eliminating cycles.
The requirement to navigate from t to x and y is more difficult, since making x a resource of ix would create cycles. The problem has a conceptual component. Suppose there exists another version x′ in the X object of x, which also sees t as a transaction. Should the screen for t link to x or x′?
The solution combines a few observations:
This analysis is relevant to other cases. A very similar one is IMDb, with apparent bidirectional relationship between actors and movies. A more complex one is how cash-flows and new trades are consolidated with existing positions in a trading book. While a discussion is beyond the scope here, it is worth mentioning the above ideas work.
7.4 Batch Representation
Computing a batch from models and IN objects requires two tasks:
While a direct computation is easy, (Propositions 4 and 8), in practice it is important to be able to update a batch after small changes efficiently, otherwise the approach is not practical. Section 9 provides algorithms for the acyclic case.
It turns out both tasks can be represented by numerical counts. For an object X, define μ(X) by counting +1 if X is marked IN, and +1 for every user Y of X (according to Y's model). Clearly X appears in the batch if and only if μ(X)>0.
Similarly, a state x does not require an auto-clone if it is a model, and all its resources, direct or indirect, are also models. Define the ρ(x) by counting +1 if x is a model, and +1 for every resource that is known NOT to require an auto-clone. An auto-clone is needed when ρ(x)<1+n(x), where n(x) is the number of resources of x. If a mutable state needs an auto-clone, the state itself is modified.
Using μ and ρ, a batch is stored as a set of entries, one for each object represented in the batch, each entry consisting of:
μ and ρ can be easily computed by hand on small cases;
A reader looking to understand the update algorithm could apply it to some of the more interesting steps, e.g. 7, 8 and 14.
8. Hierarchical Repositories
Some implementations that can support the functionality described in Section 7 are described.
8.1 Repositories and Batches
Fix two sets Ω and D.
Definition 1
For a triple (S, π; S→Ω, ν; D⊆S×→S), define D(x)=(d∈{(x,d)∈D}, νxν(x, . . . ), and R(x)={y∈S|∃(x=x0, . . . , xD=y), xi∈lm(νx
The elements of Ω will be called objects, and those of S states. Every state belongs to the unique object π(x), denoted I IM(ν
Batches represent sets of objects with compatible dependencies. We are interested in constructing a batch from a set of states A⊆S with π|A is 1-1. For A not realistic, there is no batch A⊆B⊆S, but batches can be constructed in extensions S<S′.
In practice this amounts to reconciling object resources by editing. States, as mathematical constructs, are immutable, and the edit of a state is simply another state; whether a state in S′-S shares a physical memory location with one in S is not a concern here.
Proposition 2
Let ƒi:Si→S, i∈I such that:
Proof:
This is a straightforward verification that π,ν are well defined. □
Definition 3
Let m: M⊆Ω→S:
Proposition 4
Let G⊆Ω and m a G-complete model set. Then RN[G]⊆N is independent of N. We denote the common value Rm[G], and mG=m|R
Rm(G) can be computed using a simple queuing algorithm. Starting with Q=G, objects Ω∈Q are marked as processed in order, and π(Im(νm(ω)))−Q is appended to Q. When the entire Q has been processed Rm(G)=Q.
Definition 5
Let S1,S2 be two repositories. x1∈S1, x2∈S2 will be called equivalent if π1(x1)=π2(x2), D(x1)=D(x2) and π1∘νx
Definition 6
A resolution of a batch model is an extension of the form S≤S∪B, such that:
S≤S11 M is a resolution, though not particularly useful. As extensions correspond to editing, we need to minimize B-S (see Proposition 7).
Condition 4) restricts the use of elements of S to models. While dropping it could result in smaller extensions, non-natural choices are required.
Take Ω={a,b,x}, ={1}, S={a,b,x1,x2,x3}, and π the obvious choice. Let D(a)=D(b)=, νa(1)=x1, νb(1)=x2, and D(x1)=D(x2)=D(x3)=Ø. Define M=Ω and m(a)=a,m(b)=b,m(x)=x3. As R[{a,b}] is not realistic, a resolution requires at least one new state. Two possibilities are a′ with νa′(1)=x2, and b′ with νb′(1)=x1, with no natural choice.
With condition 4), x1 and x2 are excluded. The minimal resolution will use both a′ and b′, with νa′(1)=νb′(1)=x3. This is more intuitive in practice, as the user is aware of the models to be combined, but perhaps not of all states ever created that happen to match.
Proposition 7
For every batch model m, there exist a unique (up to an isomorphism) resolution B(m) such that B(m)∩S={x∈S|R(x)⊆Im(m)}. For any other resolution B, B∩S⊆B(m)∩S, and thus |B(m)−S| is minimal.
Proof:
Start with (M, 1M, νm), and let N={x∈S|R(x)⊆Im(m)}. Glue M and S by identifying x with π(x) over N. Let S′=S11
For x∈N and y∈R(x), it can be seen that R(y)⊆R(x)⊆Im(m), therefore y∈N and N≤S. By the definition of νm,
as x∈R(x)x∈Im(m)x=m(
To show the above construction minimizes |B−S|, let B be a resolution. For x∈B∩S, as B is a batch, R(x)⊆B∩S, y∈R(x)y∈B∩Sy∈Im(m) by Condition 4) of the resolution definition, hence R(x)⊆N and B∩S⊆N.
To show that any resolution B with B∩S=N is isomorphic to S11
Computing B(m)∩S can be done via the following directed graph algorithm:
Proposition 8
Let (X,E) be a directed graph, and A⊆X. Let R(x)={y∈X|∃x=x0, x1, . . . , xn=y1 (xi,xi+1)∈E, i≥0}, and L(x) the same construction for the reverted graph. Let M[A]={x∈X|R(x)⊆A}. Then:
Proof:
Clearly M[M[A]]⊆M[A]. As y∈R(x)R(y)⊆R(x), R(x)⊆AR(x)⊆M[A], hence M[A]⊆M[M[A]].
An element x∈M[Z] can never be deleted, as rx⊆A, and x∈L(y)y∈R(x) implies ry⊆R(x)⊆A. Thus M[A]⊆M. Conversely, if x∈A−M[A], take a minimal length sequence x=x0, x1, . . . , xn with (xi−1, xi)∈E, i>0, and xn∉A. Then xn−1∈A, rx
To compute B(m)∩S use X=DG[S] reversed, and A=Im(m).
8.2 Managing Models
Given the requirements batches satisfy, it is necessary to have a practical way to construct and modify batches. The approach here is to work with sets of desired objects that must appear in the batch, and a sufficient set of models. Based on the two, a resolution batch is constructed using Proposition 7. Operations are provided for changing the set of desired objects and the models, which can be used to implement a user interface.
Given two sets X and Y, denote MX,Y={ƒ: Dom(ƒ)⊆X→Y}. Define *: MX,Y×MX,Y→MX,Y by:
on Dom(ƒ*g)=Dom(ƒ)∪Dom(g).
As Ø⊆X×Y, Ø can be thought of as an element of MX,Y, and it satisfies Ø*ƒ=ƒ*Ø=ƒ. It is easy to see * is associative, and thus (MX,Y, *, Ø) is a non-abelian monoid with unit.
Denote by MS the set of model sets. As a subset of MΩ,S, it is closed under multiplication, and therefore inherits a monoid structure. Define =(Ω)×MS, and c⊆ the set of pairs (G,m) with m G-complete. Let Δ be the monoid MΩ,(L−1)×MS. The multiplication (G,m)*(δ,q)=(G−{δ=−1}∪{δ=1}, m*q) is an associative Δ-action on G.
c is not A-invariant. Model changes affect resources, and generators can be added without sufficient models. However, only c may be of interest. Define as set of elementary operations that can be executed via actions that preserve completeness.
Proposition 9
For (G,m)∈c, we define the following operators:
⊕1: For x∈S,define Dom(δ)={
⊕: For x∈S,letNm(x)={y∈S|∃x=y0,y1, . . . ,yn=y,
⊖: For ω∈Ω,define Dom(δ)={ω},δ(ω)=−1,q=Ø,(G,m)⊖ω=(G,m)*(δ,q).
Then (G,m)⊕1 x,(G,m)⊕x,(G,m)⊖ω∈c.
Proof:
⊕1 The replaced model comes with a full set of resources. If a chain uses new resources, it has been changed and hence R(x) provides them.
⊕ No old model is replaced, so the only potential problem is
⊖ Obvious as G decreases.
The Δ action never decreases M. An implementation can reduce M to Rm[G] each operation, discarding redundant models immediately. This also simplifies computations (see Proposition 16 2 and Step 5 at the end of Section 9.2).
For
The elementary operations can be used to provide the functionality a user might expect:
9. An Incremental Algorithm for Computing Minimal Resolutions
To compute B(m), Rm(G) and S∩B(m) must be computed. While section 8.1 provides a direct algorithm, they may be computationally expensive. In Section 9.2, both problems can be rephrased in terms of numerical equations. In the acyclic case, the equations have unique solutions, computable by an incremental algorithm.
Section 9.1 below describes an algorithm applicable to a certain class of equations, used in Section 9.2 to recast computing B(m) in numerical terms. It can then be shown that B(m) can be updated after a Δ-action, by applying the methods of Section 9.1 to two related equations.
9.1 Signals Over a Acyclic Network
Let X be a finite set and ∈: X×→. For every r: X×X→, define an operator Kr: X→X by (Krƒ)(x)=Σy∈X r(x,y)∈(y, ƒ(y)). Clearly Kαr+βs=αKr+βKs, though Kr itself is not linear if ∈ is not.
Proposition 10
With the notations above, if the graph (X, supp(r)) is acyclic, the equation (I−Kr)ƒ=α, α: X→ has a unique solution. r will be called acyclic, and we denote (I−Kr)−1=Tr.
Proof:
For x∈X, define |x|r to be the maximum length of a chain x=x0, x1, . . . , xn such that r(xi, xi+1)≠0, 0≤i<n. This is well defined, as for r acyclic there are no infinite chains. The equation can be rewritten ƒ=α+Krƒ, which constitutes a recursive formula describing ƒ(x) in terms of ƒ(y) with |y|r<|x|r. Existence and uniqueness follow by induction on |.|r. □
This section provides a way to update Trƒ with small changes in r and ƒ once Trƒ has already been computed. This is purely an efficiency exercise, as the result can always be computed with a full iteration.
Let ƒ, δ: X→ (think of δ as changes that need to be propagated onto a), and x∈X. Define ƒx=ƒ+χ(x)δ and:
Denote (ƒx, δx) by (ƒ, δ)*x. For a sequence s=(x1, x2, . . . ) in X denote (ƒ, δ)s,n=(ƒ, δ)*x1*x2* . . . *xn.
Proposition 11
The following hold:
Proof:
Applying Tr to the equation in (3) with ƒ=Tra we get Tra←r δ=Tr(δ+(I−Kr)ƒ)=Tr(δ+a) which is the desired computation. Also, (ƒ←, δ)←, δ′=T((I−Kr)ƒ+δ+δ′)=∫←s (δ+δ′), allowing to consolidate changes for one application of the algorithm. Additionally, as applications of x's to (ƒ,δ) commute, a simple queuing algorithm works.
Implementations may also would want to know how to change r:
Proposition 12
Let r and s be acyclic. Then:
Tsa=Tra←sKs−rTra. 1.
Tsb=Tra←x(b−a+Ks−rTra). 2.
With the rA(x,y)=χA(x)r(x,y),A⊆X, we have Tr
Proof:
These are straight-forward verifications.
One has to be careful with cycles. The sequence (ƒ, δ)*x1*x2* . . . makes sense even when r is cyclic, as equation (2) is always defined. It is possible however that it does not stabilize. This could occur in the context of Proposition 12, if r is acyclic, but s is not.
An example is X={w,x,y,z}, ∈=sgn, r(y,x)=r(x,w)=1 and 0 otherwise, s(y,x)=s(z,y)=s(x,z)=1 and 0 otherwise, and a(w)=1, a(x)=a(y)=a(z)=0. Tra=(1,1,1,0) and Ks−rTra=(0,−1,0,1); both are solutions to the equation (I−Ks)ƒ=a.
The algorithm can be adapted so that it terminates with an error in such a case, by keeping track of information about changed vertices. When computing a sequence (ƒ,δ)*x1*x2* . . . , associate a set C(x) to every x∈X, initially Ø. Whenever Equation 2 is used with y≠x, replace C(y) with C(y)∪C(x)∪{x} and check whether y∈C(y). If so, the algorithm exits, and r is known to be cyclic.
The algorithm may finish normally, even with cycles present, thus is not a substitute for checking for cycles. In practical cases where cycles are unlikely, having an option to turn checks off helps avoiding unnecessary computations.
9.2 The μGm and ρm equations
Turning to computing Rm[G] and B(m), and one can derive numerical characterizations for Rm(G) and B(m), valid whether the graphs are acyclic or not. Using the methods of Section 9.1, one can show Equations (3) and (5) have unique solutions when both DG[ν] and DG[νm] are acyclic. Finally, an algorithm for recomputing B for the result of a Δ-action (G′, m′)=(G,m)*(δ,q) (Section 2.2), from Rm[G] and B(mG), is disclosed
Proposition 13
Let m be a G-complete model set, and define μGm: Ω→, μGm(ω)=χG(ω)+Σω′∈R
Proof:
ωϵRm[G] if and only if either ωϵG, or ωϵIm(νω′m
Proposition 14
Let m be a batch model, and define ρm(S→ by ρm(x)=χIm(m)(x)(1+ΣyϵS|ν|(y,x)χB(m)∩S(y)). Then xϵB(m)∩Sρm(x)=1+|D(x)| and
Proof:
Since Σy∈S|ν|(y,x)χB(m)∩s(y)=|{d∈D(x)|νx(d)∈B(m)∩S}|, ρm(x)≤1+|D(x)|. If the equality holds, x∈Im(m) and Im(νx)⊆B(m)∩S, hence R(x)⊆B(m)∩S⊆Im(m) and x∈B(m)∩S, by Proposition 7. Conversely, since B(m)∩S is a batch, x∈B(m)∩SR(x)⊆B(m)∩S. For y∈Im(νx)⊆R(x)⊆B(m)∩S we have χB(m)∩S(y)=1, and thus ρm(x)=1+|D(x)|.
Now γ(x, ρm(y))=1y∈B(m)∩SχB(m)∩S(y)=1 gives (5). □
For the acyclic case, Let (G′, m′)=(G,m)*(δ,q), and denote M_=M∩Dom(q), the objects whose models will be replaced.
Proposition 15
If DG[νm] acyclic, then:
Then μ′ is the result of propagating δμ onto μ, using |νm′| for edge weights and ∈: Ω×→,∈(ω,k)=sgn(k).
Proof:
With the notations of Section 9.1 and X=Ω,∈=sgn,r=|νm| Equation (3) becomes μ=χG+Krμ. DG[νm] is the same as the graph of Proposition 10. As DGrvms is acyclic, the solution to Equation (3) is unique, and μ=TrχG.
Proposition 12 2) with a=χG, s=|νm′|, b=χG′ gives δμ=δ+(Ks−Kr)μ. The conclusion follows by computing (Ks−Kr)μ=Ks−rμ (by linearlity of K).
where δ—,—is the Kronecker delta, and ω, θ∈Ω. This gives:
In practice, Equation (6) needs to be computed only ω a vm-resource of objects in Dompqq, as it 0 otherwise.
Turning to ρ:
Proposition 16
With DG[ν] and DG[νm] acyclic, let X=S, A={m(ω)|ω∈M, μ(ω)>0}⊆S, r(x,y)=|ν|(y,x), ∀x, y∈S and ∈=γ(Equation (4)):
Then ρ′ is the result of propagating δρ onto using X=S, and rA′ for edge weights.
Then x needs a new equivalent state constructed if and only if σρ(x)=1, and has an obsolete equivalent state if and only in σρ(x)=−1. σρ is called the ρ-signal of (δ,q).
Propositions 15 and 16 can be combined into the following steps to update B(mg) for the action of (δ,q).
Propositions 15 and 16 can be combined into the following steps to update B(mg) for the action of (δ,q).
1. Compute the μ-signal σμ=μ′−μ.
2. Compute the ρ-signal σρ:
3. For each x with ρ-signal +1, a new state must be created in B(M′B′)−S, while for ρ-signal −1, the unique y∈B(mG)−S, y≃x should be discarded.
4. Make appropriate equivalence-preserving changes to states otuside S, so that all resources are in B(m′G′).
5. Discard redundant models, i.e. ω∈M′ with μ′(ω)=0. This ensures the m=mG requirement of Proposition 16 2) is satisfied for the next iteration.
The steps can be done manually on the example of
At 402, information is stored as a plurality of objects. Each object can have a plurality of states. For example, the object may be, e.g., a software code, a stock value, a sports event score, a candidate's vote tally in an election, etc.
At 404, one or more temporal histories for each object is maintained based on the plurality of states of the object at a plurality of time instances. In some implementations, the time instances at which the state of the object is tracked may be periodic (e.g., once every second or once every day). In some implementations, the time instances may be triggered based on the relative periodicity with which changes occur to the state. For example, a user or an external system may provide a rule for tracking changes to the object.
In some implementations, state changes to the object may be based on at least one a priory function for changing the state of the object. In some cases, the state may not be changeable using the a priori function. In this case, a new temporal history may be started for the object. For example, to track the price of a stock, a function may specify daily closing price of the stock to be tracked as a state of the stock price object. However, the stock may split, or may be changed from a preferred stock to another type of stock. This change may be captured by starting a new temporal history for the stock. As another non-limiting example, in a software code development effort, normal changes to code files may be tracked as changes to a given temporal history, based on the a priori function that specifies normal code changes. However, occasionally, changes may be tracked as a different temporal history (e.g., when the code author changes, or when the source file starts or stops supporting certain operating system feature etc.).
At 406, at least one state of an object is selectively changed in response to the request. Some states may be in a frozen state, e.g., are not permitted to be changed by requests. For example, a request attempting to change the 1950 World Series champion may be rejected. However, Sections 1 to 6 disclose a trimming method by which frozen states can be changed. One useful example would be to fix a mistake to the 1950 World Series champion in a database.
It will be appreciated that techniques are provided for managing changes to information. The disclosed techniques maintain one or more temporal histories for data objects. States of data objects may be interdependent upon each other.
It will further be appreciated that the interdependencies in the states of data objects are represented as relationships between “resource” states and “user” state. An acyclic relationship is enforced between user states and resource states to facilitate maintaining temporal histories of data objects.
The disclosed and other embodiments, modules and the functional operations described in this document can be implemented in digital electronic circuitry, or in computer software, firmware, or hardware, including the structures disclosed in this document and their structural equivalents, or in combinations of one or more of them. The disclosed and other embodiments can be implemented as one or more computer program products, i.e., one or more modules of computer program instructions encoded on a computer readable medium for execution by, or to control the operation of, data processing apparatus. The computer readable medium can be a machine-readable storage device, a machine-readable storage substrate, a memory device, a composition of matter effecting a machine-readable propagated signal, or a combination of one or more them. The term “data processing apparatus” encompasses all apparatus, devices, and machines for processing data, including by way of example a programmable processor, a computer, or multiple processors or computers. The apparatus can include, in addition to hardware, code that creates an execution environment for the computer program in question, e.g., code that constitutes processor firmware, a protocol stack, a database management system, an operating system, or a combination of one or more of them. A propagated signal is an artificially generated signal, e.g., a machine-generated electrical, optical, or electromagnetic signal, that is generated to encode information for transmission to suitable receiver apparatus.
A computer program (also known as a program, software, software application, script, or code) can be written in any form of programming language, including compiled or interpreted languages, and it can be deployed in any form, including as a stand alone program or as a module, component, subroutine, or other unit suitable for use in a computing environment. A computer program does not necessarily correspond to a file in a file system. A program can be stored in a portion of a file that holds other programs or data (e.g., one or more scripts stored in a markup language document), in a single file dedicated to the program in question, or in multiple coordinated files (e.g., files that store one or more modules, sub programs, or portions of code). A computer program can be deployed to be executed on one computer or on multiple computers that are located at one site or distributed across multiple sites and interconnected by a communication network.
The processes and logic flows described in this document can be performed by one or more programmable processors executing one or more computer programs to perform functions by operating on input data and generating output. The processes and logic flows can also be performed by, and apparatus can also be implemented as, special purpose logic circuitry, e.g., an FPGA (field programmable gate array) or an ASIC (application specific integrated circuit).
Processors suitable for the execution of a computer program include, by way of example, both general and special purpose microprocessors, and any one or more processors of any kind of digital computer. Generally, a processor will receive instructions and data from a read only memory or a random access memory or both. The essential elements of a computer are a processor for performing instructions and one or more memory devices for storing instructions and data. Generally, a computer will also include, or be operatively coupled to receive data from or transfer data to, or both, one or more mass storage devices for storing data, e.g., magnetic, magneto optical disks, or optical disks. However, a computer need not have such devices. Computer readable media suitable for storing computer program instructions and data include all forms of non-volatile memory, media and memory devices, including by way of example semiconductor memory devices, e.g., EPROM, EEPROM, and flash memory devices; magnetic disks, e.g., internal hard disks or removable disks; magneto optical disks; and CD ROM and DVD-ROM disks. The processor and the memory can be supplemented by, or incorporated in, special purpose logic circuitry.
While this patent document contains many specifics, these should not be construed as limitations on the scope of an invention that is claimed or of what may be claimed, but rather as descriptions of features specific to particular embodiments. Certain features that are described in this document in the context of separate embodiments can also be implemented in combination in a single embodiment. Conversely, various features that are described in the context of a single embodiment can also be implemented in multiple embodiments separately or in any suitable sub-combination. Moreover, although features may be described above as acting in certain combinations and even initially claimed as such, one or more features from a claimed combination can in some cases be excised from the combination, and the claimed combination may be directed to a sub-combination or a variation of a sub-combination. Similarly, while operations are depicted in the drawings in a particular order, this should not be understood as requiring that such operations be performed in the particular order shown or in sequential order, or that all illustrated operations be performed, to achieve desirable results.
Only a few examples and implementations are disclosed. Variations, modifications, and enhancements to the described examples and implementations and other implementations can be made based on what is disclosed.
This patent document is a 35 U.S.C. § 371 National Stage application of PCT Application No. PCT/US2014/017500 entitled “MANAGING CHANGES TO INFORMATION,” filed on Feb. 20, 2014, which further claims the benefits and priorities of U.S. Provisional Patent Application No. 61/767,202 entitled “MANAGING CHANGES TO INFORMATION” and U.S. Provisional Patent Application No. 61/767,215 entitled “MANAGING ATEMPORAL HIERARCHICAL DATA,” both filed on Feb. 20, 2013. The entire content of the aforementioned patent applications are incorporated by reference as part of the disclosure of this application.
Filing Document | Filing Date | Country | Kind |
---|---|---|---|
PCT/US2014/017500 | 2/20/2014 | WO | 00 |
Publishing Document | Publishing Date | Country | Kind |
---|---|---|---|
WO2014/130733 | 8/28/2014 | WO | A |
Number | Name | Date | Kind |
---|---|---|---|
7774191 | Berkowitz | Aug 2010 | B2 |
8712944 | Kim | Apr 2014 | B1 |
20030093435 | Bandekar | May 2003 | A1 |
20050144198 | Bergstraesser | Jun 2005 | A1 |
20050216248 | Ciolfi | Sep 2005 | A1 |
20060031235 | Foresti | Feb 2006 | A1 |
20060149582 | Hawkins | Jul 2006 | A1 |
20070018953 | Kipersztok | Jan 2007 | A1 |
20080059773 | Fant | Mar 2008 | A1 |
20080208372 | Pannese | Aug 2008 | A1 |
20090234899 | Kramer | Sep 2009 | A1 |
20100280809 | Takahashi | Nov 2010 | A1 |
20110320228 | Kowalski | Dec 2011 | A1 |
20120005534 | Li | Jan 2012 | A1 |
20120023078 | Malatesta | Jan 2012 | A1 |
20130325787 | Gerken | Dec 2013 | A1 |
20140359584 | Chu | Dec 2014 | A1 |
20160148103 | Sarrafzadeh | May 2016 | A1 |
Entry |
---|
Young, Lee W., Authorized Officer, ISA/US, International Search Report and Written Opinion, International Application No. PCT/US2014/017500, dated Jul. 14, 2014, 7 pages. |
Number | Date | Country | |
---|---|---|---|
20150379061 A1 | Dec 2015 | US |
Number | Date | Country | |
---|---|---|---|
61767215 | Feb 2013 | US | |
61767202 | Feb 2013 | US |