אִיטֵרַצְיָה (באנגלית: Iteration; על פי האקדמיה ללשון העברית: חִזְרוּר) היא פעולה החוזרת על עצמה במהלך פתרון של בעיה, בדרך כלל בעיה כמותית. כל חזרה נקראת איטרציה. תהליך המורכב מאיטרציות קרוי תהליך איטרטיבי (או תהליך חזרור). כאשר מדובר בבעיה כמותית, ניתן לבצע את האיטרציות הן באופן ידני והן בעזרת מחשב. בדרך כלל משמשים מושגים אלה לתיאור תהליך במסגרת תוכנית מחשב, ובאופן כללי יותר לתיאור אלגוריתמים.
בערך זה נעשה שימוש בסימנים מוסכמים מתחום המתמטיקה. להבהרת הסימנים ראו סימון מתמטי. |
- ביצוע גוף לולאה (Loop) באלגוריתם המשמש לכתיבת תוכניות מחשב באמצעות שפת תכנות.
- מחזור של רקורסיה. במובן מסוים של המונח איטרציה קיימת הבחנה בין אלגוריתם איטרטיבי המתייחס ללולאה בלבד, לבין אלגוריתם רקורסיבי.
- בפרשת עכן, המתוארת בספר יהושע, נלכד עכן בתהליך איטרטיבי בן ארבעה שלבים: ”וַיַּשְׁכֵּם יְהוֹשֻׁעַ בַּבֹּקֶר וַיַּקְרֵב אֶת יִשְׂרָאֵל לִשְׁבָטָיו, וַיִּלָּכֵד שֵׁבֶט יְהוּדָה. וַיַּקְרֵב אֶת מִשְׁפַּחַת יְהוּדָה וַיִּלְכֹּד אֵת מִשְׁפַּחַת הַזַּרְחִי, וַיַּקְרֵב אֶת מִשְׁפַּחַת הַזַּרְחִי לַגְּבָרִים וַיִּלָּכֵד זַבְדִּי. וַיַּקְרֵב אֶת בֵּיתוֹ לַגְּבָרִים, וַיִּלָּכֵד עָכָן בֶּן כַּרְמִי בֶן זַבְדִּי בֶּן זֶרַח לְמַטֵּה יְהוּדָה.” (ספר יהושע, פרק ז', פסוקים ט"ז–י"ח) תהליך איטרטיבי דומה מופיע בתיאור המלכתו של שאול: ”וַיַּקְרֵב שְׁמוּאֵל אֵת כָּל שִׁבְטֵי יִשְׂרָאֵל, וַיִּלָּכֵד שֵׁבֶט בִּנְיָמִן. וַיַּקְרֵב אֶת שֵׁבֶט בִּנְיָמִן לְמִשְׁפְּחֹתָיו וַתִּלָּכֵד מִשְׁפַּחַת הַמַּטְרִי, וַיִּלָּכֵד שָׁאוּל בֶּן קִישׁ וַיְבַקְשֻׁהוּ וְלֹא נִמְצָא.” (ספר שמואל א', פרק י', פסוקים כ'–כ"א)
- הפעלה פונקציה על אובייקט מספר פעמים בזו אחר זו. למשל, עבור הפונקציה , ו־, הן איטרציות של הפעלת הפונקציה פעמיים או מספר מסוים של פעמים על אובייקט כלשהו.
לאיטרציה יש גודל, המשקף את מספר פקודות המחשב שבכל איטרציה או את הזמן הנדרש לביצועה. משמעות גודל האיטרציה משתנה בהקשרים שונים. בלולאות שבתוכניות מחשב, לדוגמה, סופרים את מספר מחזורי השעון באיטרציה.
מספר האיטרציות בתהליך מסוים יכול לנוע בין אפס לאינסוף. בדרך כלל מספר האיטרציות הוא פונקציה של הקלט לתוכנית או לאלגוריתם, ושל יעילות האלגוריתם. דוגמה: לחיפוש איבר מבוקש ברשימה ממוינת בת 1,024 איברים יידרשו לכל היותר 1,024 איטרציות (ובממוצע 512 איטרציות) כאשר החיפוש נעשה באמצעות סריקה סדרתית של הרשימה. אבל כאשר מבוצע חיפוש בינארי, שהוא יעיל יותר, יידרשו לכל היותר 10 איטרציות,
משום ש- , או בניסוח אחר .
ישנם תהליכים בהם איטרציות מהוות 'צוואר בקבוק', ולכן אם לגורם הזמן יש משמעות ובפרט במערכות זמן אמת (Real time), יש חשיבות מיוחדת ליעילות האיטרציה.
מתכנתים מתייחסים ליעילות של איטרציה בהבטים אחדים:
- זמן קצר ככל האפשר לכל איטרציה. חיסכון של מעט זמן בכל איטרציה עשוי להסתכם בחיסכון של זמן רב מאוד, כאשר הוא מוכפל במספר האיטרציות.
- הספק רב ככל האפשר בכל איטרציה בודדת, כך שמספר האיטרציות הכללי יפחת.
- באיטרציות המשמשות תוכניות מחשב יש חשיבות לכך שכל איטרציה 'תתפוס' מינימום מזיכרון המחשב, מהסיבות הבאות:
- מניעת גלישת חוצץ.
- מניעת גלישת מחסנית, שעשויה להתרחש במקרה של שימוש ברקורסיה עמוקה מידי.
- השארת הזיכרון פנוי למשימות אחרות.
בתוכניות מחשב בהן מתבצעת פעולה ממושכת המהווה 'צוואר בקבוק', כגון לולאה, בזמן התרחשות הפעולה המשתמש אינו יכול לבצע פעולה נוספת (בתוכנית עצמה ובמקרים אחרים אף במחשב כולו) וכן אינו מבין למה המחשב 'נתקע' ומתרעם על כך.
ישנם מספר אמצעים, בעזרתם ניתן 'לשחרר' את המחשב:
- מִקבול משימות התוכנית, באמצעות שימוש במספר תהליכונים (Threads).
- קביעת עדיפות (Priority) נכונה עבור התהליכון המהווה 'צוואר בקבוק'.
- תזמון הפעולה, המהווה 'צוואר בקבוק', לעיתוי נוח יותר. לפעמים מעבירים פעולות כאלו לשעת טעינת התוכנית.
אמצעים אחרים נועדו לשתף את המשתמש בידע על המתרחש:
- הצגת הודעה מילולית המסבירה למשתמש את פשר העיכוב והמידעת אותו על המתרחש.
- הצגת מד־התקדמות (Progress bar), בעזרתו יכול המשתמש לדעת בכל רגע כמה אחוזים מהתהליך כבר התבצעו.
- הצגת סרטון וידאו המייצג את המתרחש.
- שינוי צורת סמן העכבר לצורת שעון חול.
דרך השימוש באמצעים שהוזכרו שונה משפת מחשב אחת לשפת מחשב אחרת. מומלץ להשתמש בכמה מהאמצעים יחדיו.
- משפטי איטרציה (Iteration statements) – כגון while ו־for, הם סוג של משפטי בקרה על זרימת תוכנית מחשב שמאפשרים חזרה על קוד. משפטי איטרציה נבדלים ממשפטי בחירה (Selection statements), כגון if ו־switch, שגם הם סוג של משפטי בקרה שמאפשרים לבצע קטעי קוד נבחרים.
- בקרת איטרציות (Iteration controls) – קובעת את מספר האיטרציות שיתקיימו.
- איטרטור – מחלקה המאפשרת מעבר באיטרציות במבנה נתונים כלשהו. בשפת ++C, איטרטורים הם חלק נכבד מהספרייה התקנית STL.
- מעבר על פני רשימה (Iterate over a list), שהיא סוג של מבנה נתונים.
- דילמת האסיר האיטרטיבית
- משחק החיים - משחק מסוג אוטומט תאי המשוחק באיטרציות.
מידע נוסף מיזמי קרן ויקימדיה ...
סגירה