Apparatus and methods for producing data structures having internal self-references suitable for immutably representing and verifying data

Information

  • Patent Grant
  • 12231566
  • Patent Number
    12,231,566
  • Date Filed
    Sunday, November 6, 2022
    3 years ago
  • Date Issued
    Tuesday, February 18, 2025
    9 months ago
Abstract
Some embodiments described herein relate to a computer implemented method that includes performing a first work step associated with a first activity and with a first data product and performing a second work step associated with a second activity and associated with a second data product. A first chain of trust between the first work step and the second work step can be defined by defining a second manifest document that is associated with the second data product and that references a first manifest document associated with the first data product. An immutable data structure representing a second chain of trust independent of the first chain of trust can be defined by submitting the first manifest document and the second manifest document to a distributed ledger for validation.
Description
FIELD

The present application generally relates to a chain of data structures each having an internal reference to other data structures in the chain and methods and apparatus for creating and interacting with such data structures. The data structures can be committed to a distributed ledger.


BACKGROUND

As opposed to a simple or bilateral transaction a complex transaction involves multiple participants and may include non-principal third parties such as regulators, auditors, financial modelers, legal advisors, and so forth. A complex transaction may involve long periods of time (months to years) to complete and may involve voluminous transaction data, including transfer of assets, satisfaction of assets, as well as data products generated by non-principal third parties such as regulatory approval, audit reports, financial models, legal opinions, and so forth that the complex transaction incorporates or relies upon. Example complex transactions are private equity transactions, securities trading, commercial banking, energy trading, municipal bonds, and so forth. Generally speaking, a complex transaction is a transaction involving three or more participants that cannot be reduced to a set of computerexecutable instructions that completely describes the transaction.


Some known distributed ledger systems may be suitable to carry out relatively simple (e.g., bilateral) transactions using “smart contracts,” or the like. Such known distributed ledger systems, however, typically assume that an entire transaction can be reduced to computer-executable code that can be automatically triggered when certain conditions are met. This assumption does not hold for many complex transactions. Often events and data products associated with complex transactions cannot be reduced to computer-executable code, and may depend upon underlying legal instruments that cannot be stored on a distributed ledger system, such as original deeds and notes. Embodiments described herein generally relate to systems and methods that include both an on-ledger trust system (e.g., using known distributed ledger or blockchain) transaction verification systems and an off-ledger trust system which is described in further detail herein.





BRIEF DESCRIPTION OF THE DRAWINGS


FIG. 1A is a schematic representation of a system operable to process, store, and/or reference events associated with a complex transaction, according to an embodiment.



FIG. 1B is a logical schematic representation of the system of FIG. 1A, according to an embodiment.



FIG. 2 is an example data structure associated with a complex transaction, such as may be generated by the systems of FIGS. 1A and/or 1B.



FIG. 3 is a flow chart of a method for representing a complex transaction as cryptographically secure data, according to an embodiment.



FIG. 4 is a flow chart of a method for processing cryptographically-secured data stored in a distributed ledger and data products stored off the distributed ledger to reconstruct a complex transaction, according to an embodiment,



FIG. 5 is a flow chart of a method of simulating, replaying, and/or verifying a complex transaction, according to an embodiment.



FIG. 6 is a signal diagram illustrating a method for representing a complex transaction as cryptographically secure data, according to an embodiment.



FIG. 7 is a signal diagram illustrating a method for processing data stored in a distributed ledger and data products stored off the distributed ledger to reconstruct a complex transaction, according to an embodiment.





DETAILED DESCRIPTION

Some embodiments described herein relate to a first compute device having a non-transitory processor readable memory and a processor that is a node of a distributed database. Similarly stated the first compute device along with other nodes (other compute devices) can collectively implement a distributed database, such as a blockchain ledger. The first compute device can therefore store a first instance of the distributed database. The first instance of the distributed database (and typically all instances of the distributed database) can include a first manifest document. The first manifest document can be associated with a first activity and/or work step of a complex transaction. The first manifest document can include a reference to a first data product associated with the first activity that is stored in a first data repository, for example off the distributed ledger. The first instance of the distributed database (and typically all instances of the distributed database) can include a second manifest document similar to the first manifest document. The second manifest document can be associated with a later time than the first manifest document and can therefore be stored in a later block on the distributed ledger than the first manifest document. The second manifest document can include a reference to the first manifest document and a reference to a second data product that is stored in a second data repository, for example off the distributed ledger. The first compute device can receive an indication of an activity associated with a third data product and, in response, define a third manifest document that references the third data product and the second manifest document. The first compute device can commit the third manifest document to the first instance of the distributed database and send a signal to a second compute device (e,g., another node of the distributed database) such that the second compute device commits the third manifest document to the second instance of the distributed database. In this way, the third manifest document can be committed to all instances of the distributed database.


Some embodiments described herein relate to a computer implemented method that includes defining a first manifest document associated with a first activity that is associated with and references a non-digital artifact maintained in a physical artifact repository. The first manifest document can be cryptographically encoded to produce a first archive. The first archive can then be submitted to a distributed ledger for validation. A second manifest document associated with a second activity and that references the first archive and a second data product associated with the second activity can be defined and submitted to the distributed ledger for validation. The second data product can be submitted to a digital data repository, which may be different from the distributed ledger.


Some embodiments described herein relate to a computer implemented method that includes performing a first work step associated with a first activity and with a first data product and performing a second work step associated with a second activity and associated with a second data product. A first chain of trust between the first work step and the second work step can be defined by defining a second manifest document that is associated with the second data product and that references a first manifest document associated with the first data product. An immutable data structure representing a second chain of trust independent of the first chain of trust can be defined by submitting the first manifest document and the second manifest document to a distributed ledger for validation.



FIG. 1A is a schematic representation of a system operable to process, store, and/or reference events associated with a complex transaction, according to an embodiment. FIG. 16 is a logical schematic representation of the system of FIG. 1A, according to an embodiment. FIG. 2 is an example data structure associated with a complex transaction, such as may be generated by the systems of FIGS. 1A and/or 16.


A complex transaction system 100 includes one or more cooperating computer systems (each having a processor and a memory) and associated software that, when executed, is operable to define and/or interpret data models representing a complex multi-step process, execute (or initiate the execution of) activities associated with the complex transaction, record the results of activities into event series data products 122, and/or store any related artifacts produced as a result of the activity in a repository for data products 120. In some instances, the complex transaction system 100 can commit transactions to a shared trust system 150, The shared trust system 150 can include, define, and/or manage a distributed ledger 110, such as the ethereum network. As discussed in further detail herein, transactions committed to the distributed ledger can include encrypted archives 112 that can contain manifest documents, data products (e.g., data files), and/or copies of or references to previous transactions. As discussed in further detail herein external trust system nodes 154 can be operable to validate contents of the archives 112 independently of the distributed ledger itself.


The complex transaction system 100 can include a complex transaction engine 1200. The complex transaction engine 1200 can include one or more cooperating software (executing on a processor) and/or hardware modules operable to execute sequencing, flow control, and/or messaging between a workflow interface 1210, an event series interface 1220, a distributed ledger interface 1230, a manifest data interface 1240, and/or an archival data interface 1250. The complex transaction engine 1200 can be operable to create archives 112 or trust transactions under programmatic control, for example, based on time-triggers, external programmatic inputs to the complex transaction engine 1200 (e.g., from an external system workflow 130), a manual interaction with a human user, or other external computer system process. The complex transaction engine 1200 can submit such archives 112 to the distributed ledger 110 for validation, e.g., via the distributed ledger interface 1230, such that the archives 112 are committed to the distributed ledger. The distributed ledger interface 1230 can further be operable to read transaction or other data from the distributed ledger.


Each archive 112 represents one or more manually-initiated or automatically-performed activities associated with the complex transaction (e.g., a dividend payment, an audit report, a regulatory filing, a share/security sale, etc.). Each archive 112 can be cryptographically encoded, affixed with appropriate tamper-proof data signatures, and/or committed to the distributed ledger over time as it is created. Archives can also include an archival data reference 1264 that uniquely identifies an information asset contained within the archive 112. Additionally, in some instances, an archive 112 can include a checksum 1268 of data held in the archive 112 and/or a checksum algorithm identifier (e.g., “SHA256”),


As discussed in further detail herein, each archive 112 may contain, identify, and/or reference earlier transactions on the distributed ledger (e.g., earlier archives), earlier transactions that are maintained separately from the distributed ledger (e.g., an archive 112 can contain a reference to trust information, such as a verifiable cryptographic signature representing that a trusted transaction participant certifies that an activity occurred or the status of non-digital information), data products 120 associated with the current activity, a description of the current activity, and/or references to data products 120 associated with the current or previous activities that are maintained separately from the distributed ledger. The time series 110 of archives 112 represents part or all of the workflow of a complex transaction. The archives 112 store information related to the semantics of the complex transaction including, for example, information identifying authorized individuals performing or involved in activities, the result of activities, electronic data products produced by activities, instructions describing the conditions that caused the activity to occur, and/or instructions for simulating or recreating the activity.


The archival data interface 1250 of the complex transaction system can be operable to define, access, read, store, and otherwise provide a programmatic interface between the complex transaction engine 1200 and data products 120. The archival data interface 1250 can also be operable to define a look-up table that can allow a mapping between data products 120 (or indicators associated with data products 120) database keys, and unique identifiers or names from external storage locations into a uniform series of identifiers. As discussed in further detail herein, data products 120 can be externally stored (e.g., stored off the distributed ledger), so the mapping of uniform identifiers to external references, which may be highly variable in form and/or structure, can allow archives 112 and/or manifest documents 114 to provide or reference immutable references to data products 120 whose storage locations may change over time. The archival data interface 1250 can also be operable to calculate and verify data checksums or fingerprints and report information on algorithms used to calculate such checksums or fingerprints.


The manifest data interface 1240 of the complex transaction system 100 can be operable to define a manifest document 114, which can be included within at least some archives 112. Similarly stated, at least some of the archives 112 can be decrypted to retrieve a manifest document 114, which can include the date and time 1262 that the manifest document 114 was created, data products, references to data products 1264, identifiers of persistent electronic locations of data products 1264, checksums of fingerprints for data products, which may be contained within or stored separately from the manifest document 114, workflow definitions that were executed to produce data products, checksums for workflow definitions, public-key signed references to individuals/electronic systems that performed actions associated with the event, references to distributed ledger transactions associated with prior events, and/or references to additional (e.g., prior) manifest documents 1266.


As discussed above, archives 112 can be committed to a distributed ledger system as they are created. Similarly stated, each archive 112 can be submitted to the distributed ledger such that a copy of the archive is stored in a block of each copy of the distributed ledger maintained by local trust system nodes 152 (e.g., computer systems participating in the distributed trust system 150), ensuring the immutability of the archive. Thus, an archive 112 can include an encrypted manifest document 114, a reference to a manifest document 114, a signature of a manifest document 114, a unique activity identifier, and/or the activity date. The distributed ledger therefore establishes a public, ledger-based trusted, immutable time series record of the activities that make up a complex transaction. As discussed in further detail herein, each manifest document 114 can reference related manifests and/or activities that were generated or occurred earlier in time and previously committed to the distributed ledger.


Because manifest documents 114 can include references to earlier manifest documents 114 that are stored on the distributed ledger, for example, by identifying a location on the distributed ledger where an archive 112 containing an earlier manifest document 114 can be located, a trust chain can be created independently of the distributed ledger. A manifest document 114 can further include a checksum, fingerprint, or other description of an earlier manifest document 114 such that that earlier manifest document 114 can be uniquely identified. In this way, a series of manifest documents 114, where each manifest document 114 references at least one previous manifest document 114 creates a trust chain that is not dependent on the distributed ledger itself. Similarly stated, even in the absence of the distributed ledger, an individual with access to the series of manifest documents 114 could have confidence that the series of manifests represents an unchanged accounting of the complex transaction because each manifest uniquely identifies (e.g., through a fingerprint or checksum) at least one previous manifest. The trust chain that is independent from the distributed ledger can extend arbitrarily far back in time, for example to the origination of the complex transaction. The series of manifest documents 114 can represent the time linear flow of activities and transactions related to the complex transaction that culminates in the final manifest document 114, which can represent the most recent activity that occurred in the complex transaction and/or that was committed to the distributed ledger.


The workflow interface 1210 of the complex transaction system 100 can provide a programmatic interface between the complex transaction system engine 1200 and external system workflows 130. The external system workflow can be a compound data structure configured to model a sequence of events to be performed to execute a complex transaction. Such data models may define computational actions to perform, steps to be performed by a human participant, transformations to be applied to data products, and/or transactions to be performed with external systems. The workflow interface 1210, therefore, can be operable to invoke external workflow steps, receive data describing (externally) executed steps, and the results of (externally) executed steps for subsequent use by the event series interface 1220 in persisting the results of the workflow execution.


The event series interface 1220 can provide a programmatic interface between the complex transaction engine 1200 and the event series data store 122. The event series data store 122 can be computer-readable data structure, such as a keyed, indexed, or relational database that may be configured for creation, reading, updating, and/or deleting event series records. The event series data store 122 can be operable to store a series of data records that record data and time of activities of the complex transaction, references to participants (human users and/or automated systems) involved in the complex transactions, actions performed in an external system workflow 130, references to data products 120, and so forth.



FIG. 3 is a flow chart and FIG. 6 is a signal diagram of a method for representing a complex transaction as cryptographically secure data, according to an embodiment. FIG. 6 refers to the workflow interface 1210, the event series interface 1220, the complex transaction engine 1200, the manifest data interface 1240, the archival data interface 1250, and the distributed trust system 110 shown and described above with reference to FIG. 1B, FIG. 3 is described in conjunction with FIG. 6 for ease of description, but it should be understood that the method of FIG. 3 can be performed on any suitable system, including systems that may not include all the structures and/or functionality of the system of FIG. 1B.


At 212, a first (N) transaction work step can be performed. For example, the complex transaction engine 1200 can initiate the first (N) workflow step by sending a signal 600 to the workflow interface 1210. Typically a first (N) transaction work step will be an origination event, although it should be understood that in some instances the first transaction work step may refer to an action or transaction of an already-existing complex transaction or an action or transaction that predates the origination of a complex transaction, such as preliminary actions or transactions that a contemplated complex transaction will reference or incorporate. In some instances, the first (N) transaction work step can be the execution of a smart contract. For example, a smart contract configured to initiate the complex transaction can be defined and submitted to a distributed ledger. When the conditions associated with the smart contract are satisfied, the smart contract can automatically execute causing the complex transaction to initiate, for example, by defining and distributing tokens associated with the complex transaction.


The first transaction work step will typically create, rely on, and/or reference one or more data products. For example, the first (N) transaction work step may reference one or more assets (e.g., deeds, notes, supply contracts, etc.), may create tradeable shares or tokens (e.g., ownership interests in asset(s)), may include origination documents describing the terms and conditions of the complex transaction, may distribute shares or tokens to stakeholders, and so forth. Some data products may be created automatically, for example through the execution of a smart contract, while other data products may be created manually, for example through legal or financial drafting. Data products can be stored on or represented on a distributed ledger (e.g., tokens, smart contracts, etc.), in traditional electronic data repositories (e.g., on a secure server, on a cloud-based data repository, on a local storage device, etc.), or maintained in physical form (e.g., original deeds or notes). A data product can also describe steps to be taken to perform a transaction work step and/or conditions that caused the transaction work step to be performed.


The workflow interface 1210 can send signals 602 and/or 603 to the event series interface 1220 and/or archival data interface 1250, respectively, which can be operable to cause the event series interface 1220 and/or the archival data interface 1250 to store data products created, relied on, or referenced by the first (N) transaction work step. Specifically, the event series interface 1220 can cause data products to be stored to the distributed ledger 110 and/or the archival data interface 1250 can be operable to cause data products to be stored to a non-distributed ledger data repository.


At 214, a first (N) manifest document can be defined. The first (N) manifest document can be defined by the complex transaction engine 1200 sending signal 604 to the manifest data interface 1240. Furthermore, the manifest data interface 1240 can retrieve activity from the event series interface 1220 and/or the archival data interface 1250 as shown as signals 606 and 608, respectively.


The first (N) manifest document can include or reference data products defined, relied on, or referenced by the first transaction work step. The first (N) manifest document can also include a description of the activity that caused the first (N) manifest document to be defined. For example, in some instances, the first manifest document can include a list of checksums, hashes, and/or fingerprints suitable to identify each data product defined, relied on, or referenced by the first transaction work step. In some instances a complete copy of some or all data products associated with the first transaction work step can be incorporated into or packaged with the first manifest document. In some instances, a data product can identify a location on a distributed ledger or other data storage system where a data product can be located. In some instances, a data product can identify an authorized user or entity. Another type of data product can include an authorized user/entity certifying, for example through a cryptographic signature, the status of an asset. A certification by an identified and authorized user/entity is particularly well suited for non-digital data products or assets. For example, a bank or broker can certify that a physical asset or an original note or deed is in its possession and make representations regarding the contents or status of that asset. The first (N) manifest document can reference different data products in different ways (e.g., a complete copy of one data product can be incorporated into the manifest, while a digital fingerprint and metadata description of another data product can be listed). It should also be understood that some data products may be identified in the manifest by multiple techniques, such as by including a complete copy of the data product into the manifest and referencing an external data source (e,g., a blockchain location, a SEC document identifier, etc.). In some instances, the distributed ledger interface 1230 can be operable to retrieve data products (signal 616) from the distributed ledger interface 1230 based on a reference or indicator associated with data product(s), which can be included in the first (N) manifest document as an archival data reference 1264.


At 216, the first (N) manifest document and/or data products associated with the first (N) manifest document can be encoded to produce a first (N) encrypted archive. At 218, the first (N) encrypted archive can be submitted for validation on a distributed ledger system, such as the ethereum network. For example, the complex transaction engine 1200 can send signal 612 to the distributed ledger interface 1230 to cause the distributed ledger interface 1230 to create a trust transaction (e.g., an ERC-20 token) at 630 and to send signal 618 to the distributed trust system 110 to cause the distributed trust system 110 to validate the trust transaction. The distributed ledger can validate the first (N) encrypted archive, committing it to the distributed ledger. In addition or alternatively, the manifest data interface 1240 can be operable to send signal 610 to the archival data interface 1250 to cause the archival data interface 1250 to cause the encrypted archive to be stored in a non-distributed ledger data repository.


Events similar to those described above with reference to 212, 214, 216, and/or 218 can be repeated any number of times for each activity associated with the complex transaction. For example, at 222, a second (N+1) transaction work step can be performed, which can be similar to the first (N) transaction work step performed at 212. The second transaction work step can define, reference, and/or rely upon additional data products and/or can be associated with previously referenced data products (e.g., data products associated with the first (N) transaction work step performed at 212). As illustrated at 232, another (N+x) transaction work step can be performed. Again, the N+x transaction work step can define, reference, and/or rely upon new or previously generated data products. Work steps can include, for example, generating documents, logging a document into a data repository (e.g., other than a distributed ledger), detecting that an individual has accessed a document stored in a data repository, verifying that an investor is accredited (e.g., a compliance officer can certify that an investor is accredited), registering a payment against a debt instrument, paying a dividend to an investor, transferring an ownership stake (or token) from one entity or compute device to another entity or compute device, and so forth.


Similar to the defining the first (N) manifest document at 214, a manifest document that includes or references data products associated with each transaction work step (e.g., the N+1 transaction work step, the N+x transaction work step) can be defined at 224 and 234. Each manifest document can include or reference a previous manifest document. Because manifest documents are created as the complex transaction unfolds, manifest documents may not reference future or not-yet-defined manifest documents. For example, the second (N+1) manifest document can include or reference the first (N) manifest document. A third (N+2) manifest document (not shown) can include or reference the second (N+1) manifest document, and so forth. In some instances, a manifest document can include or reference all previous manifest documents (e.g., the third manifest document can include or reference the second (N+1) manifest document and the first (N) manifest document). In other instances a manifest document may only reference an immediately previous manifest document.


Typically each manifest document will be associated with multiple activities of the complex transaction, although in some instances a manifest document will be associated with only a single activity or work step. Typically a manifest document will be associated with all work steps or activities that have occurred since the last manifest document was defined. For example, work steps and/or data products can be batched such that one manifest document references multiple work steps and/or data products. For example, manifest documents can be automatically defined daily, weekly, or on any other suitable pre-defined schedule. In addition or alternatively, a manifest document can be defined in response to a manually initiated process, for example in response to an important or critical work step having been performed (e.g., deal closing, regulatory approval, etc.).


At 226 and 236, manifest documents defined at 224 and 234 and/or data products associated with those manifest documents can be encoded to produce encrypted archives. At 228 and 238, such encrypted archives can be submitted for validation on a distributed ledger system. Typically, each encrypted archive will be recorded on a single distributed ledger, but in some embodiments, at least some encrypted archives can be recorded on different distributed ledgers. For example, one encrypted archive can be recorded on the public ethereum ledger, another encrypted archive can be recorded on another ledger (optionally operating under a different protocol, such as ripple), and another encrypted archive can be recorded on a private ethereum ledger. Thus, each encrypted archive can be recorded to an immutable block of a distributed ledger. Batching data products and/or work steps as discussed above can reduce the number of blocks written to the distributed ledger, which can reduce transaction costs and allow the ledger to be used more efficiently. Similarly stated, cost and computational resource savings can be realized by defining manifests that selectively batch data products and work steps. For example, in some instances, activities associated with the complex transaction can occur faster than blocks are written to the distributed ledger. Defining a manifest that includes or references a batch of work steps and data products can enable data generated according to a relatively fast-moving process (the complex transaction) to be recorded on a relatively slow-moving data record (the distributed ledger).


In some embodiments, encrypted archives and/or manifest documents can themselves be stored as data products on a non-distributed ledger storage system. In this way, the parallel storage strategies (on the distributed ledger and off the distributed ledger) can improve data resiliency and reduce the possibility of data loss (for example, if an archive is not accepted to the distributed ledger), Similarly stated, after a manifest document is defined and/or encrypted, one copy of the manifest document can be stored in a traditional data repository (e.g., local or cloud storage) and another copy of the manifest document can be recorded to the distributed ledger. As discussed above, because each manifest document can reference one or more previous manifest documents, the manifest documents can establish a chain of trust that is independent of the distributed ledger.



FIG. 4 is a flow chart and FIG. 7 is a signal diagram of a method for processing cryptographically-secured data stored in a distributed ledger and data products stored off the distributed ledger to reconstruct a complex transaction, according to an embodiment. FIG. 7 refers to the event series interface 1220, the complex transaction engine 1200, the manifest data interface 1240, the archival data interface 1250, and the distributed trust system 110 shown and described above with reference to FIG. 1B. FIG. 4 is described in conjunction with FIG. 7 for ease of description, but it should be understood that the method of FIG. 4 can be performed on any suitable system, including systems that may not include all the structures and/or functionality of the system of FIG. 1B.


The method described above with reference to FIG. 3 describes an embodiment by which archives associated with events of a complex transaction can be stored on a distributed ledger system. The method shown in FIG. 4 generally relates to an embodiment by which such archives can be “unpacked” and, optionally, combined with other data stored on a distributed ledger and/or data stored off the distributed ledger to understand, recreate, simulate, verify, audit, study, etc. the complex transaction.


At 340 a complex transaction can be identified. In some embodiments, the complex transaction can be identified by a reference to the complex transaction in a token associated with the complex transaction. For example, an individual or entity involved in the transaction (e.g., a shareholder, trader, payee, etc.) can be in possession of a token that establishes that individual or entity's interest in the complex transaction. In some instances, an individual involved in the transaction or an analyst studying the transaction (e.g., an auditor, an individual conducting diligence on the complex transaction, a financial advisor, etc.) can select a complex transaction for validation via a user interface 700, for example by selecting an icon representing a token, a manifest document or encrypted archive associated with the complex transaction (e.g., retrieved from a non-distributed ledger data repository) or selecting a representation of any other suitable artifact associated with the complex transaction.


At 338, an encrypted archive associated with the complex transaction can be retrieved from a distributed ledger. For example the complex transaction engine 1200 can receive an indication of the complex transaction 702 from the user interface 700, send signal 704 to the distributed ledger interface 1230, such that the distributed ledger interface 1230 accesses the distributed ledger 110 and retrieves 706 the encrypted archive, which can be returned 708 to the complex transaction engine 1200.


Typically the first encrypted archive associated with the complex transaction to be retrieved will be the last (N+x) encrypted archive committed to the distributed ledger. Similarly stated, typically reconstructing a complex transaction will begin by retrieving an encrypted archive associated with the most recent activity in the complex transaction. It should be understood, however, that in some instances, reconstructing a complex transaction (or a portion of a complex transaction) can begin with an archive associated with any activity (not necessarily the last or most recent activity) in the complex transaction.


At 336, the (N+x) archive can be decrypted. In some instances, a token that establishes an individual or entity's interest in the complex transaction can include a decryption key by which data associated with the complex transaction can be retrieved. Similarly stated, a token (e,g., a ERC-20 token) that connotes ownership or interest in a complex transaction or security can include a decryption key by which archives associated with the complex transaction can be decrypted. In this way, individuals and/or entities associated with the complex transaction can be empowered to access, examine, validate, audit, etc. archives of the complex transaction. Similarly stated, a digital token can act as a reference to one or more trust chains. For example, a token can act as a reference to a chain of encrypted archives stored in the distributed ledger by virtue of the token and one or more of the encrypted archives having a common parent (e.g., a smart contract). As discussed in further detail herein, this can enable individuals and entities with an interest in the complex transaction to verify a chain of trust back to the origination of the complex transaction. In some instances a token connoting an ownership interest in a complex transaction can include a decryption key operable to decrypt all archives associated with the complex transaction. In other instances at least some tokens connoting an interest in a complex transaction can be more limited and operable only to decrypt some archives associated with the complex transaction. For example, access to highly sensitive or confidential data may be restricted from some token holders.


By decrypting the last (N+x) archive a last (N+x) manifest document and/or data products associated with the last (N+x) manifest document can be retrieved. As discussed above with reference to event 234, the last (N+x) manifest document can contain or reference an immediately-previous manifest (N+x−1) associated with an immediately previous (N+x−1) activity in the complex transaction and/or other earlier manifests associated with other earlier activity in the complex transaction, optionally dating back to a first (N) manifest document associated with an origination (N) of the complex transaction.


Furthermore, as discussed above with reference to events 214, 224, and 234, manifest documents can include or reference data products associated with the complex transaction. For example, the last (N+x) manifest document can describe (optionally, in computer executable form) the conditions that caused an activity associated with the last (N+x) manifest document to be defined. Additionally, the last (N+x) archive and/or manifest document can include or reference data products that were defined as a result of or otherwise associated with the last (N+x) activity in the complex transaction. The last (N+x) manifest document can include or reference data products stored on the distributed ledger from which the last (N+x) archive was retrieved, can reference data products stored in other locations, and/or can include a certification by an identified and authorized user/entity as to the content and/or status of an asset or data product. Manifest documents can further reference one or more tokens that are operable to decrypt archives, for example by name and/or token symbol. In some such embodiments, the relationship between such tokens and archives/manifest documents may be bidirectional. The complex transaction engine 1200 can be operable to send signal 710 to the manifest data interface 1240 to cause the manifest data interface 1240 to retrieve 712 data products from their storage location(s).


As discussed above, an activity associated with the complex transaction can define, reference, or rely upon a wide variety of data products, such as transaction records, audit reports, regulatory filings, and so forth. At 334, data products referenced by or incorporated in the last (N+x) archive and/or manifest document can be verified by any suitable means. For example, certifications by identified and authorized individuals or entities can be checked to verify the identity of the authorized individuals using a public/private key signature verification technique, certifications can be checked against primary documentation, the existence and/or content of expected/required audit reports or regulatory filings can be reviewed, and so forth. If evidence of tampering is revealed, for example, if an “authorized” cryptographic signature cannot be verified, if expected data products are missing, or so forth, an alert can be generated such that a further investigation into the irregularity can be conducted.


Because manifest documents (other than the first (N) manifest document) each reference at least one previous manifest document, an individual, entity, or compute device with sufficient permissions having a single manifest document can walk up the chain of trust established by manifest-to-manifest references to recreate the entire complex transaction from that manifest document to the origination of the complex transaction. Similarly stated, each manifest document will allow an individual, entity, or compute device to identify where a previous manifest document is stored. If that individual, entity, or compute device has access to the storage location (e.g., has a decryption key that can decrypt an archive stored on a distributed ledger or has access to a password-protected data repository containing manifest documents), that individual, entity, or compute device can move from manifest-reference to manifest reference to retrieve all the manifests for the complex transaction. Furthermore, because each manifest document can contain a checksum or fingerprint of at least one previous manifest, an individual, entity, or compute device reading manifest documents can be assured that if the fingerprint or checksum of that manifest document matches the fingerprint or checksum reported in a subsequent manifest document then that manifest document has not been altered any time after the subsequent manifest document was defined.


Therefore, based on a reference contained in the last (N+x) manifest document, a previous (N+x−1) encrypted archive can be identified, retrieved from the distributed ledger, and decrypted, at 326, such that a previous (N+Fx−1) manifest document and/or associated data products can be retrieved. Events 328 and 326 can be similar to events 338 and 336 discussed above, At 324, the previous (N+Fx−1) manifest document can be verified by computing a hash or fingerprint on the previous (N+x−1) manifest and comparing that hash or fingerprint against a hash or fingerprint reported in the last (N) manifest document. In addition or alternatively, at 324, data products identified by or incorporated in the previous (N+x−1) manifest document can be verified. In instances in which data products or transactions identified in the last (N+x) manifest document depend upon actions or data products that were supposed to have occurred or be associated with an activity associated with the previous (N+x−1) manifest document the occurrence of such actions and/or existence/contents of such data products can be verified. For example, if the last (N+x) manifest document indicates a payment to a shareholder was made, the previous (N+x−1) manifest document (and/or associated data products) can be checked to verify that the shareholder was a shareholder in good standing and entitled to a payment at the time the previous (N+x−1) manifest document was generated. Again if verification fails, an alert can be generated such that a further investigation into the irregularity can be conducted.


In some instances, if a chain of trust is broken, for example, if an expected archive is missing from the distributed ledger or off-ledger data repository, an alert can be generated, but the transaction can be validated based on redundantly stored data. Such redundantly stored data can, in some instances, be validated using a hash or checksum recorded in a later manifest document. For example, if an encrypted archive containing the previous (N+x−1) manifest document is not located on the distributed ledger in the expected location, the previous (N+x−1) manifest document can be retrieved from a non-distributed ledger data repository. The last (N+x) manifest document can contain a checksum or hash of the previous (N+x−1) manifest document, which can be used to validate the copy of the previous (N+x−1) manifest document that was retrieved from a non-distributed ledger (e.g., non-immutable) data repository.


This process can be repeated indefinitely, for example, until a first (N) encrypted archive associated with the complex transaction is retrieved from the distributed ledger at 318. The first encrypted archive can be decrypted to retrieve a first (N) manifest document, at 316. Typically the first (N) manifest document will be associated with an origination of the complex transaction and incorporate or reference origination data products. It should be understood, however, that in some instances, the first manifest document may not be associated with origination of a complex transaction. Similarly stated, in some embodiments, data associated with a complex transaction can be first committed to a distributed ledger sometime after or sometime before the complex transaction was initiated. Data products associated with the first (N) manifest document can be verified at 314.



FIG. 5 is a flow chart of a method of simulating, replaying, and/or verifying a complex transaction, according to an embodiment. In some instances, the method of FIG. 5 can be performed in conjunction with the method described above with reference to FIGS. 4 and 7. For example, the manifest documents retrieved during the performance of the method of FIG. 4 and/or the data products referenced and/or included in the manifest documents can be used during the performance of the method of FIG. 5.


As discussed above, each manifest document encrypted and committed to the distributed ledger as an archive can be associated with an activity of the complex transaction. Furthermore, the distributed ledger can ensure that each manifest document is permanently and immutably stored. Additionally, each manifest document can reference one or more previous manifest documents (including, for example, a checksum or fingerprint of the previous manifest document(s)), establishing a chain of trust that is not dependent upon the distributed ledger. Thus, performing the method of FIG. 4 can allow an individual or entity to obtain a manifest document for each activity that has occurred in a complex transaction from a first (N) activity to a last (N+x) activity.


At 402, a continuity of references to encrypted archives can be verified. As discussed above, each manifest document can include a reference to and/or unique description (e.g., a fingerprint or checksum) of one or more previous encrypted archives committed to the distributed ledger. Therefore at 402, a chain of activities of the complex transaction can be verified by sequentially verifying that an unbroken chain of manifest documents exists. Similarly stated, the last (N+x) manifest document can be examined to identify the location of the next-to-last (N+x−1) archive on the distributed ledger, which can be decrypted to retrieve the next-to-last (N+x−1) manifest document. The next-to-last (N−x−1) manifest document can in turn be examined to identify the location of the second-next-to-last (N+x−2) archive on the distributed ledger and so on and so forth, until the second (N+1) archive is decrypted to retrieve the second (N+1) manifest document. The second (N+1) manifest document can reveal the location of the first (N) archive, which can be decrypted to retrieve the first (N) manifest document, which can include or reference the origination data products of the complex transaction.


At 404, a representation of the complex transaction can be replayed or simulated by retrieving the origination data products from the first (N) manifest document, then identifying an activity associated with the second (N+1) manifest document, which may include reviewing, executing, verifying, or otherwise analyzing data products contained within or referenced by the first (N) and/or second (N+1) manifest document. For example, as shown with reference to FIG. 7, the complex transaction engine 1200 can retrieve 716, 720 validated manifest data and data products from various data repositories This process can be repeated indefinitely until an activity associated with the last (N+x) manifest document is identified. Trust and validity of the current state of the complex transaction can be verified by replaying and/or simulating each action that caused a manifest document to be generated, encrypted, and committed to the distributed ledger (e.g., as described above with reference to FIG. 3). Furthermore, because the manifest documents can include or reference each data product or artifact associated with each activity in the complex transaction, a complete description of the state of the complex transaction at any point in time can be recreated, visualized, and/or otherwise analyzed. The manifest documents can also be operable to provide a fingerprint or checksum of each externally stored data (e.g., data products not stored on the distributed ledger) such that an analyst can be assured that external data products remain intact and unmodified from their initial creation. The manifest documents can further include a description of each activity that caused that manifest document to be defined and/or code operable to cause a simulation of each activity to be executed.


The full complex transaction from first activity to most recent activity, or the complex transaction at any point in time can thereby be expressed as a human readable narrative describing the complex transaction, computer-executable instructions to simulate the complex transaction at a future time, examine a state of the complex transaction under counter-factual conditions (e.g., if an activity such as a trade had not occurred or had occurred differently) and so forth. The simulation of the complex transaction can be used to produce compliance reports for governmental regulators or any other suitable report for any suitable party. The simulation of the complex transaction can be used to present a redacted view of the transaction, for example, to preserve confidential or proprietary data associated with the complex transaction. As shown in FIG. 7, signals 722 and 724 represent that the user interface 700 can present data received from the complex transaction engine 1200 and/or the event series interface 1220, respectively.


The above-described methods can be performed on compute devices, such as client computer devices, servers, mainframe computers, etc. For example, the distributed trust system can be implemented on one or more servers interconnected by a network such as a wireless network(s), wired network(s), the Internet, an intranet(s) and/or any combination thereof. For other examples, the execution of complex multi-step transactions, the production of transaction records, the cryptographically encoding of those transaction records, the affixing of appropriate tamper-proof data signatures, and the submission of such information to a distributed trust system can be performed by user compute devices (e.g., client devices) that operatively coupled to the distributed trust system via the above-described network. Similarly, any reconstruction of the complex multi-step transactions and representation of the related data can be performed by the user compute devices accessing the distributed trust system.


It should be understood that each compute device can include a processor and a memory operatively coupled to that processor. Such a memory can be a non-transitory computer-readable medium (also can be referred to as a non-transitory processor-readable medium or memory) having instructions or computer code thereon for performing various computer-implemented operations and for execution by the processor. The computer-readable medium (or processor-readable medium) is non-transitory in the sense that it does not include transitory propagating signals per se (e.g., a propagating electromagnetic wave carrying information on a transmission medium such as space or a cable), The media and computer code (also can be referred to as code) may be those designed and constructed for the specific purpose or purposes. Examples of non-transitory computer-readable media include, but are not limited to: magnetic storage media such as hard disks, floppy disks, and magnetic tape; optical storage media such as Compact Disc/Digital Video Discs (CD/DVDs), Compact Disc-Read Only Memories (CD-ROMs), and holographic devices; magneto-optical storage media such as optical disks; carrier wave signal processing modules; and hardware devices that are specially configured to store and execute program code, such as Application-Specific Integrated Circuits (ASICs), Programmable Logic Devices (PLDs), Read-Only Memory (ROM) and Random-Access Memory (RAM) devices. Other embodiments described herein relate to a computer program product, which can include, for example, the instructions and/or computer code discussed herein.


While various embodiments have been described above, it should be understood that they have been presented by way of example only, and not limitation. Where methods and steps described above indicate certain events occurring in certain order, the ordering of certain steps may be modified. Additionally, certain of the steps may be performed concurrently in a parallel process when possible, as well as performed sequentially as described above. Although various embodiments have been described as having particular features and/or combinations of components, other embodiments are possible having any combination or sub-combination of any features andior components from any of the embodiments described herein.

Claims
  • 1. An apparatus, comprising: a first compute device, including a non-transitory processor readable memory and a processor, the first compute device communicatively coupled to a second compute device, the second compute device being from a plurality of compute devices that collectively implement a distributed ledger via a network that operably couples to the plurality of compute devices, the distributed ledger including: a first manifest document that includes (1) a first reference to a first data product stored in a first non-blockchain database and (2) a fingerprint of the first data product, anda second manifest document that includes (1) a second reference to the first manifest document, (2) a fingerprint of the first manifest document, and (3) a third reference to a second data product stored in a second non-blockchain database; andthe processor operatively coupled to the non-transitory processor readable memory, the processor configured to: receive an indication of an activity associated with a third data product,define a third manifest document that includes (1) the fingerprint of the first manifest document, (2) a fifth reference to the second manifest document, (3) a fingerprint of the second manifest document, and (4) a sixth reference to the third data product, andcommit the third manifest document to the distributed ledger.
  • 2. The apparatus of claim 1, wherein the processor is configured to encrypt the third manifest document to produce an archive, the archive committing the third manifest document to the distributed ledger.
  • 3. The apparatus of claim 1, wherein: the processor is configured to store a copy of the third manifest document in a third non-blockchain database that includes a copy of the second manifest document and a copy of the first manifest document such that a third compute device with access to the third non-blockchain database is configured to retrieve, without accessing any instance of the distributed ledger:(1) the first manifest document based on the third manifest document including the fingerprint of the first manifest document, and(2) the second manifest document based on the third manifest document including the fifth reference to the second manifest document.
  • 4. The apparatus of claim 1, wherein: the processor is configured to store a copy of the third manifest document in a third non-blockchain database that includes a copy of the second manifest document and a copy of the first manifest document such that a third compute device with access to the third non-blockchain database is configured to retrieve, without accessing any instance of the distributed ledger:(1) the second manifest document based on the third manifest document including the fifth reference to the second manifest document, and(2) the first manifest document based on the second manifest document including the second reference to the first manifest document.
  • 5. The apparatus of claim 1, wherein the first non-blockchain database and the second non-blockchain database are a common non-blockchain database.
  • 6. The apparatus of claim 1, wherein the first data product includes a cryptographic signature of an identified party and a representation of an attestation by the identified party as to a status of an asset.
  • 7. The apparatus of claim 1, wherein the first manifest document includes a fingerprint of a fourth manifest document, the fourth manifest document not being represented in the distributed ledger.
  • 8. The apparatus of claim 1, wherein the first compute device is not from the plurality of compute devices that collectively implement the distributed ledger.
  • 9. The apparatus of claim 1, wherein the second manifest document includes a fingerprint of the second data product.
  • 10. A non-transitory processor readable medium storing code representing instructions configured to be executed by a processor, the code comprising code to cause the processor to: define a second manifest document associated with a first activity and a second time, the second manifest document including a fingerprint of a first data product such that the second manifest document is configured to verify that the first data product has not been altered;define a third manifest document associated with a second activity and a third time after the second time, the third manifest document including (1) a reference to a second data product, and (2) a fingerprint of a first manifest document that is associated with a first time before the second time; andsubmit the third manifest document to a distributed ledger for validation.
  • 11. The non-transitory processor readable medium of claim 10, wherein the reference to the second data product included in the third manifest document references a network location from which the second data product can be retrieved, the network location not being a location on any distributed ledger.
  • 12. The non-transitory processor readable medium of claim 10, wherein a second archive representing the third manifest document is submitted to the distributed ledger, the code further comprising code to cause the processor to: encrypt the first manifest document to produce a first archive; andsubmit the first archive to the distributed ledger for validation.
  • 13. The non-transitory processor readable medium of claim 10, wherein a second archive representing the third manifest document is submitted to the distributed ledger, the code further comprising code to cause the processor to: define a smart contract configured to produce a plurality of tokens, at least a subset of the plurality of tokens containing a key that is configured to access the second archive; andsubmit the smart contract to the distributed ledger for validation.
  • 14. The non-transitory processor readable medium of claim 10, the code further comprising code to cause the processor to: define a smart contract configured to generate the second data product, generate a plurality of tokens, and distribute the plurality of tokens to compute devices of a plurality of rights holders;
  • 15. The non-transitory processor readable medium of claim 10, wherein the distributed ledger is an ethereum blockchain.
  • 16. The non-transitory processor readable medium of claim 10, wherein the fingerprint of the first data product is at least one of a hash and a checksum.
  • 17. The non-transitory processor readable medium of claim 10, wherein the distributed ledger is a first distributed ledger, the code further comprising code to cause the processor to submit the first manifest document to a second distributed ledger for validation, the second distributed ledger being different from the first distributed ledger.
  • 18. The non-transitory processor readable medium of claim 10, wherein at least one of the first manifest document and the second manifest document is not represented in the distributed ledger.
  • 19. The non-transitory processor readable medium of claim 10, wherein the third manifest document includes a fingerprint of the second manifest document.
  • 20. The non-transitory processor readable medium of claim 10, wherein the third manifest document includes a reference to the second manifest document and a fingerprint of the second manifest document; andthe second manifest document includes a reference to the first manifest document and the fingerprint of the first manifest document.
  • 21. The non-transitory processor readable medium of claim 10, wherein the second data product is a non-digital artifact maintained in a physical artifact repository.
  • 22. A non-transitory processor readable medium storing code representing instructions configured to be executed by a processor, the code comprising code to cause the processor to: perform a first work step associated with a first activity and with a first data product;define a first manifest document that comprises a fingerprint of the first data product such that the first manifest document uniquely identifies the first data product;perform a second work step associated with a second activity and associated with a second data product;define a second manifest document that comprises a fingerprint of the second data product and a fingerprint of the first manifest document such that the second manifest document uniquely identifies the second data product and the first manifest document, the second manifest document's unique identification of the first manifest document defining a first chain of trust between the first work step and the second work step; anddefine an immutable data structure representing a second chain of trust independent of the first chain of trust by submitting the first manifest document and the second manifest document to a distributed ledger for validation.
  • 23. The non-transitory processor readable medium of claim 22, wherein the code representing instructions to cause the processor to perform the first work step is a smart contract configured to automatically execute on a virtual machine of the distributed ledger when predicate conditions of the smart contract are satisfied.
  • 24. The non-transitory processor readable medium of claim 22, wherein the code representing instructions to cause the processor to perform the second work step includes code to cause a data product to be generated in response to an operation performed by a user.
CROSS REFERENCE TO RELATED APPLICATIONS

This application is a continuation of non-provisional application Ser. No. 16/130,628, filed Sep. 13, 2018, which claims the benefit of priority of U.S. Provisional Application Nos. 62/558,140 and 62/558,142, each filed Sep. 13, 2017, the disclosure of each of which is hereby incorporated by reference in its entirety. This application is related to U.S. Non-Provisional application Ser. No. 16/130,619, now U.S. Pat. No. 10,873,457, filed Sep. 13, 2018, and, at the time of filing, entitled “Data Structure Having Internal Self-References Suitable for Immutably Representing and Verifying Data Generated over Time and Apparatus and Methods for Producing and Interacting with Such Data Structures,” the disclosure of which is hereby incorporated by reference in its entirety.

US Referenced Citations (426)
Number Name Date Kind
4309569 Merkle Jan 1982 A
5499294 Friedman Mar 1996 A
5606609 Houser Feb 1997 A
5862218 Steinberg Jan 1999 A
5920629 Rosen Jul 1999 A
5966446 Davis Oct 1999 A
6363481 Hardjono Mar 2002 B1
7028263 Maguire Apr 2006 B2
7212808 Engstrom May 2007 B2
7272179 Siemens Sep 2007 B2
7572179 Choi Aug 2009 B2
7729950 Mendizabal Jun 2010 B2
7730113 Payette Jun 2010 B1
8245038 Golle Aug 2012 B2
8266439 Haber Sep 2012 B2
8359361 Thornton Jan 2013 B2
8442903 Zadoorian May 2013 B2
8560722 Gates Oct 2013 B2
8612477 Becker Dec 2013 B2
8706616 Flynn Apr 2014 B1
8712887 Degroeve Apr 2014 B2
8867741 Mccorkindale Oct 2014 B2
8943332 Horne Jan 2015 B2
8990322 Cai Mar 2015 B2
9124423 Jennas, II Sep 2015 B2
9378343 David Jun 2016 B1
9396006 Kundu Jul 2016 B2
9398018 Macgregor Jul 2016 B2
9407431 Bellare Aug 2016 B2
9411524 O'Hare Aug 2016 B2
9411976 Irvine Aug 2016 B2
9411982 Dippenaar Aug 2016 B1
9424576 Vandervort Aug 2016 B2
9436923 Sriram Sep 2016 B1
9436935 Hudon Sep 2016 B2
9472069 Roskowski Oct 2016 B2
9489827 Quinn Nov 2016 B2
9584493 Leavy Feb 2017 B1
9588790 Wagner Mar 2017 B1
9647977 Levasseur May 2017 B2
9722790 Ebrahimi Aug 2017 B2
9818109 Loh Nov 2017 B2
9830580 Macgregor Nov 2017 B2
9875510 Kasper Jan 2018 B1
9876646 Ebrahimi Jan 2018 B2
9882918 Ford Jan 2018 B1
10025941 Griffin Jul 2018 B1
10046228 Tran Aug 2018 B2
10102265 Madisetti Oct 2018 B1
10102526 Madisetti Oct 2018 B1
10108954 Dunlevy Oct 2018 B2
10135607 Roets Nov 2018 B1
10163080 Chow Dec 2018 B2
10270599 Nadeau Apr 2019 B2
10346815 Glover Jul 2019 B2
10355869 Bisti Jul 2019 B2
10366204 Tanner, Jr. Jul 2019 B2
10373129 James Aug 2019 B1
10411897 Paolini-Subramanya Sep 2019 B2
10419225 Deery Sep 2019 B2
10438285 Konstantinides Oct 2019 B1
10476847 Smith Nov 2019 B1
10532268 Tran Jan 2020 B2
10586270 Reddy Mar 2020 B2
10628268 Baruch Apr 2020 B1
10685399 Snow Jun 2020 B2
10693652 Nadeau Jun 2020 B2
10749848 Voell Aug 2020 B2
10764752 Avetisov Sep 2020 B1
10783164 Snow Sep 2020 B2
10817873 Paolini-Subramanya Oct 2020 B2
10826685 Campagna Nov 2020 B1
10855446 Ow Dec 2020 B2
10873457 Beaudoin Dec 2020 B1
10915895 Fogg Feb 2021 B1
10929842 Arvanaghi Feb 2021 B1
10949926 Call Mar 2021 B1
10956973 Chang Mar 2021 B1
10958418 Ajoy Mar 2021 B2
10997159 Iwama May 2021 B2
11042871 Snow Jun 2021 B2
11044095 Lynde Jun 2021 B2
11044097 Snow Jun 2021 B2
11044100 Deery Jun 2021 B2
11063770 Peng Jul 2021 B1
11075744 Tormasov Jul 2021 B2
11093933 Peng Aug 2021 B1
11134120 Snow Sep 2021 B2
11164250 Snow Nov 2021 B2
11164254 Gordon, III Nov 2021 B1
11170366 Snow Nov 2021 B2
11205172 Snow Dec 2021 B2
11276056 Snow Mar 2022 B2
11295296 Snow Apr 2022 B2
11296889 Snow Apr 2022 B2
11328290 Snow May 2022 B2
11334874 Snow May 2022 B2
11347769 Snow May 2022 B2
11348097 Snow May 2022 B2
11348098 Snow May 2022 B2
11423398 Mullins Aug 2022 B1
20010029482 Tealdi Oct 2001 A1
20030018563 Kilgour Jan 2003 A1
20040085445 Park May 2004 A1
20050206741 Raber Sep 2005 A1
20060075228 Black Apr 2006 A1
20060184443 Erez Aug 2006 A1
20070027787 Tripp Feb 2007 A1
20070094272 Yeh Apr 2007 A1
20070174630 Shannon Jul 2007 A1
20070296817 Ebrahimi Dec 2007 A1
20080010466 Hopper Jan 2008 A1
20080028439 Shevade Jan 2008 A1
20080059726 Rozas Mar 2008 A1
20090025063 Thomas Jan 2009 A1
20090287597 Bahar Nov 2009 A1
20100049966 Kato Feb 2010 A1
20100058476 Isoda Mar 2010 A1
20100161459 Kass Jun 2010 A1
20100228798 Kodama Sep 2010 A1
20100241537 Kass Sep 2010 A1
20110061092 Bailloeul Mar 2011 A1
20110161674 Ming Jun 2011 A1
20120203670 Piersol Aug 2012 A1
20120264520 Marsland Oct 2012 A1
20130142323 Chiarella Jun 2013 A1
20130222587 Roskowski Aug 2013 A1
20130275765 Lay Oct 2013 A1
20130276058 Buldas Oct 2013 A1
20140022973 Kopikare Jan 2014 A1
20140201541 Paul Jul 2014 A1
20140229738 Sato Aug 2014 A1
20140282852 Vestevich Sep 2014 A1
20140289802 Lee Sep 2014 A1
20140297447 O'Brien Oct 2014 A1
20140344015 Puértolas-Montañés Nov 2014 A1
20150193633 Chida Jul 2015 A1
20150206106 Yago Jul 2015 A1
20150242835 Vaughan Aug 2015 A1
20150244729 Mao Aug 2015 A1
20150309831 Powers Oct 2015 A1
20150332256 Minor Nov 2015 A1
20150363769 Ronca Dec 2015 A1
20150378627 Kitazawa Dec 2015 A1
20150379484 Mccarthy Dec 2015 A1
20160002923 Alobily Jan 2016 A1
20160012240 Smith Jan 2016 A1
20160021743 Pai Jan 2016 A1
20160071096 Rosca Mar 2016 A1
20160098578 Hincker Apr 2016 A1
20160119134 Hakoda Apr 2016 A1
20160148198 Kelley May 2016 A1
20160162897 Feeney Jun 2016 A1
20160217436 Brama Jul 2016 A1
20160239653 Loughlin-Mchugh Aug 2016 A1
20160253663 Clark Sep 2016 A1
20160260091 Tobias Sep 2016 A1
20160267472 Lingham Sep 2016 A1
20160267558 Bonnell Sep 2016 A1
20160275294 Irvine Sep 2016 A1
20160283920 Fisher Sep 2016 A1
20160292396 Akerwall Oct 2016 A1
20160292672 Fay Oct 2016 A1
20160292680 Wilson, Jr. Oct 2016 A1
20160294783 Piqueras Jover Oct 2016 A1
20160300200 Brown Oct 2016 A1
20160300234 Moss-Pultz Oct 2016 A1
20160321675 Mccoy Nov 2016 A1
20160321751 Creighton, IV Nov 2016 A1
20160321769 Mccoy Nov 2016 A1
20160328791 Parsells Nov 2016 A1
20160330031 Drego Nov 2016 A1
20160330244 Denton Nov 2016 A1
20160337119 Hosaka Nov 2016 A1
20160342977 Lam Nov 2016 A1
20160342989 Davis Nov 2016 A1
20160344737 Anton Nov 2016 A1
20160371771 Serrano Dec 2016 A1
20170000613 Lerf Jan 2017 A1
20170005797 Lanc Jan 2017 A1
20170005804 Zinder Jan 2017 A1
20170033933 Haber Feb 2017 A1
20170053249 Tunnell Feb 2017 A1
20170061396 Melika Mar 2017 A1
20170075938 Black Mar 2017 A1
20170103167 Shah Apr 2017 A1
20170124534 Savolainen May 2017 A1
20170124535 Juels May 2017 A1
20170134162 Code May 2017 A1
20170148016 Davis May 2017 A1
20170161439 Raduchel Jun 2017 A1
20170177898 Dillenberger Jun 2017 A1
20170178237 Wong Jun 2017 A1
20170213287 Bruno Jul 2017 A1
20170221052 Sheng Aug 2017 A1
20170228731 Sheng Aug 2017 A1
20170236123 Ali Aug 2017 A1
20170243208 Kurian Aug 2017 A1
20170243289 Rufo Aug 2017 A1
20170244757 Castinado Aug 2017 A1
20170330279 Ponzone Nov 2017 A1
20170344983 Muftic Nov 2017 A1
20170346693 Dix Nov 2017 A1
20170352031 Collin Dec 2017 A1
20170353309 Gray Dec 2017 A1
20170359374 Smith Dec 2017 A1
20170364642 Bogdanowicz Dec 2017 A1
20170373859 Shors Dec 2017 A1
20180005186 Hunn Jan 2018 A1
20180048599 Arghandiwal Feb 2018 A1
20180075239 Boutnaru Mar 2018 A1
20180075527 Nagla Mar 2018 A1
20180082043 Witchey Mar 2018 A1
20180088928 Smith Mar 2018 A1
20180091524 Setty Mar 2018 A1
20180097779 Karame Apr 2018 A1
20180101701 Barinov Apr 2018 A1
20180101842 Ventura Apr 2018 A1
20180108024 Greco Apr 2018 A1
20180117446 Tran May 2018 A1
20180123779 Zhang May 2018 A1
20180139042 Binning May 2018 A1
20180144292 Mattingly May 2018 A1
20180157700 Roberts Jun 2018 A1
20180158034 Hunt Jun 2018 A1
20180167201 Naqvi Jun 2018 A1
20180173906 Rodriguez Jun 2018 A1
20180176017 Rodriguez Jun 2018 A1
20180181768 Leporini Jun 2018 A1
20180182042 Vinay Jun 2018 A1
20180189333 Childress Jul 2018 A1
20180189781 Mccann Jul 2018 A1
20180204213 Zappier Jul 2018 A1
20180219683 Deery Aug 2018 A1
20180219685 Deery Aug 2018 A1
20180225640 Chapman Aug 2018 A1
20180225649 Babar Aug 2018 A1
20180241565 Paolini-Subramanya Aug 2018 A1
20180260888 Paolini-Subramanya Sep 2018 A1
20180260889 Paolini-Subramanya Sep 2018 A1
20180268162 Dillenberger Sep 2018 A1
20180268382 Wasserman Sep 2018 A1
20180268504 Paolini-Subramanya Sep 2018 A1
20180276270 Bisbee Sep 2018 A1
20180276668 Li Sep 2018 A1
20180276745 Paolini-Subramanya Sep 2018 A1
20180285879 Gadnis Oct 2018 A1
20180285970 Snow Oct 2018 A1
20180285971 Rosenoer Oct 2018 A1
20180288022 Madisetti Oct 2018 A1
20180315051 Hurley Nov 2018 A1
20180316502 Nadeau Nov 2018 A1
20180356236 Lawrenson Dec 2018 A1
20180365201 Hunn Dec 2018 A1
20180365686 Kondo Dec 2018 A1
20180365764 Nelson Dec 2018 A1
20180367298 Wright Dec 2018 A1
20190012637 Gillen Jan 2019 A1
20190013948 Mercuri Jan 2019 A1
20190018947 Li Jan 2019 A1
20190034459 Qiu Jan 2019 A1
20190036887 Miller Jan 2019 A1
20190036957 Smith Jan 2019 A1
20190043048 Wright Feb 2019 A1
20190044727 Scott Feb 2019 A1
20190050855 Martino Feb 2019 A1
20190057382 Wright Feb 2019 A1
20190065709 Salomon Feb 2019 A1
20190073666 Ortiz Mar 2019 A1
20190080284 Kim Mar 2019 A1
20190081793 Martino Mar 2019 A1
20190081796 Chow Mar 2019 A1
20190087446 Sharma Mar 2019 A1
20190123889 Schmidt-Karaca Apr 2019 A1
20190132350 Smith May 2019 A1
20190188699 Thibodeau Jun 2019 A1
20190197532 Jayachandran Jun 2019 A1
20190205563 Gonzales, Jr. Jul 2019 A1
20190236286 Scriber Aug 2019 A1
20190251557 Jin Aug 2019 A1
20190253240 Treat Aug 2019 A1
20190253258 Thekadath Aug 2019 A1
20190268141 Pandurangan Aug 2019 A1
20190268163 Nadeau Aug 2019 A1
20190281259 Palazzolo Sep 2019 A1
20190287107 Gaur Sep 2019 A1
20190287199 Messerges Sep 2019 A1
20190287200 Schuler Sep 2019 A1
20190288832 Dang Sep 2019 A1
20190296915 Lancashire Sep 2019 A1
20190303623 Reddy Oct 2019 A1
20190303887 Wright Oct 2019 A1
20190306150 Letz Oct 2019 A1
20190311357 Madisetti Oct 2019 A1
20190324867 Tang Oct 2019 A1
20190332691 Beadles Oct 2019 A1
20190333054 Cona Oct 2019 A1
20190334715 Gray Oct 2019 A1
20190334912 Sloane Oct 2019 A1
20190340586 Sheng Nov 2019 A1
20190340607 Lynn Nov 2019 A1
20190342422 Li Nov 2019 A1
20190347444 Lowagie Nov 2019 A1
20190347628 Al-Naji Nov 2019 A1
20190349190 Smith Nov 2019 A1
20190349426 Smith Nov 2019 A1
20190354606 Snow Nov 2019 A1
20190354607 Snow Nov 2019 A1
20190354611 Snow Nov 2019 A1
20190354724 Lowagie Nov 2019 A1
20190354725 Lowagie Nov 2019 A1
20190354964 Snow Nov 2019 A1
20190356733 Snow Nov 2019 A1
20190361917 Tran Nov 2019 A1
20190372770 Xu Dec 2019 A1
20190378128 Moore Dec 2019 A1
20190385165 Castinado Dec 2019 A1
20190386940 Hong Dec 2019 A1
20190391540 Westervelt Dec 2019 A1
20190391858 Studnicka Dec 2019 A1
20190394044 Snow Dec 2019 A1
20190394048 Deery Dec 2019 A1
20200004263 Dalla Libera Jan 2020 A1
20200004946 Gilpin Jan 2020 A1
20200005290 Madisetti Jan 2020 A1
20200019937 Edwards Jan 2020 A1
20200034571 Fett Jan 2020 A1
20200034813 Calinog Jan 2020 A1
20200042635 Douglass Feb 2020 A1
20200042960 Cook Feb 2020 A1
20200042982 Snow Feb 2020 A1
20200042983 Snow Feb 2020 A1
20200042984 Snow Feb 2020 A1
20200042985 Snow Feb 2020 A1
20200042986 Snow Feb 2020 A1
20200042987 Snow Feb 2020 A1
20200042988 Snow Feb 2020 A1
20200042990 Snow Feb 2020 A1
20200042995 Snow Feb 2020 A1
20200044827 Snow Feb 2020 A1
20200044856 Lynde Feb 2020 A1
20200044857 Snow Feb 2020 A1
20200065761 Tatchell Feb 2020 A1
20200067907 Avetisov Feb 2020 A1
20200075056 Yang Mar 2020 A1
20200089690 Qiu Mar 2020 A1
20200099524 Schiatti Mar 2020 A1
20200099534 Lowagie Mar 2020 A1
20200104712 Katz Apr 2020 A1
20200118068 Turetsky Apr 2020 A1
20200127812 Schuler Apr 2020 A1
20200134760 Messerges Apr 2020 A1
20200145219 Sebastian May 2020 A1
20200167870 Isaacson May 2020 A1
20200175506 Snow Jun 2020 A1
20200195441 Suen Jun 2020 A1
20200211011 Anderson Jul 2020 A1
20200234386 Blackman Jul 2020 A1
20200258061 Beadles Aug 2020 A1
20200279324 Snow Sep 2020 A1
20200279325 Snow Sep 2020 A1
20200279326 Snow Sep 2020 A1
20200280447 Snow Sep 2020 A1
20200302433 Green Sep 2020 A1
20200320097 Snow Oct 2020 A1
20200320514 Snow Oct 2020 A1
20200320521 Snow Oct 2020 A1
20200320522 Snow Oct 2020 A1
20200320620 Snow Oct 2020 A1
20200382480 Isaacson Dec 2020 A1
20200389294 Soundararajan Dec 2020 A1
20210035092 Pierce Feb 2021 A1
20210042758 Durvasula Feb 2021 A1
20210044976 Avetisov Feb 2021 A1
20210073212 Conley Mar 2021 A1
20210073750 Ledford Mar 2021 A1
20210090076 Wright Mar 2021 A1
20210097602 Eichel Apr 2021 A1
20210119785 Ben-Reuven Apr 2021 A1
20210144149 Simons May 2021 A1
20210174353 Snow Jun 2021 A1
20210200653 Jetzfellner Jul 2021 A1
20210201321 Studnitzer Jul 2021 A1
20210201328 Gunther Jul 2021 A1
20210226769 Snow Jul 2021 A1
20210226773 Snow Jul 2021 A1
20210241282 Gu Aug 2021 A1
20210248514 Cella Aug 2021 A1
20210266167 Lohe Aug 2021 A1
20210266174 Snow Aug 2021 A1
20210272103 Snow Sep 2021 A1
20210273810 Lynde Sep 2021 A1
20210273816 Deery Sep 2021 A1
20210326815 Brody Oct 2021 A1
20210328804 Snow Oct 2021 A1
20210342836 Cella Nov 2021 A1
20210366586 Ryan Nov 2021 A1
20220006641 Snow Jan 2022 A1
20220012731 Derosa-Grund Jan 2022 A1
20220019559 Snow Jan 2022 A1
20220020001 Snow Jan 2022 A1
20220023742 Tran Jan 2022 A1
20220027893 Snow Jan 2022 A1
20220027897 Snow Jan 2022 A1
20220027994 Snow Jan 2022 A1
20220027995 Snow Jan 2022 A1
20220027996 Snow Jan 2022 A1
20220029805 Snow Jan 2022 A1
20220030054 Snow Jan 2022 A1
20220034004 Snow Feb 2022 A1
20220040557 Tran Feb 2022 A1
20220043831 Douglass Feb 2022 A1
20220058622 Snow Feb 2022 A1
20220058623 Snow Feb 2022 A1
20220083991 Kemper Mar 2022 A1
20220103341 Snow Mar 2022 A1
20220103343 Snow Mar 2022 A1
20220103344 Snow Mar 2022 A1
20220103364 Snow Mar 2022 A1
20220141231 Simons May 2022 A1
20220156737 Wright May 2022 A1
20220172207 Cella Jun 2022 A1
20220173893 Basu Jun 2022 A1
20220198554 Filter Jun 2022 A1
20220215389 Balaraman Jul 2022 A1
20220245626 Sewell Aug 2022 A1
Foreign Referenced Citations (23)
Number Date Country
107392618 Nov 2017 CN
110392052 Oct 2019 CN
110599147 Dec 2019 CN
112329041 Feb 2021 CN
10128728 Jan 2003 DE
3726438 Oct 2020 EP
3862947 Aug 2021 EP
S5383297 Jul 1978 JP
2021152931 Sep 2021 JP
100653512 Dec 2006 KR
1747221 May 2017 KR
101747221 Jun 2017 KR
0049797 Aug 2000 WO
2007069176 Jun 2007 WO
2015077378 May 2015 WO
2017190795 Nov 2017 WO
2018013898 Jan 2018 WO
2018109010 Jun 2018 WO
2018127923 Jul 2018 WO
2018127923072018 Jul 2018 WO
2019180702 Sep 2019 WO
2019207504 Oct 2019 WO
2020125839 Jun 2020 WO
Non-Patent Literature Citations (36)
Entry
Encoding, Encryption, and Hashing by Andrea Chiarelli (Year: 2022).
Al-Naji, Nader et al., “Basis: A Price-Stable Cryptocurrency with an Algorithmic Central Bank” www.basis.io Jun. 20, 2017, 27 pages.
Alsolami, Fahad, and Terrance E. Boult. “CloudStash: using secret-sharing scheme to secure data, not keys, in multi-clouds.” Information Technology: New Generations (ITNG), 2014 11th International Conference on. IEEE, 2014.
Ana Reyna et al.; On blockchain and its integration with IoT. Challenges and opportunities. Future generation computer systems. vol. 88, Nov. 2018, pp. 173-190. https://www.sciencedirect.com/science/article/pii/S0167739X17329205 (Year: 2018).
Casey, “BitBeat: Factom Touts Blockchain Tool for Keeping Record Keepers Honest”, Wall Street Journal, Nov. 5, 2014.
Chakravorty, Antorweep, and Chunming Rong, “Ushare: user controlled social media based on blockchain.” Proceedings of the 11th International Conference on Ubiquitous Information Management and Communication. ACM, 2017.
Chen, Zhixong, and Yixuan Zhu. “Personal Archive Service System using Blockchain Technology: Case Study, Promising and Challenging.” AI & Mobile Services (AIMS), 2017 IEEE International Conference on. IEEE, 2017.
Crosby, Michael et al., “BlockChain Technology, Beyond Bitcoin”, Sutardja Center for Entrepreneurship & Technology, Berkeley Engineering, Oct. 16, 2015, 35 pages.
Dai et al. TrialChain: A Blockchain-Based Platform to Validate Data Integrity in Large, Biomedical Research Studies arXiv: 1807.03662 Jul. 10, 2018 (Year: 2018).
Eberhardt et al., “ZoKrates - Scalable Privacy-Preserving Off-Chain Computations,” https://ieeeexplore.ieee.org/stamp/JSP?tp:::&armumber:::8726497. (Year:2018).
Feng and Luo, “Evaluating Memory-Hard Proof-of-Work Algorithms on Three Processors,” PVLDB, 13(6): 898-911, 2020.
Fernandez-Carames et al.; A Review on the Use of Blockchain for the Internet of Things. https://ieeexplore.ieee.org/stamp/stamp.jsp?arnumber=8370027 (Year: 2018). 23 pages.
Haarmann, et al., “DMN Decision Execution on the Ethereum Blockchain,” Hasso Plattner Institute, University of Potsdam, May 17, 2018, 15 pages.
Iddo Bentov, Bitcoin and Secure Computation with Money, May 2016 (Year: 2016).
Kim et al., “A Perspective on Blockchain Smart Contracts,” Schulich School of Business, York University, Toronto, Canada, 2017, 6 pages.
Kroeger, T. et al., The Case for Distributed Data Archival Using Secret Splitting with Percival, 6th International Symposium on Resilient Control Systems (available at IEEE Xplore), p. 204-209 (Year: 2013).
Krol, Michal et al., “SPOC: Secure Payments for Outsourced Computations” https://arxiv.org/pdf/1807.06462.pdf. (Year: 2018).
Luther, “Do We Need A “Fedcoin” Cryptocurrency?,” ValueWalk, Newstex Global Business Blogs, Dec. 30, 2015 (Year: 2015).
Luu et al., Making Smart Contracts Smarter, 2016.
Menezes, Alfred. J., et al. “Handbook of Applied Cryptography,” 1997, CRC Press, p. 527-28.
Merkle Mountain Ranges (MMRs)—Grin Documentation, https://quentinlesceller.github.io/grin-docs/technical/building-blocks/merkle-mountain-ranges/, 5 pages, printed Jun. 1, 2022.
Merkle Mountain Ranges, https://github.com/opentimestamps/opentimestamps-server/blob/master/doc/merkle-mountain-range.md, 3 pages, printed Jun. 1, 2022.
Michelson, Kyle, et al., “Accumulate: An identity-based blockchain protocol with cross-chain support, human-readable addresses, and key management capabilities”, Accumulate Whitepaper, v1.0, Jun. 12, 2022, 28 pages.
MOF-BC: A Memory Optimized and Flexible BlockChain for Large Scale Networks. lle:///C:/Users/eoussir/Documents/e-Red%20Folder/16905961/NPL_MOF_BC_A%20Memory%20Optimized%20and%20Flexible%20Blockchain.pdf (Year:2018) 43 pages.
Muhamed et al. EduCTX: A Blockchain-Based Higher Education Credit Platform, https://ieeexplore.ieee.org/stamp/stamp.jsp?arnumber=8247166. (Year: 2017). 16 pages.
On blockchain and its integration with IoT. Challenges and opportunities. file:///C:/Users/eoussir/Downloads/1-s2.0 80167739X17329205-main%20(1).pdf (Year: 2018) 18 pages.
Sokolowski, R. (2011). Signed, sealed, delivered: EMortgages are protected from unauthorized alteration by something called a tamper seal. Mortgage Banking, 71(6), 108(4). Retrieved from https://dialog.proquest.com/professional/docview/1068158815?accountid=131444 (Year: 2011).
United States: New Generation cryptocurrency, USDX Protocol, Offers Crypto Advantages and Fiat Pegging, Apr. 2, 2018 (Year: 2018).
Unknown, “Federated Learning: Collaborative Machine Learning without Centralized Training Data” Apr. 6, 2017, 11 pages.
Unknown, “Midex”, https://promo.midex.com/Midex_EN.pdf, 2017, 25 pages.
Unknown, Xtrade White Paper, https://xtrade1-9649.kxcdn.com/wp-content/uploads/2017/09/xtrade-whitepaper.pdf Feb. 7, 2018, 37 pages.
Watanabe, Hiroki, et al. “Blockchain contract: Securing a blockchain applied to smart contracts.” 2016 IEEE International Conference on Consumer Electronics (ICCE). IEEE, 2016.
White, Ron, “How Computers Work,” Oct. 2003, Que, Seventh Edition (Year: 2003), 23 pages.
Why offchain storage is needed for blockchain_V4_1 Final (Year: 2018), by IBM, 13 pages.
Written Opinion in PCT/US2021/040207, Inventor Snow, Mail date Oct. 7, 2021, 14 pages.
ZoKrates—Scalable Privacy-Preserving Off-Chain Computations, by Jacob Eberhardt, Stefan Tai , 8 pages, Nov. 3, 2011 (Year: 2011).
Related Publications (1)
Number Date Country
20230059806 A1 Feb 2023 US
Provisional Applications (2)
Number Date Country
62558142 Sep 2017 US
62558140 Sep 2017 US
Continuations (1)
Number Date Country
Parent 16130628 Sep 2018 US
Child 17981435 US