נפה ריבועית

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

שיטת הנפה הריבועית היא שיטה מהירה לפירוק לגורמים של מספר שלם, המתאימה בעיקר למספרים בני 40–100 ספרות עשרוניות (אלגוריתם rho של פולרד עדיף לפירוק מספרים קטנים יותר, בעוד שבמספרים ארוכים יותר נפת שדה המספרים היא השיטה היעילה ביותר).

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

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

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

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

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

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

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

תיאור האלגוריתם[עריכת קוד מקור | עריכה]

קלט: מספר פריק

פלט: אחד הגורמים הראשוניים של

  1. בחירת גורמי בסיס
    בוחרים בסיס גורמים (Factor base) אותו מסמנים , כאשר ויתר האלמנטים הם המספרים הראשוניים החל מ-2 ועד לגבול מסוים, כאשר בוחרים רק את הראשוניים אשר הוא שארית ריבועית מודולו , כלומר שלהם סימן לז'נדר . הגבול העליון נקרא גבול חלקות (Smoothness bound) ולמעשה מכתיב את גודל בסיס הגורמים. הערך מייצג את מספר הגורמים הראשוניים בבסיס, מספר זה ישפיע ישירות על כמות הווקטורים הדרושים לפירוק ועל גודלם.
  2. הכנת מאגר זוגות שלמים
    מכינים זוגות שלמים כדלהלן: מחשבים את השורש השלם של אותו מסמנים ב-. מכינים את הפולינום , מחשבים את ובודקים אם הוא מספר חלק ביחס ל- (כלומר שכל גורמיו הראשוניים נמצאים בבסיס הגורמים). אם אינו מספר חלק ביחס ל-, בוחרים אחר (לפי הסדר הזה: ). אם הוא אכן מספר חלק כלומר ניתן לייצגו כמכפלה של גורמי בסיס: , אזי מגדירים את , זוג הערכים נוסף למאגר.
    הערה: ניתן לבדוק חלקות באמצעות חלוקה נסיונית (פשוט על ידי חלוקה בכל גורמי הבסיס), אולם שלב זה הוא הקריטי והארוך ביותר באלגוריתם ועל כן יעילותו מתבטאת בעיקר באופן בו מיושמת בדיקת החלקות. באופן מעשי מקובל להשתמש בתהליך הניפוי (sieving) המתואר להלן.
  3. מציאת מספר ריבועי
    כיוון שהגורמים של כל ידועים, קל למצוא תת-קבוצה של אשר מכפלתה היא מספר ריבועי. כיוון שצריך רק מספרים שהחזקה של כל גורם שלהם זוגית. ניתן לפשט זאת על ידי הכנת וקטור בינארי של המעריכים מודולו 2 כלומר כאשר . כיוון שבהכרח בוקטור זה תמצא תלות ליניארית כלשהי, משתמשים באלגברה ליניארית כדי למצוא תת-קבוצה של וקטורים שסכומה הוא וקטור האפס . משנמצאה תת-קבוצה כזו, מכפילים את המספרים החלקים המתאימים (שהמציין שלהם ב-), כלומר מחשבים את . בהכרח מתקיים כי הוא מספר ריבועי. כמו כן ניתן לראות שגם מכפלת ריבועיהם של כל המתאימים יהיה מספר ריבועי. כלומר נותן מספר ריבועי.
  4. חישוב
    מחשבים את השורשים הריבועיים של התוצאה האמורה, את האחד מוצאים על ידי חישוב שורש ריבועי של התוצאה האמורה ואת השני על ידי הכפלת מספרי המתאימים. מציבים ב- את וב- את השורש הריבועי של . מספרים אלה עונים על הדרישה האמורה, כלומר ריבועיהם שקולים מודולו . בדרך כלל קיימות מספר תלויות ליניאריות כך שבסבירות גבוהה אחת מהן תניב כאלה שאינם שקולים מודולו .
  5. מציאת גורם ראשוני
    מחשבים את המחלק המשותף המקסימלי של ההפרש של עם . התוצאה תהיה גורם ראשוני של , אשר עשוי להיות גם גורם טריוויאלי כמו עצמו או 1. במקרה כזה, מנסים שוב עם תלות ליניארית אחרת של המספרים החלקים.

הגדרת בסיס הגורמים וטווח הניפוי[עריכת קוד מקור | עריכה]

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

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

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

שיפורים אפשריים[עריכת קוד מקור | עריכה]

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

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

הניפוי – Sieving[עריכת קוד מקור | עריכה]

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

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

לכל בבסיס הגורמים אם אז גם . ובכיוון ההפוך, אם אז גם .

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

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

שיפורים אפשריים[עריכת קוד מקור | עריכה]

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

שלב המטריצה[עריכת קוד מקור | עריכה]

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

עבור מספר חלק מעל :

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

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

שיפורים אפשריים[עריכת קוד מקור | עריכה]

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

דוגמאות לייצוג וקטורי מעל בסיס B[עריכת קוד מקור | עריכה]

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

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

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

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

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

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

נפת שדה המספרים מול הנפה הריבועית[עריכת קוד מקור | עריכה]

שיטה נוספת לפירוק מספר לגורמים היא נפת שדה המספרים (Number Field Sieving), זוהי שיטה מהירה יותר אסימפטוטית מהנפה הריבועית (Quadratic Sieve), אך מסובכת הרבה יותר.

שתי השיטות מחולקות לשני שלבים: שלב הניפוי ושלב מטריצה.

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

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

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

  • Landquist, E., “MATH 488: Cryptographic Algorithms”, “The Quadratic Sieve Factoring Algorithm”, December 14, 2001
  • Pomerance, C., “A Tale of Two Sieves”, December, 1996.

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

  • TWINKLE – מכשיר אלקטרואופטי תאורטי, המממש את שיטת הנפה הריבועית לפירוק מהיר לגורמים.

קישורים חיצוניים[עריכת קוד מקור | עריכה]