The present invention pertains to a computer-implemented method for storing data in accumulators or accumulator structures.
Further aspects relate to a computing system and a computer program product.
Computing systems, in particular distributed computing systems such as in distributed networks, provide computing services, in particular distributed computing services. In such computing systems it is often a challenge to provide efficient mechanisms for providing access to computational results of the computing system/the computing services, and in particular to provide such access in an authenticable manner.
In this respect accumulators are known as a means to store data in a way that allows to access it in an authenticable manner. In general, accumulators are entities, units, logics or algorithms which combine a set of accumulator elements into a digest. One prominent and widely used example of an accumulator are hash trees.
Accumulators may be used in particular to certify the membership of an accumulator value in the accumulator. This can be done by computing a witness for a corresponding accumulator value.
Accordingly, one object of an aspect of the invention is to provide an advantageous method for storing data, in particular heterogeneous data, in a way that allows an efficient access to the data, in particular in a way that facilitates an efficient authentication and/or signing of the data.
According to an embodiment of an aspect of the invention there is provided a computer-implemented method for storing data, in particular heterogeneous data. The method comprises storing the data in a hierarchical accumulator structure. The hierarchical accumulator structure comprises at least a first level and a second level. The first level comprises a first level accumulator and the second level comprises a plurality of second level accumulators. The first level accumulator encompasses a plurality of first level elements and a first level digest of the plurality of first level elements. Each of the plurality of second level accumulators encompasses a plurality of second level elements and a second level digest of the plurality of second level elements and each of the second level digests of the plurality of second level accumulators corresponds to one of the plurality of first level elements. At least a subset of the plurality of first level elements comprises or is associated with metadata. The metadata comprises accumulator information for the corresponding second level accumulator. The step of storing the data comprises computing the plurality of second level accumulators in dependence on the respective accumulator information of the metadata of the first level elements.
Such a hierarchical accumulator structure allows a flexible and efficient storage of the data. This is in particular useful for heterogeneous data, i.e. data which have different characteristics and/or access patterns. The accumulator information of the metadata may be used to specify any desired or useful property for the computation of the corresponding second level accumulator. The accumulator information of the metadata is then taken into account for the computation of the corresponding accumulator. This allows to adapt each computation of the accumulators to the specifics of the data that is stored in the respective accumulator. As a result, each of the plurality of second level accumulators may be individually adapted and computed in dependence on the metadata.
The digest each of the second level accumulators has a corresponding first level element. Accordingly, the respective first level elements correspond and hence form an interface between the first level accumulator and the respective second level accumulator. This structure allows in particular that each of the second level accumulators can be changed and updated independently from the other second level accumulators. According to an embodiment, storing the data comprises computing different accumulator types of the second level accumulators in dependence on the respective accumulator information of the metadata of the first level elements.
Hence according to embodiments, the hierarchical accumulator structure may comprise a heterogeneous set of different types of second level accumulators. Each accumulator type may be chosen and computed in dependence on the metadata/the accumulator information of the metadata and may hence be optimized for the respective characteristics of the data that is stored in the respective second level accumulator.
According to embodiments, the hierarchical accumulator structure may further comprise a third level comprising a plurality of third level accumulators. Each of the plurality of third level accumulators may encompass a plurality of third level elements and a third level digest of the plurality of third level elements. Each of the third level digests of the plurality of third level accumulators corresponds to one of the plurality of second level elements. Furthermore, at least a subset of the plurality of second level elements comprises metadata and the metadata comprises accumulator information for the corresponding third level accumulator.
Providing additional levels increases the flexibility of the accumulator structure and allows to increase the overall number of individual accumulators which are stored in the accumulator structure. According to embodiments a fourth, fifth, and further levels may be added to the accumulator structure.
According to embodiments, the accumulator information of the metadata comprises information of the data type of the corresponding second level and/or third level accumulators.
According to such an embodiment, the method may take into account the data type to compute the corresponding second or third level accumulator. The data type may specify e.g. that the data of the corresponding accumulator stores data in a queue structure or that the data is a mapping, e.g. a key mapping.
According to another embodiment, the accumulator information defines an accumulator type for the corresponding second level and/or third level accumulators.
According to such an embodiment, it is specified in advance which kind of accumulator type shall be computed for the respective accumulator. Possible accumulator types include e.g. that the accumulator shall be computed as a hash tree which represents the data as a balanced tree, a red-black tree, a Patricia trie or a hash chain. Each of such trees may be suitable and chosen for a particular type of data. As an example, a Patricia trie may be in particular suitable for the storage of mappings, e.g. key mappings. On the other hand, a hash chain may be in particular suitable for the storage of queues.
According to another embodiment, the accumulator information comprises information of write and/or read access patterns the of corresponding accumulator.
This information can then be used to compute the corresponding accumulator in such a way that future write and/or read accesses are improved. As an example, accumulator elements which are accessed very often may be stored e.g. close to the digest of the accumulator.
According to embodiments, the method comprises selecting the respective accumulator type such that one or more predefined operations on the data of the corresponding accumulator can be performed in an optimized way.
Such operations may include e.g. write accesses such as inserts, updates, and deletes of data as well as read accesses.
According to an embodiment, the method comprises computing the first level accumulator and/or one or more of the plurality of second level accumulators and/or one or more of the plurality of third level accumulators as cryptographic accumulators, in particular as hash trees.
This facilitates in particular an efficient authentication and/or signing of the accumulator elements. According to embodiments, storing the data comprises regularly analysing write accesses and/or read accesses to the hierarchical accumulator structure. The method may further comprise adapting the metadata of the plurality of first level elements and/or one or more of the plurality of second level elements and/or one or more of the plurality of third level elements in dependence on the analysis of the write accesses and/or the read accesses
Such an embodiment allows to adapt the computation of the respective accumulator dynamically to changing access patterns of the data. This may then in return dynamically improve an efficient authentication and/or signing of the corresponding accumulator elements.
According to another embodiment, the method comprises regularly computing a sequence of payloads, regularly storing computational results of the sequence of payloads in the hierarchical accumulator structure and regularly analysing the computational results. According to such an embodiment the method may include regularly adapting the metadata of the plurality of first level elements and/or the plurality of second level elements and/or the plurality of third level elements in dependence on the analysis of the computational results.
Hence according to such an embodiment the computational results are analysed and used to adapt the metadata.
According to an embodiment, the method comprises receiving a request for a computational result, computing a witness for the computational result and providing the witness, the computational result and the digest of the first level accumulator as response to the request.
Such a witness benefits in particular from the fact that the hierarchical accumulator structure allows to flexibly adapt and optimize the respective accumulator in view of an efficient provisioning of witnesses.
According to embodiments the accumulators may be computed in particular to improve/reduce the witness size. More particularly, the plurality of second level accumulators and/or the plurality of third level accumulators may be computed in such a way that an average witness size of witnesses for the accumulator elements of the second level accumulators and/or the plurality of third level accumulators is minimized. This can be achieved according to embodiments by placing accumulator elements which are frequently/often accessed on a higher level of the accumulator, i.e. closer to the digest, than accumulator elements which are less frequently updated.
According to an embodiment of another aspect of the invention, a computing system, e.g. a distributed network, is provided which is configured to perform the method aspects of the invention.
According to an embodiment of another aspect of the invention, a computer program product for operating a computing system is provided. The computer program product comprises a computer readable storage medium having program instructions embodied therewith, the program instructions executable by one or more of a plurality of nodes of the distributed network to cause the one or more of the plurality of nodes to perform steps of the method aspect of the invention.
Features and advantages of one aspect of the invention may be applied to the other aspects of the invention as appropriate.
Other advantageous embodiments are listed in the dependent claims as well as in the description below.
The invention will be better understood and objects other than those set forth above will become apparent from the following detailed description thereof. Such description makes reference to the annexed drawings, wherein:
At first, some general aspects and terms of embodiments of the invention will be introduced.
According to embodiments, a distributed network comprises a plurality of nodes that are arranged in a distributed fashion. In such a distributed network computing, software and data is distributed across the plurality of nodes. The nodes establish computing resources and the distributed network may use in particular distributed computing techniques.
According to embodiments, distributed networks may be embodied as blockchain networks. The term “blockchain” shall include all forms of electronic, computer-based, distributed ledgers. According to some embodiments, the blockchain network may be embodied as proof-of-work blockchain network. According to other embodiments, the blockchain network may be embodied as proof-of-stake blockchain network.
Accumulator: Generally a digest accumulating a plurality of accumulator elements. More particularly any entity, unit, logic or algorithm which combines a set of accumulator elements, in particular a large set of accumulator elements, into a digest or in other words an accumulator value, in particular a short digest/accumulator value, such that there is a witness, that a given accumulator element is indeed a valid element of the accumulator. At the same time it is intractable to come up with a witness for an element not in the accumulator. According to embodiments an accumulator may be a hash of all the accumulator elements. A witness for an accumulator element X in such an embodiment would consist of all accumulator elements except X.
Cryptographic accumulator: A cryptographic accumulator may be defined as an accumulator which is configured to or allows to succinctly represent a set of accumulator elements as a compact digest or in other words as a compact accumulator value. For each accumulator element that is part of the accumulated set of accumulator elements one can obtain a compact witness to attest membership of the accumulator element relative to the compact accumulator value/digest, whereas it is intractable to obtain a valid witness for an element which is not part of the accumulated set of accumulator elements. According to embodiments cryptographic accumulators may have additional, in particular sophisticated features like the support for non-membership witnesses for elements which are not in the accumulated set, or creating a single compact witness that allows to verify membership of multiple elements relative to the accumulator.
According to embodiments cryptographic accumulators may be viewed as a realization of the concept of accumulators introduced above, which relies on cryptographic hardness assumptions to realize succinctness features of the accumulator value/digest and/or the witnesses.
Hash tree: A hash tree may also be denoted as Merkle-tree and was originally described by Ralph Merkle
in Merkle, R. C. (1988). “A Digital Signature Based on a Conventional Encryption Function”. Advances in Cryptology—CRYPTO '87. Lecture Notes in Computer Science. 293. pp. 369-378.
A hash tree may be generally described as a tree in which every leaf node is labelled with the cryptographic hash of data elements and every non-leaf node is labelled with the cryptographic hash of the labels of its child nodes. Hash trees may be considered as a generalization of hash lists and hash chains.
According to embodiments hash trees can be used to instantiate cryptographic accumulators, but may also provide additional features like assigning an implicit ordering to the accumulator elements.
A Patricia trie, which may also be denoted as a radix tree, is a data structure that represents a space-optimized trie (prefix tree) in which each node that is the only child is merged with its parent.
A red-black is a self-balancing binary search tree. Each node stores an extra bit representing “color” (“red” or “black”), used to ensure that the tree remains balanced during insertions and deletions.
A balanced tree may also be denoted as self-balancing tree. It may refer to any node-based binary search tree that automatically keeps its height (maximal number of levels below the root) small in the face of arbitrary item insertions and deletions. A red-black tree and a Patricia-trie are instantiations/examples of a balanced tree.
A hash chain may be defined as a binary hash tree where all right children, i.e. children on the right side of any inner nodes, are leaf nodes.
Metadata may be generally defined as data that provides information about the respective accumulator element and its corresponding digest. The metadata comprises in particular accumulator information about the accumulator of the corresponding lower level accumulator of the hierarchical accumulator structure. In other words, it may be any data about the corresponding accumulator. As an example, the first level elements comprise metadata on the corresponding second level accumulator, the second level elements comprise metadata on the corresponding third level accumulator and so forth. The accumulator information may be in particular any data that can be used to compute and store the lower level accumulator in an advantageous way. The accumulator information may directly define an accumulator type for the corresponding lower level accumulators, it may comprise a data type of the data that is stored in the lower level accumulator and/or it may comprise information of write and/or read access patterns of the corresponding lower level accumulator. The metadata may then be used by the underlying processing system/computing system to compute and store the respective accumulator. Metadata may include data structure parameters, i.e. parameters on the structure of the data such as the accumulator type.
The hierarchical accumulator structure 100 comprises a first level L1, a second level L2, a third level L3 and a fourth level L4. The first level L1 comprises a first level accumulator ACCL1 and the second level comprises a plurality of second level accumulators, more particularly the second level accumulators ACCL21, ACCL22 and ACCL23.
The first level accumulator ACCL1 encompasses a plurality of first level elements, namely the first level element E11, E12 and E13, and a first level digest D11 of the plurality of first level elements E11, E12 and E13.
Each of the plurality of second level accumulators ACCL21, ACCL22 and ACCL23 encompasses a plurality of second level elements. More particularly, the second level accumulator ACCL21 comprises the second level elements E21, E22 and E23. The second level accumulator ACCL22 comprises the second level elements E24 and E25. The second level accumulator ACCL23 comprises the second level elements E26 and E27. Furthermore, each of the plurality of second level accumulators comprises a second level digest of the plurality of second level elements. More particularly, the second level accumulator ACCL21 comprises the second level digest D21, the second level accumulator ACCL22 comprises the second level digest D22 and the second level accumulator ACCL23 comprises the second level digest D23.
Each of the second level digests of the plurality of second level accumulators corresponds to one of the plurality of first level elements. More particularly, the second level digest D21 of the second level accumulator ACCL21 corresponds or in other words is equal to the first level element E12. The second level digest D22 of the second level accumulator ACCL22 corresponds or in other words is equal to the first level element E11. And the second level digest D23 of the second level accumulator ACCL23 corresponds or in other words is equal to the first level element E13.
The third level L3 and the fourth level L4 are arranged in a corresponding manner. More particularly, the third level L3 comprises the third level accumulators ACCL31, ACCL32, ACCL33 and ACCL34 and the fourth level L4 comprises the fourth level accumulator ACCL41.
The third level accumulator ACCL31 comprises the third level elements E31, E32, E33 and E34. The third level accumulator ACCL32 comprises the third level elements E35 and E36. The third level accumulator ACCL33 comprises the third level elements E37 and E38. And the third level accumulator ACCL34 comprises the third level elements E39, E310 and E311. The third level accumulator ACCL31 comprises the third level digest D31, the third level accumulator ACCL32 comprises the third level digest D32, the third level accumulator ACCL33 comprises the third level digest D33 and the third level accumulator ACCL34 comprises the third level digest D34. Each of the third level digests of the plurality of third level accumulators corresponds to one of the plurality of second level elements. As an example, the third level digest D31 of the third level accumulator ACCL31 corresponds or in other words is equal to the second level element E21.
Finally, the fourth level accumulator ACCL41 comprises the fourth level elements E41 and E42 and the fourth level digest D41. The fourth level digest D41 of the fourth level accumulator ACCL41 corresponds or in other words is equal to the third level element E36.
In general, at least a subset of the plurality of first level elements comprise metadata which comprises or defines accumulator information for the corresponding second level accumulator. More particularly, each of the first level elements which correspond to a digest of a second level accumulator comprises such metadata. In other words, each of the first level elements which are not a leaf comprise such metadata. In the exemplary embodiment shown in
Likewise, a subset of the plurality of second level elements comprise metadata which comprises the accumulator information for the corresponding third level accumulator and a subset of the plurality of third level elements comprise metadata which comprises the accumulator information for the corresponding fourth level accumulator. More particularly, each of the second level elements which correspond to a digest of a third level accumulator comprises such metadata. In the embodiment of
More particularly, the second level element E21 comprises the metadata MD31 which comprises the accumulator information for the corresponding third level accumulator ACCL31. The second level element E23 comprises the metadata MD32 with the accumulator information for the corresponding third level accumulator ACCL32, the second level element E26 comprises the metadata MD33 which comprises the accumulator information for third level accumulator ACCL33 and the second level element E27 comprises the metadata MD34 with the accumulator information for third level accumulator ACCL34. Finally, the third level element E36 comprises the metadata MD41 with the accumulator information for the corresponding fourth level accumulator ACCL41.
The metadata of the hierarchical data structure as shown in
The hierarchical accumulator structure 100 allows to adapt a respective accumulator “on the fly”, i.e. during operation, e.g. in dependence on the current data that is to be stored as well as in dependence on an analysis of write and/or read accesses. Such a dynamic adaptation may be a complete change of the accumulator type, e.g. from a red-black tree to a Patricia trie as well as an adaption of the respective instantiation of the respective accumulator type. Furthermore, such an adaptation may be done on an individual level, i.e. an adaption/change of the accumulator may be done only for one or a selected subset of the plurality of accumulators.
According to embodiments, the accumulators of the hierarchical accumulator structure 100, e.g. the first level, second level, third level and/or fourth level accumulators may be embodied as cryptographic accumulators, in particular as hash trees.
According to embodiments the hash tree may represent the data as a balanced tree, a red-black tree, a Patricia trie or a hash chain. The concrete type of tree may be selected such that it makes certain processing operations such as the insertion, the update and the deletion on the underlying data type efficient.
For this example it is assumed that the metadata MD21 comprises the information that the accumulator element E22 and corresponding witnesses for the accumulator element E22 are more often requested than the other accumulator elements E21/D31 and E23/D32. Accordingly, the processing system stores the accumulator ACCL21 in such a way that it facilitates an efficient/improved access to the accumulator element E22, in particular in such a way that the witness size is reduced/minimized. In the embodiment of
If on the contrary and in particular without the knowledge of the metadata MD21 a hash tree 220 were computed, a witness would have a bigger size. More particularly, in the hash tree 220 the accumulator element E22 is placed in the lowest level of the hash tree 220. Accordingly, a corresponding witness 221 comprises the digests D32 and D31, having a double witness size compared to the witness 211.
For this example it is assumed that the metadata MDXX of the accumulator 310 comprises the information that accumulator 310 comprises or the represents a queue structure as data type and that the accumulator 310 shall be computed as hash chain.
The hash chain 330 has a constant witness size of 1 for witnesses of the set of accumulator elements of the current queue structure 320. More particularly, if the root hash, i.e. in the shown example the hash Hr=H5 is known or can be received in a verifiable way, only the hash H0 is needed as a witness 331 for the accumulator elements EX1, EX2, EX3, EX4 and EX5.
On the contrary and in particular without the knowledge of the metadata MDXX a hash tree 340 may have been computed which shows a balanced binary hash tree. Accordingly, a corresponding witness 341 comprises the accumulator element EX6 and the hash HX, having a double witness size compared to the witness 331.
Compared e.g. with the balanced tree 340 of
For this example it is assumed that the metadata MDXX of the accumulator 610 comprises as accumulator information the information that the accumulator 610 comprises or represents a mapping as data type. In addition, it may be specified as accumulator information that the accumulator 610 shall be computed/instantiated as Patricia-trie. Such a mapping performs generally a mapping between a set of source elements and a set of destination elements.
The accumulator computational unit 711 is in particular configured to perform a computation of the accumulators of the hierarchical accumulator structure in dependence on metadata of the respective accumulators.
At steps 810, the processing unit 710 (regularly) computes payloads, in particular a sequence of payloads.
At a step 820, the accumulator processing unit 711 of the processing unit receives a request/message/instruction to store data, in particular a computational result, in the accumulator storage unit 721 of the storage unit 720. The accumulator computational unit 713 checks then, at a step 830, the metadata and the accumulator information as specified by the metadata of the corresponding accumulator of the hierarchical accumulator structure.
Next, at a step 840, the accumulator computational unit 713 computes the respective accumulator in dependence on the metadata and stores it in the accumulator storage unit 721 of the storage unit 720. In addition to the computation of the respective accumulator, the accumulator computational unit 713 also computes any necessary updates of the hierarchical accumulator structure, i.e. in particular updates of other accumulators as required. Furthermore, it stores the updated accumulator/accumulator structure in the accumulator storage unit 721 of the storage unit 720.
The computation and storage of data in the accumulator storage unit 721 may be denoted as write accesses, while reading out data from the accumulator storage unit 721 may be denoted as read access.
At steps 910, the accumulator analysis unit 712 of the processing unit 710 analyses the computational results and/or write accesses/write access patterns to the accumulator storage unit 721 and/or read accesses/read access patterns from the accumulator storage unit 721. The analysis of the write accesses encompasses e.g. the detection of accumulators as well as accumulator elements which are frequently updated. Likewise, the analysis of the read accesses encompasses e.g. the detection of accumulators as well as accumulator elements which are frequently read and for which e.g. witnesses are frequently requested.
At steps 920, the processing system 700 may update the metadata of the hierarchical accumulator structure in dependence on the analysis of the computational results and/or the write access patterns and/or the read access patterns.
At steps 930, the processing system 700 may update the hierarchical accumulator structure in dependence on the analysis of the computational results and/or the write access patterns and/or the read access patterns and/or the metadata. In particular, the first level accumulator, one or more of the plurality of second level accumulators and one or/more of the plurality of further level accumulators may be updated.
Referring now to
The computing system 1000 may be described in the general context of computer system-executable instructions, such as program modules, being executed by a computer system. Generally, program modules may include routines, programs, objects, components, logic, data structures, and so on that perform particular tasks or implement particular abstract data types. The computing system 1000 is shown in the form of a general-purpose computing device. The components of computing system 1000 may include, but are not limited to, one or more processors or processing units 1015, a system memory 1020, and a bus 1016 that couples various system components including system memory 1020 to processor 1015.
Bus 1016 represents one or more of any of several types of bus structures, including a memory bus or memory controller, a peripheral bus, an accelerated graphics port, and a processor or local bus using any of a variety of bus architectures. By way of example, and not limitation, such architectures include Industry Standard Architecture (ISA) bus, Micro Channel Architecture (MCA) bus, Enhanced ISA (EISA) bus, Video Electronics Standards Association (VESA) local bus, and Peripheral Component Interconnect (PCI) bus.
Computing system 1000 typically includes a variety of computer system readable media. Such media may be any available media that is accessible by computing system 1000, and it includes both volatile and non-volatile media, removable and non-removable media.
System memory 1020 can include computer system readable media in the form of volatile memory, such as random access memory (RAM) 1021 and/or cache memory 1022. Computing system 1000 may further include other removable/non-removable, volatile/non-volatile computer system storage media. By way of example only, storage system 1023 can be provided for reading from and writing to a non-removable, non-volatile magnetic media (not shown and typically called a “hard drive”). Although not shown, a magnetic disk drive for reading from and writing to a removable, non-volatile magnetic disk (e.g., a “floppy disk”), and an optical disk drive for reading from or writing to a removable, non-volatile optical disk such as a CD-ROM, DVD-ROM or other optical media can be provided. In such instances, each can be connected to bus 1016 by one or more data media interfaces. As will be further depicted and described below, memory 1020 may include at least one computer program product having a set (e.g., at least one) of program modules that are configured to carry out the functions of embodiments of the invention.
Program/utility 1030, having a set (at least one) of program modules 1031, may be stored in memory 1020 by way of example, and not limitation, as well as an operating system, one or more application programs, other program modules, and program data. Each of the operating system, one or more application programs, other program modules, and program data or some combination thereof, may include an implementation of a networking environment. Program modules 1031 generally carry out the functions and/or methodologies of embodiments of the invention as described herein. Program modules 1031 may carry out in particular one or more steps of a computer-implemented method for providing a user of a distributed network access to computational results computed by the distributed network, e.g. of one or more steps of the methods as described above.
Computing system 1000 may also communicate with one or more external devices 1017 such as a keyboard or a pointing device as well as a display 1018. Such communication can occur via Input/Output (I/O) interfaces 1019. Still yet, computing system 1000 can communicate with one or more networks 40 such as a local area network (LAN), a general wide area network (WAN), and/or a public network (e.g., the Internet) via network adapter 1041. According to embodiments the network 1040 may be in particular a distributed network comprising a plurality of network nodes 10, e.g. the network 100 as shown in
Aspects of the present invention may be embodied as a system, in particular a distributed network comprising a plurality of subnets, a method, and/or a computer program product. The computer program product may include a computer readable storage medium (or media) having computer readable program instructions thereon for causing a processor to carry out aspects of the present invention.
The computer readable storage medium can be a tangible device that can retain and store instructions for use by an instruction execution device. The computer readable storage medium may be, for example, but is not limited to, an electronic storage device, a magnetic storage device, an optical storage device, an electromagnetic storage device, a semiconductor storage device, or any suitable combination of the foregoing. A computer readable storage medium, as used herein, is not to be construed as being transitory signals per se, such as radio waves or other freely propagating electromagnetic waves, electromagnetic waves propagating through a waveguide or other transmission media (e.g., light pulses passing through a fiber-optic cable), or electrical signals transmitted through a wire.
Computer readable program instructions described herein can be downloaded to respective computing/processing devices from a computer readable storage medium or to an external computer or external storage device via a network, for example, the Internet, a local area network, a wide area network and/or a wireless network. The network may comprise copper transmission cables, optical transmission fibers, wireless transmission, routers, firewalls, switches, gateway computers and/or edge servers. A network adapter card or network interface in each computing/processing device receives computer readable program instructions from the network and forwards the computer readable program instructions for storage in a computer readable storage medium within the respective computing/processing device.
Computer readable program instructions for carrying out operations of the present invention may be assembler instructions, instruction-set-architecture (ISA) instructions, machine instructions, machine dependent instructions, microcode, firmware instructions, state-setting data, or either source code or object code written in any combination of one or more programming languages, including an object oriented programming language such as Smalltalk, C++ or the like, and conventional procedural programming languages, such as the “C” programming language or similar programming languages.
Aspects of the present invention are described herein with reference to flowchart illustrations and/or block diagrams of methods, networks, apparatus (systems), and computer program products according to embodiments of the invention.
Computer readable program instructions according to embodiments of the invention may be provided to a processor of a general purpose computer, special purpose computer, or other programmable data processing apparatus to produce a machine, such that the instructions, which execute via the processor of the computer or other programmable data processing apparatus, create means for implementing the functions/acts specified in the flowchart and/or block diagram block or blocks. These computer readable program instructions may also be stored in a computer storage medium that can direct a computer, a programmable data processing apparatus, and/or other devices to function in a particular manner, such that the computer readable storage medium having instructions stored therein comprises an article of manufacture including instructions which implement aspects of the function/act specified in the flowchart and/or block diagram block or blocks.
The computer readable program instructions may also be loaded onto a computer, other programmable data processing apparatus, or other device to cause a series of operational steps to be performed on the computer, other programmable apparatus or other device to produce a computer implemented process, such that the instructions which execute on the computer, other programmable apparatus, or other device implement the functions/acts specified in the flowchart and/or block diagram block or blocks.
The flowchart and block diagrams in the figures illustrate the architecture, functionality, and operation of possible implementations of networks, systems, methods, and computer program products according to various embodiments of the present invention. In this regard, each block in the flowchart or block diagrams may represent a module, segment, or portion of instructions, which comprises one or more executable instructions for implementing the specified logical function(s). In some alternative implementations, the functions noted in the block may occur out of the order noted in the figures. For example, two blocks shown in succession may, in fact, be executed substantially concurrently, or the blocks may sometimes be executed in the reverse order, depending upon the functionality involved.
While there are shown and described presently preferred embodiments of the invention, it is to be distinctly understood that the invention is not limited thereto but may be otherwise variously embodied and practiced within the scope of the following claims.
Filing Document | Filing Date | Country | Kind |
---|---|---|---|
PCT/EP2021/062205 | 5/7/2021 | WO |