Legal claims defining the scope of protection, as filed with the USPTO.
1. A database comprising: a plurality of data stores configured to store time-series data; and a plurality of processing nodes comprising respective memories, memory maps, and computer processors, wherein respective processing nodes of the plurality of processing nodes correspond to respective data stores of the plurality of data stores, wherein the respective memory maps identify segments of the respective memories that store portions of time-series data, wherein the database is configured to: determine a processing node, of the plurality of processing nodes, for executing an operation; access, by the determined processing node and by reference to the memory map of the determined processing node, a portion of first time-series data and a portion of second time-series data from the memory of the determined processing node; and execute, by the determined processing node, the operation using at least the portion of the first time-series data and the portion of the second time-series data to generate an output, wherein the memory map of the determined processing node identifies segments of the memory of the determined processing node that store portions of time-series data, and wherein the stored portions of time-series data are obtained by mapping from a data store of the plurality of data stores that corresponds to the determined processing node.
2. The database of claim 1, wherein the database is further configured to retrieve data values from the first time-series data that are associated with timestamp values that fall within a start time and an end time provided by a user, and data values from the second time-series data that are associated with timestamp values that fall within the start time and the end time.
3. The database of claim 1, wherein a first data value from the portion of the first time-series data comprises a plurality of data values that are each associated with a different timestamp value, and wherein a second data value from the portion of the second time-series data comprises a plurality of data values that are each associated with a different timestamp value.
4. The database of claim 1, wherein the database is further configured to: receive, from a data source, third time-series data and fourth time-series data, wherein the third time-series data and the fourth time-series data correspond with a first sensor and comprise overlapping time values; and compact the third time-series data and the fourth time-series data to generate the second time-series data.
5. The database of claim 4, wherein the database is further configured to: determine, for each overlapping time value, whether a third data value corresponding to the third time-series data or a fourth data value corresponding to the fourth time-series data is stored in a later-modified file; and insert the data value stored in the later-modified file into the second time-series data in association with the respective overlapping time value.
6. The database of claim 1, wherein the database is further configured to: receive, from a user device, a start time and an end time, wherein the start time and the end time correspond to a window of data viewed by a user via an interactive user interface.
7. The database of claim 6, wherein a period between the start time and the end time identifies a period of time that corresponds with a width of a pixel in the interactive user interface.
8. The database of claim 7, wherein the database is further configured to: determine whether the period is greater than a period of time between each timestamp value in the first time-series data; aggregate data values such that a period of time between an earliest timestamp value corresponding to a data value in the aggregate and a latest timestamp value corresponding to a data value in the aggregate equals the period in response to a determination that the period is greater than the period of time between each timestamp value in the first time-series data; and for the period, identify a first aggregated data value from the portion of the first time-series data and a third data value from the portion of the second time-series data that are both associated with a same timestamp value, and apply the operation to the first aggregated data value and the third data value to generate the value.
9. The database of claim 1, wherein the operation comprises a first operation associated with the first time-series data and the second time-series data and a second operation associated with a result of the first operation and the first time-series data.
10. The database of claim 1, wherein the operation comprises at least one of: a sum, a difference, a product, a ratio, a moving average, a zScore, or a square root.
11. The database of claim 1, wherein the first time-series data is stored in the database and is immutable.
12. A method comprising: determining, by a database configured with specific computer-executable instructions, a processing node, of a plurality of processing nodes, for executing an operation, wherein the database comprises: a plurality of data stores configured to store time-series data; and the plurality of processing nodes comprising respective memories and memory maps, wherein respective processing nodes of the plurality of processing nodes correspond to respective data stores of the plurality of data stores, wherein the respective memory maps identify segments of the respective memories that store portions of time-series data; accessing, by the determined processing node and by reference to the memory map of the determined processing node, a portion of first time-series data and a portion of second time-series data from the memory of the determined processing node; and executing, by the determined processing node, the operation using at least the portion of the first time-series data and the portion of the second time-series data, wherein the memory map of the determined processing node identifies segments of the memory of the determined processing node that store portions of time-series data, wherein the stored portions of time-series data are obtained by mapping from a data store of the plurality of data stores that corresponds to the determined processing node, and wherein the method is performed by the database.
13. The method of claim 12, further comprising retrieving data values from the first time-series data that are associated with timestamp values that fall within a start time and an end time provided by a user, and data values from the second time-series data that are associated with timestamp values that fall within the start time and the end time.
14. The method of claim 12, wherein a first data value from the portion of the first time-series data comprises a plurality of data values that are each associated with a different timestamp value, and wherein a second data value from the portion of the second time-series data comprises a plurality of data values that are each associated with a different timestamp value.
15. The method of claim 12, further comprising: receiving, from a data source, third time-series data and fourth time-series data, wherein the third time-series data and the fourth time-series data correspond with a first sensor and comprise overlapping time values; and compacting the third time-series data and the fourth time-series data to generate the second time-series data.
16. The method of claim 15, further comprising: determining, for each overlapping time value, whether a third data value corresponding to the third time-series data or a fourth data value corresponding to the fourth time-series data is stored in a later-modified file; and inserting the data value stored in the later-modified file into the second time-series data in association with the respective overlapping time value.
17. The method of claim 12, further comprising: receiving, from a user device, a start time and an end time, wherein the start time and the end time correspond to a window of data viewed by a user via an interactive user interface.
18. The method of claim 17, wherein a period between the start time and the end time identifies a period of time that corresponds with a width of a pixel in the interactive user interface.
19. The method of claim 18, further comprising: determining whether first period is greater than a period of time between each timestamp value in the first time-series data; aggregating data values such that a period of time between an earliest timestamp value corresponding to a data value in the aggregate and a latest timestamp value corresponding to a data value in the aggregate equals the first period in response to a determination that the period is greater than the period of time between each timestamp value in the first time-series data; and for the period, identifying a first aggregated data value from the portion of the first time-series data and a third data value from the portion of the second time-series data that are both associated with a same timestamp value, and applying the operation to the first aggregated data value and the third data value to generate the value.
20. One or more non-transitory computer-readable storage media comprising computer-executable instructions, wherein the computer-executable instructions, when executed by a database comprising: a plurality of data stores configured to store time-series data; and a plurality of processing nodes comprising respective memories, memory maps, and computer processors, wherein respective processing nodes of the plurality of processing nodes correspond to respective data stores of the plurality of data stores, wherein the respective memory maps identify segments of the respective memories that store portions of time-series data, cause the database to: determine a processing node, of the a plurality of processing nodes, for executing an operation; access, by the determined processing node and by reference to the memory map of the determined processing node, a portion of first time-series data and a portion of second time-series data from the memory of the determined processing node; and execute, by the determined processing node, the operation using at least the portion of the first time-series data and the portion of the second time-series data to generate an output, wherein the memory map of the determined processing node identifies segments of the memory of the determined processing node that store portions of time-series data, and wherein the stored portions of time-series data are obtained by mapping from a data store of the plurality of data stores that corresponds to the determined processing node.
Unknown
January 28, 2025
Browse 5M+ US patents with plain-English claim translations and AI-generated analysis.