mirror of
https://github.com/mimblewimble/grin.git
synced 2025-01-21 03:21:08 +03:00
Small formatting, typographical, and grammatical edits to documentation (#117)
* Fix indentation issue on structured list * Fix small typographical and grammatical errors in docs
This commit is contained in:
parent
798849d7e9
commit
33688e9958
5 changed files with 17 additions and 17 deletions
|
@ -2,7 +2,7 @@
|
||||||
|
|
||||||
Find an area you can help with and do it. Open source is about collaboration and open participation. Try to make your code look like what already exists and submit a pull request.
|
Find an area you can help with and do it. Open source is about collaboration and open participation. Try to make your code look like what already exists and submit a pull request.
|
||||||
|
|
||||||
The [list of issues](https://github.com/ignopeverell/grin/issues) is a good place to start, especially the ones tagged as "help wanted" (but don't let that stop you from looking at others).If you're looking for additional ideas, the code includes `TODO` comments for minor to major improvements. Grep is your friend.
|
The [list of issues](https://github.com/ignopeverell/grin/issues) is a good place to start, especially the ones tagged as "help wanted" (but don't let that stop you from looking at others). If you're looking for additional ideas, the code includes `TODO` comments for minor to major improvements. Grep is your friend.
|
||||||
|
|
||||||
Additional tests are rewarded with an immense amount of positive karma. So is documentation.
|
Additional tests are rewarded with an immense amount of positive karma. So is documentation.
|
||||||
|
|
||||||
|
|
|
@ -98,7 +98,7 @@ Let the mining server find a few blocks, then stop (just ctrl-c) the mining serv
|
||||||
|
|
||||||
The following outlines a more advanced example simulating a multi-server network with transactions being posted.
|
The following outlines a more advanced example simulating a multi-server network with transactions being posted.
|
||||||
|
|
||||||
For the sake of example, we're going to run three nodes with varying setups. Create two more directories beside your node1 directory, called node2 and node3. If you want to clear data from your previous run (or anytime you want to reset the blockchain and all peer data,) just delete the wallet.dat file in the server1 directory and run rm -rf .grin to remove grin's database.
|
For the sake of example, we're going to run three nodes with varying setups. Create two more directories beside your node1 directory, called node2 and node3. If you want to clear data from your previous run (or anytime you want to reset the blockchain and all peer data) just delete the wallet.dat file in the server1 directory and run rm -rf .grin to remove grin's database.
|
||||||
|
|
||||||
### Node 1: Genesis and Miner
|
### Node 1: Genesis and Miner
|
||||||
|
|
||||||
|
|
|
@ -3,7 +3,7 @@ Blockchain Syncing
|
||||||
|
|
||||||
We describe here the different methods used by a new node when joining the network
|
We describe here the different methods used by a new node when joining the network
|
||||||
to catch up with the latest chain state. We start with reminding the reader of the
|
to catch up with the latest chain state. We start with reminding the reader of the
|
||||||
following assumptions, that are all characteristics of Grin or MimbleWimble:
|
following assumptions, which are all characteristics of Grin or MimbleWimble:
|
||||||
|
|
||||||
* All block headers include the root hash of all unspent outputs in the chain at
|
* All block headers include the root hash of all unspent outputs in the chain at
|
||||||
the time of that block.
|
the time of that block.
|
||||||
|
@ -38,7 +38,7 @@ provide history archival and allow later checks and verifications to be made.
|
||||||
Identical to other blockchains:
|
Identical to other blockchains:
|
||||||
|
|
||||||
* If all nodes we're connected to are dishonest (sybil attack or similar), we can
|
* If all nodes we're connected to are dishonest (sybil attack or similar), we can
|
||||||
be lied about the whole chain state.
|
be lied to about the whole chain state.
|
||||||
* Someone with enormous mining power could rewrite the whole history.
|
* Someone with enormous mining power could rewrite the whole history.
|
||||||
* Etc.
|
* Etc.
|
||||||
|
|
||||||
|
@ -65,7 +65,7 @@ With this information it can verify:
|
||||||
* the sum of all UTXO commitments equals the expected money supply
|
* the sum of all UTXO commitments equals the expected money supply
|
||||||
* the root hash of all UTXOs match the root hash in the block header
|
* the root hash of all UTXOs match the root hash in the block header
|
||||||
|
|
||||||
Once the validation done, the peer can download and validate the blocks content
|
Once the validation is done, the peer can download and validate the blocks content
|
||||||
from the horizon up to the head.
|
from the horizon up to the head.
|
||||||
|
|
||||||
While this algorithm still works for very low values of `Z` (or in the extreme case
|
While this algorithm still works for very low values of `Z` (or in the extreme case
|
||||||
|
|
|
@ -11,7 +11,7 @@ treat Merkle sum trees as the default option, and address the sums here.
|
||||||
|
|
||||||
A design goal of Grin is that all structures be as easy to implement and
|
A design goal of Grin is that all structures be as easy to implement and
|
||||||
as simple as possible. MimbleWimble introduces a lot of new cryptography
|
as simple as possible. MimbleWimble introduces a lot of new cryptography
|
||||||
so it should made as easy to understand as possible. Its validation rules
|
so it should be made as easy to understand as possible. Its validation rules
|
||||||
are simple to specify (no scripts) and Grin is written in a language with
|
are simple to specify (no scripts) and Grin is written in a language with
|
||||||
very explicit semantics, so simplicity is also good to achieve well-understood
|
very explicit semantics, so simplicity is also good to achieve well-understood
|
||||||
consensus rules.
|
consensus rules.
|
||||||
|
@ -31,8 +31,8 @@ The root sum should be equal to the sum of all excesses since the genesis.
|
||||||
|
|
||||||
Design requirements:
|
Design requirements:
|
||||||
|
|
||||||
1. Efficient additions and updating from unspent to spent
|
1. Efficient additions and updating from unspent to spent.
|
||||||
2. Efficient proofs that a specific output was spent
|
2. Efficient proofs that a specific output was spent.
|
||||||
3. Efficient storage of diffs between UTXO roots.
|
3. Efficient storage of diffs between UTXO roots.
|
||||||
4. Efficient tree storage even with missing data, even with millions of entries.
|
4. Efficient tree storage even with missing data, even with millions of entries.
|
||||||
5. If a node commits to NULL, it has no unspent children and its data should
|
5. If a node commits to NULL, it has no unspent children and its data should
|
||||||
|
@ -147,8 +147,8 @@ structure of the tree without needing all the hashes, and can determine which
|
||||||
nodes are siblings, and so on.
|
nodes are siblings, and so on.
|
||||||
|
|
||||||
In the output set each node also commits to a sum of its unspent children, so
|
In the output set each node also commits to a sum of its unspent children, so
|
||||||
a validator knows if it is missing data on unspent coins, by checking whether
|
a validator knows if it is missing data on unspent coins by checking whether or
|
||||||
this sum on a pruned node is zero or not.
|
not this sum on a pruned node is zero.
|
||||||
|
|
||||||
|
|
||||||
## Algorithms
|
## Algorithms
|
||||||
|
@ -200,8 +200,8 @@ In the example above, we have 2 chunks X[A,B] and Y[C,D] and a root chunk
|
||||||
G[M,E]. The cutoff height H=1 and the root height R=3.
|
G[M,E]. The cutoff height H=1 and the root height R=3.
|
||||||
|
|
||||||
Note that each non-root chunk is a complete and fully valid MMR sum tree in
|
Note that each non-root chunk is a complete and fully valid MMR sum tree in
|
||||||
itself. The the root chunk, with each chunk replaced with a single pruned
|
itself. The root chunk, with each chunk replaced with a single pruned node,
|
||||||
node is also a complete and fully valid MMR.
|
is also a complete and fully valid MMR.
|
||||||
|
|
||||||
As new leaves get inserted in the tree, more chunks get extracted, reducing the
|
As new leaves get inserted in the tree, more chunks get extracted, reducing the
|
||||||
size of the root chunk.
|
size of the root chunk.
|
||||||
|
|
|
@ -8,12 +8,12 @@ The grin blockchain includes the following types of data (we assume prior
|
||||||
understanding of the MimbleWimble protocol):
|
understanding of the MimbleWimble protocol):
|
||||||
|
|
||||||
1. Transaction outputs, which include for each output:
|
1. Transaction outputs, which include for each output:
|
||||||
1. A Pedersen commitment (33 bytes).
|
1. A Pedersen commitment (33 bytes).
|
||||||
2. A range proof (over 5KB at this time).
|
2. A range proof (over 5KB at this time).
|
||||||
2. Transaction inputs which are just output references (32 bytes).
|
2. Transaction inputs, which are just output references (32 bytes).
|
||||||
3. Transaction "proofs", which include for each transaction:
|
3. Transaction "proofs", which include for each transaction:
|
||||||
1. The excess commitment sum for the transaction (33 bytes).
|
1. The excess commitment sum for the transaction (33 bytes).
|
||||||
2. A signature generated with the excess (71 bytes average).
|
2. A signature generated with the excess (71 bytes average).
|
||||||
4. A block header includes Merkle trees and proof of work (about 250 bytes).
|
4. A block header includes Merkle trees and proof of work (about 250 bytes).
|
||||||
|
|
||||||
Assuming a blockchain of a million blocks, 10 million transactions (2 inputs, 2.5
|
Assuming a blockchain of a million blocks, 10 million transactions (2 inputs, 2.5
|
||||||
|
|
Loading…
Reference in a new issue