原創(chuàng):劉教鏈
一片花飛減卻春,風(fēng)飄萬點正愁人。且看欲盡花經(jīng)眼,莫厭傷多酒入唇。
五月的加密市場,BTC(比特幣)在6萬刀踟躕不前,春去花落一片紅。無甚熱鬧,但徜徉湖邊,看綠水青山,心底寧靜,倉位致遠。
BTC乃加密行業(yè)之根。總量2100萬之上限,乃BTC之本。一切都從這個神奇的數(shù)字展開。可是它,為何是這樣一個數(shù)字呢?
教鏈在2020年12月5日文章《為什么比特幣最多只會有2100萬枚?》中,就曾介紹過這個數(shù)字的計算方法。簡而言之是這樣的:
1. 每區(qū)塊產(chǎn)量 50 BTC
2. 每21萬個區(qū)塊,產(chǎn)量減半
使用等比數(shù)列求和可以輕松算出,最終BTC的總產(chǎn)量為:(50 + 25 + 12.5 + 6.25 + 3.125 + ...) x 21萬 = 2100萬枚。
進一步的,調(diào)節(jié)“挖礦”難度使得大約每10分鐘產(chǎn)生一個新區(qū)塊,即每小時6個新區(qū)塊,21萬個區(qū)塊就大概是人間4年。
這也就是比特幣4年產(chǎn)量減半周期的來歷。
但是,如此只是對既定事實的一個鋪敘而已。一是缺乏一些細節(jié)的考察;二是并未真正揭示比特幣發(fā)明人中本聰為何要選擇和設(shè)計這樣一個數(shù)字的原因。
先說細節(jié)。
首先,2100萬并非2100萬,而是2,099,999,997,690,000。對,后面這個數(shù)字比2100萬要大1億倍,即大約是2100萬億。在比特幣系統(tǒng)內(nèi)部,都是這個萬億級的整數(shù)。
當(dāng)我們把BTC“展示”為這個整數(shù)點上8位小數(shù)位,也就變成了2 0,99 9,99 9.97 690 000。這里我用空格提示了上面作為整數(shù)時的千分位分割點。我們一眼就會看到,中本聰選擇8位小數(shù)位其實有些奇怪的,因為這樣會導(dǎo)致8位小數(shù)的BTC整數(shù)部分的逗號分割點,和系統(tǒng)內(nèi)真正的整數(shù)的逗號分割點不一致。
8位小數(shù)位,也就是1億分之一,這個就不太西方。眾所周知,英文里對數(shù)字采用千分位分割,所以計數(shù)法的單位是千(thousand)、百萬(million)、十億(billion)、萬億(trillion)。英文里并沒有“億”這個單位。而中國的計數(shù)法略有不同,是以4位數(shù)字也就是萬分位為分割的,乃有萬、億、萬億。
2100萬億用萬分位分割就是這樣的:2099 9999 9769 0000;2100萬帶8位小數(shù)則是這樣的:2099 9999.9769 0000。都是4小節(jié),每小節(jié)4位數(shù)字,沒有任何混亂。所以看起來,8位小數(shù)位,1億分之一,嗯,這很東方。
其次,2100萬億之所以是2,099,999,997,690,000而不是精確的2,100,000,000,000,000,也正是因為8位小數(shù)位的精度限制。
上文的等比數(shù)列(50 + 25 + 12.5 + 6.25 + 3.125 + ...)并非真正的無窮數(shù)列,而是當(dāng)它減小到0.0000 0001之后,再減半就歸零了。因此,這是一個截斷了的有窮數(shù)列,其加和就要小于無窮數(shù)列求和的結(jié)果100。所以,乘以21萬之后,最終結(jié)果也要略小于2100萬。
第三,注意第一點的敘述,8位小數(shù)位和小數(shù)點僅僅是一個“展示”層面的設(shè)計。在系統(tǒng)內(nèi)部只有那個萬億級的整數(shù)。
既然僅僅是“展示”,那么其實小數(shù)點是可以任意挪動的?,F(xiàn)在點在8位小數(shù)的位置,以后也可以點在5位或者4位小數(shù)的位置。
比如,20,999,999,976.90000(5位小數(shù)),或者2099 9999 9769.0000(4位小數(shù))。
那么,8位小數(shù)時的1枚比特幣,當(dāng)移位到5位小數(shù)時,就顯示為1000,移位到4位小數(shù)時,就顯示為10000。相應(yīng)的,原來的0.001或者0.0001 BTC現(xiàn)在就會顯示為1。
這移位的想法并非教鏈杜撰的,而是中本聰真實的想法。在2009年4月12日中本聰給Mike Hearn的回信[1]中,他這樣寫道:
"My choice for the number of coins and distribution schedule was an educated guess.? It was a difficult choice, because once the network is going it's locked in and we're stuck with it.? I wanted to pick something that would make prices similar to existing currencies, but without knowing the future, that's very hard.? I ended up picking something in the middle.? If Bitcoin remains a small niche, it'll be worth less per unit than existing currencies.? If you imagine it being used for some fraction of world commerce, then there's only going to be 21 million coins for the whole world, so it would be worth much more per unit.? Values are 64-bit integers with 8 decimal places, so 1 coin is represented internally as 100000000.? There's plenty of granularity if typical prices become small.? For example, if 0.001 is worth 1 Euro, then it might be easier to change where the decimal point is displayed, so if you had 1 Bitcoin it's now displayed as 1000, and 0.001 is displayed as 1."
“我對硬幣數(shù)量和發(fā)行時間表的選擇是經(jīng)過深思熟慮的。這是一個艱難的選擇,因為一旦網(wǎng)絡(luò)開始運行,它就會被鎖定,我們就會被它困住。我想選擇一種能讓價格與現(xiàn)有貨幣相近的(數(shù)字),但在不知道未來的情況下,這很難做到。最后,我選擇了中間值。如果比特幣仍然是一種小眾貨幣,那么它的單位價值就會低于現(xiàn)有貨幣。如果你想象比特幣被用于世界商業(yè)的某個部分,那么全世界只有 2100 萬個比特幣,所以它的單位價值會更高。幣值是小數(shù)點后 8 位的 64 位整數(shù),因此 1 枚硬幣在內(nèi)部表示為 100000000。如果典型(應(yīng)用場景的)價格變小,則有足夠的粒度。例如,如果 0.001 價值 1 歐元,那么改變小數(shù)點的顯示位置可能會更容易(查看和使用),所以如果你有 1 個比特幣,現(xiàn)在顯示為 1000,而 0.001 顯示為 1?!?/p>
有人說,對于普遍的64位計算機而言,如果我們使用64位二進制數(shù)同時表示整數(shù)和小數(shù)(又稱浮點數(shù)),那么最安全的做法是把整數(shù)限制在浮點數(shù)的整數(shù)部分可表達的上限內(nèi)。
稍微了解計算機原理的朋友都知道,計算機內(nèi)部并沒有什么小數(shù),都是0和1的數(shù)位。所謂64位整數(shù),就是指64個0或者1所組成的二進制整數(shù)。對應(yīng)10進制就是2^64 = 18446744073709551616。這個數(shù)字要遠大于2100萬億。但是,如果要讓計算機能夠處理浮點數(shù),那么就要把64位中拆出一部分用來表達小數(shù)部分,還要留出1位來表示正負(fù)號。這就成了IEEE 754浮點數(shù)編碼標(biāo)準(zhǔn)。其中標(biāo)準(zhǔn)定義,雙精度浮點數(shù)用64位二進制是這樣編碼的:

這樣一來,整數(shù)部分就只能使用53位,也就是最大不超過2^53 = 9007199254740992。而如果希望容易測試結(jié)果是否為整數(shù),則最好不要超過2^51 = 2251799813685248。如此,可以選擇22(百萬億),但是22不是一個“三角數(shù)”(triangular number),所以中本聰選擇了21(百萬億)。

據(jù)此許多人認(rèn)為中本聰選擇2100萬億,大大地方便了各種編程語言處理比特幣數(shù)量相關(guān)的計算。
不過,教鏈看了中本聰?shù)泥]件后,覺得中本聰也許并沒有這么復(fù)雜的想法?;蛘咚拇_思忖過,但是并沒有講透他的全盤考慮。他只是講,也曾經(jīng)考慮過其他數(shù)字,比如4200萬億,但是感覺太大了,于是就折中成了2100萬億。在2011年1月10日中本聰回復(fù)Mike Hearn的郵件[2]中,他是這樣寫的:
"It works out to an even 10 minutes per block:
21000000 / (50 BTC * 24hrs * 365days * 4years * 2) = 5.99 blocks/hour
"I fudged it to 364.58333 days/year.? The halving of 50 BTC to 25 BTC is after 210000 blocks or around 3.9954 years, which is approximate anyway based on the retargeting mechanism's best effort.
"I thought about 100 BTC and 42 million, but 42 million seemed high.
"I wanted typical amounts to be in a familiar range.? If you're tossing around 100000 units, it doesn't feel scarce.? The brain is better able to work with numbers from 0.01 to 1000.
"If it gets really big, the decimal can move two places and cents become the new coins."
看起來,中本聰是先定了時間諸參數(shù),而后調(diào)整區(qū)塊產(chǎn)量和總量,并思考多大的數(shù)字較為適合。
依中本聰?shù)囊馑?,大多?shù)人手里的BTC數(shù)量最好在0.01到1000之間,不要動輒就搞個6、7位數(shù)的幣,那樣會缺乏稀缺感。
以上就是關(guān)于2100萬枚總量數(shù)字的來龍去脈。