Aller au contenu principal

קמליה (צופן)


קמליה (צופן)


קמליה - Camellia הוא צופן בלוקים סימטרי שפותח בשנת 2000 בשיתוף פעולה של מיצובישי ו-NTT על ידי צוות קריפטוגרפים בראשות מיצורו מצואי . הוצע לגופי תקינה רבים, נכלל ברשימת הצפנים המומלצים של פרויקט NESSIE האירופאי משנת 2003 ופרויקט CRYPTREC של ממשלת יפן, הוצע במזכר RFC 3713 של IETF כתוספת ל-IPSec, אושר על ידי ארגון התקינה הבינלאומי בתקן ISO/IEC 18033-3 ונכלל בפרוטוקולי אבטחה פופולריים רבים, ביניהם SSL, OpenPGP ו-S/MIME. ספריות אבטחה רבות מספקות תמיכה לקמליה, ביניהן Crypto++, GPG, OpenSSL. קמליה מוגן בפטנט והותר על ידי NTT לשימוש ברישיון חופשי.

הצופן מקבל בלוק מידע בגודל 128 סיביות ומפתח הצפנה בשלושה גדלים אפשריים 128, 192 או 256 סיביות והפלט הוא בלוק מוצפן בגודל 128 סיביות. הצופן בעל סגנון ייחודי - מעין רשת פייסטל רקורסיבית, בשמונה-עשר או עשרים וארבעה סבבים בהתאם לאורך המפתח ופועל ברמה של בתים. הפונקציה הפנימית מתנהגת כרשת החלפה-תמורה על שמונה בתים, שכבת ההחלפה מתבצעת במקביל באמצעות שמונה תיבות החלפה (S-box) בגודל 8x8 סיביות ושכבת התמורה היא קומבינציה של XOR בין בתי הקלט. בנוסף, בדומה לMISTY ו-KASUMI כולל גם שכבת טרנספורמציה ליניארית תלוית מפתח שמופעלת אחת לשישה סבבים.

ביטחון

צופן קמליה קיבל הכרה כצופן מודרני בטוח ואינו נופל ברמתו מ-AES. הוא זוכה לפופולריות רבה גם עקב פשטותו ויעילותו הרבה הן בחומרה והן בתוכנה. ההתקפות הטובות ביותר הידועות נגד הצופן הן התקפה שנקראת Square Attack על גרסה מצומצמת (תשעה סבבים) בסיבוכיות של 2 202 {\displaystyle 2^{202}} הצפנות ועם 2 61 {\displaystyle 2^{61}} טקסטים מוצפנים. התקפה אחרת שנקראת Rectangle Attack של Shirai מצליחה לשבור את הצופן בעשרה סבבים בסיבוכיות של 2 241 {\displaystyle 2^{241}} קריאות זיכרון עם 2 127 {\displaystyle 2^{127}} טקסטים נבחרים. התקפה נוספת שהיא סוג של התקפה דיפרנציאלית אינה טובה משמעותית מכוח גס. בכללות אילו התקפות תאורטיות שאינן מסכנות את ביטחון הצופן. יש לציין שהטרנספורמציה הליניארית הנוספת (להלן), אחראית בין היתר על חוזקו.

תיאור הצופן

צופן קמליה (על שם צמח התה) הוא ממשיכו של E2 שהיה מהמועמדים ל-AES והסגנון הייחודי שלו מבוסס עליו במידה רבה. הפעולות בצופן הן בעיקר פעולות החלפה ופעולות לוגיות OR, XOR ו-AND על מילים או בתים. כאשר המרות ממילים לבתים וההפך הן לפי סדר בתים גדול (למשל אם המילה מכילה את הערך 0x01234567 (בבסיס הקסדצימלי) בהמרה לבתים הבית הראשון יכיל 0x01, השני 0x23, השלישי 0x45 והרביעי 0x67). בגרסת מפתח 128 סיביות, בלוק המידע עובר 18 סבבים של טרנספורמציה במבנה פייסטל בנוסף לשכבות הטרנספורמציה הליניארית F L {\displaystyle FL} והטרנספורמציה ההופכית F L 1 {\displaystyle FL^{-1}} לאחר הסבב השישי והסבב השנים-עשר (כמתואר בתרשים משמאל). פונקציית הרחבת המפתח מקבלת את המפתח הסודי המסופק על ידי המשתמש ומייצרת ממנו תת-מפתחות מורחבים לכל הסבבים שהם ארבעה מפתחות הלבנה המסומנים k w t {\displaystyle kw_{t}} כאשר t = 1 , 2 , 3 , 4 {\displaystyle t=1,2,3,4} , שמונה עשר מפתחות סבבים k u {\displaystyle k_{u}} כאשר u = 1 , 2 , . . . , 18 {\displaystyle u=1,2,...,18} וכן ארבעה מפתחות k l v {\displaystyle kl_{v}} (עבור הפונקציות הליניאריות) כאשר v = 1 , 2 , 3 , 4 {\displaystyle v=1,2,3,4} , כולם מילים באורך 64 סיביות. תחילה בלוק הטקסט M {\displaystyle M} מחובר ב-XOR (המסומן כאן ב- {\displaystyle \oplus } ) עם שני המפתחות הראשונים k w 1 , k w 2 {\displaystyle kw_{1},kw_{2}} בהתאמה, פעולה זו נקראת הלבנה. התוצאה מחולקת לשני חצאים L {\displaystyle L} ו- R {\displaystyle R} ואז הפעולות הבאות מבוצעות r {\displaystyle r} פעמים כאשר r = 1 , . . . , 18 {\displaystyle r=1,...,18} למעט הסבבים 6 ו-12:

L r = R r 1 F ( L r 1 , k r ) {\displaystyle L_{r}=R_{r-1}\oplus F(L_{r-1},k_{r})} ,
R r = L r 1 {\displaystyle R_{r}=L_{r-1}} .

עבור הסבבים 6 ו-12 מבצעים כדלהלן:

L r = R r 1 F ( L r 1 , k r ) {\displaystyle L_{r}^{'}=R_{r-1}\oplus F(L_{r-1},k_{r})} ,
R r = L r 1 {\displaystyle R_{r}^{'}=L_{r-1}} ,
L r = F L ( L r , k l 2 r / 6 1 ) {\displaystyle L_{r}=FL(L_{r}^{'},kl_{2r/6-1})} ,
R r = F L 1 ( R r , k l 2 r / 6 ) {\displaystyle R_{r}=FL^{-1}(R_{r}^{'},kl_{2r/6})} .

לבסוף התוצאות האחרונות R 18 {\displaystyle R_{18}} ו- L 18 {\displaystyle L_{18}} עוברים שוב הלבנה עם המפתחות k w 3 , k w 4 {\displaystyle kw_{3},kw_{4}} בהתאמה. במילים אחרות פלט הצופן הוא C = ( R 18 k w 3     L 18 k w 4 ) {\displaystyle C=(R_{18}\oplus kw_{3}\ \|\ L_{18}\oplus kw_{4})} .


מפתחות 192 ו-256 סיביות

כאשר נבחר מפתח באורך 192 או 256 סיביות יחולו השינויים הבאים. יהיו שישה מפתחות עבור הפונקציות הליניאריות כלומר נוספו שני מפתחות k l 5 , k l 6 {\displaystyle kl_{5},kl_{6}} . יהיו 24 מפתחות k u {\displaystyle k_{u}} במקום 18 וכן קוראים לטרנספורמציה הליניארית והטרנספורמציה ההופכית שלה שלוש פעמים; בסבבים 6, 12 ו-18. כל היתר זהה.

פענוח

הפענוח בקמליה זהה להצפנה למעט היפוך סדר תת-המפתחות. אם המפתח הוא באורך 128 סיביות, תחילה מבטלים את ההלבנה על ידי חיבור ב-XOR עם המפתחות k w 3 , k w 4 {\displaystyle kw_{3},kw_{4}} בהתאמה ומתקבלים החצאים L 18 , R 18 {\displaystyle L_{18},R_{18}} מהסבב האחרון של ההצפנה ואז מבצעים עבור r = 18 {\displaystyle r=18} עד r = 1 {\displaystyle r=1} בסדר יורד למעט הסבבים 13 ו-7 כדלהלן:

R r 1 = L r F ( R r , k r ) {\displaystyle R_{r-1}=L_{r}\oplus F(R_{r},k_{r})} ,
L r 1 = R r {\displaystyle L_{r-1}=R_{r}} .

בסבבים 13 ו-7 מבצעים:

R r 1 = L r F ( R r , k r ) {\displaystyle R_{r-1}^{'}=L_{r}\oplus F(R_{r},k_{r})} ,
L r 1 = R r {\displaystyle L_{r-1}^{'}=R_{r}} ,
R r 1 = F L ( R r 1 , k l 2 ( r 1 ) / 6 ) {\displaystyle R_{r-1}=FL(R_{r-1}',kl_{2(r-1)/6})} ,
L r 1 = F L 1 ( L r 1 , k l 2 ( r 1 ) / 6 1 ) {\displaystyle L_{r-1}=FL^{-1}(L_{r-1}^{'},kl_{2(r-1)/6-1})} .

הטקסט הקריא יהיה M = ( L 0 k w 1     R 0 k w 2 ) {\displaystyle M=(L_{0}\oplus kw_{1}\ \|\ R_{0}\oplus kw_{2})} .

אם המפתח הנבחר הוא באורך 192 או 256 סיביות, ההבדלים הם שמתבצעים בסך הכול 24 סבבים בסדר יורד והטרנספורמציה הליניארית מתבצעת בסבבים 19, 13 ו-7.

הכנת מפתח

הכנת המפתח נעשית באמצעות גרסה מצומצמת של רשת פייסטל כמתואר בתרשים משמאל. תחילה מגדירים שני משתנים מקומיים K L , K R {\displaystyle K_{L},K_{R}} באורך 128 סיביות כל אחד בהם מציבים את המפתח המסופק על ידי המשתמש. לכל משתנה אפשר להתייחס כאל מילה אחת באורך 128 סיביות או שתי מילים באורך 64 סיביות המייצגים את שני החצאים של משתנה האב, צד ימין של K L {\displaystyle K_{L}} ייקרא K L R {\displaystyle K_{LR}} וצד שמאל K L L {\displaystyle K_{LL}} וכן לגבי K R {\displaystyle K_{R}} , בסך הכול ארבעה רבעים K L L , K L R , K R L {\displaystyle K_{LL},K_{LR},K_{RL}} ו- K R R {\displaystyle K_{RR}} באורך 64 סיביות כל אחד. כאשר המפתח המסופק על ידי המשתמש הוא באורך 128 סיביות מציבים אותו ב- K L {\displaystyle K_{L}} ואילו המילה K R = 0 {\displaystyle K_{R}=0} . את המפתח המסופק על ידי המשתמש טוענים למשתנים הפנימיים כך שהכללים הבאים מתקיימים:

  • עבור מפתח 128 סיביות; המפתח בחצי השמאלי K L {\displaystyle K_{L}} ואילו החצי הימני K R = 0 {\displaystyle K_{R}=0} . שים לב ש- K L L {\displaystyle K_{LL}} ו- K L R {\displaystyle K_{LR}} מכילים את שני חצאי K L {\displaystyle K_{L}} בהתאמה.
  • עבור מפתח 192 סיביות; המפתח מחולק כך ש- K = K L     K R L , K R R = K R L ¯ {\displaystyle K=K_{L}\ \|\ K_{RL},K_{RR}={\overline {K_{RL}}}} . הסמל x ¯ {\displaystyle {\overline {x}}} הוא המשלים ל-1 של x {\displaystyle x} (אותו אפשר לקבל על ידי חיבור XOR עם וקטור של 64 אחדים). המפתח מתפרס על פני K L {\displaystyle K_{L}} ומחצית מ- K R {\displaystyle K_{R}} - כלומר K R L {\displaystyle K_{RL}} ואילו החלק האחרון K R R {\displaystyle K_{RR}} מכיל את המשלים של K R L {\displaystyle K_{RL}} .
  • עבור מפתח 256 סיביות; המפתח מחולק כך ש- K = K L     K R {\displaystyle K=K_{L}\ \|\ K_{R}} .
  • עבור כל המפתחות; K L = K L L     K L R {\displaystyle K_{L}=K_{LL}\ \|\ K_{LR}} וכן K R = K R L     K R R {\displaystyle K_{R}=K_{RL}\ \|\ K_{RR}} .

בנוסף מגדירים שני משתנים K A {\displaystyle K_{A}} ו- K B {\displaystyle K_{B}} באורך 128 סיביות כל אחד, אותם מאתחלים כדלהלן. תחילה מבצעים K L K R {\displaystyle K_{L}\oplus K_{R}} , את התוצאה מצפינים בהצפנה מקוצרת ברשת פייסטל בשני סבבים עם הפונקציה F {\displaystyle F} המתוארת להלן כאשר הערכים Σ 1 , Σ 2 {\displaystyle \Sigma _{1},\Sigma _{2}} מתוך הטבלה להלן משמשים כמפתחות הצפנה. את התוצאה מחברים ב-XOR עם K L {\displaystyle K_{L}} ושוב מצפינים עם Σ 3 {\displaystyle \Sigma _{3}} ו- Σ 4 {\displaystyle \Sigma _{4}} והתוצאה האחרונה תהיה K A {\displaystyle K_{A}} . את K A {\displaystyle K_{A}} מחברים שוב ב-XOR עם K R {\displaystyle K_{R}} ומצפינים עם Σ 5 , Σ 6 {\displaystyle \Sigma _{5},\Sigma _{6}} והתוצאה האחרונה היא K B {\displaystyle K_{B}} . התהליך מומחש בתרשים משמאל.

ערכי הקבועים הם 16 ספרות החל מהספרה השנייה ועד הספרה ה-17 של הייצוג ההקסדצימלי של חלק השבר של השורש הריבועי של ששת המספרים הראשוניים הראשונים.

מתוך המשתנים K L , K R , K A , K B {\displaystyle K_{L},K_{R},K_{A},K_{B}} גוזרים תת-מפתחות ( k w t , k u , k l v ) {\displaystyle (kw_{t},k_{u},kl_{v})} כל אחד באורך 64 סיביות. כל מפתח נגזר מהחלק השמאלי או הימני של הזזה מעגלית של אחד מהמשתנים האמורים לפי הטבלה הבאה. למשל אם המפתח הנבחר הוא 192 או 256 סיביות אזי לפי הטבלה הימנית, ערכו של תת-המפתח k 8 {\displaystyle k_{8}} עבור הסבב השמיני הוא החצי הימני של K B {\displaystyle K_{B}} המסומן בטבלה K B R {\displaystyle K_{BR}} לאחר הזזה מעגלית 30 פוזיציות לשמאל.

הביטוי x y {\displaystyle x\lll y} פירושו כאן הזזה מעגלית של x {\displaystyle x} במספר סיביות המצוין על ידי y {\displaystyle y} בגבולות מילה באורך 64 סיביות. לדוגמה אם המשתנה באורך 8 סיביות (בית), והוא מכיל את הערך 169 או 'A9' (בבסיס בינארי "10101001") לאחר הזה מעגלית לשמאל שלוש סיביות יתקבל 53 או '35' ("110101").

היות שכל מפתח כאמור הוא תוצאה של הזזה מעגלית של אחד המשתנים האמורים, אפשר להכין את מפתחות הסבבים תוך כדי ריצה במקום לאחסן את כל הטבלה בזיכרון ובכך לחסוך מקום.

פונקציות עזר

להלן תיאור הפונקציות המרכיבות את הצופן מהגדול לקטן. הפונקציה F {\displaystyle F} המופיעה בתרשים משמאל מוגדרת כדלהלן:

F ( X , k ) Y = P ( S ( X k ) {\displaystyle {\boldsymbol {F(X,k)\longmapsto Y=P(S(X\oplus k)}}}

הפונקציה מקבלת שני פרמטרים, ערך X {\displaystyle X} וקטע מתאים מהמפתח המורחב k {\displaystyle k} באורך 64 סיביות כל אחד ומחזירה את Y {\displaystyle Y} גם הוא באורך 64 סיביות תוך שימוש בפונקציות S {\displaystyle S} ו- P {\displaystyle P} המייצגות החלפה ותמורה בהתאמה בנוסף לחיבור עם k {\displaystyle k} .

הפונקציה FL

הפונקציה הליניארית F L {\displaystyle FL} מקבלת שני פרמטרים; X {\displaystyle X} באורך 64 סיביות המחולק לצד ימין וצד שמאל X L {\displaystyle X_{L}} ו- X R {\displaystyle X_{R}} בהתאמה ואת k l {\displaystyle kl} המחולק גם הוא לשני חצאים k l L , k l R {\displaystyle kl_{L},kl_{R}} ומחזירה את Y {\displaystyle Y} באורך 64 סיביות כדלהלן:

F L ( X L     X R , k l L     k l R ) Y L     Y R {\displaystyle FL(X_{L}\ \|\ X_{R},kl_{L}\ \|\ kl_{R})\longmapsto Y_{L}\ \|\ Y_{R}}

כאשר

Y R = ( ( X L k l L ) 1 ) X R {\displaystyle Y_{R}=((X_{L}\land kl_{L})\lll 1)\oplus X_{R}} ,
Y L = ( Y R k l R ) X L {\displaystyle Y_{L}=(Y_{R}\lor kl_{R})\oplus X_{L}} .

הסימן {\displaystyle \land } מייצג את האופרטור הלוגי AND והסימן {\displaystyle \lor } מייצג את האופרטור הלוגי OR.

הפונקציה הליניארית ההופכית

הפונקציה ההופכית מוגדרת כך:

F L 1 ( Y L     Y R , k l L     k l R ) X L     X R {\displaystyle FL^{-1}(Y_{L}\ \|\ Y_{R},kl_{L}\ \|\ kl_{R})\longmapsto X_{L}\ \|\ X_{R}}

כאשר

X L = ( Y R k l R ) Y L {\displaystyle X_{L}=(Y_{R}\lor kl_{R})\oplus Y_{L}} ,
X R = ( ( X L k l L ) 1 ) Y R {\displaystyle X_{R}=((X_{L}\land kl_{L})\lll 1)\oplus Y_{R}} .

התרשים משמאל מתאר את שתי הפונקציות הליניאריות.

הפונקציה S

פונקציית ההחלפה מקבלת קלט l {\displaystyle l} באורך 8 בתים ונעזרת בארבע טבלאות החלפה s 1 , s 2 , s 3 {\displaystyle s_{1},s_{2},s_{3}} ו- s 4 {\displaystyle s_{4}} להלן כדי להחליף את ערכי הבתים בבתים שבטבלה לפי אינדקסים - בכל טבלה בסך הכול 256 ערכים אפשריים. כדלהלן:

l 1 = s 1 ( l 1 ) , l 2 = s 2 ( l 2 ) , l 3 = s 3 ( l 3 ) , l 4 = s 4 ( l 4 ) {\displaystyle l_{1}=s_{1}(l_{1}),l_{2}=s_{2}(l_{2}),l_{3}=s_{3}(l_{3}),l_{4}=s_{4}(l_{4})}
l 5 = s 2 ( l 5 ) , l 6 = s 3 ( l 6 ) , l 7 = s 4 ( l 7 ) , l 8 = s 1 ( l 8 ) {\displaystyle l_{5}=s_{2}(l_{5}),l_{6}=s_{3}(l_{6}),l_{7}=s_{4}(l_{7}),l_{8}=s_{1}(l_{8})}

לדוגמה אם ערכו של הבית l 1 = 12 {\displaystyle l_{1}=12} , התוצאה לפי הטבלה הראשונה היא l 1 = s 1 ( 12 ) = 234 {\displaystyle l_{1}=s_{1}(12)=234} .

תיבות ההחלפה

תיבות ההחלפה של קמליה (s-box) הן ערכי שקילות אפינית של פונקציות הופכיות מעל השדה G F ( 2 8 ) {\displaystyle GF(2^{8})} . בהצגה אלגברית:

s 1 ( x ) h ( g ( f ( 0xc5 x ) ) ) 0x6a {\displaystyle s_{1}(x)\longmapsto \mathbf {h} (\mathbf {g} (\mathbf {f} ({\text{0xc5}}\oplus x)))\oplus {\text{0x6a}}}
s 2 ( x ) s 1 ( x ) 1 {\displaystyle s_{2}(x)\longmapsto s_{1}(x)\lll 1}
s 3 ( x ) s 1 ( x ) 1 {\displaystyle s_{3}(x)\longmapsto s_{1}(x)\ggg 1}
s 4 ( x ) s 1 ( x 1 ) {\displaystyle s_{4}(x)\longmapsto s_{1}(x\lll 1)}

הפונקציה f {\displaystyle \mathbf {f} } היא צירוף ליניארי של סיביות הקלט לפי הנוסחה:

b 1 = a 6 a 2 , b 2 = a 7 a 1 , b 3 = a 8 a 5 a 3 , b 4 = a 8 a 3 {\displaystyle b_{1}=a_{6}\oplus a_{2},b_{2}=a_{7}\oplus a_{1},b_{3}=a_{8}\oplus a_{5}\oplus a_{3},b_{4}=a_{8}\oplus a_{3}} ,
b 5 = a 7 a 4 , b 6 = a 5 a 2 , b 7 = a 8 a 1 , b 8 = a 6 a 4 {\displaystyle b_{5}=a_{7}\oplus a_{4},b_{6}=a_{5}\oplus a_{2},b_{7}=a_{8}\oplus a_{1},b_{8}=a_{6}\oplus a_{4}} .

הפונקציה g {\displaystyle \mathbf {g} } מוגדרת כך:

( b 8 + b 7 α + b 6 α 2 + b 5 α 3 ) + ( b 4 + b 3 α + b 2 α 2 + b 1 α 3 ) β {\displaystyle (b_{8}+b_{7}\alpha +b_{6}\alpha ^{2}+b_{5}\alpha ^{3})+(b_{4}+b_{3}\alpha +b_{2}\alpha ^{2}+b_{1}\alpha ^{3})\beta }
= 1 / ( ( a 8 + a 7 α + a 6 α 2 + a 5 α 3 ) + ( a 1 + a 3 α + a 2 α 2 + a 1 α 3 ) β ) {\displaystyle =1/((a_{8}+a_{7}\alpha +a_{6}\alpha ^{2}+a_{5}\alpha ^{3})+(a_{1}+a_{3}\alpha +a_{2}\alpha ^{2}+a_{1}\alpha ^{3})\beta )}

כאשר β {\displaystyle \beta } מקיים β 8 + β 6 + β 5 + β 3 + 1 = 0 {\displaystyle \beta ^{8}+\beta ^{6}+\beta ^{5}+\beta ^{3}+1=0} וכן α = β 238 = β 6 + β 5 + β 3 + β 2 {\displaystyle \alpha =\beta ^{238}=\beta ^{6}+\beta ^{5}+\beta ^{3}+\beta ^{2}} הוא אלמנט בשדה G F ( 2 4 ) {\displaystyle GF(2^{4})} המקיים α 4 + α + 1 = 0 {\displaystyle \alpha ^{4}+\alpha +1=0} .

הפונקציה h {\displaystyle \mathbf {h} } מוגדרת בסיביות עבור הקלט a = a 1 a 2 a 3 a 4 a 5 a 6 a 7 a 8 {\displaystyle a=a_{1}a_{2}a_{3}a_{4}a_{5}a_{6}a_{7}a_{8}} כך:

b 1 = a 5 a 6 a 2 , b 2 = a 6 a 2 , b 3 = a 7 a 4 , b 4 = a 8 a 2 {\displaystyle b_{1}=a_{5}\oplus a_{6}\oplus a_{2},b_{2}=a_{6}\oplus a_{2},b_{3}=a_{7}\oplus a_{4},b_{4}=a_{8}\oplus a_{2}}
b 5 = a 7 a 3 , b 6 = a 8 a 1 , b 7 = a 5 a 1 , b 8 = a 6 a 3 {\displaystyle b_{5}=a_{7}\oplus a_{3},b_{6}=a_{8}\oplus a_{1},b_{7}=a_{5}\oplus a_{1},b_{8}=a_{6}\oplus a_{3}}

אפשר לראות שערכי התיבות s 2 , s 3 {\displaystyle s_{2},s_{3}} ו- s 4 {\displaystyle s_{4}} למעשה נגזרות מהתיבה הראשונה. לכן אם הזיכרון מוגבל כמו בכרטיס חכם, אפשר לאחסן בזיכרון רק את הטבלה הראשונה ולחשב את ההחלפה במקום על ידי הנוסחאות המתוארות. למשל אם x = 20 {\displaystyle x=20} החלפה של x {\displaystyle x} לפי טבלה 3 היא: s 1 ( 20 ) 1 = 69 1 = 162 {\displaystyle \textstyle s_{1}(20)\ggg 1=69\ggg 1=162} .


להלן ערכי תיבות ההחלפה:

s 1 {\displaystyle \mathbf {s_{1}} }

s 2 {\displaystyle \mathbf {s_{2}} }

s 3 {\displaystyle \mathbf {s_{3}} }

s 4 {\displaystyle \mathbf {s_{4}} }

הפונקציה P

הפונקציה P {\displaystyle P} מקבלת מערך של שמונה בתים z 1 , . . . , z 8 {\displaystyle z_{1},...,z_{8}} ומחזירה את התמורה שלהם לפי:


דרך אחרת להציג זאת היא על ידי כפל מטריצות:

( z 8 z 7 z 1 ) ( z 8 z 7 z 1 ) = P ( z 8 z 7 z 1 ) {\displaystyle {\begin{pmatrix}z_{8}\\z_{7}\\\vdots \\z_{1}\end{pmatrix}}\longmapsto {\begin{pmatrix}z_{8}\\z_{7}\\\vdots \\z_{1}\end{pmatrix}}=P{\begin{pmatrix}z_{8}\\z_{7}\\\vdots \\z_{1}\end{pmatrix}}}

כאשר

P = ( 0 1 1 1 1 0 0 1 1 0 1 1 1 1 0 0 1 1 0 1 0 1 1 0 1 1 1 0 0 0 1 1 0 1 1 1 1 1 1 0 1 0 1 1 0 1 1 1 1 1 0 1 1 0 1 1 1 1 1 0 1 1 0 1 ) {\displaystyle P={\begin{pmatrix}0&1&1&1&1&0&0&1\\1&0&1&1&1&1&0&0\\1&1&0&1&0&1&1&0\\1&1&1&0&0&0&1&1\\0&1&1&1&1&1&1&0\\1&0&1&1&0&1&1&1\\1&1&0&1&1&0&1&1\\1&1&1&0&1&1&0&1\\\end{pmatrix}}}

קוד לדוגמה

להלן קוד שלם בשפת ++C של הצפנת קמליה לפי RFC 3713:

ראו גם

  • צופן בלוקים
  • KASUMI
  • ARIA

הערות שוליים


Collection James Bond 007


Text submitted to CC-BY-SA license. Source: קמליה (צופן) by Wikipedia (Historical)



ghbass