日本黄色一级经典视频|伊人久久精品视频|亚洲黄色色周成人视频九九九|av免费网址黄色小短片|黄色Av无码亚洲成年人|亚洲1区2区3区无码|真人黄片免费观看|无码一级小说欧美日免费三级|日韩中文字幕91在线看|精品久久久无码中文字幕边打电话

當(dāng)前位置:首頁 > 物聯(lián)網(wǎng) > 區(qū)塊鏈
[導(dǎo)讀] 傳說,在人類成功打造出第一臺(tái)超級(jí)智能電腦之時(shí),決定做一個(gè)小測驗(yàn),來試試看這臺(tái)超級(jí)電腦的能耐到底能到多少?實(shí)驗(yàn)的設(shè)計(jì)很簡單:讓超級(jí)電腦計(jì)算圓周率是多少。于是,在人們還沒反應(yīng)出來的一瞬間,這臺(tái)超能電

傳說,在人類成功打造出第一臺(tái)超級(jí)智能電腦之時(shí),決定做一個(gè)小測驗(yàn),來試試看這臺(tái)超級(jí)電腦的能耐到底能到多少?實(shí)驗(yàn)的設(shè)計(jì)很簡單:讓超級(jí)電腦計(jì)算圓周率是多少。于是,在人們還沒反應(yīng)出來的一瞬間,這臺(tái)超能電腦已經(jīng)攻占整個(gè)地球,然后對外太空發(fā)動(dòng)了戰(zhàn)爭,征服整個(gè)銀河系,把整個(gè)可知的宇宙空間變成了巨大的超能電腦,最后花上了無盡的時(shí)間,只為了計(jì)算出人類給它的這個(gè)問題:圓周率。

這是我在閱讀人類大歷史這本書中讀到的一篇故事,原文討論的內(nèi)容是算法程序?qū)τ谌祟惖耐{;那些不斷產(chǎn)生出來并且持續(xù)的在優(yōu)化、改進(jìn),聲稱用以改善人類生活的算法軟件,既使一開始創(chuàng)作者本身是完全出于良好善意,或是學(xué)術(shù)研究而建立的系統(tǒng),最終仍可能會(huì)完全失控的造成毀滅性的結(jié)果。這個(gè)故事讓我想起了Bitcoin等加密貨幣的挖礦程序算法,在過去一段時(shí)間以來對我們生活的沖擊影響。還記得2017年加密貨幣正夯時(shí),全球的挖礦熱潮引爆的全民搶電瘋,當(dāng)時(shí)就有媒體報(bào)導(dǎo)指出,加密貨幣的挖礦機(jī)器將會(huì)導(dǎo)致社會(huì)大眾無電可用,甚至有人傳言,那年夏天的幾次臺(tái)電臨時(shí)跳電事件,就是太多人在挖比特幣造成的。

這篇文章,就是要來談?wù)劚忍貛磐诘V背后的那個(gè)算法:加密哈希函數(shù)。

原本呢,我是計(jì)劃在第二篇就開始進(jìn)入程序開發(fā)的部分,只是我發(fā)現(xiàn)到,不先了解哈希函數(shù)的原理功能、或是留給讀者自行g(shù)oogle,會(huì)破壞這個(gè)系列文章的完整性,尤其是在實(shí)作內(nèi)存塊鏈的不可逆性、或是Key創(chuàng)建等功能,讀者的感受與理解會(huì)有差異,所以還是決定,在進(jìn)入開發(fā)區(qū)塊鏈之前,寫一篇文章來專門介紹哈希函數(shù),尤其是其在密碼學(xué)方面的應(yīng)用

哈希函數(shù)應(yīng)用在區(qū)塊鏈的哪些地方?

1. 區(qū)塊鏈透過哈希函數(shù)的結(jié)果,將數(shù)據(jù)串聯(lián)成為一條難以篡改的連接

2. 比特幣、以太幣、瑞波幣等電子加密貨幣(題外話,有人說要正名為密碼貨幣),透過哈希函數(shù)產(chǎn)生錢包地址

3. 在加密貨幣挖礦(Mining)的世界,使用Hash Rate: TH/s(trillions of hashes per second)來計(jì)算區(qū)塊鏈 network的運(yùn)算能力

4. Bitcoin透過調(diào)整哈希函數(shù)的難度,控制整個(gè)Bitcoin network平均每10分鐘產(chǎn)生一個(gè)block內(nèi)存塊。

那我們就開始來了解哈希函數(shù)算法吧

首先,哈希函數(shù)具有下列兩項(xiàng)特點(diǎn):

1. 無論傳入(input)哈希函數(shù)的數(shù)據(jù)量大小,哈希函數(shù)回傳的數(shù)據(jù)長度都是固定的相同的input,回傳

2. 相同的output;不同的input,回傳不同的output;

換句話說,哈希函數(shù)的回傳結(jié)果(稱之為hash value),是一個(gè)長度一致,但是數(shù)據(jù)內(nèi)容卻是獨(dú)一無二(unique)的數(shù)值。所以,如果看到兩個(gè)完全不一樣的”hash value”,我們就可以推斷其原始的input一定是不一樣的;反之,兩個(gè)相同的hash value,其原本的input值則會(huì)是一模一樣的。

我們可以用Python內(nèi)置的SHA-256 Hash Algorithm,展示一下上述的哈希函數(shù)特性

import hashlib

x1=”my 1st Bitcoin”.encode()

y1=hashlib.sha256(x1).hexdigest()

x2=”I am not Satoshi Nakamoto”.encode()

y2=hashlib.sha256(x2).hexdigest()

print(f’y1= {y1}’)

print(f’y2= {y2}’)

print(f’y1 include {len(y1)} words’)

print(f’y2 include {len(y2)} words’)

如果尚未安裝Python,可以利用下面這個(gè)網(wǎng)址試試,看看將my 1st Bitcoin Hash后的值是不是和上圖用Python跑出來的值(y1=后面的那串)是一樣的:

https://anders.com/區(qū)塊鏈/hash.html

加密哈希函數(shù)是哈希函數(shù)于密碼學(xué)上的一項(xiàng)應(yīng)用,上述的SHA-256就是一個(gè)加密哈希函數(shù)的實(shí)作產(chǎn)品。

哈希函數(shù)還有另一項(xiàng)特點(diǎn):one-way(單向)function

以上述的Python程序?yàn)槔?,在已知input值=”my 1st Bitcoin”,透過sha256 funcTIon,可以快速的算出hash value=”a5e4c0673fcedff2bc2174123e97b511d5d17f4317869e7bd60d0a6d3d7fa1c6”;但反過來說,我們想從”a5e4c0673fcedff2bc2174123e97b511d5d17f4317869e7bd60d0a6d3d7fa1c6”這一串?dāng)?shù)據(jù)中反推出input的值:”my 1st Bitcoin”,唯一的方式是透過暴力解法,也就是不斷地丟字串給sha256 funcTIon,直到得到hash value是一樣時(shí),也就是傳入的input字串為”my 1st Bitcoin”時(shí),才能得到答案。各位可以想像這猜中的機(jī)率是多低?如果你能一猜就中,那你也不用在這研究內(nèi)存塊鏈了,直接去買樂透比較快。

區(qū)塊鏈透過上述哈希函數(shù)的三個(gè)特性,構(gòu)架起了內(nèi)存塊鏈中的數(shù)據(jù),只要一經(jīng)寫入就無法修改的獨(dú)特功能。

各位可以到下面這個(gè)網(wǎng)址體驗(yàn)區(qū)塊鏈如何透過哈希函數(shù),緊密的連接起每一個(gè)Block內(nèi)存塊,并且堅(jiān)固地保障了已經(jīng)建立完成的Block區(qū)塊,其內(nèi)容是難以被竄改的。

https://anders.com/區(qū)塊鏈/區(qū)塊鏈.html

Base58編碼

在文章前頭,我們曾提到過哈希函數(shù)應(yīng)用在加密貨幣錢包地址的例子,你可能在一些網(wǎng)站或Blog上,看到過這些亂碼數(shù)字。實(shí)際應(yīng)用上,部落客或是賣家,會(huì)提供一組很像亂碼的Bitcoin addresses,讓你可以支付比特幣給對方;Bitcoin addresses,看起來似乎是一堆英數(shù)字的隨機(jī)編碼,但其中也是有特殊的設(shè)計(jì):所有的Bitcoin addresses都是使用Base58進(jìn)行編碼。

解釋Base58前,先來看看比較常見的,例如已經(jīng)應(yīng)用在Email上的電腦編碼:Base64。Base64編碼包含了26個(gè)小寫英文字母、26個(gè)大寫英文字母、10個(gè)阿拉伯?dāng)?shù)字(0~9),和兩個(gè)特殊字元(+和?—?)。

Base58是Base64的子集合,提供一個(gè)較高可讀性、和較容易發(fā)現(xiàn)和防范錯(cuò)誤的編碼格式,因此廣為眾多加密貨幣所使用。Base58剔除了容易辨識(shí)錯(cuò)誤、或是在某些字體格式看起來十分類似的字元:數(shù)字0,大寫的英文字母O,小寫的英文字母l、大寫的英文字母I,并且移除了特殊字元(+和?—?)。換句話說,Base58就是包含了大、小寫英文字母,和阿拉伯?dāng)?shù)字,但移除了四個(gè)字元(0,O,l,I)的集合:

Bitcoin’s Base58 alphabet:

123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz

Hashing Power

最后,如果對于Bitcoin Network hashing power有興趣的讀者,可以到下面這個(gè)網(wǎng)址查看Bitcoin網(wǎng)絡(luò)的hash rate變化:

https://www.區(qū)塊鏈.com/charts/hash-rate

粗略估算,Bitcoin network整體的hashing power,從2009年一秒鐘不到一個(gè)MegaHash(MH/sec),如今一秒鐘已經(jīng)超過40個(gè)ExaHash(EH/sec),光用表面數(shù)字計(jì)算,成長幅度超過40兆。

HashPower的單位換算可參考下列網(wǎng)址

https://coinguides.org/hashpower-converter-calculator/

OK,我們已經(jīng)透過兩篇文章對內(nèi)存塊鏈有ㄧ定程度的基礎(chǔ)了解了,該是動(dòng)手寫一個(gè)區(qū)塊鏈程序的時(shí)候了。

在進(jìn)入下一篇文章進(jìn)行開發(fā)前,請各位先確定電腦的開發(fā)環(huán)境已經(jīng)安裝好下列Python版本和相關(guān)modules

· Python 3.6+

· flask 0.12.2

· requests 2.18.4

我另外使用了兩個(gè)flask module,以建立表單和畫面

· flask-wtf

· flask-bootstrap

上述modules皆可透過PIP安裝

· pip install flask

· pip install requests

· pip install flask-wtf

· pip install flask-bootstrap

那,就先請各位準(zhǔn)備好Python環(huán)境啦。

本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點(diǎn),本站亦不保證或承諾內(nèi)容真實(shí)性等。需要轉(zhuǎn)載請聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請及時(shí)聯(lián)系本站刪除。
換一批
延伸閱讀

LED驅(qū)動(dòng)電源的輸入包括高壓工頻交流(即市電)、低壓直流、高壓直流、低壓高頻交流(如電子變壓器的輸出)等。

關(guān)鍵字: 驅(qū)動(dòng)電源

在工業(yè)自動(dòng)化蓬勃發(fā)展的當(dāng)下,工業(yè)電機(jī)作為核心動(dòng)力設(shè)備,其驅(qū)動(dòng)電源的性能直接關(guān)系到整個(gè)系統(tǒng)的穩(wěn)定性和可靠性。其中,反電動(dòng)勢抑制與過流保護(hù)是驅(qū)動(dòng)電源設(shè)計(jì)中至關(guān)重要的兩個(gè)環(huán)節(jié),集成化方案的設(shè)計(jì)成為提升電機(jī)驅(qū)動(dòng)性能的關(guān)鍵。

關(guān)鍵字: 工業(yè)電機(jī) 驅(qū)動(dòng)電源

LED 驅(qū)動(dòng)電源作為 LED 照明系統(tǒng)的 “心臟”,其穩(wěn)定性直接決定了整個(gè)照明設(shè)備的使用壽命。然而,在實(shí)際應(yīng)用中,LED 驅(qū)動(dòng)電源易損壞的問題卻十分常見,不僅增加了維護(hù)成本,還影響了用戶體驗(yàn)。要解決這一問題,需從設(shè)計(jì)、生...

關(guān)鍵字: 驅(qū)動(dòng)電源 照明系統(tǒng) 散熱

根據(jù)LED驅(qū)動(dòng)電源的公式,電感內(nèi)電流波動(dòng)大小和電感值成反比,輸出紋波和輸出電容值成反比。所以加大電感值和輸出電容值可以減小紋波。

關(guān)鍵字: LED 設(shè)計(jì) 驅(qū)動(dòng)電源

電動(dòng)汽車(EV)作為新能源汽車的重要代表,正逐漸成為全球汽車產(chǎn)業(yè)的重要發(fā)展方向。電動(dòng)汽車的核心技術(shù)之一是電機(jī)驅(qū)動(dòng)控制系統(tǒng),而絕緣柵雙極型晶體管(IGBT)作為電機(jī)驅(qū)動(dòng)系統(tǒng)中的關(guān)鍵元件,其性能直接影響到電動(dòng)汽車的動(dòng)力性能和...

關(guān)鍵字: 電動(dòng)汽車 新能源 驅(qū)動(dòng)電源

在現(xiàn)代城市建設(shè)中,街道及停車場照明作為基礎(chǔ)設(shè)施的重要組成部分,其質(zhì)量和效率直接關(guān)系到城市的公共安全、居民生活質(zhì)量和能源利用效率。隨著科技的進(jìn)步,高亮度白光發(fā)光二極管(LED)因其獨(dú)特的優(yōu)勢逐漸取代傳統(tǒng)光源,成為大功率區(qū)域...

關(guān)鍵字: 發(fā)光二極管 驅(qū)動(dòng)電源 LED

LED通用照明設(shè)計(jì)工程師會(huì)遇到許多挑戰(zhàn),如功率密度、功率因數(shù)校正(PFC)、空間受限和可靠性等。

關(guān)鍵字: LED 驅(qū)動(dòng)電源 功率因數(shù)校正

在LED照明技術(shù)日益普及的今天,LED驅(qū)動(dòng)電源的電磁干擾(EMI)問題成為了一個(gè)不可忽視的挑戰(zhàn)。電磁干擾不僅會(huì)影響LED燈具的正常工作,還可能對周圍電子設(shè)備造成不利影響,甚至引發(fā)系統(tǒng)故障。因此,采取有效的硬件措施來解決L...

關(guān)鍵字: LED照明技術(shù) 電磁干擾 驅(qū)動(dòng)電源

開關(guān)電源具有效率高的特性,而且開關(guān)電源的變壓器體積比串聯(lián)穩(wěn)壓型電源的要小得多,電源電路比較整潔,整機(jī)重量也有所下降,所以,現(xiàn)在的LED驅(qū)動(dòng)電源

關(guān)鍵字: LED 驅(qū)動(dòng)電源 開關(guān)電源

LED驅(qū)動(dòng)電源是把電源供應(yīng)轉(zhuǎn)換為特定的電壓電流以驅(qū)動(dòng)LED發(fā)光的電壓轉(zhuǎn)換器,通常情況下:LED驅(qū)動(dòng)電源的輸入包括高壓工頻交流(即市電)、低壓直流、高壓直流、低壓高頻交流(如電子變壓器的輸出)等。

關(guān)鍵字: LED 隧道燈 驅(qū)動(dòng)電源
關(guān)閉