מחשב קוונטי

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

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

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

המחקר התאורטי בתחום המחשוב הקוונטי החל בשנות השבעים של המאה ה-20 ומהווה מוקד עניין הן באקדמיה והן בגופי ממשל וצבא ברחבי העולם, בזכות ההבטחות לשיפור משמעותי בביצועים של חישובים שונים. נבנו מספר דגמים שמימשו מחשבים קוונטיים בני קיוביטים בודדים לפרקי זמן קצרים, ובשנת 2011 נעשה שימוש במחשב קוונטי על מנת לפרק לגורמים את המספר 143 בעזרת אלגוריתם שור; המספר הגדול ביותר שפורק אי-פעם לגורמים באמצעות מחשב קוונטי הוא 56,153. עם זאת, הטכנולוגיה הקיימת היום עדיין אינה מאפשרת בניית מחשב קוונטי שיוכל לפרק לגורמים מספרים ראשוניים גדולים המשמשים לצפנים במערכות מסחריות או צבאיות. יכולת לפרק מספר בן 2,048 ביטים (שעדיין אינה פרקטית ב-2023) תאפשר[1][2] פיצוח של המסרים המוצפנים בשיטת RSA, שהיא השיטה הנפוצה היום ביישומים פיננסיים ומסחריים.

אחת השאיפות המרכזיות בפיתוח מחשב קוונטי היא להגיע לעליונות קוונטית (אנ'), היינו נקודת הזמן בהיסטוריה בה מחשב קוונטי יבצע משימה חישובית, ששום מחשב קלאסי לא יכול לבצע בזמן סביר[3]. ב-23 באוקטובר 2019, גוגל הכריזה כי הצליחה להשיג עליונות קוונטית[4]. IBM חולקת על טענה זו.[5]

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

רקע

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

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

קיוביט

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

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

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

ישנן כמה טכנולוגיות (שונות מאד) למימוש קיוביט:

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

שערים קוונטיים

ערך מורחב – שער קוונטי

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

הכח החישובי של מודלים קוונטיים

חיפוש

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

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

מציאת גורמים ראשוניים

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

מגבלות עקרוניות

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

אלגוריתמים קוונטיים

במשך השנים הציעו החוקרים רשימה של בעיות עבורם ידועים אלגוריתמים קוונטיים שהם יותר יעילים מהאלגורתמים הקלאסיים. [8]

מחשבים קוונטיים קיימים

כיום קיימים מחשבים קוונטיים פרימיטיביים ביותר ובעלי ביצועים נמוכים. אך כבר ניתן להריץ עליהם אלגוריתמים קוונטיים ולחוות את השוני המהותי בין המחשבים הקלאסיים למחשבים הקוונטיים. מעת לעת אף מתפרסמים מחקרים שמראים שעם מאמץ והרצות חוזרות ונשנות של אלגוריתמים ניתן להגיע להישגים מרשימים[9].

ספקי מחשבים

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

  • IBM Quantum - ספקית מובילה של מערכות, תוכנות ושירותים של מחשוב קוונטי, במטרה לאפשר לעולם לפתור את הבעיות המורכבות ביותר. IBM מציעה מחשבים קוונטיים שכוללים שערים המבוססים על קיוביטים מוליכי-על. מעבדי מודל שער מבצעים מעגלים קוונטיים. סוג זה של QPU הוא הצעד הראשון לקראת מחשוב קוונטי אוניברסלי ומיועד למניפולציה של מידע קוונטי[10]. בדצמבר 2023 פירסמה IBM שהיא עומדת להשיג יתרון קוונטי ראשוני תוך פחות משנה, כאשר היא נעזרת בחברת קדמה הישראלית לתיקון שגיאות[11].
  • Amazon Bracket - שירות מחשוב קוונטי מנוהל במלואו שנועד לעזור להאיץ מחקר מדעי ופיתוח תוכנה עבור מחשוב קוונטי. Amazon Braket הוא שירות AWS מנוהל במלואו המספק סביבת פיתוח לחקירה והתנסות במחשוב קוונטי. הוא מאפשר למפתחים, חוקרים ומדענים לתכנן, לבדוק ולהפעיל אלגוריתמים קוונטיים על מחשבים קוונטיים מספקי חומרה שונים[12].
  • Azure Quantum - שירות מבוסס ענן המסופק על ידי Microsoft Azure המספק למפתחים ולחוקרים גישה למשאבי מחשוב קוונטי ולכלים. מציעה מגוון טכנולוגיות מחשוב קוונטי, לרבות מערכות מבוססות קיוביטים, מערכות מבוססות חישול וסימולטורים, מספקי חומרה שונים, כגון Honeywell ו-IonQ[13].

כלי פיתוח

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

  • Qiskit‏ - SDK בקוד פתוח לעבודה עם מחשבים קוונטיים ברמה של פולסים, מעגלים ומודולי יישומים[14].
  • Cirq - ספרייה בשפת Python לכתיבה, מניפולציה ואופטימיזציה של מעגלים קוונטיים, ולאחר מכן הפעלתם במחשבי קוונטים ובסימולטורים קוונטיים. Cirq מספקת הפשטות שימושיות להתמודדות עם המחשבים הקוונטים הרועשים של ימינו בקנה מידה בינוני, שבהם פרטי החומרה חיוניים להשגת תוצאות מתקדמות[15].
  • Amazon Brcket Python SDK - מסופק על ידי Amazon Web Services (AWS) עבור מפתחים וחוקרים שרוצים לבנות יישומים קוונטיים בשירות המחשוב הקוונטי של Amazon Braket. הוא מספק קבוצה של כלים וספריות לפיתוח, בדיקה והרצה של אלגוריתמים ומעגלים קוונטיים על סימולטורים וחומרה קוונטית.
  • Rigetti PyQuil - כרכיב של Rigetti Forest SDK, המסגרת של pyQuil מאפשרת לבנות ולהפעיל תוכניות Quil באמצעות Python. השימוש ב-pyQuil דורש התקנה של שאר הרכיבים של Forest SDK, כלומר מהדר Quil (quilc) וה-Quantum Virtual Machine (QVM), המשמשים להדמיית מחשבים קוונטיים[16].
  • Q# and the QDK - השפה Q# היא שפת תכנות המהווה חלק מ-Quantum Development Toolkit (QDK) מבית מיקרוסופט. ה-Quantum Development Toolkit (QDK) היא ה-SDK הנדרש להתממשק עם Azure Quantum service. עם ה-QDK, ניתן לבנות תוכניות הפועלות על חומרה קוונטית או לנסח בעיות הפועלות על פותרי אופטימיזציה בהשראת קוונטים ב-Azure Quantum[17].
  • D-Wave Ocean - חבילה של כלי Python בקוד פתוח הנגישים דרך ערכת פיתוח התוכנה של Ocean (SDK) הן במאגר D-Wave GitHub[18] והן בשירות הענן הקוונטי של Leap. התוכנה Ocean מאפשרת למפתחים להתנסות, לפתח במהירות ולנצל את הכוח של המחשב הקוונטי של Advantage כדי לפתור בעיות מורכבות[19].

בישראל

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

בישראל פועלות חברות הזנק אחדות בתחום החומרה והתוכנה למחשב קוונטי, בהן קוונטום מאשינז[21],, קוונט-אל–אר (הצפנה קוונטית)[22], קדמה מחשוב קוונטי (מערכת הפעלה למחשב קוונטי)[23], קלאסיק טכנולוגיות (פיתוח תוכנה למחשוב קוונטי)[24] ועוד.

בפברואר 2022 פורסם כי רשות החדשנות ומשרד הביטחון יממנו הקמת מחשב קוונטי ראשון למדינת ישראל בכ-200 מיליון שקל[25].

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

ראו גם

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

ויקישיתוף מדיה וקבצים בנושא מחשב קוונטי בוויקישיתוף

הערות שוליים

  1. ^ Vaishali Bhatia, K.R. Ramkumar, An Efficient Quantum Computing technique for cracking RSA using Shor’s Algorithm, 2020 IEEE 5th International Conference on Computing Communication and Automation (ICCCA), IEEE, 2020-10-30 doi: 10.1109/iccca49541.2020.9250806
  2. ^ Moolchand Sharma, Vikas Choudhary, R. S. Bhatia, Sahil Malik, Anshuman Raina, Harshit Khandelwal, Leveraging the power of quantum computing for breaking RSA encryption, Cyber-Physical Systems 7, 2020-09-03, עמ' 73–92 doi: 10.1080/23335777.2020.1811384
  3. ^ לי פלג, גוגל בדרך לעליונות קוונטית, במדור "חדשות מדע" באתר של מכון דוידסון לחינוך מדעי, 6 באוקטובר 2019
  4. ^ אושרי אלקסלסי, גוגל: המחשב הקוונטי שלנו ביצע ב-3 דקות מה שייקח למחשב רגיל אלפי שנים, באתר גיקטיים, ‏22.9.19
  5. ^ Adrian Cho, IBM casts doubt on Google's claims of quantum supremacy, Science, ‏23 אוקטובר 2019
  6. ^ Google Quantum AI, Suppressing quantum errors by scaling a surface code logical qubit, Nature 614, 2023-02, עמ' 676–681 doi: 10.1038/s41586-022-05434-1
  7. ^ The Many Faces of a Qubit | Quantum Computing Inc., ‏2021-12-10 (באנגלית אמריקאית)
  8. ^ רשימה כזאת של אלגוריתמים המוכרים כיום נמצאת באתר https://quantumalgorithmzoo.org/.
  9. ^ Alex Khan, Quantum computing experimentation with Amazon Braket : explore Amazon Braket quantum computing to solve combinatorial optimization problems, 2022, מסת"ב 1800565267
  10. ^ IBM Quantum, IBM Quantum (באנגלית)
  11. ^ "יתרון קוונטי ראשוני תוך פחות משנה": החברה הישראלית שצועדת עם IBM אל עבר העתיד | ישראל היום, באתר www.israelhayom.co.il, ‏2023-12-11
  12. ^ Quantum Cloud Service - Quantum Computing Service - Amazon Braket - AWS, Amazon Web Services, Inc. (באנגלית אמריקאית)
  13. ^ Azure Quantum - Quantum Cloud Computing Service | Microsoft Azure, azure.microsoft.com (באנגלית אמריקאית)
  14. ^ Qiskit, qiskit.org
  15. ^ Cirq, Google Quantum AI (באנגלית)
  16. ^ Welcome to the Docs for pyQuil! — pyQuil 3.4.1 documentation, pyquil-docs.rigetti.com
  17. ^ SoniaLopezBravo, Introduction to Q# & Quantum Development Kit - Azure Quantum, learn.microsoft.com (באנגלית אמריקאית)
  18. ^ dwavesystems/dwave-ocean-sdk, 2023-04-02, נבדק ב-2023-04-14
  19. ^ Ocean™ Developer Tools | D-Wave, www.dwavesys.com (באנגלית אמריקאית)
  20. ^ דוח מסכם של ועדת ההיגוי המייעצת לות"ת לנושא מדע וטכנולוגיה קוונטיים, באתר המועצה להשכלה גבוהה, פברואר 2018
  21. ^ אורי ברקוביץ', "אנחנו רוצים להיות הגוגל של המחשוב הקוונטי", גלובס
  22. ^ האוניברסיטה העברית, ‏חברת ההזנק בתחום ההצפנה הקוונטית 'קוונט-אל-אר' רשמה הישג בהגנה על רשתות סיבים אופטיים, באתר "הידען", 30 בינואר 2020
  23. ^ אתר למנויים בלבד אמיתי זיו, בביתן קטן בתל אביב, קבוצת פרופסורים עובדת על ההמצאה שתשנה את העולם, באתר TheMarker‏, 9 ביולי 2021
  24. ^ סתיו קורן, Classiq הישראלית גייסה 33 מיליון דולר, ביזפורטל,‏ 17 בפברואר 2022
  25. ^ דני זקן, ‏רשות החדשנות ומשרד הביטחון יממנו הקמת מחשב קוונטי ראשון למדינת ישראל בכ-200 מיליון שקל, באתר גלובס, 15 בפברואר 2022.
  26. ^ אתר למנויים בלבד גדעון לב, לראשונה בישראל, חוקרים במכון ויצמן בנו מחשב קוונטי, באתר הארץ, 22 במרץ 2022


הערך באדיבות ויקיפדיה העברית, קרדיט,
רשימת התורמים
רישיון cc-by-sa 3.0

38637745מחשב קוונטי