在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

基于格密碼全同態加密的數學基礎

Linux閱碼場 ? 來源:Linux閱碼場 ? 作者:甄建勇 ? 2022-10-31 09:16 ? 次閱讀

--基于格密碼全同態加密的數學基礎

此情此景,我想先吟詩二首:

8e0105cc-58b1-11ed-a3b6-dac502259ad0.png

從文學的角度看,以上兩首詩比李白寫的稍微遜色一點,不過,從數學角度來看,簡直可以獲得諾貝爾數學領域的文學獎(可惜了,目前還沒有這個獎項)。

以上是定場詩,本文旨在盡量少用數學公式的情況下,解釋清楚FHE(Fully Homomorphic Encryption,全同態加密)相關的數學基礎。話不多說,我們繼續。

一點定乾坤

當時的故事是這樣的:

一個陽光明媚的下午,初三(一)班剛剛上完第二節數學課,老師講的是函數相關的內容。陽光灑在我課桌上,溫暖的光線散射到眼睛里,而我卻盯著老師講的拋物線函數圖像,一動也不動。

當時我本子上的圖像是下面這樣的:

8e0c5cce-58b1-11ed-a3b6-dac502259ad0.png

發呆的時候,我們班里的泰勒同學去完廁所從教室前門走了進來,我的座位正沖門口,可能是他發現了我在發呆,就徑直走了過來,跟我說:

“干嘛呢?大白天的,發什么呆啊?”

“發呆跟白天晚上有關系嗎?”我應道,“別打擾我,我在思考一個深奧的問題!”

“什么問題啊?別思考了,我跟你說個事兒,我會魔法你知道嗎?”泰勒不僅沒走開,反而挨著我坐了下來。

“別扯了,我們又不是幼兒園的小朋友,都初三了,誰還相信魔法?!”我有點不耐煩,打算繼續思考我的深奧的問題。

“你別不信啊,我眼睛有透視的能力”泰勒有點不依不饒,繼續說道:

“不信的話,你把你的草稿本合起來,別讓我看到,我可以在不看你本子的前提下,知道你畫的是什么函數”

“滾一邊兒去,我沒那閑工夫跟你玩兒”因為泰勒打斷我的思路,想趕緊轟他走。

“實在不信的話,我們試試不就知道了嗎?!”泰勒不僅沒走,還挪了一下凳子,離我更近了。

“好吧,好吧,如果不靈的話,有多遠滾多遠,行不行?”我說。

“沒問題,這樣,你把你的函數圖像用兩本書遮起來,兩書之間只留一個點,我可以根據這一個點的信息得到整幅函數圖像!”泰勒顯得有點興奮。我自已也有點躍躍欲試。

“行啊,沒問題,就給你留一個點,看你怎么猜!”我心想,別說一個點,就是給你十個點,你能猜出來的話,我也算你贏。

我邊說邊把草稿本打開,用語文書和英語書遮住,中間只留了一個小縫兒,我自己剛剛能看到橫軸上‘1’對應的那一點點圖像。

“行了,我準備好了,猜吧!”我說。

“好,現在正式開始,不過我要先問你幾個問題”泰勒說。

“問吧,問吧!”我說。

“請問,在這個點,這個函數的一階導數是多少?”泰勒正式開始了他莫名其妙的發問。

“一階導數?是2”我略作思考,回答道。

“二階導數呢?”泰勒繼續問。

“還是2”我腦筋微轉,答道。

“三階導數呢?”泰勒繼續問。

“三階導數啊?是0”我快速說道。

“四階導數呢?”泰勒還要問,沒有停下來的意思。

“哎呀,你煩不煩,三階導數后面所有的導數都是0”我說。

這時,只見泰勒嘴角上揚,微微一笑,說:“你畫的函數是8e40e37c-58b1-11ed-a3b6-dac502259ad0.png,對不對啊?!”

“這怎么可能?!”我很是驚訝,僅僅通過一個點的信息,泰勒怎么會知道整幅函數圖像的呢?

只見泰勒那時的表情,得意洋洋,心滿意足,開始手舞足蹈。。。

我還是不信,懷疑剛才泰勒偷看到了我的草稿本兒。所以我又緊接著測試了8e51dd58-58b1-11ed-a3b6-dac502259ad0.png,甚至還測試了8e5f014a-58b1-11ed-a3b6-dac502259ad0.png,還有很多其它很復雜的函數,令人震驚的是,這些函數,無一例外,泰勒都只通過一個點就猜出來了。

“怎么樣?這回相信我會魔法了吧?!”泰勒見我不解,輕飄飄撂下這句話就走開了,只留下凌亂的我,張著嘴巴,一臉懵。。。

“還真是啊,‘一點定乾坤’,難道說的就是這個?”我不禁自言自語。

讀到這里,聰明的同學可能早就可以拆穿泰勒所謂的魔法了,不過我實在是愚鈍,我們繼續往下看。。。

一時含永遠

泰勒同學前腳剛走,我的另外一個叫傅里葉的同學就跑了過來,他好像是看到了我和泰勒玩的游戲,跟我說:

“泰勒那哪叫魔法啊,我會的才是真正的魔法,我可以讓時間停止,讓瞬間變永恒”

“你跟泰勒一個德性,凈扯玄乎兒的,把我當幼兒園小朋友耍”我還在琢磨剛剛泰勒是怎么做到的。

“你不相信的話,我們也做個游戲試試”傅里葉不想放棄展示他的魔法。

“沒問題,直接開始吧,你說怎么玩?”我說。

“好,我的第一個問題是,當8e6e7800-58b1-11ed-a3b6-dac502259ad0.png的時候,函數的值是多少?”見我同意玩,傅里葉也是開門見山,一下子問出了第一個問題,其實,也是唯一的一個問題。

我奮筆疾書,畢竟x是個e指數,還包含三角函數的角度,但是,我真正計算才發現,根本用不到筆算,口算就可以。我都一一回答了。當然,在這過程中,我把本子捂得很緊,沒敢讓他偷看一眼。

“我知道了,你的函數是8e8078fc-58b1-11ed-a3b6-dac502259ad0.png,對不對啊!”傅里葉得意的問。

“我K,你是怎么知道的?!,難道傳說中的‘一時含永遠’,說的就是你?!”我被徹底震驚了。

。。。

。。。

。。。

好吧,我承認,泰勒和傅里葉不是我的同學,上面的故事都是編的。我也是實在編不下去了,很多聰明的同學也早就發現了泰勒和傅里葉的秘密。

泰勒的秘密就是:

對于任何一個光滑函數,都可以表示為多項式的形式,而多項式的系數可以通過某一點的導數獲得。

是的,你沒看錯,一個點竟然蘊含了一個函數的所有信息。

傅里葉的秘密是:

對于任何一個光滑函數,都可以表示為三角函數累加(積分)的形式,而每一項的系數可以通過多個點的自變量和因變量對兒(x, f(x))獲得。

是的,你沒看錯,我們手機里的歌曲,不管你播不播放,他總是呆在那里,不曾改變。一個隨時間變化的信號,經過傅里葉變換之后,時間將消失,音樂會上一段美妙的音樂,不過是樂譜的再一次重復,而無論重復多少次,樂譜從未發生絲毫改變。

以上被稱為“感覺第一定理”。

對于喜歡看公式的同學(對于不喜歡看數學公式的同學,直接跳過公式部分,絲毫不用擔心會影響你對本文的理解),就是:

泰勒公式一句話描述:就是用多項式函數去逼近光滑函數。

8e982682-58b1-11ed-a3b6-dac502259ad0.png

傅里葉變換一句話描述:將用一般多項式表示的時域的信號,變成頻域的信號(這句不懂沒關系,看完后面就懂了)。

8ea4d486-58b1-11ed-a3b6-dac502259ad0.png

你在其它地方看到的傅里葉變換可能是下面的樣子:

8eafce68-58b1-11ed-a3b6-dac502259ad0.png

那是因為歐拉這位同學的存在,可以把e指數變成三角函數的形式。

歐拉公式:

8ebf3718-58b1-11ed-a3b6-dac502259ad0.png

所以,我總結下來,就是,對于任何一個函數,都可以用一些簡單的東西的線性組合得到。這里面提到的簡單的東西,就可以認為是搭積木的一個個小積木塊,用數學的語言,小積木塊就是函數的基。用線性代數的語言,小積木塊就是單位向量。而具體的函數,就是用小積木塊搭出來的各種形狀的積木,以及用單位向量組成的一般向量。

以上被稱為“感覺定理-2”

彎路走的快

稍作休息,我又可以繼續編故事了,還是續集。

傅里葉同學說完答案,同樣留下一頭霧水的我,瀟灑的走開了。當時,我腦袋里真是一團漿糊,泰勒同學的秘密還沒搞懂,又來一個傅里葉的秘密。秘密加秘密,我就更摸不著頭腦了。

正當我一籌莫展之際,我的第三位同學-凱萊出現在了我的面前。還沒等我張口請教,凱萊就發話了:

“泰勒和傅里葉的三腳貓功夫,有啥了不起的,在我看來,不就是多項式的兩種表示形式而已。”

“多項式,我知道,不過,我只知道一種形式,另外一種是啥?”我問。

凱萊,不像泰勒和傅里葉,他舉止優雅,陣腳不亂,簡稱“矩陣”(sorry,這是個諧音梗)。

“不用著急,聽我給你慢慢說”凱萊搬了自己的凳子來,輕坐在我旁邊。

你看啊,我們一般見到的多項式是下面這樣的,叫多項式的系數表示法。

8ed00de0-58b1-11ed-a3b6-dac502259ad0.png

這其中的8ede88b6-58b1-11ed-a3b6-dac502259ad0.png就是多項式的系數,所以叫“系數(coefficient)表示法”,沒錯,數學就是這么直白。

除了系數表示法之外,還有一種,叫“點值表示法(point-value representation)”,顧名思義,就是用這個多項式上的點,以及這點對應的值來表示。

比如,上面的多項式,用點值表示法,就是:

8eee7e88-58b1-11ed-a3b6-dac502259ad0.png

看到這里,我就有點不太理解了,為啥點值表示法也能代表這個多項式呢?凱萊,不緊不慢,耐心解釋道:

你看啊,點值表示法里面的每一對點值,是不是表示下面一個等式,比如,第一對兒點值,表示的就是下面的一個等式。

8efc64bc-58b1-11ed-a3b6-dac502259ad0.png

第二對兒點值對應的是下面的等式:

8f08fce0-58b1-11ed-a3b6-dac502259ad0.png

從點值表示法來看,本來在一個平面上有無數條曲線,每次確定一個點,就要求我們想要的曲線必須經過這個點,當我們確定的點的數量和這條曲線的次數(就是上面式子中的n)相同時,我們就找到了經過我們指定所有點的唯一一條曲線。這是“感覺定理-3”

這時,凱萊好像看出了我的心思,說:

“瞎想什么啊,太難理解了,我們初中生,剛學過矩陣,用矩陣表示比你那個‘真感情’容易多了!”

“什么意思啊?”我還是不太理解。

“你看啊。。。”凱萊又開始娓娓道來:

上面用點值表示法表示的多項式,每個點值對兒都對應一個方程,如果我們把他們組合到一起,寫成矩陣的形式,不就是下面這個樣子嗎:

8f12ad08-58b1-11ed-a3b6-dac502259ad0.png


點值表示法,就是上面三個矩陣,第1個和第3個,分別表示“點”和“值”,第2個矩陣是多項式的系數。當其中第1個和第3個矩陣都確定的情況下,第2個系數矩陣其實也就確定了。所以,從這個角度看,點值表示法和系數表示法,只是同一個函數的兩種表示方式,就好像同一個函數既可以按泰勒同學的方式展開,也可以按傅里葉同學的方式展開,兩種方式描述的其實是一個東西。

就好像光的波粒二象性似的,泰勒同學強調的是粒子性,而傅里葉同學強調的是波動性。或者說,系數表示法強調的是函數的波動性,點值表示法更多體現函數的粒子性。
此為“感覺定理-4”.

凱萊同學啰啰嗦嗦的說了半天,我也不知道說了些什么東西,就問:

“凱萊,你說的點值法,我是聽懂了,可我沒看出點值法有啥用處啊”

“這個用處可就太大了,可以加速多項式乘法!”凱萊說。

你看啊,比如,我們有兩個用系數表示法表示的多項式:

8f2a93f0-58b1-11ed-a3b6-dac502259ad0.png

那么這兩個多項式的乘法結果8f39dd74-58b1-11ed-a3b6-dac502259ad0.png的計算過程如下所示:

8f4cd294-58b1-11ed-a3b6-dac502259ad0.png

這個多項式乘法的復雜度是8f5ad5e2-58b1-11ed-a3b6-dac502259ad0.png,另外還要注意的是,“多項式乘法”中的“乘法”兩個字非常容易產生誤導作用,給人一種真的是普通乘法的錯覺,其實,多項式的乘法操作,實際上就是卷積運算,這一點一定要謹記。

“卷積?有什么特殊的呢?這和點值表示法有啥關系啊?”我還是似懂非懂的問。

“別著急啊,還記得剛剛走的傅里葉同學嗎?他剛剛使用的秘密武器就是傅里葉變換,還記得嗎?”凱萊問我。

“當然記得,傅里葉變換可以讓時間消失的,太厲害了,可以將時域的信號,變成頻域的信號!”我說。

“完全正確!”凱萊對我的回答非常滿意,他接著說:

“多項式的乘法(也就是卷積運算),可以先將兩個多項式分別做傅里葉變換,變完之后的兩個式子,直接對應項相乘,對應項相乘完之后的結果再做傅里葉逆變換,得到的結果就是兩個原始多項式的乘法結果!!!”凱萊興奮的嚷道。

“這個我知道,這不就是卷積定理嘛!卷積定理說的是,在一個域的相乘等于另一個域的卷積,用式子表示,就是下面這樣子的”我補充道。

8f6b63ee-58b1-11ed-a3b6-dac502259ad0.png

“可是,這個和你前面提到的矩陣有什么關系啊?!又和多項式的點值表示法有什么關系啊?!”我還是沒完全理解凱萊的意思。

“不用著急,這兩個問題很快你就明白了,只需最后一步!”凱萊還是慢條斯理的樣子。

“最后一步?什么最后一步啊?”我問。

你看啊,其實啊,點值表示法有個非常大的好處,我之前沒提到,就是:

對于用點值表示法表示的兩個多項式的乘法(實際是卷積),可以直接對應項相乘即可,即,

8f7d9d52-58b1-11ed-a3b6-dac502259ad0.png

“我知道了,凱萊,原來復雜度為8f904c86-58b1-11ed-a3b6-dac502259ad0.png的多項式乘法運算,復雜度降低成8f9fa5be-58b1-11ed-a3b6-dac502259ad0.png了”我好像發現了什么新大陸,也吼了起來。

“不對啊,好像哪里不對啊,這個復雜度的降低要想實現,需要先把系數表示法變成點值表示法才行啊!,這個從系數轉點值的復雜度也是啊,你這搞半天不是瞎搞了嗎!本來可以有直行的路可以到達,你這越走越遠啊!”我剛剛發現的新大陸瞬間又不香了,滿臉狐疑的看著凱萊。

“不對啊,好像哪里不對啊,這個復雜度的降低要想實現,需要先把系數表示法變成點值表示法才行啊!,這個從系數轉點值的復雜度也是8f904c86-58b1-11ed-a3b6-dac502259ad0.png啊,你這搞半天不是瞎搞了嗎!本來可以有直行的路可以到達,你這越走越遠啊!”我剛剛發現的新大陸瞬間又不香了,滿臉狐疑的看著凱萊。

“你別著急啊,你再仔細看看,你說的沒錯,如果是一般的系數變點值,復雜度確實降不下來,可是,如果我取得點是一些特殊的點的話,情況就完全不一樣啦”凱萊繼續給我解釋,不緊不慢。
“取什么樣的點,才能降低復雜度呢?哦!我知道了,復數域的單位根,復數域的單位根,復數域的單位根!”我連續說了三遍,生怕凱萊聽不清楚。
在復數域內,方程有個根,就叫單位根,這些根分別是:

8fb2e476-58b1-11ed-a3b6-dac502259ad0.png

就是前面傅里葉同學表演“一時含永遠”魔法的時候用的那幾個點!!這幾個點太好了,口算就能知道對應的函數值,這樣的話,系數到點值的轉換就簡單多了。
“是的,你終于發現了傅里葉變換的另外一個秘密,就是傅里葉變換,其實就是多項式的系數轉點值,當然,我們考慮的是離散的傅里葉變換(DFT)”凱萊繼續說道。
“嗯,后面我就知道了,DFT有個快速算法,叫FFT,FFT的計算復雜度是8fbf2bd2-58b1-11ed-a3b6-dac502259ad0.png看到了希望,我又開心了起來。

為了防止忘記,我在心里又重新梳理了一下多項式乘法的過程:

多項式乘法本質是卷積運算

卷積運算可以分三步:

a. 先把兩個多項式從系數表示變成點值表示,這一步就是DFT,可以用FFT加速,FFT采用分治法,可以將一根很長的木棍兒每次都折半,這樣遞歸下去,就可以降低計算復雜度。FFT選用的是單位根,NTT選用的是原根,目的一樣,為了加速DFT, 相比于FFT,NTT還便于取模運算。

b. 然后,將用點值形式的兩個多項式,對應項相乘,就得到了最終結果的點值表示形式。

c. 最后,還需要把最終結果的點值表示變回系數表示

“前幾步上面都提到了,我也理解了,可這最后一步是怎么做到了?”雖然大部分的內容我理解了,可再三回憶,最后一步確實沒聽凱萊說過。

“哎呀,這還不簡單嗎?提示你一下,看看多項式的矩陣表示形式,對了,不用往上翻了,我們再寫一遍,就是下面的樣子”凱萊嘿嘿一笑:

8fd3eeaa-58b1-11ed-a3b6-dac502259ad0.png

還是原來的配方,還是熟悉的味道。點值表示變回系數表示的過程,不就是已知上面的第1個矩陣和第3個矩陣,求中間的系數矩陣嘛?!

“原理我貌似有點懂了,可是,具體怎么求啊,我線性代數也學的不好”我繼續追問凱萊,凱萊畢竟是矩陣理論的大師級人物,這點小問題應該難不倒他。果然,還不到1秒鐘的時間,凱萊就發話了:

“這個問題嘛,等式兩邊都乘上第1個矩陣的逆矩陣就可以了,注意啊,是“矩陣的逆:”,不是”矩陣的轉置:”,這個千萬別混淆了”凱萊細心的提醒我。
“知道啦,不過,矩陣的逆,復雜度可很大啊,是8fe15504-58b1-11ed-a3b6-dac502259ad0.png,你這又是南轅北轍啊?!”我又有被凱萊耍了的感覺。

“你說的沒錯,上面的第一個矩陣,是一個特殊的矩陣,叫范德蒙矩陣,一般的范德蒙矩陣的逆,運算復雜度也是8fe15504-58b1-11ed-a3b6-dac502259ad0.png,不過,但是,如果我們按照傅里葉同學的思路,搞出來的這個范德蒙矩陣是特殊中的特殊,它的逆矩陣,就是矩陣中的每個元素的共軛,再除以n,就是這么簡單,哎喲,就是這么巧合,你說神奇不神奇”凱萊難得的大笑起來。用式子表示,就是下面這個樣子的:

8ffefd84-58b1-11ed-a3b6-dac502259ad0.png

這個矩陣的逆,就是:

900910bc-58b1-11ed-a3b6-dac502259ad0.png

“原來如此,原來如此啊,如果我記得沒錯的話,點值到系數的變換過程就是傳說中的傅里葉逆變換,也叫IDFT,這個也有加速版本的IFFT。”我終于恍然大悟,“彎路走的快”,誠不欺我,有圖為證。

901e3c80-58b1-11ed-a3b6-dac502259ad0.png

故事講到這里,我不禁又想起了最開始的兩首詩,史上最富含數學知識的文學作品,名副其實。不過,看標題,內容是同態加密啊,故事都講到這兒了,嘚啵嘚啵嘮半天嗑,咋同態加密的影兒都沒看著啊?!
別著急,這是同態加密的上篇,我們稍作休息,請等待后面的精彩故事。

此情此景,我想再吟詩二首:

9036a0ae-58b1-11ed-a3b6-dac502259ad0.png

話說上篇我們了解到了很多非常重要的內容:

多項式從系數表示變成點值表示的過程,就是離散傅里葉變換(DFT/FFT)

多項式從點值表示變成系數表示的過程,就是離散傅里葉逆變換(IDFT/IFFT)

多項式的乘法,本質是卷積運算,一次卷積運算可以分為三步:Convolution=FFT->multiply->IFFT,即卷積定理表達的內容。

以上三種場景,都有相應的矩陣操作與之對應。原因是:一個多項式的點值表示和一個線性方程組對應,線性方程組又和一個矩陣乘法運算對應,這樣多項式的乘法就可以轉換成FFT相關的計算。這一點非常重要,是理解FHE的關鍵所在。
仔細思考上篇中討論的內容,加上上面幾點提示,這樣我們就把FHE相關的幾個非常重要的概念,以及這些概念之間的關系就搞清楚了,此時,我們的腦海里應該出現以下幾個概念,并且這些概念不再是獨立的孤島,而是腦海里一片廣闊的大陸:泰勒公式,多項式,系數表示法,點值表示法,DFT,FFT,卷積,卷積定理,線性方程組,矩陣,矩陣的逆。

好,收拾行囊,我們繼續趕路,在正式向FHE山頂發起沖鋒前,我們有必要加深一下對傅里葉變換的理解,如下圖所示:

9076f7c6-58b1-11ed-a3b6-dac502259ad0.png


仔細查看上圖。。。在觀察這段時間里的某個時刻,一道金光從腦海劃過:為什么時間消失了?!我們感知到的隨著時間流淌的宇宙,進行傅里葉變換后會怎樣?我們又該怎么選擇傅里葉變換的旋轉因子(twiddle factor)?如果你的腦海沒有金光劃過,可以先閱讀一下。

如果腦海里實在是沒有金光劃過,也沒關系,不會影響我們最終站上FHE的山頂。我們繼續。。。

在FHE領域,我們可能會反復看到一句話:“FHE是基于格密碼學的”。這句話很簡短,既然反復看到,說明應該很重要,可是,我從這句話里面又看不出什么東西,每個字我都認識,但就是不知道整句話什么意思。什么道理都懂,仍然過不好一生。不用著急,我們慢慢拆解

首先,這里面最難懂的可能是“格”這個字,于是,我們就百度里一下,“格”是這么定義的:

“ “格”是一種特殊的偏序集。”

也很簡短,不過不出意外,還是每個字都認識,但仍然不明白整句話說的是啥意思。按道理,既然名字叫“格”,應該跟“格子”有關系啊?!

于是,我們繼續查找FHE相關的資料,除了“格”這個東西,經常出現的還有“環”這個概念,于是百度之,“環”定義的第一個條件是:

“ 集合R在+運算下構成阿貝爾群” 此外還有“理想(Ideal)”兩個字也出現在了附近。

也很簡短,不過不出意外,還是每個字都認識,但仍然不明白整句話說的是啥意思。按道理,既然名字叫“環”,應該跟“鐵環、手環”之類的東西有關啊?!

按圖索驥,從“環”的定義里,我們發現了“阿貝爾群”這幾個字,“阿貝爾”應該是個人名,那“群”又是啥意思?!,于是,繼續百度之,

“在數學中,群表示一個擁有滿足封閉性、滿足結合律、有單位元、有逆元的二元運算的代數結構,包括阿貝爾群、同態和共軛類。”

這句話相比之前“格”“環”的定義稍稍多了幾個字。欣喜的是,這句話中提到的幾個概念好像都知道什么意思,比如“結合律”,“單位元”,“共軛”等,此外,還見到了我們苦苦追尋的“同態”兩個字,相比最開始的漆黑一片,終于見到了幾個火星兒,希望有了,勝利可能就在眼前。。。

于是,我們沖向FHE這個山頂的第一條路徑就出現在了我們眼前,那便是:群->環->域->格。雖然只有四個字,可每個字看起來都不是那么好搞定的,畢竟,我們好像依稀聽說過,“群論”,“環論”,“抽象代數”這幾個可怕的怪物,這么陡峭的山體,一不小心就可能摔得粉身碎骨,永遠達不到矗立在山頂的FHE。

我駐足沉思,難道到山頂只有一條路可走?難道必須從山腳下的“群”開始?現在都是新時代,出門爬個山,累了都有纜車啊, FHE這座山真有沒有纜車可坐?如果FHE這座山沒有纜車,那么FHE這座山附近有沒有其它的山,如果有其它的山的話,有沒有可能在兩山的山頂建有“山頂纜車”?

一堆問題在我附近的空間里縈繞盤旋,我得不到回答,于是,在沒看到“山頂纜車”之前,我開始從山腳下的“群”開始一步一步地爬。。。群是有點抽象,剛開始確實不太容易理解,不過我走得很快,不一會就建立了“群,環,域”的簡單概念。

繼續爬。。。

爬呀爬。。。
。。。
。。。
。。。
幾天以后。。。

又有一道金光劃過我腦海的上空,原本漆黑的海面上變得亮了起來。這道金光就是:

“很多格子擺在一起,看起來很像矩陣啊!”

是的啊,確實很多格子排列在一起,從遠處看,就是一個矩陣啊,所以,“格”和“矩陣”之間一定存在某種關系!這個關系,不就是兩座山頂之間的“山頂纜車”嗎?!

“矩陣”,我們是比較了解的,如果矩陣和格之間建有山頂纜車的話,豈不美哉。

稍作驗證,果不其然,我的想法是對的,“山頂纜車”早已建成,因為我看到了“整數格”的定義:

“離散的基向量生成空間集合,稱之為整數格(Integer Lattice)”

這里面可能稍有難度的是“生成空間”,我們先來搞定它。

在線性代數中,如果我們要描述一個線性空間的話,我們需要先找到這個空間的一組基(Basis)。(PS:看到“基”這個字,你是不是又想起了傅里葉,想起了泰勒,想起了點值法,想起了消失的時間。。。)

比如常見的二維平面空間(笛卡爾坐標系),我們可以選用x軸和y軸的單位向量,作為我們的基向量(或者叫單位向量),分別是:

90a3a2f8-58b1-11ed-a3b6-dac502259ad0.png

這樣的話,任何XY坐標系的向量90b65254-58b1-11ed-a3b6-dac502259ad0.png都可以用上面的一組基來表示。即,

90bf17c2-58b1-11ed-a3b6-dac502259ad0.png

其中c_0和c_1可以是任意實數,如果是任意實數,那么v的所有可能的組合,就可以鋪滿整個二維平面空間,我們管所有的v組成的這個線性空間,就叫做,b_1兩個基向量的線性生成空間(Span)。

我們不難想象,如果c_0和c_1是實數,那么b_0,b_1的生成空間是“連成一片”的,可以叫“片”,但是,如果c_0和c_1是只能是整數的話,那么b_0,b_1的生成空間就由“片”變成了無數個離散的“點”,這些點整齊的排列在一起,非常像無數個小格子,我們把這樣的一個離散的生成空間,叫做“整數格(Integer Lattice)”。

果不其然,從“矩陣”到“格”,只有簡單的一步,這個“山頂纜車”建得實在是太好了。

乘坐這條意外發現的纜車,我們快速抵達了“格”,這時,我們離FHE的核心腹地--LWE只有一步之遙了,加油,勝利就在眼前。

90d6c584-58b1-11ed-a3b6-dac502259ad0.png

稍微瞄一眼上圖,我們就會發現,這確實是很多格子啊,“格”這個字用的還是挺好的。

有了Lattice(格),就有很多跟Lattice 有關的有意思的問題就出現了。比如,想要表達一個向量v:

90e93340-58b1-11ed-a3b6-dac502259ad0.png

我們會發現,這個向量沒辦法在整數格中表達它,因為整數格中的系數必須是整數才行啊。

好了,問題來了,既然不能用整數格完美表達v,那么,是否可以找到一個最接近v的v_0,而v_0可以用整數格完美表達。對于上面的例子:

91042ff6-58b1-11ed-a3b6-dac502259ad0.png

這個就是著名的CVP(Closest Vector Problem)難題!!

你可能會說,這算哪門子難題啊?我一秒鐘就破解了。

沒錯,如果只是二維正交基向量的格,那么CVP問題不是特別難,但是,如果基向量不正交呢?如果v的維度變大到, 的成員的值變大到需要1000bit呢?

910e3000-58b1-11ed-a3b6-dac502259ad0.png

這個難度是被嚴格證明的,CVP問題是非常難解決的(Nondeterministic Polynomial hard, NP-hard)。

是的,這個乍看起來很簡單,實際上很難的問題,就是格密碼學的開端。

“什么?!搞了這么久,我以為已經達到了頂峰,竟然被你說成是‘開端‘?!!”

“是的,的確是格密碼學的開端,現實就是這么的殘酷,你以為的天花板,很可能只是別人的起點。比如,你家的天花板,可能只是樓上的地板,…^_^”

不過不要氣餒,前面就是我們要找的LWE了。

在正式引入LWE之前,我們先回顧一下,送我們快速到達“格”的山頂纜車—矩陣。

是的,通過上篇的學習,我們早就知道了,一個矩陣乘的式子,對應一個線性方程組:
911ee27e-58b1-11ed-a3b6-dac502259ad0.png
其中A是一個矩陣,x是一個向量,b也是一個向量。

已知A和b,求x的過程,就是求解線性方程組的過程。具體就是在上篇提到的方法:等式兩邊都乘以的逆矩陣,乘完之后,等式左邊就只剩下我們要求出的未知向量了。

現在稍稍把上面的矩陣乘法等式變化一下:
912dc38e-58b1-11ed-a3b6-dac502259ad0.png
其中e是一個在固定數值范圍內隨機采集的一個隨機噪音向量。這時,之前“等式兩邊都乘以A的逆矩陣”的方法就不行了,那我們怎么求呢?答案很簡單:

“只能暴力破解”

也就是一個一個的猜x這個向量里的值,然后逐漸逼近。

這就是我們苦苦尋找的LWE(Learning With Error)問題!即:

已知一個矩陣,和它與一個向量相乘得到的乘積再加上一定的誤差,也就是,如何有效的還原(learn)未知的向量。

“什么?LWE的定義這么草率嗎?”

“是的,有時候勝利來得就是這么突然。”

“LWE,我們是知道了,可前面為啥提到CVP問題啊?”

如果我們細心的看LWE的問題描述的話,可以發現,LWE問題與我們之前提到的CVP問題有著驚人的相似。

不能說相似,簡直一模一樣。都是需要找到一組“系數”--,使得一組基向量--的線性組合,無限逼近我們想要的目標向量--。這里我們使用誤差噪音--的大小來定義到底我們需要距離目標向量多近。

所以,如果CVP是一個NP-hard問題的話,那么LWE問題也是一個NP-hard問題了。

現在,我么是時候展示一下LWE問題的數學定義了:

913a5ba8-58b1-11ed-a3b6-dac502259ad0.png

91499762-58b1-11ed-a3b6-dac502259ad0.png

是不是猛一看,一堆亂七八糟的數學符號,想直接跳過去?莫慌,其實很簡單。此外,這幾個數學符號會反復出現在FHE有關的論文中,我們是繞不過去的。

從上面的學習中,我們知道,一個LWE問題中,包含以下幾步:

第一,我們需要定義矩陣A的維度--m×n,其中m代表了整個線性方程組包含幾個方程,而n代表每個方程中有幾個未知數,也稱為“安全系數”。n越大,LWE越難,m越大,LWE越簡單。

第二,我們需要決定有限整數域中的,一般會選擇一個很大的素數。越大,LWE越難。

第三,我們要決定疊加的噪音的取值上限。越大,915b0d44-58b1-11ed-a3b6-dac502259ad0.png越難。

第四,上面三條已經足夠,不過,為了簡單,我們一般只設置一個參數n,然后通過一個函數計算出一組合適的m,q,B,可以保證LWE問題實例很大概率會擁有唯一的解,一般m,q都是n的多項式倍數(m=poly(n))。

我們定義了這些參數之后,LWE問題就好理解了:已知9164a520-58b1-11ed-a3b6-dac502259ad0.png9171b7a6-58b1-11ed-a3b6-dac502259ad0.png,求未知向量s。其實,還是我們前面反復看到的這個矩陣乘法等式:

917b2c8c-58b1-11ed-a3b6-dac502259ad0.png

此情此景,我就不再吟詩了。。。

到此為止,其實我們已經掌握了FHE的絕大部分內容了,萬事俱備,東風也不欠了,現在我們正式構建一個我們自己的同態加密系統。

首先,一個典型的HE系統包含以下幾步:

第一,密鑰生成(KeyGen)
第二,加密(Enc)
第三,解密(Dec)
第四,同態運算(Eval)

我們下面通過一個具體的例子來說明如何構建一個HE系統。
首先,KeyGen(),我們先隨機生成一個私密向量s,然后在這個向量的最下面加一個“-1”,變成918b715a-58b1-11ed-a3b6-dac502259ad0.png,對,沒錯,就是這么草率,就是密鑰。

然后,919dc6a2-58b1-11ed-a3b6-dac502259ad0.png,其中 m是我們要加密的明文-一個數。我們通過以下方式計算密文:

91b14088-58b1-11ed-a3b6-dac502259ad0.png

其中91c40312-58b1-11ed-a3b6-dac502259ad0.png就是我們上面提到的LWE問題,A是隨機生成的矩陣,s是我們第一步KenGen()生成的,e是一個隨機噪音,所以LWE(A,A·s+e)的結果是一個看起來亂七八糟的91db795c-58b1-11ed-a3b6-dac502259ad0.png的矩陣。

91ec6a0a-58b1-11ed-a3b6-dac502259ad0.png是一個91fcbad6-58b1-11ed-a3b6-dac502259ad0.png單位矩陣。

一個91fcbad6-58b1-11ed-a3b6-dac502259ad0.png矩陣C就是我們對加密之后的密文。
第三步,9222bf1a-58b1-11ed-a3b6-dac502259ad0.png,在解密時,對于一個密文矩陣,我們只需要計算9231d5d6-58b1-11ed-a3b6-dac502259ad0.png,就會得到9242fcbc-58b1-11ed-a3b6-dac502259ad0.png我們是我們的密鑰,是已知的,所以,明文m就水落石出了。不知道各位在這時有沒有想到矩陣的特征值和特征向量這兩個概念。這里,密鑰是特征向量,明文是特征值,所以不加噪聲的話,明文實際上是在裸奔,畢竟求一個已知矩陣的特征值和特征向量還是很容易的!

第四步,92535b70-58b1-11ed-a3b6-dac502259ad0.png,即,密文直接加、乘就可以了。這里需要注意的是,密文下的乘法運算可能會將噪音放大,導致解密失敗,為了提高成功解密的概率,我們可以將和,進行二進制分解(就是用只包含0、1的二進制表示)。

如果你看到了這里,那么恭喜你,已基本掌握了FHE的精髓,最后,我們用下圖來結束本文:

92695862-58b1-11ed-a3b6-dac502259ad0.png

我定睛觀察上面的圖,持續十分鐘,然后閉上眼睛,這時圖中的格子忽然動了起來:

Polynomial、Point-Value、Convolution、DFT、FFT、NTT、UnitRoot、PrimitiveRoot、Matrix、Lattice、LWE。。。

這些原來一個個相互獨立的單詞,忽然間變成了一個個精靈,他們開心的跳著歡快的舞步,旋轉、跳躍、相互握手,點頭致意。。。

。。。

。。。

。。。
最后的最后,送上一幅藏寶圖,祝一路順風:

92c09c94-58b1-11ed-a3b6-dac502259ad0.png







審核編輯:劉清

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • 傅里葉變換
    +關注

    關注

    6

    文章

    442

    瀏覽量

    42665
  • 三角函數
    +關注

    關注

    0

    文章

    14

    瀏覽量

    6759
  • 同態加密
    +關注

    關注

    1

    文章

    5

    瀏覽量

    1923

原文標題:看完這篇文章,還搞不懂全同態加密,你過來打我--基于格密碼全同態加密的數學基礎

文章出處:【微信號:LinuxDev,微信公眾號:Linux閱碼場】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    加密算法的選擇對于加密安全有多重要?

    加密算法的選擇對于加密安全至關重要,因為它直接影響到數據保護的有效性和可靠性。以下是幾個關鍵點來說明加密算法選擇的重要性: 加密強度: 加密
    的頭像 發表于 12-17 15:59 ?154次閱讀

    常見的加密算法有哪些?它們各自的優勢是什么?

    常見的加密算法及其優勢如下: AES(Advanced Encryption Standard): AES是一種對稱加密算法,采用分組密碼體制,支持128位、192位和256位密鑰長度。AES的優勢
    的頭像 發表于 12-17 15:57 ?181次閱讀

    對稱加密技術在實際應用中如何保障數據安全?

    ,如使用安全的密鑰協商和密鑰分發方式,定期更換密鑰等。 密碼學原理的安全性: 對稱加密算法的安全性基于密碼學原理,需要確保密碼學原理的安全性,如避免使用弱
    的頭像 發表于 12-16 13:59 ?227次閱讀

    NAS重置密碼攻略來襲,讓你告別‘密碼焦慮’!

    你是否曾遇到過這樣的尷尬場景:當你登錄某個賬號時,突然發現自己的腦子像是被格式化了一樣,一片空白。好不容易憑感覺輸入了幾組可能的密碼組合,結果系統無情地吐出了“密碼錯誤”的提示。 更讓人抓狂
    的頭像 發表于 12-11 15:29 ?321次閱讀
    NAS重置<b class='flag-5'>密碼</b>攻略來襲,讓你告別‘<b class='flag-5'>密碼</b>焦慮’!

    Linux系統設置用戶密碼規則(復雜密碼策略)方法

    Linux系統下的用戶密碼的有效期 可以修改密碼可以通過login.defs文件控制。設置密碼過期期限(默認情況下,用戶的密碼永不過期。) 編輯 /etc/login.defs 文件,
    的頭像 發表于 12-07 09:24 ?365次閱讀

    艾體寶洞察 一文讀懂最新密碼存儲方法,揭秘密碼存儲常見誤區!

    本篇文章將引入并介紹密碼存儲中的基石,關于密碼哈希、鹽加密(Salting)、密鑰派生函數(KDF)的原理及其應用,揭示密碼存儲中的常見誤區,并分享一系列安全實踐。
    的頭像 發表于 09-14 17:37 ?405次閱讀
    艾體寶洞察 一文讀懂最新<b class='flag-5'>密碼</b>存儲方法,揭秘<b class='flag-5'>密碼</b>存儲常見誤區!

    擁有SHA-256核心和32Kbits的EEPROM應用的加密芯片-GEN-FA

    加密芯片 - GEN -FA有32 Kbits的EEPROM。配置數據和用戶數據可以保存在EEPRO m。數據由密碼加密n保護。GEN有SHA-256核心。SHA-256用于身份驗證。
    的頭像 發表于 09-13 09:36 ?328次閱讀
    擁有SHA-256核心和32Kbits的EEPROM應用的<b class='flag-5'>加密</b>芯片-GEN-FA

    深圳特信屏蔽器 4G5G手機信號放大器:一鍵開啟,屋信號滿

    深圳特信屏蔽器|4G5G手機信號放大器:一鍵開啟,屋信號滿
    的頭像 發表于 07-23 09:03 ?772次閱讀

    SSID和密碼是否以加密形式存儲在ESP8266中?

    1.) SSID和密碼是否以加密形式存儲在ESP8266中。如果是,加密格式是什么? 2.) 芯片的唯一MAC ID是否加密
    發表于 07-22 07:35

    請問ESP32使用AT固件如何讓配對密碼大于6位?

    AT+BLESECPARAM 指令密匙長度設置成多少都回復的是 6 位數字的配對密碼。 使用的指令如下: 藍牙 AT 加密指令參考: AT+RESTORE // 恢復出廠設置 AT+GMR//查詢模組版本信息
    發表于 06-27 07:42

    MySQL忘記root密碼解決方案

    mysql登錄密碼為password()算法加密,解密成本太高,以下為通用方案; 原理:mysql提供了特殊啟動方式,即跳過權限表驗證,啟動后,登錄不需要提供密碼; 登錄后,即可修改mysql數據庫的user表,重置
    的頭像 發表于 04-23 16:08 ?749次閱讀

    AES加密協議是什么?AES加密協議的應用

    AES(Advanced Encryption Standard,高級加密標準)是一種廣泛使用的對稱密鑰加密協議,它被設計用于保護電子數據的安全。以下是對AES加密協議的詳細概述: 歷史與標準化
    的頭像 發表于 04-15 15:34 ?935次閱讀

    什么是TLS加密?TLS加密的功能特點

    :使用強大的密碼學算法(如AES、ChaCha20等)對傳輸中的數據進行加密,確保即使數據在傳輸過程中被截獲,未經授權的第三方
    的頭像 發表于 04-03 13:49 ?739次閱讀

    指紋加密移動硬盤詳細方案解析

    全盤數據硬件SM4/AES加密存儲,即使拆出存儲芯片,也無法通過探針攻擊、功率攻擊等手段來破解存儲的密文數據。  全數字密碼鍵盤,口令長度范圍6~32位。  支持密鑰備份和恢復功能,密鑰備份采用
    的頭像 發表于 03-18 15:23 ?760次閱讀
    指紋<b class='flag-5'>加密</b>移動硬盤詳細方案解析

    加密狗是什么意思 加密狗怎么解除加密

    加密狗(Dongle)又稱為加密鎖、硬件鎖或USB密鑰是一種用于軟件保護和授權管理的硬件設備。它通常是一個外部設備,插入到計算機的USB接口上,以確保只有經過授權的用戶可以訪問該軟件。加密狗使用各種
    的頭像 發表于 01-25 17:19 ?8949次閱讀
    主站蜘蛛池模板: 精品二区| 亚洲精品色图| 欧美极品一区| 天堂影院在线| 尤物啪啪| 午夜免费福利片观看| 色多多在线看| 男女爱爱福利| 狠狠曹| 成人亚洲视频| 天天躁日日躁狠狠躁一级毛片| 天天做天天爱夜夜爽毛片毛片| 特黄特黄| 操美女免费网站| 91美女啪啪| 高清一区二区| 四虎网址最新| 美女在线看永久免费网址| 国产精品国产三级国快看| 伊人色综合久久天天爱| 欧美在线成人午夜影视| 把小嫩嫩曰出白浆| 亚洲婷婷综合中文字幕第一页| 高h细节肉爽文bl1v1| 手机在线色| 久久99精品久久久久久野外| 俺就色| 久久新视频| 亚洲一二三区视频| 亚洲伊人久久大香线蕉啊| 欧美一区二区三区四区视频 | 欧美性猛交xxxx黑人猛交| 亚洲专区一区| 五月激情六月婷婷| 免费看一级毛片| 夜色成人| 2016天天干| 中出丰满大乳中文字幕| 欧美性色欧美a在线播放| china国语对白刺激videos| 黄网在线观看免费|