לדלג לתוכן

בעיית הלוגריתם הבדיד

מתוך ויקיפדיה, האנציקלופדיה החופשית
(הופנה מהדף לוגריתם בדיד)

באלגברה חישובית ובקריפטוגרפיה, בעיית הלוגריתם הבָּדִיד (דיסקרטי) המסומנת בקיצור DLP (באנגלית: Discrete Logarithm Problem), היא מציאת המעריך בהינתן הבסיס והתוצאה כך שמתקיים , בקיצור כאשר ו- הם מספרים שלמים.

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

חבורה ציקלית

[עריכת קוד מקור | עריכה]
ערך מורחב – חבורה ציקלית

תהי חבורה סופית מסדר . עבור כל איבר קבוצת החזקות של :

היא תת-חבורה ציקלית של שהסדר שלה הוא השלם הקטן ביותר המקיים . קל לראות שהרצף חוזר על עצמו כי וכן וכן הלאה. במקרה זה נקרא יוצר או איבר פרימיטיבי (שורש פרימיטיבי). אם ראשוני אז היא צקלית וכל איבריה פרט ל-1 הם יוצרים שלה. לעומת זאת סדר החבורה הכפלית אינו ראשוני (למעט אם ). לדוגמה לפי אוילר היא מסדר . לא כל האיברים של חבורה זו הם יוצרים שלה, רואים ש-2 למשל אינו יוצר של החבורה כי והסדר שלו הוא 4 (כלומר אם מעלים את 2 בחזקת עבור רואים שמתקבלת חבורה ציקלית עם ארבעה איברים שחוזרים על עצמם). כן רואים שלפי חוקי החבורות סדר תת-חבורה תמיד מחלק של סדר החבורה. אם היא חבורה ציקלית מסדר ראשוני , קיים יוצר של החבורה כך שמתקיים (למעשה יכולים להיות יוצרים רבים). במילים אחרות, עבור כל שלם קיים שלם ייחודי המקיים . אם החבורה מובנת מההקשר קוראים ל- "הלוגריתם הבדיד" של בבסיס ואפשר לכתוב זאת בקיצור . כמו כן אם עבור שלם כלשהו אז . הסיבה שהלוגריתם נקרא כאן "בדיד" נובעת מהעובדה שהוא נלקח מעל חבורה סופית, זאת בניגוד ללוגריתם רגיל שטווח הערכים שלו הוא מעל קבוצה אין סופית.

חוקי הלוגריתמים

[עריכת קוד מקור | עריכה]

לוגריתם בדיד מציית לחוקי הלוגריתמים הרגילים. למשל, (כאשר '1' הוא איבר יחידה של ) וכן:

  • .
  • עבור שלם כלשהו.

הגדרה פורמלית

[עריכת קוד מקור | עריכה]

הגדרה פורמלית[1] של בעיית הלוגריתם הבדיד היא:

נתונה חבורה ציקלית סופית מסדר המסומנת ב- ונתון יוצר של החבורה ויהי איבר כלשהו. מצא את הלוגריתם הבדיד של בבסיס בקיצור שהוא איבר יחידי בטווח המקיים: .

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

ניסוי לוגריתם בדיד :

  1. מריצים את כדי לקבל את כאשר היא חבורה ציקלית מסדר ו- הוא יוצר של .
  2. בוחרים איבר (אפשר לעשות זאת על ידי בחירת איבר אקראי וחישוב ).
  3. האלגוריתם מקבל את ומחשב את .
  4. הניסוי יוכתר בהצלחה אם אחרת הוא מסתיים בכישלון.

בהגדרה פורמלית, אומרים שבעיית הלוגריתם הבדיד (המסומנת בקיצור DLP) קשה לפתרון ביחס ל- אם עבור כל אלגוריתם פולינומי הסתברותי קיימת פונקציית זניחות כך שמתקיים:

במילים, ההשערה היא שקיימת חבורה שבה בעיית DLP קשה לפתרון מבחינה חישובית למעט בהסתברות זניחה.

דוגמה במספרים קטנים

[עריכת קוד מקור | עריכה]

אם אז היא חבורה ציקלית מסדר . אם ניקח יוצר של למשל . בהינתן השלם , הבעיה היא למצוא המקיים , היות ש- , אז ב-.

הכללה של בעיית הלוגריתם הבדיד

[עריכת קוד מקור | עריכה]

נתונה חבורה ציקלית מסדר ראשוני , המסומנת ב-, ונתונים יוצרים . בהינתן איבר כלשהו, בעיית ייצוג הלוגריתם הבדיד (discrete logarithm representation problem) בקיצור DLREP, היא למצוא n-יה כך ש-. n-יה כזו נקראת הייצוג של ביחס ל-.

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

בעיית דיפי-הלמן

[עריכת קוד מקור | עריכה]

ויטפילד דיפי ומרטין הלמן פרסמו ב-1976 מאמר פורץ דרך שהעלה לראשונה את רעיון ההצפנה האסימטרית והציעו לבססה על בעיה מתמטית קשה בתורת המספרים הקשורה לבעיית הלוגריתם הבדיד שנקראת כיום בעיית דיפי-הלמן והיא מתחלקת לשתים, בעיית דיפי הלמן חישובית, המסומנת בקיצור CDH ובעיית הכרעת דיפי-הלמן המסומנת בקיצור DDH. שתיהן בעיות בעלות חשיבות רבה בתחום הקריפטוגרפיה. נתונה חבורה ציקלית ויוצר ונתונים שני איברים מהחבורה ו- כאשר ו- עבור שני שלמים ו- לא ידועים. פונקציית דיפי-הלמן מוגדרת כדלהלן:

.

הבעיה הראשונה, בעיית CDH, היא לחשב את פונקציית דיפי-הלמן עבור שני איברים אקראיים (כאשר ו- אינם ידועים אחרת הבעיה טריוויאלית). הבעיה השנייה DDH היא בעיית הכרעה, להבחין בין פלט הפונקציה לבין איבר אקראי כלשהו מהחבורה. במילים אחרות עבור איברים שנבחרו באקראי ופתרון אפשרי הבעיה היא להכריע האם או הוא איבר אקראי חסר משמעות.

אם בעיית הלוגריתם הבדיד קלה לפתרון אז אפשר לפתור גם את בעיית דיפי-הלמן, תחילה מחשבים את ואז מחזירים את . מאידך לא ברור האם קושיה המשוער של בעיית דיפי-הלמן שקול לבעיית הלוגריתם הבדיד.

בעיית DDH נחשבת לבעיה קשה ביחס ל- אם עבור כל אלגוריתם הסתברותי פולינומי קיימת פונקציית זניחות כך שהמתקיים:

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

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

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

דוגמה לבעיית דיפי-הלמן במספרים קטנים

[עריכת קוד מקור | עריכה]

נתון הראשוני החבורה הציקלית מסדר והיוצר . אם נבחר וכן . אם נתונים האיברים ו- (מודולו 97), בעיית דיפי-הלמן היא לגלות את (כאשר ו- לא ידועים), יש לשים לב שאת החזקה מצמצמים מודולו ההסדר של החבורה 96.

עקום אליפטי

[עריכת קוד מקור | עריכה]
ערך מורחב – הצפנה מבוססת עקום אליפטי

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

.

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

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

האלגוריתם הטוב ביותר הידוע כיום לפתרון בעיית הלוגריתם הבדיד בעקום אליפטי (אם לא מביאים בחשבון אלגוריתם קוונטי) היא גרסה מקבילית של אלגוריתם רו של פולרד ללוגריתמים.

אלגוריתמים

[עריכת קוד מקור | עריכה]

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

  • אלגוריתם צעד-קטן צעד-גדול של דויד שנקס שמסוגל למצוא לוגריתם בדיד בזמן ריצה של ובסיבוכיות מקום בסדר גודל .
  • אלגוריתם פוליג-הלמן הוא אלגוריתם ספציפי המתאים במקרה שהגורמים הראשוניים של סדר החבורה ידועים. במיוחד, אם לסדר החבורה יש גורמים קטנים, אלגוריתם זה מאפשר לצמצם את הבעיה לשתי בעיות לוגריתם בדיד מסדר קטן יותר (לפי גודלם של הגורמים הראשוניים) והפתרונות שלהם ניתנים לשילוב כדי לקבל פתרון לבעיה המקורית בסיבוכיות זמן זהה לבעיות הקטנות.
  • אלגוריתם רו של פולרד ללוגריתמים שזמן ריצתו הוא בדומה לאלגוריתם צעד-קטן צעד-גדול אך ללא סיבוכיות מקום.
  • אלגוריתם תחשיב אינדקסים שרץ בזמן ריצה תת-מעריכי ונחשב לאלגוריתם החזק ביותר הידוע כיום לפתרון בעיית הלוגריתם הבדיד בחבורות מסדר גדול מאוד כמו עבור פריק. גרסה אחת שלו הנקראת אלגוריתם Coppersmith מסוגלת להגיע לזמן ריצה של עבור קבוע כלשהו .
  • כאשר מחשבים קוונטיים יהיו מעשיים אפשר יהיה לפתור את בעיית הלוגריתם הבדיד בזמן פולינומי עם אלגוריתם שור[2].

אלגוריתם צעד-קטן צעד-גדול

[עריכת קוד מקור | עריכה]
המחשה של אלגוריתם צעד-קטן צעד-גדול

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

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

.

שלב זה נקרא "צעד-גדול". כעת היות ש- נמצא באחד מהמרווחים, מובטח שאחד מ- האיברים

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

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

פירוט מהלכי האלגוריתם

[עריכת קוד מקור | עריכה]

קלט: תת-חבורה , האיבר וסדר החבורה .

פלט: .

  1. מחשבים את .
  2. עבור עד מבצעים כדלהלן:
    1. מחשבים את .
  3. ממיינים את כל הזוגות () לפי הערך השני.
  4. עבור עד מבצעים:
    1. מחשבים את ובודקים
    2. אם עבור כלשהו מחזירים את מודולו .

דוגמה במספרים קטנים

[עריכת קוד מקור | עריכה]

בחבורה מסדר , אם ו- כדי לחשב את הלוגריתם הבדיד של 17 בבסיס 2 תחילה מחשבים את ואז מכינים טבלה עם זוגות הערכים הבאים (מודולו 29) ממוינת לפי הערך השני:

1 2 3 4 5 6

ואז מחשבים את הערכים הבאים עם המונה :

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

לוגריתם בדיד בקריפטוגרפיה

[עריכת קוד מקור | עריכה]

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

כדי להתמודד עם האיום של האלגוריתמים המנויים לעיל, ההנחה היא כיום שראשוני בגודל 2048 סיביות מספק מרווח ביטחון סביר. תקן DSA מגדיר למשל מספר רמות אבטחה לאלגוריתם חתימה דיגיטלית כשהמרבית היא, p ראשוני בסדר גודל של 3072 סיביות.

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

קישורים חיצוניים

[עריכת קוד מקור | עריכה]

הערות שוליים

[עריכת קוד מקור | עריכה]
  1. ^ Introduction to Modern Cryptography (2nd edition), Jonathan Katz and Yehuda Lindell
  2. ^ Shor, Peter (1997). "Polynomial-Time Algorithms for Prime Factorization and Discrete Logarithms on a Quantum Computer". SIAM Journal on Computing