Spending with Raw Public Key
Last Updated on 24. April 2024 by Mario Oettler
In this topic, we look at a simple spend with a raw public key. There are two options:
- single signature
- multi signatures
Single Signature
This means, the sender has to provide a single signature that matches the public key of the P2TR-UTXO. A Taproot output has the following form:
data:image/s3,"s3://crabby-images/fcbac/fcbac9ffd339112e63b82a414040c6c101b9db6d" alt=""
OP_1 pushes “1” to the stack and indicates that the output follows the SegWit-Version 1. Q is the output key or witness program.
When looking at the spend with a raw public key, Q is only the internal public key P. It is obtained by the Schnorr Signature scheme.
data:image/s3,"s3://crabby-images/d56e0/d56e000141a8ed65072a88924588c58cb9253058" alt=""
The signature required to spend this output is provided in the witness section of the so-called control block of the input script.
data:image/s3,"s3://crabby-images/e780e/e780ebdd2445d37f56b8bc7a27b0567d70932bfa" alt=""
Multi Signature
Taproot, along with Schnorr signatures, also allows to combine multiple private keys into a single private key and create a single signature from multiple private keys. This feature is called MuSig2. It takes up less space than the older version of multi-signature, which required a complete signature of each key involved.
data:image/s3,"s3://crabby-images/7f289/7f289be47823b11a76b086682fe152913b955f57" alt=""
Each participant’s public keys are aggregated into a single public key P. And when signing, each participant’s signatures are aggregated into a single signature.
If a person wants to spend the output, they must provide a valid signature. Such a signature can consist of several individual signatures. From outside, an aggregated signature is indistinguishable from a signature generated by a single private key.