-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathoutput.html
210 lines (210 loc) · 32.7 KB
/
output.html
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
<center>
<h1>
PeerAssets
</h1>
</center>
<sub>
<center>
<h3>
Peer-to-peer Assets
</h3>
</center>
<p></sub></p>
<p>by: Peerchemist <script type="text/javascript">
<!--
h='protonmail.ch';a='@';n='peerchemist';e=n+a+h;
document.write('<a h'+'ref'+'="ma'+'ilto'+':'+e+'" clas'+'s="em' + 'ail">'+e+'<\/'+'a'+'>');
// -->
</script><noscript>peerchemist at protonmail dot ch</noscript>, April, 2016.</p>
<h1 id="introduction">Introduction</h1>
<p>The idea to use the blockchain to transmit other tokens of value beside the blockchain's native currency first became mainstream in 2013. <sup><a href="http://www.coindesk.com/colored-coins-paint-sophisticated-future-for-bitcoin">1</a></sup>. One of the first proposals of implementation was "EPOBC" <sup><a href="https://github.com/chromaway/ngcccbase/wiki/EPOBC_simple">2</a></sup> which inspired "Colored Coins" by M. Rosenfeld in 2012. <sup><a href="https://bitcoil.co.il/BitcoinX.pdf">3</a></sup>. Both proposals utilize Bitcoin's OP_RETURN transaction output to encode the metadata and describe the asset. Ever since then, Bitcoin's ecosystem was enriched by different variations of the idea like OpenAssets <sup><a href="https://github.com/OpenAssets/open-assets-protocol/blob/master/specification.mediawiki">4</a></sup> and CoinSpark <sup><a href="https://github.com/coinspark">5</a></sup> which are collectively called "Colored Coins", after the original idea. Bitcoin ecosystem offers other ways to transact with assets like Counterparty <sup><a href="http://counterparty.io/">6</a></sup> and Omni <sup><a href="http://www.omnilayer.org/">7</a></sup> but they are not considered "Colored Coins" as they use auxiliary currencies. Other crypto-currencies and crypto-platforms have their own implementations which are either variations on the OP_RETURN scheme or differ radically on Bitcoin's implementation and are frequently integrated in the core functionality, like NXT which has taken this concept a long way with integrated asset exchange and dividend payout system <sup><a href="https://nxt.org/what-is-nxt/asset-exchange/">8</a></sup>.</p>
<p>The following paper describes a simple, blockchain agnostic protocol which enables peers to issue and transact with assets. A simple explanation on how PeerAssets protocol works would be that it works by writing and reading messages on the blockchain, where messages represent assets and addresses represent peers. PeerAsset protocol based assets can be utilized to represent any type of asset like bonds or equity. PeerAssets can also represent real life objects, and by doing so confirm their existence on the blockchain. PeerAssets is a <em>light</em> protocol, as it utilizes no extra layers over the underlying blockchain. It does not require external value tokens beside the blockchain's native currency, which is used to pay transaction fees. PeerAssets does not participate in organizing nor maintaining of the public ledger, but takes advantage of its stability and trustworthiness. PeerAssets can work on top of every cryptocurrency that is forked from Bitcoin and has kept a compatible codebase, which includes Peercoin, Litecoin and alike.</p>
<p>PeerAssets require no hard nor soft fork of the host network, but it requires development of PeerAssets aware client. PeerAssets is also inspired by the original idea of "Colored Coins" and uses OP_RETURN to write data on the blockchain, but offers some optimizations to reduce amount of data written in the OP_RETURN and enables easy querying of the blockchain for relevant transactions with some extra features like shareholder voting and dividends payouts.</p>
<h1 id="protocol-overview">Protocol overview</h1>
<p>The PeerAssets protocol uses the blockchain to distribute messages and store them permanently. PeerAsset messages are written as metadata attached to transactions, which inseparably tie them to: sending address, transaction ID and block height. Issuing an asset is equal to writing a properly formatted message, then signing it with your unique signature and sticking it on the public bulletin board. After doing that, the entire network will know that you have issued this new asset, which can represent some real object or company stock. The transaction ID of the transaction that posted this message to the blockchain is now considered an asset ID. When you want to send a specific quantity of an asset to another peer, you just write another message stating that you (the issuer) transfer some quantity of the asset to a new owner and sign the message with your unique signature. Now everyone interested can see that you have given up control of said amount of the asset and transferred it to another peer. You can no longer claim that you have the full issued quantity of the asset under your control as everyone who has seen the message would know that you are lying. Instead of sending tokens of value which also represent assets, PeerAssets work by referencing the recieving addresses/peers in the messages posted publicly. PeerAssets security model works the same as card counting in casino card games. <sup><a href="https://en.wikipedia.org/wiki/Card_counting">9</a></sup>If you know the size and type of the card deck and you have those two queens in your hand, you are sure that the other guy is lying if he claims that he has three. Each time an asset is created, a new deck (of cards) is spawned and every transaction of a card (asset) is visible to all interested parties, so everyone can keep count of the cards in the deck.</p>
<p>PeerAsset protocol is based on four simple rules:</p>
<ol style="list-style-type: decimal">
<li>Math is simple, 2+2 will always equal four (card counting).</li>
<li>If it is wrong, ignore it (ignore bogus messages).</li>
<li>Nature of blockchain allows proof-of-timeline security model.</li>
<li>First come first served, protocol will always favor older message.</li>
</ol>
<h4 id="terminology-of-peerassets">Terminology of PeerAssets</h4>
<p>I have found this analogy with a deck of cards the easiest way to describe the protocol, so it is used throughout the paper to explain the internals of the protocol as well as the transaction types.</p>
<p><em>Deck spawning</em> – A transaction which creates a deck.</p>
<p><em>Deck</em> – A declarative message which describes the nature of the asset, and its quantity; contains cards.</p>
<p><em>Card</em> – A quantifiable piece of the deck which effectively behaves like a single asset.</p>
<p><em>Card transfer</em> – A transaction which transfers the ownership of a card to another owner.</p>
<p><em>Bogus transfer</em> - A card transfer that does not have a legit timeline.</p>
<h2 id="proof-of-timeline">Proof of timeline</h2>
<p><em>A timeline is a way of displaying a list of events in chronological order.</em> <sup><a href="https://en.wikipedia.org/wiki/Timeline">10</a></sup></p>
<p>Each deck spawning transaction is public and every subsequent card transfer. Following PeerAsset transactions from their source, the deck spawning transaction, to the present describes the timeline of the deck. Each peer on the network follows this timeline independently. Based on the timeline, it registers whether or not there is an card in his possession. When there is a verifiable path from a deck spawning transaction to a card transfer that makes peer the legit card owner, that is called <em>proof of timeline</em>.</p>
<p><em>Proof of timeline</em> is the security and verification model for PeerAsset protocol. It is based on three basic blockchain properties - <strong>immutability</strong>, <strong>linear time passage</strong> and <strong>public visibility</strong> of all data.</p>
<p>The proof of timeline model depends on the fact that the block which contains PeerAsset transactions is considered valid and is accepted by all network nodes. It is imperative that all peers involved in PeerAsset transactions wait more than one confirmation so they are sure nothing will corrupt the timeline they are depending on for their asset transfers. A transaction should not be considered confirmed until it is a certain number of blocks deep. <sup><a href="https://en.bitcoin.it/wiki/Confirmation">11</a></sup></p>
<div class="figure">
<img src="timeline.png" alt="Deck timeline" />
<p class="caption">Deck timeline</p>
</div>
<p><sub>Figure 1. Timeline of the deck</sub></p>
<p>If we look from block height 231700, from this timeline it can be deducted that:</p>
<ul>
<li>Issuer has issued 1200 cards</li>
<li>David holds 87.5 cards</li>
<li>Bob holds 182.5 cards</li>
<li>Alice holds 80 cards</li>
<li>Issuer is left with 850 cards.</li>
</ul>
<p>This timeline is verifiable by every peer on the network.</p>
<p>Fourth rule of PeerAssets (first come first served) is elemental to producing valid timeline. Proof of timeline uses the serialization order of transactions which is: block height, transaction sequence number in block and transaction output sequence number in transaction. This allows client to always be sure which message is older, even if they are in the same block. In general client which is assembling timeline for any specific deck will look for lower sequence number if two conflicting transactions are in the same block. <sup><a href="http://bitcoin.stackexchange.com/questions/2025/what-is-txins-sequence">12</a></sup> The serialization order is chosen by the miner, mostly at random so this is not something that can be exploited by malicious peers.</p>
<h2 id="pay-to-taghash-p2th">Pay-to-tagHash (P2TH)</h2>
<p>Pay to tag hash paper proposes a <em>tagging mechanism, Pay-to-TagHash (P2TH), that allows efficient lookup of application specific transactions based on the addition of transaction outputs to deterministic tagged addresses. P2TH also allows thin clients to find application specific messages using standard functions included in standard client software or via publicly available blockexplorers.</em> <sup><a href="http://peerassets.github.io/P2TH/">13</a></sup></p>
<p>One of the outstanding traits of the PeerAssets protocol is that it utilizes P2TH to mark the relevant transactions, so it enables fast and easy querying of them. This allows unmatched performance and enables very light clients. P2TH is important piece of PeerAsset protocol design as it allows much cleaner implementation of client and it reduces quantity of data that needs to be packed in the OP_RETURN. P2TH paper was inspired by first draft of PeerAssets paper. In return, the present version of PeerAssets paper is inspired by the proposals found in P2TH paper. Original idea of the P2TH paper was to make traversing of the blockchain for PeerAsset transactions more efficient, however it turns out that that is just the start of its possible applications.</p>
<p>PeerAssets uses P2TH for:</p>
<ul>
<li>Deterministic tag addresses</li>
<li>Tagging transactions</li>
<li>Querying tagged transactions</li>
</ul>
<p>For more details on how is this done, please read the P2TH paper which is located in the same Github repository.</p>
<hr />
<h1 id="how-it-works">How it works</h1>
<p>PeerAssets protocol has four elemental transaction types:</p>
<ol style="list-style-type: decimal">
<li><p>Deck spawning transaction</p></li>
<li><p>Card issue transaction</p></li>
<li><p>Card burn transaction</p></li>
<li><p>Card transfer transaction</p></li>
</ol>
<p>Please note that when I simplify the protocol by saying "Bob" or "Alice" that it actually means an address. It can also mean that it is a multisig address in control of several people.</p>
<h2 id="deck-spawning-transaction">Deck spawning transaction</h2>
<p><em>Deck spawning transaction – a transaction which starts deck's timeline and describes the parameters of the deck.</em></p>
<p>Deck is spawned by sending transaction that includes outputs to:</p>
<ul>
<li>P2TH derived address as marker</li>
<li>OP_RETURN with descriptive metadata</li>
</ul>
<p>Paying to tag hash - derived address serves as a marker and permanently marks this transaction as PeerAssets transaction. P2TH address is calculated from "PeerAssets/deck spawn" string + salt. OP_RETURN transaction carries descriptive metadata like name, url, etc. The transaction ID of such transaction is also considered an asset ID so it is distinguishable from all the other assets on the blockchain.</p>
<p>Example:</p>
<blockquote>
<p>Bob writes the message that he is issuing an asset and publishes it on the blockchain. To write it on the blockchain, Bob will send a transaction which carries needed data. Message includes name of the asset and other optional metadata like url of the asset page or forum post. In the following representation, paying to P2TH derived address is equal to "Hey!". You can think of it as a secret code, one which is understood by all the PeerAsset protocol aware clients to have a specific meaning, in this case that this transaction is about PeerAssets. Deck spawning starts the asset timeline, starting from block height when transaction was included and progressing linearly to the future. Due to nature of the blockchain this message is now permanent and immutable.</p>
</blockquote>
<blockquote>
<div class="figure">
<img src="DeckSpawning.png" alt="Bob declares the asset" />
<p class="caption">Bob declares the asset</p>
</div>
</blockquote>
<p><sub>Figure 2. Bob declares the asset</sub></p>
<p>This deck is now described by:</p>
<ul>
<li>Sender's address (issuing address)</li>
<li>P2TH tag</li>
<li>Block height</li>
<li>Transaction ID</li>
<li>Metadata in OP_RETURN</li>
</ul>
<p>Using transaction ID as deck (asset) ID is important as all subsequent card transfers of this deck must refer back to spawning transaction via pay-to-tagHash derived from the asset ID. Please note that balance of this deck is still zero, as quantity of the cards is still not defined. This was just declaration.</p>
<h3 id="multisig-deck-spawns">Multisig deck spawns</h3>
<p>As Bitcoin and most of its forks support multi-signature transactions, there is integrated way to issue an asset which is tied to several privkeys as multisig deck. Multisig deck would function the same as normal deck, but the deck spawning transaction and card issue transaction would require multiple signing keys. Card consumers should favor multisig decks as it stops a single issuer from diluting the supply of the cards at will. In case of a multisig deck spawn, Bob would be a group of people who would sign the deck spawning transaction with several private keys. Using multisig deck not only increases credibility but also security of the deck.</p>
<h2 id="card-issue-transaction">Card issue transaction</h2>
<p><em>Card issue transaction - A transaction which prints out the cards and attaches them to a specific deck</em></p>
<p>Bob has declared "yellow rabbit" deck, but he did not state how many cards that deck will contain. That is declared in a special transaction called "card issue transaction." This type of transaction is separate from a deck spawning transaction to allow the deck consuming community to regulate the supply of the cards in their deck. For example, this allows a company which has issued equity via PeerAssets to raise extra funds by issuing and selling new stocks to investors. Naturally, this dilutes the supply of equity and it is important that shareholders agree on it. No other address but the one that has spawned a deck can issue cards for it, and only the spawning address can have a negative balance of the cards. Each transaction originating from spawning address creates new cards, which means that every output of issuing address is new card issue.</p>
<p>Card issue transaction pays to:</p>
<ul>
<li>Card receiver (new owner)</li>
<li>P2TH address derived from asset ID</li>
<li>OP_RETURN stating quantity</li>
</ul>
<p>Example:</p>
<blockquote>
<p>Bob decides to issue 1000 "yellow rabbit" assets. He sends 1000 "yellow rabbit" tokens from the spawning address to his other address, making him the original owner of "yellow rabbit" assets. After this event, by reading the timeline of the asset it can be verified that 1) There are 1000 "yellow rabbit" assets, 2) Bob now holds 1000 of those assets, 3) Issuing address now has a balance of -1000 "yellow rabbit" assets.</p>
</blockquote>
<p>An issuing address is allowed to have a negative balance, and it serves as a checksum for the entire timeline as it is possible to verify the final balance against it.</p>
<p><code>balance(deck_spawning_addr) = 0 - sum(balance(all_accounts_on_the_timeline))</code></p>
<p>There is no integrated way to stop the deck issuer from just “printing” more cards. This is left to the market and relationship between the deck issuer and the card consumers. The market should react to events like this without any need for external influence. Breaking an economic social contract should result with the asset value spiraling to zero. Due to this, it is recommended to issue a deck using multisig transactions including more than one shareholder.</p>
<h2 id="card-burn-transaction">Card burn transaction</h2>
<p>Cards can be destroyed (burned) by simply assigning the cards back to issuing address. All inputs on the issuing address are card burns. Final balance of the issuing address always represents negative balance equal to all the cards in circulation. Equation mentioned above must always be valid:</p>
<p><code>balance(deck_spawning_addr) = 0 - sum(balance(all_accounts_on_the_timeline))</code></p>
<h2 id="card-transferring-transaction">Card transferring transaction</h2>
<p><em>Card transfer – a transaction which transfers the ownership of a card to another owner</em></p>
<p>Card transferring transaction pays to:</p>
<ul>
<li>P2TH derived from asset ID</li>
<li>OP_RETURN stating quantity</li>
<li>Address of the new owner</li>
</ul>
<p>Example:</p>
<blockquote>
<p>Alice and everyone else on the network can now see that Bob has issued an asset with specific name, quantity and other metadata. It is verifiable that Bob owns full quantity of "yellow rabbit" asset. Alice wants to trade with Bob for specific quantity of the asset, and Bob agrees to trade so he can send Alice some of his assets. Bob now writes the message, with attached metadata stating quantity of the asset being transferred and transaction ID of transaction when that assets deck was spawned (asset ID).</p>
</blockquote>
<blockquote>
<div class="figure">
<img src="CardTransfer.png" alt="Bob transfers a card to Alice" />
<p class="caption">Bob transfers a card to Alice</p>
</div>
</blockquote>
<p><sub>Figure 3. Bob transfers a card to Alice</sub></p>
<p>Now each peer on the network can see that Bob has transferred control of 100 "yellow rabbit" cards to Alice.</p>
<p>To be valid, a card transfer must originate from an address which is mentioned in that deck's timeline, meaning that it has some assets assigned to it. The assigned quantity of the asset to such an address has to be larger than the user is trying to spend, otherwise it does not have valid timeline and is considered <em>bogus</em>. Each receiving client will verify for following conditions:</p>
<ul>
<li>Does senders address belong to the deck's timeline?</li>
<li>Does sender have more or equal to quantity of the cards that are included in transaction?</li>
<li>Incoming quantitiy of cards must be a float non-zero number.</li>
</ul>
<p>As a consequence of this mechanism, losing control of the address that has PeerAssets assigned means assets become immovable and un-spendable, which confirms that security model of PeerAssets is solid. A card transfer transaction uses same P2TH mechanism to tag it as PeerAssets transaction, however it uses transaction ID of deck spawning transaction to design P2TH address so this address refers to the deck spawning transaction ID. This enables quick and easy verification of the timeline.</p>
<h2 id="verifying-ownership">Verifying ownership</h2>
<p><em>Verifying ownership is verifying if the address is mentioned in the timeline of some deck.</em></p>
<p>What if Alice decides to double spend her assets, and how to verify someone owns an asset? For example, > Alice agrees to trade 10 of her "yellow rabbit" assets with David for his 25 "marble" assets and 10 of that same "yellow rabbit" assets back to Bob for another batch of 30 "marble" assets. In this example Alice is trying to double spend her 10 "yellow rabbit" assets. How will Bob and David protect them selves from being cheated? The asset ID of "marble" asset is publicly known, as it was publicly published by the asset issuer and referenced to Alice at the moment they were sent to her. Alice must check if David really controls 25 of "marble" assets, and to do that Alice must know two facts:</p>
<blockquote>
<p>David's address: P9ffxiPYxk3EK4iro83vAszFY2i4XNKVGd</p>
</blockquote>
<blockquote>
<p>Asset ID: 548ad20c2081d88bd053520d9b33f2e7b59ebd819dc3a87f68c0d8cd152523fd</p>
</blockquote>
<p>What is lacking is the proof that there is timeline that assigns the asset to David.</p>
<p>Next step is to verify that David owns "marble" asset. Alice does this by verifying <em>proof-of-timeline</em> for David's address and asset ID. By knowing transaction ID of this deck's spawning transaction, Alice knows where to start traversing. Alice starts traversing from block height of 223400 until the current block height.</p>
<blockquote>
<div class="figure">
<img src="TraversingBlockchain.png" alt="Alice traverses the blockchain" />
<p class="caption">Alice traverses the blockchain</p>
</div>
</blockquote>
<p><sub>Figure 4. Alice traverses the blockchain</sub></p>
<p>As shown in the illustration Alice query’s the blockchain for transaction ID: 548ad20c2081d88bd053520d9b33f2e7b59ebd819dc3a87f68c0d8cd152523fd which is the transaction ID of a deck spawning transaction for "marble" asset. Transaction ID is pointer to block height (223400) when the deck was started, so it is obvious where to start traversing and assembling the timeline. From the timeline spanning from that transaction to the present Alice can find how many assets were created, who is the original owner and the balance of issuing address, as well as who holds the cards now. By following all PeerAssets transactions marked with P2TH derived from that asset ID since that block height Alice learns about timeline of "marble" asset and verifies that at block height of 248057 issuer of "marble" deck has transferred 30 cards to David. If this block is confirmed by six or more miners, this is considered proof that David does indeed control the assets as promised.</p>
<p>To conclude the trade agreement, Alice transfers her 10 "yellow rabbit" cards over to David and David transfers his 25 "marble" cards to Alice. Both of the card transfer transactions are now part of each asset's timeline, and are verifiable by anyone.</p>
<p>If "David" is just an another alias in control of Bob, Alice does not know that. The PeerAsset protocol does not deal with that. An address is an address. Later on if Bob wants to group his cards into one address, he will simply transfer them to a single address.</p>
<h2 id="doublespending">Doublespending</h2>
<p>There is no mechanism to stop peers from sending out bogus PeerAsset transactions or trying to double spend a card (asset). However, thanks to proof-of-timeline it is easy for any counterparty on the other side of the bogus card transfer to simply dismiss it as bogus, as explained in PeerAsset rule #2. Only thing that the dishonest peer accomplishes is spending transaction fees.</p>
<h3 id="alice-tries-to-double-spend">Alice tries to double spend</h3>
<p>After transferring her "yellow rabbit" cards to David, Alice no longer controls any of the "yellow rabbit" cards. Still, she will try to double spend them by transferring them to Bob again. Alice confirms that Bob holds ownership in the same way she did for Davids assets, so she proceeds with the trade. Bob registers the incoming transaction which is transferring him 10 of "yellow rabbit" cards, however Bob does not know if this is double spend or not. Bob waits for 6 confirmations of that transaction to make sure that blockchain can not be reversed. After six confirmations Bob traverses timeline for "yellow rabbit" deck to verify if he can claim to own the asset from now on. After blockchain scan is complete Bob figures out that Alice did not have those cards in the first place, as she has transferred them to David 18 blocks before trying to send them to Bob. As there is no legit <em>proof-of-timeline</em> that gets the cards to Bob, Bob dismisses the transfer as bogus and cancels trade with Alice.</p>
<p>If Alice does this two card transfer transactions in the same block, the valid one is the one that gets included in the block first and the other one is considered bogus.</p>
<hr />
<h1 id="using-peerassets-to-issue-equity">Using PeerAssets to issue equity</h1>
<p>While missing out on power features like smart contracts or control over block time interval, PeerAssets might be ideal framework for decentralized companies and organizations that require only basic tools and don't need to dedicate themselves to a fully independent and separate network. If such an organization simply requires the means of tracking ownership, voting and dividend payout, then PeerAssets is the perfect tool for the job. Organizations and companies using PeerAssets do not need to bother with blockchain security nor network infrastructure. PeerAssets will just work for them. The nature of the PeerAssets allows companies and organizations to be blockchain and cryptocurrency agnostic for the most time. The only dependency being the transaction fees of the underlying blockchain, but if necessary that can be obfuscated from the end user as well. Another advantage of PeerAssets is that the protocol can work on top of various blockchains that are based on the original Bitcoin technology, Bitcoin included. This means that PeerAsset decks are movable between blockchains as they please, however a legit version of a company's assets can only exist on one blockchain at a time. This ability to move between blockchains makes PeerAssets a much less risky choice, as a company's assets will always be safe in the event the network that hosts their assets becomes unstable or abandoned by its developers. Organizations utilizing PeerAssets can pick the blockchain that fits them best and move on to another one whenever they choose to. How this is actually done will be described in future addendums of this paper. PeerAssets is a great fit for issuing company equity as it allows easy and reliable transacting, dividend payments, full control over the supply of stocks by extending the deck or burning the cards and voting proportionally to ownership. In the following text I will propose several ways in which PeerAssets can be used to pay out dividends and allow shareholder voting. A future PeerAssets based company or organization does not have to utilize any, as these are just a showcase and an intro to possible features. However, I do recommend that the rules and scheme of both are communicated to future shareholders before the deck has been spawned by the issuer.</p>
<h2 id="paying-out-dividends">Paying out dividends</h2>
<p>As anyone reading the blockchain can easily verify who holds the assets in any given moment, paying out dividends is very straightforward. Dividend payout starts by identifying which addresses are tied to ownership of an asset, verifying how many assets are tied to them, calculating their stake in the company and multiplying that number with total dividend sum and sending coins to those shareholders. Some other parameters can be implemented into counting, as per wish of asset issuer/dividend payer, for example exempting last 300 blocks from count which is effectively doing a snapshot of chain from two days ago and eliminating “last minute” changes in asset ownership. This “integrated” feature effectively and simply implements 'ex-dividend'.</p>
<h2 id="shareholder-voting">Shareholder voting</h2>
<p>Voting can be implemented in similar manner to the dividend payout. As it is known who has how much of an asset, a snapshot of the blockchain can be taken in any given moment and it can be verified who has how many cards at that time interval. After that, all shareholders would be instructed to send a transaction from address connected with asset to a specific “voting” address created by the vote starter. Voting address should be proof-of-burn address for obvious reasons. If the vote is simple yes or no, both “yes” and “no” can be two unique addresses. With simple mathematics of counting transactions to “yes” and “no” addresses and considering each shareholders stake in the deck, it is easy to conclude who has the upper hand in this vote. There is no need for central authority to count the votes, as anyone on the network can verify the results. Also, there is no point in trying to prevent shareholders from casting multiple votes as "protocol will always favor the older message". Only the first vote is counted. Additional votes are simply ignored.</p>
<h3 id="voting-schemes">Voting schemes</h3>
<p>More variations of the voting scheme can be implemented, like considering <em>card age</em> in the calculation. Card age is a term derived from "coin age" <sup><a href="https://github.com/ppcoin/ppcoin/blob/master/src/kernel.cpp">14</a></sup> used in Peercoin and it represents a product of quantity of the tokens and days they have been idle. In PeerAssets context card age is a product of the card balance of the account and the time which card has spent being immovable with that account (address). This is also easily verifiable from the deck's timeline by anyone on the network. The higher the card age, the more influential the vote is from this shareholder. Naturally, this can be capped to 30 days or any other number. This kind of voting scheme rewards long term holders.</p>
<p>Another variation of voting scheme would be the scheme which rewards frequent voters, "active voting". Voting is done by sending transaction to "voting address" and due to nature of the blockchain, those votes are permanently recorded. That feature enables gathering of statistics on each asset holder and his voting habits. This data would enable the asset community to reward frequent voters by multiplying their voting power with some factor.</p>
<p>Further variations are possible by crossing over card-age scheme and active voting. This is just an example to show what can be done with this toolbox. The reference client will eventually offer these features packed in easy to use interface.</p>
<h1 id="conclusion">Conclusion</h1>
<p>PeerAssets offers the framework that enables communities and organizations to issue and transact with assets. If PeerAssets "cards" represent equity in a company, a set of financial tools are at hand like voting and dividend payout. When compared to alternatives like OpenAssets, CoinSpark and others, PeerAssets reduces the amount of data that needs to be written in OP_RETURN, therefore it reduces blockchain bloat. The great advantage of PeerAssets over competing protocols is control over the asset supply and integrated voting and dividend payout system, which many might find extremely useful.</p>
<hr />
<h1 id="references">References:</h1>
<p><a href="http://www.coindesk.com/colored-coins-paint-sophisticated-future-for-bitcoin">1</a>: Coindesk, Colored coins in media, 2013</p>
<p><a href="https://github.com/chromaway/ngcccbase/wiki/EPOBC_simple">2</a>: EPOBC proposal</p>
<p><a href="https://bitcoil.co.il/BitcoinX.pdf">3</a>: M. Rosenfeld, Overview of Colored Coins, 2012</p>
<p><a href="https://github.com/OpenAssets/open-assets-protocol/blob/master/specification.mediawiki">4</a>: OpenAssets specification</p>
<p><a href="https://github.com/coinspark">5</a>: CoinSpark</p>
<p><a href="http://counterparty.io/">6</a>: Counterparty</p>
<p><a href="http://www.omnilayer.org/">7</a>: Omni</p>
<p><a href="https://nxt.org/what-is-nxt/asset-exchange/">8</a>: NXT asset exchange</p>
<p><a href="https://en.wikipedia.org/wiki/Card_counting">9</a>: Card counting</p>
<p><a href="https://en.wikipedia.org/wiki/Timeline">10</a>: Wikipedia article - timeline</p>
<p><a href="https://en.bitcoin.it/wiki/Confirmation">11</a>: Bitcoin wiki - Bitcoin confirmations</p>
<p><a href="http://bitcoin.stackexchange.com/questions/2025/what-is-txins-sequence">12</a>: Bitcoin stackexchange - what is transaction sequence order</p>
<p><a href="http://peerassets.github.io/P2TH/">13</a>: Hans Robeers, Pay-to-TagHash (P2TH): Tagging blockchain transactions for eficient queryabilitity, 2016</p>
<p><a href="https://github.com/ppcoin/ppcoin/blob/master/src/kernel.cpp">14</a>: Peercoin source code - coin age</p>
<hr />