Computer-implemented systems and methods to enable complex functionality on a blockchain while preserving security-based restrictions on script size and opcode limits

US2022398579A1 · US · A1

Patent metadata
FieldValue
Publication numberUS-2022398579-A1
Application numberUS-202217588212-A
CountryUS
Kind codeA1
Filing dateJan 29, 2022
Priority dateDec 21, 2016
Publication dateDec 15, 2022
Grant date

How to read this patent

A practical reading order for non-experts. Skip the full description unless you need deep technical detail.

  1. Title

    What the patent document calls the invention.

  2. Abstract

    A short plain-language summary of the technical disclosure.

  3. Assignees and inventors

    Who owns or filed the patent and who is credited as inventor.

  4. Key dates

    Filing, priority, publication, and grant dates set the timeline.

  5. First independent claim

    The legal scope of protection — read this for what is actually claimed.

  6. CPC / IPC classifications

    Technology tags used to group this patent with similar filings.

  7. Citations and related patents

    Prior art links and similar publications in this corpus.

Abstract

Official abstract text for this publication.

The invention relates to blockchain technologies such as the Bitcoin blockchain. The invention uses a novel technique to decompose the functionality of a blockchain transaction script into several chunks or functional parts, and to use the output of a chunk as the input of the next chunk. Advantageously, this allows the blockchain to be used for ever complex tasks and computations while minimising script size, and also provides a novel architecture for the distributed execution of computational processes. The invention comprises a method of using a plurality of blockchain transactions to execute a computer-implemented task, comprising the steps: using an unlocking script (ULS 1 ) associated with a first input (In 1 ) in a blockchain transaction (Tx 2 ) to present at least one data item to a locking script (LS 1 ) of another transaction (Tx 1 ) so as to provide a result on a stack; amending the blockchain transaction (Tx 2 ) to include a second input (In 2 ); generating a further unlocking script (ULS 2 ) associated with the second input (In 2 ), the further unlocking script (ULS 2 ) comprising the result from the stack; and presenting the further unlocking script (ULS 2 ) to a further locking script (LS 2 ) such that the result from the stack is provided as input to the further locking script (LS 2 ). Preferably, the locking script (LS 1 ) and the further locking script (LS 2 ) are provided in association with different outputs within the same blockchain transaction (Tx 1 ).

First claim

Opening claim text (preview).

1 - 16 . (canceled) 17 . A method comprising: obtaining an unlocking script (ULS 2 ) associated with an input (In 2 ), the unlocking script (ULS 2 ) comprising a result from a stack-based data structure, wherein the result is based on an output from a first blockchain transaction (Tx 1 ) resulting from a different unlocking script (ULS 1 ) associated with a different output (In 1 ), the unlocking script (ULS 2 ) and unlocking script (ULS 1 ) provided within a blockchain transaction (Tx 2 ); and presenting the unlocking script (ULS 2 ) to an associated locking script (LS 2 ) such that the result from the stack-based data structure is provided as input to the locking script (LS 2 ), wherein the locking script (LS 2 ) is provided within a different blockchain transaction (Tx 1 ). 18 . The method according to claim 17 , wherein a blockchain including the blockchain transaction is of a consensus-based, distributed, electronic ledger. 19 . The method according to claim 17 , further comprising: using a data item in execution of a calculation or sequence of instructions provided within a different locking script (LS 1 ) associated with the different unlocking script (ULS 1 ). 20 . The method according to claim 19 , wherein: the result is provided as metadata within the unlocking script (ULS 2 ). 21 . The method according to claim 17 , wherein: the result from the stack-based data structure is provided as input to further locking script (LS 2 ), wherein the different locking script (LS 1 ) and the locking script (LS 2 ) are provided in association with different outputs within the different blockchain transaction (Tx 1 ). 22 . The method according to claim 17 , further comprising: obtaining the result from the stack-based structure as metadata within the unlocking script (ULS 2 ). 23 . The method according to claim 17 , further comprising: validating one or more of the blockchain transaction (Tx 2 ) and the different transaction (Tx 1 ) to generate the result from the stack-based structure. 24 . The method according to claim 17 , wherein validating the one or more of the blockchain transaction (Tx 2 ) and the different transaction (Tx 1 ) includes: obtaining, by an agent, a value from the stack-based data structure; and adding, by the agent, the value to a script opcode. 25 . The method according to claim 17 , wherein: obtaining the different unlocking script (ULS 1 ) and the unlocking script (ULS 2 ) in association with different inputs (In 1 In 2 ) within the blockchain transaction (Tx 2 ). 26 . The method according to claim 17 , wherein: the locking script (LS 1 ) and the further locking script (LS 2 ) are provided in association with different outputs within the different blockchain transaction (Tx 1 ). 27 . The method according to claim 17 , wherein: presenting the unlocking script (ULS 2 ) to the locking script (LS 2 ) provides a further result on the stack-based structure. 28 . The method according to claim 17 , further comprising: using a blockchain client to obtain the result from the stack-based structure. 29 . The method according to claim 17 , and further comprising: submitting one or more of the blockchain transaction (Tx 2 ) and different blockchain transaction (Tx 1 ) to a blockchain network. 30 . The method according to claim 17 , wherein: the blockchain transaction (Tx 2 ) is modified to include a second input (ln 2 ). 31 . The method according to claim 17 , and further comprising: using the method to compute a final result, and using the final result to control a process performed off the blockchain. 32 . A computer-implemented system comprising: a processor; and memory storing non-transitory computer-readable instructions that, when executed by the processor, cause the processor to at least: obtain an unlocking script (ULS 2 ) associated with an input (In 2 ), the unlocking script (ULS 2 ) comprising a result from a stack-based data structure, wherein the result is based on an output from a first blockchain transaction (Tx 1 ) resulting from a different unlocking script (ULS 1 ) associated with a different output (In 1 ), the unlocking script (ULS 2 ) and unlocking script (ULS 1 ) provided within a blockchain transaction (Tx 2 ); and present the unlocking script (ULS 2 ) to an associated locking script (LS 2 ) such that the result from the stack-based data structure is provided as input to the locking script (LS 2 ), wherein the locking script (LS 2 ) is provided within a different blockchain transaction (Tx 1 ). 33 . The computer-implemented system according to claim 32 , wherein the instructions include further instructions that cause the processor to: use a data item in the execution of a calculation or sequence of instructions provided within a different locking script (LS 1 ) associated with the different unlocking script (ULS 1 ). 34 . The computer-implemented system according to claim 32 , wherein: the result from the stack-based data structure is provided as input to further locking script (LS 2 ), wherein the different locking script (LS 1 ) and the locking script (LS 2 ) are provided in association with different outputs within the different blockchain transaction (Tx 1 ). 35 . The computer-implemented system according to claim 32 , wherein the instructions include further instructions that cause the processor to: obtain the result from the stack-based structure as metadata within the unlocking script (ULS 2 ); and obtain the different unlocking script (ULS 1 ) and the unlocking script (ULS 2 ) in association with different inputs (In 1 In 2 ) within the blockchain transaction (Tx 2 ).

Assignees

Inventors

Classifications

  • Keeping log of transactions for guaranteeing non-repudiation of a transaction · CPC title

  • the encryption apparatus using shift registers or memories for block-wise {or stream} coding, e.g. DES systems {or RC4; Hash functions; Pseudorandom sequence generators} · CPC title

  • H04L9/3239Primary

    involving non-keyed hash functions, e.g. modification detection codes [MDCs], MD5, SHA or RIPEMD · CPC title

  • Transaction processing · CPC title

  • Hash functions, e.g. MD5, SHA, HMAC or f9 MAC · CPC title

Patent family

Related publications grouped by family.

External sources

Frequently asked questions

Answers are generated from the same data shown on this page.

What does patent US2022398579A1 cover?
The invention relates to blockchain technologies such as the Bitcoin blockchain. The invention uses a novel technique to decompose the functionality of a blockchain transaction script into several chunks or functional parts, and to use the output of a chunk as the input of the next chunk. Advantageously, this allows the blockchain to be used for ever complex tasks and computations while minimis…
Who is the assignee on this patent?
Nchain Licensing Ag
What technology area does this patent fall under?
Primary CPC classification H04L9/3239. Mapped technology areas include Electricity.
When was this patent published?
Publication date Thu Dec 15 2022 00:00:00 GMT+0000 (Coordinated Universal Time) (A1). Legal status and post-grant events are not shown on this page.
What related patents are in patentsdb?
We list 1 related publication on this page (citations in our corpus or others sharing the same primary CPC).