作者:?胡凱
編者注:原標題為《智能合約系列2:智能合約工程SCE:SmartContractEngineering》
合約是經濟社會運行的基石之一。合約確定了多方交易的時間、期限、地點和內容等,使得合約參與的多方可以在信任或不信任的條件下執行合約協議,保證交易活動的正常和有序運行。合約通常在法律上是具有強制執行力的,且以書面明示為原則。而智能合約是數字社會活動的基礎保障,計算機程序能夠管理機械設備的工作,進行更復雜和更高效的數字財產交易。智能合約代碼甚至可以取代律師和實體機構,來智能處理數字社會交易和法律判定,數字化財產能夠以將智能合約代碼內置到物理實體的方式被創造出來。我們可以預測到智能合約在未來幾年將會有巨大而普遍的需求,而智能合約工程是推動和保障發展的路徑。
1.智能合約工程起源的背景
就像軟件工程對于軟件發展的作用,建立并使用完善的工程化原則,以較經濟的手段獲得能在實際機器上有效運行的可靠軟件的一系列方法;智能合約工程就對于智能合約的作用,就是智能合約開發和維護的一系列經濟工程方法。
智能合約平臺Matic Network推出LINK喂價工具:智能合約平臺Matic Network 19日宣布,將全面推出五種LINK喂價工具(Price Feeds):Matic /USD、USDC/USD、ETH/USD、USDT/USD和DAI/USD。雖然在以太坊之外有很多Chainlink集成,但其中大多數仍在開發中或間接使用以太坊feed。(Cointelegraph)[2020/11/19 21:24:19]
這里可簡要回顧一下軟件工程的發展路徑,從而預測智能合約發展之路。百科詞條給出了簡明解釋,程序設計階段出現在1946年~1955年。此階段的特點是還沒有軟件的概念,程序設計主要圍繞硬件進行開發,規模很小,工具簡單,無明確的開發者和用戶分工。而軟件設計階段出現在1956年~1970年。此階段的特點是:硬件環境相對穩定,出現了軟件開發組,建立了軟件的概念。
隨后軟件系統的規模越來越龐大,高級編程語言層出不窮,應用領域不斷拓寬,開發者和用戶有了明確的分工,社會對軟件的需求量劇增。但軟件產品的質量不高,生產效率低下,導致了60年代中期開始的“軟件危機”的產生,軟件的成本、質量、工期、維護和規模生產都無法保證。從而誕生了軟件工程這一新興的工程學科。
Acala啟動智能合約功能 為波卡DeFi提供以太坊兼容支持:波卡DeFi平臺Acala宣布啟動智能合約功能,為Substrate提供EVM和ink!模塊支持,也就是基于Substrate提供Solidity和Wasm智能合約開發支持。具體來說,Acala支持EVM模塊(又名運行時模塊),本質上是Substrate上的以太坊虛擬機實施,這意味著Acala將支持部署和運行Solidity合約。此外,Acala還支持ink!合約模塊,支持用Rust編寫的基于Wasm(WebAssembly)的Substrate原生智能合約。[2020/9/11]
軟件工程主要研究軟件生產的客觀規律性,建立與系統化軟件生產有關的概念、原則、方法、技術和工具,指導和支持軟件系統的生產活動,以期達到降低軟件生產成本、改進軟件產品質量、提高軟件生產率水平的目標。在軟件開發過程中人們開始研制和使用軟件工具,用以輔助進行軟件項目管理與技術生產,人們還將軟件生命周期各階段使用的軟件工具有機地集合成為一個整體,形成能夠連續支持軟件開發與維護全過程的集成化軟件支援環境,以期從管理和技術兩方面解決軟件危機問題。
動態 | 瑞士安全公司Kudelski Security與智能合約審計公司Hosho達成合作:據Cointelegraph消息,3月19日,瑞士網絡安全解決方案提供商Kudelski Security宣布與智能合約審計公司Hosho建立戰略合作伙伴關系,以為區塊鏈生態系統提供更高的安全性。[2019/3/20]
軟件工程確定了七條基本原理,涉及設計語言、數據庫、軟件開發工具、系統平臺、標準、設計模式等方面。目標是在給定成本、進度的前提下,開發出具有適用性、有效性、可修改性、可靠性、可理解性、可維護性、可重用性、可移植性、可追蹤性、可互操作性的軟件產品。軟件工程極大地推動和保障了現代軟件業規模的生產和應用。
智能合約作為區塊鏈上的一種鏈上軟件代碼被廣泛接受,是存儲在區塊鏈上的一類特殊軟件,可以按預先設定規則、按順序、安全、可驗證的方式實施特定的流程,合約的執行就是根據規定好的合約條款對合約方的合約信息進行的判別,并根據執行的結果采取相應的動作,職能類似于商業交易、監督管理過程中法律、法規的執行者。由于這些特點及執行價值轉移的巨大利益關聯性,智能合約的可信、公信、規模生產和可靠、正確和可監控執行帶來了新的挑戰或危機。
動態 | TrustToken智能合約已通過三項獨立安全審計:據coindesk報道,加密創業公司TrustToken周三宣布,其智能合約已通過Certik、SlowMist和Zeppelin的三項獨立安全審計,未發現任何漏洞。此外,根據該公司的數據,其TrueUSD(TUSD)穩定幣的月交易量已超過11億美元,市值為2億美元。此外,據CCN消息,TrueUSD與Nexo合作,為TUSD持有者提供加密貨幣即時貸款。[2018/12/20]
這些危機越發引起人們的極大關注,典型案例如2016年6月17日,運行在以太坊公有鏈上的TheDAO智能合約遭遇攻擊,該合約籌集的公眾款項不斷被一個函數的遞歸調用轉向它的子合約,涉及總額三百多萬以太幣,這是一起嚴重的智能合約被攻擊事件。2018年5月美鏈(BEC)被爆出安全漏洞,被黑客用以太坊ERC-20智能合約中BatchOverFlow漏洞攻擊,引發價格閃崩,據英國和新加坡的研究人員統計,超過34000個智能合約都有可被利用的安全隱患等,智能合約危機已經凸顯。筆者在2017年5月首次提出了智能合約工程方法,并申請了相關的專利,下面簡單介紹其定義和主要內容。
聲音 | 法中委員會秘書長林碧溪:中法兩國深入區塊鏈及人工智能合作:據人民網消息,2018年第五屆中法團隊合作創新獎即將在巴黎揭幕,法中委員會秘書長林碧溪表示,今年提交的候選項目中,區塊鏈、人工智能、數字化工具的項目明顯增加,且涉及領域非常廣泛,覆蓋核電站老化預測的解決方案、區塊鏈學歷認證及智慧城市能源管理等領域。林碧溪指出,中法兩國創新合作的多樣性,體現在創新合作的跨領域特征中。當今世界技術革新非常迅速,從區塊鏈、人工智能到數字應用,都需要中法合作團隊及時掌握并適應形勢,才能致力于開發未來的新技術。[2018/11/30]
2.智能合約工程的定義和主要內容
智能合約工程的定義:它是融合軟件工程、智能化方法和法律代碼化技術的智能合約系統化、規模化、判定化的開發、維護和執行過程。
一個基本的智能合約工程的開發框架如圖1所示:
圖1智能合約工程框架
這個框架中,主要融合了三個方面技術,一是傳統軟件工程的理論方法,形式化方法是合約進行確定性高級別驗證的有效手段,通過形式化語言把合約中的概念、判斷、推理轉化成智能合約模型,可以消除自然語言的歧義性、不通用性,進而采用形式化工具對智能合約建模、分析和驗證,最后自動生成驗證過的合約代碼這一周期過程;二是合約需要參與方的共同認定并盡可能智能化,合約代碼和文本需要保證一致的一致性測試性,并需要區塊鏈分布式機制保證其代碼和執行的不可更改和可信性,采用自然語言識別、認知理論和機器學習方法盡可能使復雜契約規則能夠準確地自動轉換為智能合約代碼,同時,智能合約生產過程必須更為智能,更容易為用戶理解、編寫、部署和執行監管;三是智能合約需要法律層面的規制,計算法律研究如何使用計算機技術以電子媒介的方式來實現對法律、法規、合同、章程等法律文件的表達和自動執行,保障通過計算機代碼所設定的規則與現實世界中的法定規則保持相一致。此外,描述合約交易實體間復雜耦合作用,體現價值的變化和轉移也是很有意義的,可采用數學方法分析對系統穩定性和可達集進行計算分析,指導智能合約的自動代碼生成。同時,提供系列化軟件工具來支持智能合約的全生命周期的服務產生、組合應用、驗證、部署和運維。
我們定義了智能合約工程指導下生產的智能合約應當滿足的十個方面基本屬性:
1)合法性:代碼符合法律規制,所控資產擁有所有權,且合法有效;
2)公信性:合約代碼產生機制必須具有公信、權威性,結果可驗證;
3)證據性:過程數據和場景必須被安全地存儲,可被用于法律證據;
4)一致性:智能合約應與文本一致,經過專業人士制定審核;
5)智能性:能準確反映合約各方的智力共識和復雜自然語言邏輯;
6)可信性:靜態產生和動態執行過程必須具有正確、安全、可靠和可監管;
7)可觀察性:合約方能夠通過用戶界面去觀察關于合約執行的所有狀態;
8)可驗證性:合約方執行合約的過程是運行時可驗證;
9)自強制性:對于違反合約行為的制裁必須是強制性的;
10)接入控制:合約相關的背景、場景和關系都應該作為資產保護起來,只有發生爭執的時候,才有權限地可把內容提供給第三方檢驗。
開發者在智能合約工程指導下需要完成一系列工程開發階段,包括以下基本方面:
1)M:合約建模,根據約定進行合約建模或模板填寫;
2)F:合約功能屬性和非功能屬性正確性驗證;
3)G:合約代碼的自動或半自動生成;
4)D:合約軟件的開發,開發出智能化的合約軟件;
5)C:合約代碼與合約文本之間的一致性測試,滿足約定;
6)L:合約代碼滿足契約的法律化約定,具有存證和自動判定功能。
此外,智能合約工程還將催生創新的擴展理論、方法、開發模型、計劃、標準和工具等,后期系列文章將逐步展開介紹。
可以預期區塊鏈和智能合約的關系就好像互聯網技術發展早期建網和網絡應用的關系,發展智能合約規模化生產技術就像軟件工程對發展軟件起到的重要作用一樣,必將成為區塊鏈產業和驅動應用落地最為有價值的事業。
作者胡凱為北京航空航天大學分布式實驗室、北京航空航天大學云南創新研究院教授。
Tags:USD區塊鏈以太坊ACACompound USDT區塊鏈運用的技術中不包括哪一項項op幣價格跟隨以太坊價格走radiocaca幣最新
10月下旬,中共中央局就區塊鏈技術發展現狀和趨勢進行集體學習。習近平總書記在主持學習時強調,要加快推動區塊鏈技術和產業創新發展,積極推進區塊鏈和經濟社會融合發展.
1900/1/1 0:00:00數字貨幣牛熊轉化極快,少數人賺,多數人虧。如今,福音來了,所有在數字貨幣上虧過錢的人,都可以通過起訴Bitfinex要求賠償,原因是Bitfinex涉嫌通過USDT操縱比特幣和其他數字貨幣市場.
1900/1/1 0:00:00前言:本文旗幟鮮明地認為對ASIC友好的算法才能讓普通的礦機生產商參與進來,而抗ASIC的加密算法反而為普通礦機廠商設立了很高的門檻,導致大型廠商更有競爭優勢,從而讓挖礦走向中心化.
1900/1/1 0:00:0011月8日,由巴比特主辦的“2019世界區塊鏈大會?烏鎮”順利召開,在“技術改變世界:區塊鏈底層基礎設施”分論壇上,YottaChain創始人王東臨以《中國領跑存儲公鏈》為主題進行了分享.
1900/1/1 0:00:00前言:Maker開啟了多資產抵押的新版本,這是DeFi發展史上的重要事件。雖然從資產發行量和資產成本上,去中心化的穩定幣Dai都不及中心化的穩定幣,但它開啟了一種全新類型的穩定幣,是加密史上的重.
1900/1/1 0:00:00月報摘要 “二級市場行情總覽”:10月全球區塊鏈數字資產日均市值下跌11.15%,交易量上漲18.06%.
1900/1/1 0:00:00