国产麻豆精品福利在线观看,亚洲人亚洲精品成人网站,亚洲熟妇无码AV另类VR影视,欧美A级毛欧美1级A大片免费播放

您的位置:首頁 > 互聯(lián)網(wǎng) >

SEAL全同態(tài)加密庫可映射到Python 該接口已在GitHub開源

2019-08-15 10:45:47 來源: 區(qū)塊網(wǎng)

寧波格密鏈網(wǎng)絡(luò)科技有限公司一直致力于全同態(tài)加密的應(yīng)用研究。最近陳智罡博士的團(tuán)隊(duì)開發(fā)了一個(gè)將SEAL全同態(tài)加密庫映射到Python上的接口,解

寧波格密鏈網(wǎng)絡(luò)科技有限公司一直致力于全同態(tài)加密的應(yīng)用研究。最近陳智罡博士的團(tuán)隊(duì)開發(fā)了一個(gè)將SEAL全同態(tài)加密庫映射到Python上的接口,解決了機(jī)器學(xué)習(xí)庫與全同態(tài)加密庫對(duì)接的問題,極大的方便了機(jī)器學(xué)習(xí)領(lǐng)域人員使用全同態(tài)加密算法,為其它領(lǐng)域需要用到全同態(tài)加密庫的人們提供便利的工具。該庫已經(jīng)在GitHub上開源(github.com/Huelse/pyseal)。全世界各地的工程技術(shù)人員都可以使用該庫。

微軟的SEAL全同態(tài)加密庫包含BFV和CKKS兩種全同態(tài)加密方案,陳智罡博士團(tuán)隊(duì)要做的就是將這個(gè)庫的所有可用接口都映射到Python上來,并使之在Python上正確運(yùn)行。顯然這是一個(gè)全新的項(xiàng)目。

經(jīng)過分析討論,技術(shù)路線確定為使用微軟最新的SEAL庫(3.3版本)做為基礎(chǔ),與Pybind11官方頭文件庫作為中間件綁定,使用Setuptools或CMake編譯生成動(dòng)態(tài)鏈接庫。這樣就可供Python上調(diào)用SEAL庫接口。技術(shù)框架如下:

這不是一個(gè)簡單問題。初期,他們遇到了復(fù)雜的環(huán)境和標(biāo)準(zhǔn)問題,經(jīng)過反復(fù)確認(rèn),團(tuán)隊(duì)選擇使用是C++17標(biāo)準(zhǔn)和Python3.6.8的穩(wěn)定版作為開發(fā)環(huán)境。然而接下來團(tuán)隊(duì)碰到了三個(gè)棘手問題。

第一個(gè)問題,在最新版的SEAL庫中,其使用的是一個(gè)名為MemoryPoolHandle的類和MemoryManager基類作為計(jì)算過程中的指針與內(nèi)存池管理。因?yàn)镻ython的內(nèi)存管理是自動(dòng)化的,所以這個(gè)在Python里是無法直接實(shí)現(xiàn)。于是團(tuán)隊(duì)在wrapper綁定文件中,將其作為一個(gè)參數(shù)類導(dǎo)入,最終達(dá)成了相同的功能。

第二個(gè)問題,SEAL庫的Cipertext明文類中有一個(gè)關(guān)鍵參數(shù)scale,在測(cè)試環(huán)節(jié)中是要做到可自定義修改的,但問題在于這是一個(gè)私有變量。在C++中,定義好共有方法后,可通過應(yīng)用的方式對(duì)其賦值,但在Python中因?yàn)槠湔Z言特性,同樣不可能實(shí)現(xiàn)對(duì)私有變量的直接修改。所以經(jīng)過研究,團(tuán)隊(duì)的解決方法是在Cipertext類中增加一個(gè)共有方法set_scale(),該函數(shù)方法是整個(gè)項(xiàng)目唯一對(duì)SEAL庫做出修改的地方,也僅應(yīng)用于測(cè)試環(huán)節(jié)的使用,對(duì)全同態(tài)加密整體是無影響的。

第三個(gè)問題,出自于Python的內(nèi)存管理,這是一個(gè)技術(shù)難點(diǎn)與重點(diǎn)。提前說明一下,Python中假如我們?cè)诖a文件里定義一個(gè)變量a=0,我們?cè)賹懸粋€(gè)帶參數(shù)的函數(shù)foo(a),然后函數(shù)里會(huì)對(duì)a變量進(jìn)行一系列運(yùn)算使之改變。當(dāng)我們將a帶入到這個(gè)函數(shù)并使之運(yùn)行后我們發(fā)現(xiàn),在該函數(shù)里,a這個(gè)變量的確被運(yùn)算過了,但是在這個(gè)函數(shù)體之外的那個(gè)a,它的值并不會(huì)變。通過id()方法觀察內(nèi)存,最終確認(rèn)是這樣的。

而在C++里通過指針的方式實(shí)現(xiàn)對(duì)傳入?yún)?shù)的修改,SEAL庫多處的encode和decode函數(shù)都是這樣使用的。要在盡可能不改變SEAL庫源碼的情況下將其轉(zhuǎn)移到Python上來,且Python不能操控指針,僅這個(gè)問題困擾了團(tuán)隊(duì)很久。最終團(tuán)隊(duì)給出的方案是自定義一個(gè)變量類。 

雖然在Python中單一的變量作為參數(shù)不會(huì)發(fā)生改變,但如果是一個(gè)類作為參數(shù)傳入,那它的改變是全局性的。比如uIntVector類在c++中的原型是std::vector,DoubleVector類其原型是std::vector。團(tuán)隊(duì)對(duì)類的包裝完成了這兩者最基本的數(shù)據(jù)交互,這樣CKKS方案就能完美運(yùn)行。至此陳智罡博士團(tuán)隊(duì)的Pyseal項(xiàng)目的主要工作也已完成。

最后,陳智罡博士的團(tuán)隊(duì)使用Pyseal將SEAL官方給出的6個(gè)樣例在Python上全部實(shí)現(xiàn),且運(yùn)行效率也并未減少。接口已經(jīng)在Github上開源。

寧波格密鏈網(wǎng)絡(luò)科技有限公司一直致力于全同態(tài)加密的研究與開發(fā),希望能給全世界更多的技術(shù)工程人員帶來便利,更加方便地使用全同態(tài)加密庫。(致遠(yuǎn)博士)

關(guān)鍵詞: SEAL Python GitHub

精選 導(dǎo)讀

募資55億港元萬物云啟動(dòng)招股 預(yù)計(jì)9月29日登陸港交所主板

萬科9月19日早間公告,萬物云當(dāng)日啟動(dòng)招股,預(yù)計(jì)發(fā)行價(jià)介乎每股47 1港元至52 7港元,預(yù)計(jì)9月29日登陸港交所主板。按發(fā)行1 167億股計(jì)算,萬

發(fā)布時(shí)間: 2022-09-20 10:39
管理   2022-09-20

公募基金二季度持股情況曝光 隱形重倉股多為高端制造業(yè)

隨著半年報(bào)披露收官,公募基金二季度持股情況曝光。截至今年二季度末,公募基金全市場(chǎng)基金總數(shù)為9794只,資產(chǎn)凈值為269454 75億元,同比上

發(fā)布時(shí)間: 2022-09-02 10:45
資訊   2022-09-02

又有上市公司宣布變賣房產(chǎn) 上市公司粉飾財(cái)報(bào)動(dòng)作不斷

再有上市公司宣布變賣房產(chǎn)。四川長虹25日稱,擬以1 66億元的轉(zhuǎn)讓底價(jià)掛牌出售31套房產(chǎn)。今年以來,A股公司出售房產(chǎn)不斷。根據(jù)記者不完全統(tǒng)

發(fā)布時(shí)間: 2022-08-26 09:44
資訊   2022-08-26

16天12連板大港股份回復(fù)深交所關(guān)注函 股份繼續(xù)沖高

回復(fù)交易所關(guān)注函后,大港股份繼續(xù)沖高。8月11日大港股份高開,隨后震蕩走高,接近收盤時(shí)觸及漲停,報(bào)20 2元 股。值得一提的是,在7月21日

發(fā)布時(shí)間: 2022-08-12 09:56
資訊   2022-08-12

萬家基金再添第二大股東 中泰證券擬受讓11%基金股權(quán)

7月13日,中泰證券發(fā)布公告,擬受讓齊河眾鑫投資有限公司(以下簡稱齊河眾鑫)所持有的萬家基金11%的股權(quán),交易雙方共同確定本次交易的標(biāo)的資

發(fā)布時(shí)間: 2022-07-14 09:39
管理   2022-07-14

央行連續(xù)7日每天30億元逆回購 對(duì)債市影響如何?

央行12日再次開展了30億元逆回購操作,中標(biāo)利率2 10%。這已是央行連續(xù)7日每天僅進(jìn)行30億元的逆回購縮量投放,創(chuàng)下去年1月以來的最低操作規(guī)

發(fā)布時(shí)間: 2022-07-13 09:38
資訊   2022-07-13

美元指數(shù)創(chuàng)近20年新高 黃金期貨創(chuàng)出逾9個(gè)月新低

由于對(duì)美聯(lián)儲(chǔ)激進(jìn)加息的擔(dān)憂,美元指數(shù)11日大漲近1%創(chuàng)出近20年新高。受此影響,歐美股市、大宗商品均走弱,而黃金期貨創(chuàng)出逾9個(gè)月新低。美

發(fā)布時(shí)間: 2022-07-13 09:36
資訊   2022-07-13

美股三大股指全線下跌 納斯達(dá)克跌幅創(chuàng)下記錄以來最大跌幅

今年上半年,美股持續(xù)回落。數(shù)據(jù)顯示,道瓊斯指數(shù)上半年下跌15 3%,納斯達(dá)克綜合指數(shù)下跌29 5%,標(biāo)普500指數(shù)下跌20 6%。其中,納斯達(dá)克連續(xù)

發(fā)布時(shí)間: 2022-07-04 09:51
推薦   2022-07-04

融資客熱情回升 兩市融資余額月內(nèi)增加超344億元

近期A股走強(qiáng),滬指6月以來上漲4%,融資客熱情明顯回升。數(shù)據(jù)顯示,截至6月16日,兩市融資余額1 479萬億元,月內(nèi)增加344 67億元,最近一個(gè)半

發(fā)布時(shí)間: 2022-06-20 09:41
資訊   2022-06-20

4個(gè)交易日凈買入超百億元 北向資金持續(xù)流入A股市場(chǎng)

北向資金凈流入態(tài)勢(shì)延續(xù)。繼6月15日凈買入133 59億元后,北向資金6月16日凈買入44 52億元。自5月27日至今,除6月13日以外,北向資金累計(jì)凈

發(fā)布時(shí)間: 2022-06-17 09:37
推薦   2022-06-17

熱門TAG

more
美聯(lián)儲(chǔ)今年已將基準(zhǔn)利率從接近零大幅上調(diào)至略高于3% EIA報(bào)告:美國原油庫存及戰(zhàn)略儲(chǔ)備減少,汽油及精煉油庫存輕微波動(dòng) 美國政府更廣泛推動(dòng)從汽油動(dòng)力汽車轉(zhuǎn)向電動(dòng)汽車的一部分 數(shù)據(jù)顯示:今年9月日本船企接單量延續(xù)8月下跌下跌趨勢(shì) 公告顯示:2022年前三季度TCL中環(huán)研發(fā)投入為27億元 占比營業(yè)收入5.42% 新的111.75億英鎊注資列在“對(duì)金融機(jī)構(gòu)的援助—支付給英格蘭銀行”標(biāo)題下 本次政府儲(chǔ)備肉投放面向北京18家主要連鎖超市門店及相關(guān)零售終端投放 有交易員預(yù)計(jì):如果LME不采取措施 接下來可能將有數(shù)十萬噸鋁流入LME 據(jù)報(bào)道:繼德國最大釀酒商拉德貝格啤酒公司9月宣布漲價(jià) 據(jù)報(bào)道:澳大利亞礦商Pilbara的鋰礦拍賣價(jià)再創(chuàng)新高 折算后的碳酸鋰成本 中集天達(dá)首次公開發(fā)行A股股票 招股書顯示此次擬公開發(fā)行股數(shù)不超過103, 多家銀行加強(qiáng)綠色金融頂層設(shè)計(jì) 致力于為經(jīng)濟(jì)社會(huì)綠色低碳轉(zhuǎn)型貢獻(xiàn)力量 萊特幣 比特幣 數(shù)字資產(chǎn) 火幣 以太經(jīng)典 比特股 EOS 比特幣現(xiàn)金 量子鏈 Hcash 泰達(dá)幣 瑞波幣 Qcash 比特幣鉆石 超級(jí)比特幣 優(yōu)幣 硬分叉 加密貨幣