אלגוריתם שור

מתוך המכלול, האנציקלופדיה היהודית
קפיצה לניווט קפיצה לחיפוש

אלגוריתם שוֹר (Shor - על שם פיטר שור, ממציאו), הוא אלגוריתם קוונטי המשמש לפירוק לגורמים של מספר גדול, כלומר מציאת הגורמים הראשוניים של המספר. האלגוריתם פורסם לראשונה על ידי פיטר שור[1] בשנת 1994, ויחד עם אלגוריתם גרובר נחשב לאחד משני האלגוריתמים החשובים ביותר בתחום החישוב הקוונטי.[2] פיתוח האלגוריתם זיכה את ממציאו בפרס גדל (1999). אלגוריתם שור מבוסס על הרעיונות הקוונטיים שהודגמו באלגוריתם סימון למציאת מחזור של פונקציה. האלגוריתם משתמש בהתמרת פורייה קוונטית (QFT), על מנת לקבל מחזור שהוא כפולה של אחד מהגורמים הראשוניים של המספר אותו רוצים לפרק.

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

השלכות ומשמעויות

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

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

תיאור האלגוריתם לפירוק המספר

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

השלב הקלאסי

  1. בחר מספר כלשהו .
  2. בדוק האם ‎gcd (a, N) ≠ 1‏. אם כן - מצאנו גורם, סיים.
  3. אם לא, בצע את השלב הקוונטי על מנת למצוא את המספר , שהוא המחזור של הפונקציה
  4. אם המספר r המתקבל אי-זוגי, חזור לסעיף 1.
  5. אחרת, בדוק האם .
    1. אם כן - חזור ל-1.
    2. אחרת, ל גורם ראשוני משותף עם N. חשב וקבל גורם ראשוני של N.
(הסבר: אם מחזור של אזי , כלומר, . נפתח את הביטוי:

כאשר , הגורמים של N).

השלב הקוואנטי

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

שהוא סופרפוזיציה של Q מצבים.

2. הפעל את הפונקציה הקוונטית על האוגרים, לקבלת

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

4. בצע מדידה. מתקבל ערך כלשהו וערך כלשהו. ההסתברות למדוד את הזוג נתונה על ידי

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

5. מצא מספר ומספר , כך ש ו קרוב מאוד ל, ובאופן מפורש, .

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

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

הערות שוליים

  1. ^ גרסה מתוקנת ומשופרת של המאמר של פיטר שור פירוק לראשוניים של מספרים בזמן פולינומי על ידי מחשב קוונטי (באנגלית)
  2. ^ שחר דולב, מהו מחשב קוונטי, באתר גלילאו 77, ‏01/2005
  3. ^ עופר אוחיון, הצעה ומדריך למידה לקורס "מבוא לחישוב קוונטי", עמ' 131
  4. ^ [1]
הערך באדיבות ויקיפדיה העברית, קרדיט,
רשימת התורמים
רישיון cc-by-sa 3.0

אלגוריתם שור40092297Q940334