作者:?胡凱
編者注:原標題為《智能合約系列2:智能合約工程SCE:SmartContractEngineering》
合約是經濟社會運行的基石之一。合約確定了多方交易的時間、期限、地點和內容等,使得合約參與的多方可以在信任或不信任的條件下執行合約協議,保證交易活動的正常和有序運行。合約通常在法律上是具有強制執行力的,且以書面明示為原則。而智能合約是數字社會活動的基礎保障,計算機程序能夠管理機械設備的工作,進行更復雜和更高效的數字財產交易。智能合約代碼甚至可以取代律師和實體機構,來智能處理數字社會交易和法律判定,數字化財產能夠以將智能合約代碼內置到物理實體的方式被創造出來。我們可以預測到智能合約在未來幾年將會有巨大而普遍的需求,而智能合約工程是推動和保障發展的路徑。
1.智能合約工程起源的背景
就像軟件工程對于軟件發展的作用,建立并使用完善的工程化原則,以較經濟的手段獲得能在實際機器上有效運行的可靠軟件的一系列方法;智能合約工程就對于智能合約的作用,就是智能合約開發和維護的一系列經濟工程方法。
數據:Cardano Plutus智能合約超3000個,ADA錢包突破350萬:8月5日消息,據Cardano Blockchain Insights數據顯示,Cardano Vasil 硬分叉前達到兩個里程碑,截至目前基于 Plutus 腳本的 Cardano 智能合約數量達到 3031 個,該指標展示了 Cardano 允許用戶編寫與區塊鏈交互的應用程序的能力。此外,ADA 錢包已突破 350 萬,截至最新 8 月 4 日數據為 3,505,141 個。
此前消息,原本計劃于 7 月底進行的 Cardano 主網 Vasil 硬分叉升級再次推遲,延遲或將打到數周時間。[2022/8/6 12:05:43]
這里可簡要回顧一下軟件工程的發展路徑,從而預測智能合約發展之路。百科詞條給出了簡明解釋,程序設計階段出現在1946年~1955年。此階段的特點是還沒有軟件的概念,程序設計主要圍繞硬件進行開發,規模很小,工具簡單,無明確的開發者和用戶分工。而軟件設計階段出現在1956年~1970年。此階段的特點是:硬件環境相對穩定,出現了軟件開發組,建立了軟件的概念。
巧克力COCO智能合約已通過Beosin(成都鏈安)安全審計:據官方消息,Beosin(成都鏈安)近日已完成巧克力coco智能合約項目的安全審計服務。據介紹,巧克力COCO是基于波場底層打造的一個去中心化開放金融底層基礎設施。結合波場TICP跨鏈協議,訂單簿DEX,智能挖礦等等功能的創新和聚合,進而打造全面去中心化金融平臺。巧克力COCO無ICO、零預挖且零私募,社區高度自治。合約地址:THTpbtqfoGmL6HwqaGrWKd7aJAcUTbCnoC審計報告編號:202010042149[2020/10/5]
隨后軟件系統的規模越來越龐大,高級編程語言層出不窮,應用領域不斷拓寬,開發者和用戶有了明確的分工,社會對軟件的需求量劇增。但軟件產品的質量不高,生產效率低下,導致了60年代中期開始的“軟件危機”的產生,軟件的成本、質量、工期、維護和規模生產都無法保證。從而誕生了軟件工程這一新興的工程學科。
軟件工程主要研究軟件生產的客觀規律性,建立與系統化軟件生產有關的概念、原則、方法、技術和工具,指導和支持軟件系統的生產活動,以期達到降低軟件生產成本、改進軟件產品質量、提高軟件生產率水平的目標。在軟件開發過程中人們開始研制和使用軟件工具,用以輔助進行軟件項目管理與技術生產,人們還將軟件生命周期各階段使用的軟件工具有機地集合成為一個整體,形成能夠連續支持軟件開發與維護全過程的集成化軟件支援環境,以期從管理和技術兩方面解決軟件危機問題。
動態 | Cardano發布新論文介紹在路線圖Goguen更新中實施智能合約:Cardano (ADA)在1月27日發布了一篇新論文,其中詳細介紹了如何在即將到來的路線圖Goguen更新中實施智能合約。雖然該系統是獨一無二的,但鑒于Cardano的延遲歷史,其發布日期仍不確定。(Cointelegraph)[2020/1/29]
軟件工程確定了七條基本原理,涉及設計語言、數據庫、軟件開發工具、系統平臺、標準、設計模式等方面。目標是在給定成本、進度的前提下,開發出具有適用性、有效性、可修改性、可靠性、可理解性、可維護性、可重用性、可移植性、可追蹤性、可互操作性的軟件產品。軟件工程極大地推動和保障了現代軟件業規模的生產和應用。
智能合約作為區塊鏈上的一種鏈上軟件代碼被廣泛接受,是存儲在區塊鏈上的一類特殊軟件,可以按預先設定規則、按順序、安全、可驗證的方式實施特定的流程,合約的執行就是根據規定好的合約條款對合約方的合約信息進行的判別,并根據執行的結果采取相應的動作,職能類似于商業交易、監督管理過程中法律、法規的執行者。由于這些特點及執行價值轉移的巨大利益關聯性,智能合約的可信、公信、規模生產和可靠、正確和可監控執行帶來了新的挑戰或危機。
動態 | BM 發文談智能合約設計應尊重用戶自由選擇權:BM 今日發表了新的文章,深入分析智能合約設計理念。他指出智能合約設計時應最大限度的尊重用戶自由選擇,避免增加人為限制條件,因為人為限制可以輕易的被繞開。例如,你設置了一個智能合約要求接收轉賬的人轉賬時需要收2%手續費,那么接收者可以選擇新開一個合約。你設置了 RAM 不可以交易,但用戶可以發行 RAM 錨定的代幣,從而實現二級交易。因此,他指出當前 EOS 治理決策的長期后果的實時市場反饋可能比讓選民等到未來實現多少收益要強大的多。[2019/10/18]
這些危機越發引起人們的極大關注,典型案例如2016年6月17日,運行在以太坊公有鏈上的TheDAO智能合約遭遇攻擊,該合約籌集的公眾款項不斷被一個函數的遞歸調用轉向它的子合約,涉及總額三百多萬以太幣,這是一起嚴重的智能合約被攻擊事件。2018年5月美鏈(BEC)被爆出安全漏洞,被黑客用以太坊ERC-20智能合約中BatchOverFlow漏洞攻擊,引發價格閃崩,據英國和新加坡的研究人員統計,超過34000個智能合約都有可被利用的安全隱患等,智能合約危機已經凸顯。筆者在2017年5月首次提出了智能合約工程方法,并申請了相關的專利,下面簡單介紹其定義和主要內容。
動態 | 《EOS 智能合約最佳安全開發指南》發布:據IMEOS消息,本安全實踐合集,由慢霧(SlowMist)同學主導,麒麟小組以及其他同學參與,結合近期爆發的安全熱點問題進行實戰說明,主體內容涵蓋了
安全準則以及常見已知漏洞(數值溢出、權限校驗、apply 校驗)說明,旨在為EOS社區積累良好安全的智能合約開發實踐經驗。[2018/9/21]
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:合約代碼滿足契約的法律化約定,具有存證和自動判定功能。
此外,智能合約工程還將催生創新的擴展理論、方法、開發模型、計劃、標準和工具等,后期系列文章將逐步展開介紹。
可以預期區塊鏈和智能合約的關系就好像互聯網技術發展早期建網和網絡應用的關系,發展智能合約規模化生產技術就像軟件工程對發展軟件起到的重要作用一樣,必將成為區塊鏈產業和驅動應用落地最為有價值的事業。
作者胡凱為北京航空航天大學分布式實驗室、北京航空航天大學云南創新研究院教授。
Messari長期關注加密資產供應曲線的變化趨勢。在過去的6個月里,我們花了很多時間為排名靠前的加密資產建立了完整的流動-供給曲線.
1900/1/1 0:00:00“凡心所向,素履可往。”這是木心先生的名言。巧的是,在他的故鄉烏鎮,我體會到了這樣的心情。11月8號下午,巴比特加速器技術社區GeekHub攜手高校區塊鏈技術社區BTCU舉辦了《行業新勢力,來自.
1900/1/1 0:00:00香港金融管理局與投資推廣署合辦了2019香港金融科技周的活動。為期五天的盛會吸引了數千位來自全球各地的參與者,PANews作為官方合作媒體參與了會議的全程報道.
1900/1/1 0:00:0011月20日巴比特消息,已公開交易的比特幣基金GrayscaleBitcoinTrust以表格10(Form10)的形式向美國證券交易委員會公開提交了一份注冊申請.
1900/1/1 0:00:00作者JoshStark 翻譯DUANNIYI??編輯?SonnySun??排版Roy? 來源:加密谷 導讀 互聯網再一次發生了改變。在過去的數十年中,基于互聯網的服務已經趨于中心化.
1900/1/1 0:00:00早在2013年,比特幣程序員和比特幣雜志的發行人VitalikButerin就發布了以太坊白皮書,旨在將區塊鏈技術應用到支付領域之外.
1900/1/1 0:00:00