1
0
mirror of https://github.com/bitcoinbook/bitcoinbook synced 2025-01-14 17:50:57 +00:00
Commit Graph

280 Commits

Author SHA1 Message Date
Ning Shang
555be41b2b
ch07: 2-of-5 instead of 2-of-3 for Mohammed's example
The example is a 2-of-5 multisig, according to the Pay-to-Script-Hash example description earlier, and the P2SH example a few lines below.
2021-01-18 20:00:19 -08:00
Murch
8072effb93
Correct transaction costs in segwit example
The transaction fees in the example were off.
2-of-3 P2SH inputs are between 293 and 297 bytes (293 bytes if both
signatures have low-R, 296 bytes if one signature has high-R, 297 bytes
if both signatures have high-R) and P2SH outputs are 32 bytes.

2-of-3 P2WSH (native segwit) inputs are between 104 and 104.5 vbytes
(416–418 WU, depending on low-R/high-R as above) and P2WSH outputs are
43 bytes.

The transaction header has 10 bytes for non-segwit transactions and 42
WU for segwit transactions.

Source:
https://github.com/BitGo/unspents/blob/master/src/dimensions.ts#L69

I have updated the numbers in the example and amended the conclusion
which did not match the new numbers. Calculation details follow.

-----

Let's assume that the wallet is using signature grinding and will always
produce signatures with low-R:

•Without Segregated Witness:
Transaction A using 2-of-3 P2SH inputs and P2SH outputs:
3*293 + 10 + 2*32 = 953
953 * 30 = 28,590

Transaction B using 2-of-3 P2SH inputs and P2SH outputs:
2*293 + 10 + 3*32 = 692
692 * 30 = 20,760

•With Segregated Witness:
Transaction A using 2-of-3 P2WSH (native segwit) inputs and outputs:
3*104 + 10.5 + 2*43 = 408.5
408.5 * 30 = 12,255

Transaction B using 2-of-3 P2WSH (native segwit) inputs and P2WSH
outputs:
2*104 + 10.5 + 3*43 = 347.5
347.5 * 30 = 10,425
2020-10-13 23:11:13 -04:00
Will Binns
6990e9d83a
Merge pull request #671 from jowo-io/develop
Ensuring "constant width" font is used for two references to `nLocktime`
2020-05-01 11:57:06 -06:00
Will Binns
720e376e3e
Merge pull request #661 from staciewaleyko/patch-1
Fix typo in chapter 7 ("to" => "with")
2020-04-30 22:14:23 -06:00
JoWo
0e2256e394 ensuring "constant width" of two references to nLocktime 2020-02-05 11:24:21 +01:00
Stacie Waleyko
ee79882eb8
Fix typo in chapter 7 ("to" => "with") 2019-10-28 08:30:42 -04:00
Gus
6599228da5 Removes sentence structure error: "outputs" 2019-10-10 08:35:27 -06:00
Will Binns
1bdd74320a
Merge branch 'develop' into op-tuck 2019-10-05 09:07:24 +02:00
practicalswift
fed7506d88 Fix typos 2019-08-27 12:31:52 +00:00
Will Binns
f6f5b29822
Merge pull request #594 from ottosch/develop
Fixed typo: "note than" -> "note that"
2019-06-19 23:21:37 +02:00
Will Binns
10914b174e
Merge pull request #564 from satwo/patch-1
Specify height/timestamp cutoff for nLockTime
2019-05-09 20:05:30 +00:00
Will Binns
5785fc9d5d
Merge pull request #521 from kenjiszk/kenjiszk/fix-typo-patch-1
fix segit to segwit
2019-05-08 13:17:10 +00:00
ottoteixeira
b18ee82b46
Fixed typo: "note than" -> "note that" 2018-08-17 14:37:21 -03:00
Samuel B. Atwood
d6ec46403f
Specify height/timestamp cutoff for nLockTime
Changed "If it is above 500 million..." to "If it is greater than or equal to 500 million" to more accurately reflect the protocol spec.
See: https://en.bitcoin.it/wiki/Script#Locktime
2018-05-07 11:49:35 -05:00
Arthur O'Dwyer
8fb3e8946e Add a missing period.
(This sentence appears in Appendix D, in my PDF copy!)
2018-03-26 14:18:40 -07:00
kristen@oreilly.com
ab5ae32bae Edited ch07.asciidoc with Atlas code editor 2018-03-15 10:09:31 -07:00
kristen@oreilly.com
bab88e00aa Edited ch07.asciidoc with Atlas code editor 2018-03-15 09:30:29 -07:00
kristen@oreilly.com
6486a74a86 Edited ch07.asciidoc with Atlas code editor 2018-03-14 11:20:39 -07:00
kristen@oreilly.com
02cf61ecef Edited ch07.asciidoc with Atlas code editor 2018-03-14 11:18:44 -07:00
Andreas M. Antonopoulos
3d22d30685 Errata 163567 2018-03-14 10:58:05 -06:00
kenjiszk
8280075526 fix segit to segwit 2018-03-07 17:00:56 +09:00
kristen@oreilly.com
35c2b2a6c9 Edited ch07.asciidoc with Atlas code editor 2018-03-05 11:37:10 -08:00
kristen@oreilly.com
fef931c6f4 Edited ch07.asciidoc with Atlas code editor 2018-03-05 11:31:29 -08:00
kristen@oreilly.com
81a0e7ee39 Edited ch07.asciidoc with Atlas code editor 2018-03-05 11:29:32 -08:00
Andreas M. Antonopoulos
77d0ca8ee2
Merge pull request #504 from trustkim/patch-1
correct CLTV's note description: CLTV in the inputs -> CLTV in the outputs
2018-02-14 14:58:50 -06:00
trustkim
1cc6c60e28
correct CLTV's note description
I think CLTV is output-level locktime. so it should be corrected
2018-02-09 18:11:58 +09:00
theStack
cf87badbd2 script opcode count IF vs. VERIFY: diff is two ops
v1: HASH160 <expected hash> EQUALVERIFY <Bob's Pubkey> CHECKSIG
v2: HASH160 <expected hash> EQUAL IF <Bob's Pubkey> CHECKSIG ENDIF

ignoring the push-data ops (hash, pubkey),
v1 consists of [HASH160, EQUALVERIFY, CHECKSIG] -> 3 opcodes,
v2 consists of [HASH160, EQUAL, IF, CHECKSIG, ENDIF] -> 5 opcodes,
hence the difference is two opcodes.
2018-02-05 14:23:38 -05:00
Andreas M. Antonopoulos
9c783e1edf Clarified #421 2018-02-03 21:20:42 -06:00
Andreas M. Antonopoulos
8a9869f808 Fixed missing forward reference and clean up #420 2018-02-03 19:31:31 -06:00
Andreas M. Antonopoulos
f5c0df0ed5
Merge pull request #493 from theStack/isstandard
replace "isStandard" by "IsStandard" (ref. to Bitcoin Core function)
2018-02-03 14:05:04 -08:00
Andreas M. Antonopoulos
bd730b5570
wording 2018-02-03 16:04:39 -06:00
Andreas M. Antonopoulos
76e44f226e
Rewrite 3-key limit information 2018-02-03 16:02:41 -06:00
Andreas M. Antonopoulos
1ddd89b658 Several fixes to Segwit/P2SH #440
There were several errors in the address and hash calculations. Fixed errors and added command line examples to clarify the process
2018-02-03 15:38:34 -06:00
Andreas M. Antonopoulos
240b5b0c1c Better P2SH example with bx 2018-02-03 15:36:44 -06:00
Andreas M. Antonopoulos
2fcc1db70f wording 2018-02-03 15:36:16 -06:00
Andreas M. Antonopoulos
4ebfce27d2 wording 2018-02-03 15:35:51 -06:00
theStack
2f1015c23f s/isStandard/IsStandard/ (ref. to Bitcoin Core) 2018-02-03 05:58:52 -05:00
Andreas M. Antonopoulos
3830fafc1d Merge branch 'develop' into feature/move_segwit 2018-02-02 17:10:05 -08:00
Andreas M. Antonopoulos
06158f95bf Moved segwit appendix to ch07 2018-02-02 17:08:49 -08:00
Andreas M. Antonopoulos
32464c86dd Improved P2SH example
Showing use of bx to produce script-hash
2018-02-02 16:59:08 -08:00
Andreas M. Antonopoulos
14cde54626 Add segwit to chapter 7 intro 2018-02-02 15:43:48 -08:00
Andreas M. Antonopoulos
8bdfb3b7da Remove end-of-chapter index reference 2018-02-02 15:42:28 -08:00
Will Binns
f0a57a71ff
Merge pull request #443 from philippgille/patch-1
Add detail to a benefit of P2SH
2018-01-25 00:15:59 +07:00
Philipp Gillé
bacbdd90aa
Fix typo
It should be "a specification" instead of "a specifications".
2017-12-31 18:49:18 +01:00
Philipp Gillé
080f12cdd3
Add detail to a benefit of P2SH
The bullet point previously sounded as if the long script was only stored in the UTXO set when not using P2SH, and stored on the blockchain when using P2SH. This might lead to people thinking it might lead to a smaller blockchain when the script is stored in the UTXO set *instead* of on the blockchain. But without P2SH the long script was stored both in the UTXO set *and* on the blockchain. With P2SH it's only stored on the blockchain, which is a clear advantage over not using P2SH.
2017-12-31 17:54:40 +01:00
Ed Posnak
ebbdbcf683 make binary and hex values consistent 2017-07-31 12:18:31 -04:00
nadams
886b3f3079 Edited ch07.asciidoc with Atlas code editor 2017-05-30 12:16:37 -07:00
Nick Adams
60b2563dd4 deleting some index entries 2017-05-18 15:46:40 -04:00
nadams
552cd7a132 Edited ch07.asciidoc with Atlas code editor 2017-05-18 12:11:06 -07:00
nadams
816b87962b Edited ch07.asciidoc with Atlas code editor 2017-05-18 12:09:49 -07:00
nadams
38d8fff5ef Edited ch07.asciidoc with Atlas code editor 2017-05-18 11:48:41 -07:00
nadams
546fb848f0 Edited ch07.asciidoc with Atlas code editor 2017-05-18 11:47:29 -07:00
Nick Adams
f2fb35dbb0 index edit block technology 2017-05-18 12:03:24 -04:00
nadams
65cf4422ed Edited ch07.asciidoc with Atlas code editor 2017-05-18 06:39:46 -07:00
nadams
0144be9500 Edited ch07.asciidoc with Atlas code editor 2017-05-18 06:38:32 -07:00
nadams
c988ce7b21 Edited ch07.asciidoc with Atlas code editor 2017-05-17 12:14:57 -07:00
nadams
fc845629d3 Edited ch07.asciidoc with Atlas code editor 2017-05-17 12:11:31 -07:00
nadams
66d0d5718f Edited ch07.asciidoc with Atlas code editor 2017-05-17 12:07:50 -07:00
nadams
c85b217907 Edited ch07.asciidoc with Atlas code editor 2017-05-10 13:49:07 -07:00
nadams
2c54ec448d Edited ch07.asciidoc with Atlas code editor 2017-05-10 13:46:46 -07:00
nadams
b17ca0dbfe Edited ch07.asciidoc with Atlas code editor 2017-05-10 13:46:10 -07:00
nadams
c6e9c6a039 Edited ch07.asciidoc with Atlas code editor 2017-05-10 13:00:08 -07:00
nadams
2aa88a4dda Edited ch07.asciidoc with Atlas code editor 2017-05-10 12:55:37 -07:00
Nick Adams
6055cd17f4 AU QC1 edits 2017-05-10 15:06:23 -04:00
Nick Adams
63543d007d PR edits through Ch 8 2017-05-10 10:53:34 -04:00
judymcconville@roadrunner.com
7ea7e20724 Edited ch07.asciidoc with Atlas code editor 2017-05-03 09:40:50 -07:00
judymcconville@roadrunner.com
49e9b0e485 Edited ch07.asciidoc with Atlas code editor 2017-05-03 09:40:30 -07:00
judymcconville@roadrunner.com
b96e794591 Edited ch07.asciidoc with Atlas code editor 2017-05-03 09:39:27 -07:00
judymcconville@roadrunner.com
0ab4cf1e83 Edited ch07.asciidoc with Atlas code editor 2017-05-03 09:37:12 -07:00
judymcconville@roadrunner.com
a7ec75fad4 Edited ch07.asciidoc with Atlas code editor 2017-05-01 12:51:09 -07:00
judymcconville@roadrunner.com
cabfa2ba93 Edited ch07.asciidoc with Atlas code editor 2017-05-01 12:49:35 -07:00
judymcconville@roadrunner.com
8b4c91032c Edited ch07.asciidoc with Atlas code editor 2017-05-01 12:48:29 -07:00
judymcconville@roadrunner.com
13fe9973b4 Edited ch07.asciidoc with Atlas code editor 2017-05-01 12:41:57 -07:00
judymcconville@roadrunner.com
c87b62c876 Edited ch07.asciidoc with Atlas code editor 2017-05-01 12:39:52 -07:00
judymcconville@roadrunner.com
b0ab0992b8 Edited ch07.asciidoc with Atlas code editor 2017-05-01 12:36:46 -07:00
judymcconville@roadrunner.com
e6630726d3 Edited ch07.asciidoc with Atlas code editor 2017-05-01 12:34:12 -07:00
judymcconville@roadrunner.com
22f6661ecb Edited ch07.asciidoc with Atlas code editor 2017-05-01 12:31:51 -07:00
judymcconville@roadrunner.com
3686517aa7 Edited ch07.asciidoc with Atlas code editor 2017-05-01 12:29:06 -07:00
judymcconville@roadrunner.com
83145ad600 Edited ch07.asciidoc with Atlas code editor 2017-05-01 12:26:50 -07:00
judymcconville@roadrunner.com
d34744fb09 Edited ch07.asciidoc with Atlas code editor 2017-05-01 12:22:25 -07:00
judymcconville@roadrunner.com
0aa5e51b6b Edited ch07.asciidoc with Atlas code editor 2017-05-01 12:19:27 -07:00
judymcconville@roadrunner.com
75f8a6eeee Edited ch07.asciidoc with Atlas code editor 2017-05-01 11:38:57 -07:00
judymcconville@roadrunner.com
dd0d2f8880 Edited ch07.asciidoc with Atlas code editor 2017-05-01 11:34:53 -07:00
judymcconville@roadrunner.com
ebb43a9224 Edited ch07.asciidoc with Atlas code editor 2017-05-01 11:33:16 -07:00
judymcconville@roadrunner.com
aeef5dd41e Edited ch07.asciidoc with Atlas code editor 2017-05-01 11:06:38 -07:00
judymcconville@roadrunner.com
2f11ea18d9 Edited ch07.asciidoc with Atlas code editor 2017-05-01 11:05:13 -07:00
judymcconville@roadrunner.com
61a929af9f Edited ch07.asciidoc with Atlas code editor 2017-05-01 11:04:05 -07:00
judymcconville@roadrunner.com
f771798d82 Edited ch07.asciidoc with Atlas code editor 2017-05-01 11:01:02 -07:00
judymcconville@roadrunner.com
c2d1ba4d4f Edited ch07.asciidoc with Atlas code editor 2017-05-01 10:59:47 -07:00
judymcconville@roadrunner.com
9c145d8cad Edited ch07.asciidoc with Atlas code editor 2017-05-01 10:57:38 -07:00
judymcconville@roadrunner.com
24b42883be Edited ch07.asciidoc with Atlas code editor 2017-05-01 10:56:50 -07:00
judymcconville@roadrunner.com
1b632c210a Edited ch07.asciidoc with Atlas code editor 2017-05-01 10:56:11 -07:00
judymcconville@roadrunner.com
cf996b6702 Edited ch07.asciidoc with Atlas code editor 2017-05-01 10:55:08 -07:00
judymcconville@roadrunner.com
d898ca49de Edited ch07.asciidoc with Atlas code editor 2017-05-01 10:54:09 -07:00
judymcconville@roadrunner.com
51dad31617 Edited ch07.asciidoc with Atlas code editor 2017-05-01 10:52:47 -07:00
judymcconville@roadrunner.com
3e77c0ac96 Edited ch07.asciidoc with Atlas code editor 2017-05-01 10:51:03 -07:00
judymcconville@roadrunner.com
113b848e5e Edited ch07.asciidoc with Atlas code editor 2017-05-01 10:49:44 -07:00
judymcconville@roadrunner.com
f6350d028b Edited ch07.asciidoc with Atlas code editor 2017-05-01 10:48:53 -07:00
judymcconville@roadrunner.com
4b223a789f Edited ch07.asciidoc with Atlas code editor 2017-05-01 10:44:53 -07:00
judymcconville@roadrunner.com
615899e984 Edited ch07.asciidoc with Atlas code editor 2017-05-01 10:43:24 -07:00