Signature Script Isolation and Fraud Proofs¶
To prevent transaction malleability, the ability to generate a transaction with the same input references and outputs and yet a different transaction ID, input scripts have been removed from the calculation of the transaction hash. The origins of this modification have been controversial, although it appears to have been implemented in both CryptoNote coins and sidechains in the past1 2. After the activation of the “Segregated Witness” 3 soft fork, it was implemented in Bitcoin as well. As in the Elements sidechains implementation, commitments to the witness data are included in the Merkle tree of the block2. In addition, fraud proofs, as suggested for Bitcoin’s soft fork3, are set by miners and also committed to as part of the data in the Merkle tree.