מילות מפתח: אלגוריתם של האבקת פרחים ( Flower Pollination Algorithm, FPA); למידה מאונכת (Orthogonal Learning, OL); מערך מאונך (Orthogonal Array, OA); מנגנון “אפקט השפמנון (Catfish Effect Mechanism); בעיות מיטוב כלליות (Global Optimization Problems); OCFPA
תקציר
FPA הוא שיטת מיטוב חדשנית המבוססת על התנהגויות של פרחים בשעת האבקתם. אולם יש חסרונות המגבילים את שימושה לפתרון בעיות הנדסיות, כגון נטייה להתכנסות מוקדמת (Premature convergence) ויכולת ניצול (exploitation) מוגבלת. אפשר לשפר את יכולת המיטוב של האלגוריתם, יש לשלב במפעיל (operator) ההאבקה המקומי שיטת למידה מאונכת (OL) המבוססת על תכנון ניסוי מאונך (OED). ה-OED יכול לנבא את הצירוף המיטבי של רמות הגורמים ע”י בניית קבוצת מבחן קטנה אך מייצגת על יסוד מערך מאונך. התכונות האלה של ה-OED מאפשרת ל-OL להפיק פתרון מבטיח מכמה מקורות של מידע נסיוני, המכוונים את האוכלוסייה לחפש פתרון בכיוון הגיוני אפשרי. כמו כן, היא מתמקדת באמצעות מנגנון “אפקט השפמנון”, על הפרטים הגרועים ביותר בתהליך האיטרציה. המנגנון הזה בוחן מידע חדש בעל ערך ושומר על מגוון עדיף של האוכלוסייה. תוצאות הניסוי בפונקציות הבחינה (benchmark functions) מוכיחות שהאלגוריתם משפר במידה ניכרת את ביצועי ה-FPA המקורי וכושר התחרות שלו גדול מזה של כמה אלגוריתמים משוכללים.
1. מבוא
המדע המודרני מציב אתגרים גדולים בפני שיטות המיטוב המקובלות, כי מאפייני בעיות המיטוב לא-רציפים, לא-לינאריים, מרובי משתנים בלתי תלויים (multivariate) או בלתי קמורים (nonconvex). האלגוריתמים הנוכחיים של אינטליגנציית הנחיל (Swarm intelligence) הם דרכים יעילות לפתרון בעיות מיטוב מורכבות. רוב האלגוריתמים האלה פותחו כחיקוי של דפוסי חיפוש מזון או נדידה של בעלי חיים, או על יסוד תורת האבולוציה. כאלו הם
1. האלגוריתם הגנטי (GA);
2. מיטוב נחיל החלקיקים (PSO);
3. האבולוציה הדיפרנציאלית (DE);
4. האלגוריתם של דילוג הצפרדע המבולבל (SFLA)
5. מיטוב מבוסס על ביו-גיאוגרפיה (BBO)
6. חיפוש קוקייה (CS);
7. אלגוריתם של כינוס קריל (KH);
8. המיטוב של זבוב הפירות (FFO);
9. מיטוב בהשראת מסלול היונה (PIO)
10. מיטוב בשיטת העשב הפולש (IWO)
11. אלגוריתם העטלף (BA)
ה- FPAהוא אלגוריתם הוריסטי חדשני שנוצר בהשראת התנהגות הפרחים בשעת ההאבקה. האבקת ה פרחים בטבע מתבצעת בשתי דרכים: האבקה עצמית והאבקה זרה. האבקה זרה מתבצעת בעזרת ציפורים וחרקים המעבירים אבקה לפרחים של צמחים רחוקים. האבקה עצמית מתבצעת בעזרת הרוח, אך ורק בין פרחים סמוכים של אותו צמח. לכן, ה-FPA נוצר באמצעות העתקת שיטת ההאבקה הזרה למאביקים כלליים ואת שיטת ההאבקה העצמית למאביקים מקומיים. האלגוריתם עורר עניין רב בזכות עקרונותיו הפשוטים, תנאיו המעטים וקלות הפעלתו.
אולם גם ה-FPA, כמו שאר האלגוריתמים של אינטליגנצית הנחיל, אינו מסוגל ליצור פשה מושלמת בין הניצול הכללי והמקומי. לכן הוצעו כמה שיטות להגברת יכולת החיפוש של ה-FPA. נאביל צירף את מנגנון ברירת השיבוט (Clone Selection mdechanism) למאביקים המקומיים כדי להגיע לפתרונות מדויקים יותר. הואנג ושות’ שילבו בין מפעילי המוטציה, ההכלאה, והבריכה הטבעית ב-DE כתחליף לשיטת העדכון המקורית של ההאבקה המקומית. ז’ו ושות’ פיתחו את מנגנון התנגדות העילית (Elite Opposition Mechanism), את שיטת התאמה-העצמית החמדנית (self-adaptive greedy strategy), ושיטת סבירות ההחלפה הדינמית (dynamic switch probability) כדי לאזן בין החקירה (exploration) לניצול (exploitation). סולגאטרה וסינג ניתחו את השפעתן של שיטות המוטציה השונות על ביצועי ה-FPA המקורי. פונקציות המבחן הראו שלגרסאות האלה ביצועים מעולים. כמו כן, FPA הפגין תוצאות טובות ביישומים הנדסיים נבחרים. עבדלעזיז ושות’ נעזרו ב-FPA הבסיסי לפתרון בעיית החיסכון בייצור אנרגיה (ELD). וואנג ושות’ ערכו ניתוח אשכול באמצעות FPA המבוסס על האבקה באמצעות דבורה. ז’אנג ושות’ הציעו FPA של חיפוש כאוטי לחיזוי מהירות הרוח. שו ושות’ שילבו בין ה-FPA לתורת קבוצת הנקודה הטובה (Good point set theory) ולכללים ההיוריסטיים של דב (Deb) כדי לזהות פרמטרים באופטימיזציה של עיבוד שבבי (multipass turning). סאלגוטרה וסינג יישמו במקביל את אלגוריתם העטלף ואת ה-FPA כדי לשלב בין מערכי האנטנה הקוויים (linear antenna arrays).
כידוע, FPA תקני פועל בשיטת הלמידה הדיפרנציאלית כדי לבצע חקירה כללית (global exploration) ולשכלל את הניצול. אולם דפוס ההתפתחות הפשוט הזה אינו יעיל בגלל כמה חסרונות: ראשית, התנהגות החיפוש האקראי כלפי הפרט הנוכחי חסרת מנגנון יעיל למניעת התכנסות מוקדמת. שנית, נוסחת העדכון פועלת על ווקטור הפתרון המלא במקום על כל מימד בנפרד, והתוצאה עלולה להיות נסיגה אחרי התקדמות ראשונית. הסיבה העיקרית לכך היא שלווקטורי פתרון שונים עשויים להיות רכיבים בעלי איכות שונה. לכן, רכיבים איכותיים עשויים לשפר את הפרט במימדים מסוימים, אבל רכיבים נחותים עלולים להביא להתנוונות במימדים אחרים.לאור זאת, ברור שהתנאים ההכרחיים לשיפור יכולת המיטוב הם השמירה על מגוון האוכלוסיה והניצול המשופר של מידע נסיוני.
ה-OED הוא כלי ניתוח אופייני של תכנית ניסוי שיכול לנבא בהצלחה את הצירוף המיטבי של רמות גורמים שונים באמצעות בחירת קבוצת מבחן קטנה יותר אך מייצגת. מידע בעל ערך עשוי להתקיים במימדים מסוימים של פתרונות אפשריים שונים. לכן, במחקר זה, פיתחנו שיטת OL בתכנית ניסוי מאונכת (OED) כדי להגיע לפתרון אפשרי מבטיח יותר מבין הפרט הנוכחי, הפרט הטוב ביותר, ופרט אקראי. כתוצאה מכך נשפר מאוד את מהירות הפתרון ואת דיוקו. אבל, למרות שה-OL יכול לייעל את המיטוב, האלגוריתם עדיין מוריד את המגוון. לכן הגברנו את גיוון האוכלוסייה באמצעות מנגנון “אפקט השפמנון” המחליף את המידע על בפרטים הגרועים ביותר במידע על מתחריהם. במהלך האיטרציה, הפרטים הגרועים ביותר מתקרבים לטובים ביותר, וברגע שהאלגוריתם מתחיל בהתכנסות המקומית, אפקט השפמנון עשוי להניע את אוכלוסיית המשנה הגרועה ביותר לחקור את מקומה החדש. כך נשמר מקוון האוכלוסייה. בקיצור, שילוב שיטת ה-OL ומנגנון אפקט השפמנון ב-FPA מבטיח את יציבות החיפוש ועשוי לשפר את הפתרון. תוצאות הניסויים הוכיחו שהאלגוריתם המוצע עדיף על ה-FPA המקורי ועל אלגוריתמים אבולוציוניים מתקדמים אחרים שנבדקו בפונקציות מבחן.
בחלק 2 של המחקר מתוארות הבעיות של דגם המיטוב הכללי. חלק 3, מסביר בפרוטרוט את עקרונות ה-FPA. חלק 4, את ה-OL ואת מנגנון אפקט השפמנון; חלק 5, את תוצאות האלגוריתם המשולב של האבקת הפרחים ואפקט השפמנון (OCFPA). בחלק 6 מובא סיכום המסקנות.
2. בעיות המיטוב הכללי
בעיות הנדסיות רבות ניתן לראות כבעיות מיטוב כללי, שניתן לתאר כך:
כאשר SX היא הצורה הווקטורית של משתנה החלטה, D הוא מספר משתני ההחלטה, f(SX)היא פונקציית המטרה, S מגדיר את מרחב החיפוש ל אלגוריתם המיטוב, dɩ הוא הגבול התחתון (Lower) ו-ud הוא הגבול העליון (Upper) של משתנה ההחלטה SXd. בעיית מיטוב כללי דורשת לגלות את משתנה ההחלטה הטובה ביותר באמצעות הערך המרבי או המזערי של פונקציית המטרה.
3.אלגוריתם ההאבקה
FPA הוא אלגוריתם למיטוב כללי המבוסס על אוכלוסייה. יאנג ושות’ סיכמו את תהליך ההאבקה בארבעה כללים אידיאליים:
1- האבקה זרה באמצעות ציפורים וכדומה נחשבת להאבקה כללית שבה תנועת המאביקים אקראית על פי התפלגות לוי (levy flight).
2- האבקה עצמית של פרחים קרובים נחשבת להאבקה מקומית.
3- קביעות (constancy) הפרח נחשבת לשיעור ההתרבות, שהוא יחס הישר באותה רמה בין הפרחים המעורבים בהאבקה.
4- האבקה כללית והאבקה מקומית מיושמות על בסיס סבירות מתחלפת.
מכלל 4 נובע ששני סוגי ההאבקה מתרחשים באקראי ובסבירות p. כלומר, אם ערך אקראי rand ב [0,1] קטן מ-p, תתקיים האבקה כללית, וכן ההיפך. תרשים הזרימה של FPA מוצג באיור 1
4. OCFPA
4.1 תכנון הניסוי המאונך (OED)
ההנחה היא שהניסוי כולל F גורמים ולכל אחד מהם Q רמות. להשגת הצירוף הטוב ביותר של רמות בכל גורם, הערכנו בשיטה הישירה את כל הצירופים, QF במספר. אולם החישוב בשיטה זאת מסובך, בעיקר כששני המשתנים גדולים. אמנם בשיטת OED ניתן להגיע לתוצאה במספר ניסויים קטן, אולם השיטה מופעלת על בסיס המערך המאונך (OA) וניתוח הגורמים (FA).
OA נוצר מטורים בסיסיים ולא-בסיסיים (nonbasic), כדוגמת משוואה 7. ממנה עולה כי יש כאן 6 גורמים (כמספר הטורים), לכל גורם 2 רמות (1 או 2), ו-8 צירופים (כמספר השורות):
אפשר להדגים את השימוש ב OED בעזרת המשוואה הבאה:
R2= A2+ 2B2+3C2+4D2. A, B, C, ו-D הם 4 גורמים, ולכל אחד מהם 2 רמות: A1=2 ; B1=8; C1=3 ; 1=1D; A2=5; B2=3 C2=5 ; D2=7. תת-מערך של OA גם כן נחשב ל-OA, ולכן 4 הטורים הראשונים של L8(26) נבחרו הפעם כ-OA. בסך הכל התקבלו 8 צירופים של הרמות השונות של כל הגורמים ב-OA, והם מוצגים בטבלה 1. כולם נבדקו בעזרת נוסחת הפונקציה, ותוצאות ההערכה מוצגות בעמודה ROA.
כאשר:
Egk= ההשפעה הממוצעת של רמה k בגורם g;
Ri= תוצאות ההערכה של הצירוף i. כשהרמה k והגורם g, igk=1ω. אם לא, igk=0ω. בבעיות מיזעור, ככל ש Egkקטן, רמה k טובה יותר בגורם g. פעולתו של RA במקרה זה מוצגת בטבלה 2. ממנה אם בוחרים ברמה בעלת Egk קטן יותר, מגלים צירוף חדש: A1=2; B2=3; C1=3; D1=1, ב-FA, ותוצאות ההערכה RFA טובות יותר מ-ROA.
הגורם | הרמה | Egk | תוצאות FA | RFA |
A | 2 | R1+R2+R3+R4)/4=228 ( | 2(A1) | |
5 | (R5+R6+R7+R8)/4=249 | |||
B | 8 | /4=295.3(R1+R2+R5+R6) | 3(B2) | |
3 | (R3+R4+R7+R8)/4=183.5 | |||
C | 3 | (R1+R2+R7+R8)/4=214.5 | 3(C1) | 53 |
5 | (R3+R4+R5+R6)/4=262.5 | |||
D | 1 | (R1+R3+R5+R7)/4=142.5 | 1(D1) | |
7 | (R2+R4+R6+R8)/4=334.5 |
טבלה 2: ה-FA במקרה לדוגמה.
4.2 שיטת ה–OL
למפעיל בהאבקה מקומית יש אפשרויות מוגבלות לחיפוש דיפרנצתיאלי. כדי לשפר את ביצועיו, מפעילים בשלב החיפוש המקומי את שית ה-OL המבוססת על ה-OED. זאת משום שעקרון ה-OED מאפשר ל-OL שילוב שיטתי ומושכל של מידע מועיל מפרטים שונים בכל מימד, והפעלה של פתרון איכותי שמכוון את האוכלוסייה לכיווני חיפוש מבטיחים.
לצורך מתן מידע מספיק לחיפוש, יש להפעיל את שיטת ה-OL על שלושה פרטים: ה-gbest הנוכחי המספק מידע מתקדם להכוונה; ה- SXi הנוכחי, ופרט שנחבר באקראי, SXk. שני האחרונים רגילים לשתף זה את זה בנסיון החיפוש שלהם ולכך לגוון את המידע. כך יצרנו שיטת עדכון חדשנית ל- SXi, על בסיס שיטת ה-OL, כמתואר בנוסחה הבאה:
בשיטת OL, מספר הגורם, F, תואם למספר המימדים בבעיה, D, ומספר הרמה Q של כל גורם שווה למספר הפריטים שנבחרו, כלומר 3. כשמפעילים את השיטה, הערך lvdi של רמה I (1=1,2,3) במימד d ניתן בנוסחה הבאה:
מכאן נובע שנוצרים M פתרונות אפשריים לגורם C על סמך LM(3D)של OA, כמתואר בנוסחה הבאה:
את הפתרונות האפשריים מעריכים באמצעות פונקצית מטרה מיוחדת, ומבצעים FA. שיטת OL פועלת על פי אלגוריתם 1:
01: קלט (Input)
02: מספר הגורמים (F=D) ומספר הרמות (D=3)
03: שלושה פרטים: SXi, gbest, SXk
04: פונקציית מטרה f(solution) לבעיות מיזעור (miminization) או השאה (maximization).
05: מספר הערכות הכשירות (Fitness Evaluations, FE)=0.
06: פלט (output)
07: תוצאות OL
08: התחל
09: בנה את ה-OA ע”פ F ו-Q.
10: חשב את המספר השלם הקטן ביותר j שיפתור את המשוואה
(Q1-1)(Q-1)=F, ואז הצב: M=QJ
11 בנה LM(3D) ב-OA על פי “אלגוריתם משופר למיטוב של חיפוש קוקייה (Cuckoo search ) לבעיה של הערכת פרמטרים של מערכות כאוטיות”.
12 חשב את ערכה של כל רמה בכל מימד בעזרת פקודה 10.
13 לולאת For: d=1:D
14
15 סוף לולאת For
16 צור ווקטור ל –M פתרונות C1,….Cm….CM על בסיס LM(3D).
17 מצא את M הפתרונות לפי משוואה 11
18 הערך את M הפתרונות בעזרת פונקצית המטרה.
19 M התוצאות הן: f(C1),…f(Cm),…f(CM).
20 סכם את מספר הערכות הכשירות
21 Fes=Fes+M
22 בחר בפתרון הטוב ביותר ל COA .
23
24 חשב את ההשפעה הממוצעת EdK בכל רמה k(1,2,3) של כל מימד d.
25 לולאת For: d=1:D
26 מצא את אינדקס השורה בעלת אותה הרמה במימד d על פי OA.
27 חשב את הממוצע של תוצאות הכשירות על פי ווקטור האינדקס.
28
29
30
31 השווה בין Ed1, Ed2, ו- Ed3, ובחר ברמה המועילה ביותר k במימד d.
32 סוף לולאת For
33 בנה את CFA ע”י צירוף ערכי כל הרמות המועילות ביותר lvdk
34 השווה בין COA ל-CFA, ובחר את הטוב מביניהם לתוצאת OL.
35. סיים.
מפעולות 16 עד 25 עולה כי כל הפעלה של OL מגדילה את מספר הערכות הכשירות M. בבעיה בת 30 ממדים, למשל, כשמפעילים את שיטת OL על 3 פרטים, מספר הפתרונות שאפשר לקבל בשיטת ה-OA ושצריך להעירך בעזרת פונקציית המטרה הוא 34=81. לכן, השימוש ב-OL יסבך את החישובים. כדי להקל את החישובים בכל איטרציה, יש להפעיל את ה-OL רק כשהפתרון הנוכחי, מספר i , נכלל בהאבקה המקומית והאינדקס i שווה למספר השלם האקראי u ששייך לקבוצה {1,…NP}. כך אפשר להגדיל את יכולת הניצול המקומית תוך הפחתת השימוש בחישובים.
4.3 מנגנון אפקט השפמנון
שמה של התופעה נובע ממנהגם של הדייגים להכניס שפמנון לבריכת סרדינים, כי השמפנון מאלץ את הסרדינים לשחות במרץ כדי להינצל מטריפה. התופעה הזאת שולבה בהצלחה ב-PSO.
המנגנון הזה מופעל משמש למניעת התכנסות מוקדמת של ה-FPA, בכך שהוא מאלץ את הפרטים הגרועים ביותר לחקור אזורים חדשים ולהגיע לפתרונות אפשריים טובים יותר. העקרון שמאחוריו הוא שאם ערך הכשירות של הפתרון הטוב ביותר הנוכחי לא גדל אחרי כמה איטרציות ברציפות, 10% הגרועים ביותר מאוכלוסיית “הסרדינים”, WX, יוחלפו ב”שפמנונים”, CX. כאן, הפרט “השפמנוני” הוא פתרון מתחרה לפרט ה”סרדיני”, וניתן לחשבו בנוסחה הבאה:
כאשר i הוא האינדקס של הפרטים ה”סרדיניים”. אלגוריתם 2 ממחיש את פעולתו של המנגנון:
01: קלט
02 מספר האוכלוסייה NP, מימדי האוכלוסייה D
03 מספר האיטרציה הנוכחית t, האוכלוסייה הנבדקת באיטרציה הנוכחית SX.
04 פונקציית המטרה f(solution) לבעיות מזעור או השאה.
05 וקטור אחסון f לכשירות ההיסטורית הטובה ביותר.
06 מספר איטרציות רצופות n.
07 פלט
08 הפרטים ה”שפמנוניים” CX.
09 התחל
10 לולאת t>n if
11 הפרט הטוב ביותר בכלל האוכלוסייה לא השתפר במשך n איטרציות רצופות
12 אם min(f(SX)-f best (t-n)==0
13 מיין את האוכלוסייה על פי הכשירות.
14 =sort(f(SX)[ sort_f, sort_ind].
15 בחר ב 10% הגרועים ביותר על פי sort_ind והגדר אותם כ WX.
16 WX=SX(sort_ind)0.9NP+1: NP),:)
17 צור את הפרטים “השפמנוניים”, בעזרת פקודה 12.
18 לולאתFor i= 1 עד למספר ה WX
19 לולאת For d=1:D
20 CXid=ld+ud-WXid
21 סוף לולאת For
22 סוף לולאת For
23 חשב את ערכי הכשירות f(CXi)
24 סוף לולאת if
25 החלף את כל הפרטים הגרועים ביותר , WX, פרטים “שפמנוניים” CX.
26 סוף לולאת if
27 סיים.
4.4. התהליך העיקרי ב-OCFPA.השיטה נוצרה כתוצאה משילוב שיטת ה-OL ומנגנון אפקט השפמנון ב-FPA המקורי. אלגוריתם 3 מדגים במלואה את פעולת הOCFPA:
01 קלט
02 SX של אבקת פרחים.
03 פונקצית המטרה f(SX) לבעיות מיזעור או השאה.
04 מספר האבקות (NP), מספר הערכות הכשירות (FE)
05 סבירות ההחלפה (p), גורם הצעד (γ).
06 פלט
07 האבקה הטובה ביותר בכלל (gbest).
08 התחל
09 הכניס מספר אקראי של אוכלוסיית האבקות.
10 לולאת For i= 1 עד NP.
11
12 חשב ואחסן את ערך הכשירות (SXi)f.
13 סוף לולאת For
14 בחר באבקה בעלת ערך הכשירות הגבוה ביותר לאבקה הטובה ביותר הנוכחית.
15 (לא הגענו למספר המרבי של הערכות כשירות) while
16 שלוף מספר שלם אקראי מקבוצת {1,….NP}
17 לולאת For i= 1 עד NP.
18 לולאת אם (if) p> מספר אקראי בטווח [0,1]
19 ערוך האבקה כללית.
20
21 אם לא
22 ערוך האבקה מקומית.
23 אם i~=u
24 שלוף ווקטור אקראי ξ מתחום D[0,1].
25 שלוף 2 מספרים שלמים אקראיים, j, ו-k, מקבוצת {1,….NP}
26
27 אם לא
28 צור את S ע”י הפעלת OL על פי אלגוריתם 1.
29 סוף לולאת if
30 סוף לולאת if
31 חשב את ערך הכשירות (SXi)f.
32 עדכן את SXi אם הפרט הנוכחי עדיף מקודמו.
33 סוף לולאת For.
34 גלה את האבקה בעלת הכשירות הטובה ביותר באוכלוסיה .
35 עדכן את gbest אם האבקה הטובה ביותר הנוכחית עדיפה מהאבקה הטובה ביותר הקודמת
36 הפעל את אפקט השמפנון ע”פ אלגוריתם 2.
37 חזור לדור הבא עד שתנאי ההפסקה יתקיים.
38 סוף לולאת while.
39 פלט gbest.
40 סיים.
5. ניסויי אימות והשוואה
ניסינו את האלגוריתם שלנו על 14 פונקציות מבחן, וכל פרטיהן מצוינים בטבלה 3. פונקציות 1 עד 7, למשל, הן אונימודליות ומשמשות בעיקר לבדיקת היעילות המיטבית, ואלו פונקציות 8 עד 4 הן מולטימודליות ומשמשות בעיקקר לבחינת האפשרות לחרוג מנקודות אופטימום מקומיות. הפרמטרים ל FPA ול-ODFPA הם =3γ ו p=0.8. מספר האיטרציות הרצופות n במנגנון אפקט השמפנון הוא 7. כדי להבטיח השוואה הוגנת, גודל האוכלוסייה נקבע כ-20 ומספר בדיקות הכשירות, כ-20,000. כל התוצאות הסטטיסטיות הושג ב-30 הפעלות נפרדות של האלגוריתמים. התוצאות הטובות ביותר כתובות באות עבה. הניסויים התבצעו במחשב אישי בעל יחידת עיבוד מרכזית של 3.2 ג’יגה-הרץ וזיכרון של 2.5 ג’יגה ביט, ומערכת הפעלה של Windows XP.
מס’ | שם | תחום | פתרון מיטבי | נקודת אופטימום |
1 | פונקציה כדורית (sphere functon) | D[-100, 100] | SX*=(0,0….,0) | 0 |
2 | פונקציה ממעלה רביעית עם רעש | [-1.28, 1.28] D | SX*=(0,0….,0) | 0 |
3 | פונקציה אליפטית עם תנאי גבוה (High-condition) | D [-100, 100] | SX*=(0,0….,0) | 0 |
4 | פונקצית רוזנברוק | D[-30, 30] | SX*=(0,0….,0) | 0 |
5 | פונקציה לבעיית שוופל 2.22 | D[-10, 10] | SX*=(0,0….,0) | 0 |
6 | פונקצית צעד | D[-100, 100] | SX*=(0,0….,0) | 0 |
7 | פונקצית דיקסון- פרייס | D[-10, 10] | SX*=(0,0….,0) | 0 |
8 | פונקצית שוופל | D[-500, 500] | SX*=(420.9587) | -418.9829D |
9 | פונקצית ראסטריגין | D[-5.12, 5.12] | SX*=(0,0….,0) | 0 |
10 | פונקציית גריוואנק | D[-5.12, 5.12] | SX*=(0,0….,0) | 0 |
11 | D[-5.12, 5.12] | SX*=(0,0….,0) | 0 | D[-5.12, 5.12] |
12 | פונקצית ראסטריגין לא רציפה. | D[-32, 32] | SX*=(0,0….,0) | 0 |
13 | פונקציה מוכללת עם עונש 1 | D[-10, 10] | SX*=(0,0….,0) | 0 |
14 | פונקציה מוכללת עם עונש 2 | D[-10, 10] | SX*=(0,0….,0) | 0 |
טבלה 3: פונקציות המבחן
5.1. השיפורים ב FPA לעומת OCFPA
בטבלה 4 מוצגים תוצאות הניתוחים הסטטיסטיים לביצועי שני האלגוריתמים. מהטבלה עולה ש-OCFPA עדיף מ-FPA בכל פונקציות המבחן. הוא הגיע לפתרונות טובים יותר של הפונקציות האונימודליות מס’ 1, 3, 5, ו-7, וגם בגילוי נקודות האופטימום הכלליות של הפונקציות המורכבות מס’ 2 ו-4 הצטיין יותר מ-FPA. מהתוצאות עולה כי OCFPA מצטיין ביכולת ניצול מצוינת וביעילות מיטבית. כמו כן, בפונקציות המולטימודליות מס’ 8 עד 14, במצבים של ריבוי נקו’ אופטימום מקומיות, OCFPA הגיע לפתרונות כלליים או כמעט כלליים ופתרונותיו היו מדויקים ואיתנים יותר מאלו של FPA. מכאן נובע ש FPA יכול למנוע התכנסות מקומית ולהגיע לפתרונות מדויקים יותר. לסיכום, האלגוריתם שלנו מגיע מהר יותר לפתרונות מיטביים ועולה בדיוקו על ה-FPA הבסיסי.
FPA | OCFPA | ||||
מס’ הפונקציה | ממוצע | סטיית תקן | ממוצע | סטיית תקן | |
1 | 1.56E-25 | 3.20E-25 | 1.09E-86 | 3.27E-86 | |
2 | 3.37E-02 | 1.56E-02 | 1.70E-03 | 9.08E-04 | |
3 | 6.89E-22 | 2.10E-21 | 2.09E-81 | 7.67E-81 | |
4 | 2.41E+01 | 1.81E+01 | 1.08E+81 | 7.11E+00 | |
5 | 5.51E | 6.12-17 | 2.38E-47 | 6.13E-47 | |
6 | 0 | 0 | 0 | 0 | |
7 | 5.91E-21 | 3.25E-20 | 1.36E-86 | 4.54E-86 | |
8 | -10308 | 4.92E+02 | 12569– | 4.05E-12 | |
9 | 4.12E+01 | 9.59E+00 | 0 | 0 | |
10 | 1.40E-03 | 3.20-03 | 0 | 0 | |
11 | 8.21E-01 | 6.40E-01 | 4.32E-15 | 6.49E-16 | |
12 | 2.21E+01 | 5.08E+00 | 0 | 0 | |
13 | 1.35E-27 | 2.01E-27 | 1.61E-32 | 1.18E-33 | |
14 | 1.47E-24 | 7.99E-24 | 2.09E-32 | 4.56E-32 | |
5.2 השפעת ההבדלים בין השיטות על יכולת החיפוש.
שיטות ה-OL ו”מנגנון אפקט השפמנון” שימשו להגברת יכולת החיפוש של ה-FPA. בטבלה 5 אנו משווים בין ביצועיהם של ה-FPA המבוסס על OL (OFPA), של ה-FPA המבוסס על אפקט השפמנון (CFPA), ושל ה-OFCPA על פי סטיות התקן שלהם.
ב-13 פונקציות, חוץ מפונקציה מס’ 4, OCFPA היה עדיף על OFPA. מהתוצאות עולה כי קלוש הסיכוי ששיטת OL תשפר את איכות הפתרון מהרגע שהאלגוריתם ננעל על נקודות אופטימום מקומיות, כי עיקר פעולתה של ה-OL היא שילוב בין חלקי מידע, והוא אינו יכול לחקור תחומים חדשים כדי למצוא מידע מועיל יותר. ב-10 פונקציות OCFPA היה עדיף מ-CFPA, ובפונקציות מס’ 6, 10, ו-11 ביצועיהם היו שווים. מכאן נובע שמנגנון אפקט השפמנון מסוגל להרחיב את תחום החיפוש כדי לגלות פתרונות אפשריים מבטיחים יותר.
מנתוני הטבלה עולה שפעולת הגומלין בין שתי השיטות מועילה ל-OCFPA, בשל יכולתו של מנגנון אפקט השפמנון לבדוק תחומי חיפוש חדשים ולספק ל-OL פרטים רבי ערך, ובשל יכולתה של OL לנצל במלואו את המידע המועיל כדי להגיע לפתרונות מדויקים.
מס’ פונקציה | OFPA | CFPA | OCFPA | |||
ממוצע | סטיית תקן | ממוצע | סטיית תקן | ממוצע | סטיית תקן | |
1 | 2.31E-58 | 1.26E-57 | 1.18E-51 | 1.74E-51 | 1.09E-86 | 3.27E-86 |
2 | 3.17E-70 | 1.71E-02 | 1.20E-02 | 4.74E-04 | 1.70E-03 | 9.08E-04 |
4 | 1.98E-70 | 9.05E-70 | 5.52E-48 | 6.79E-48 | 2.09E-81 | 7.67E-81 |
5 | 2.13E+00 | 2.02E-00 | 2.38E+01 | 3.02E-01 | 1.08E+01 | 7.11E+00 |
6 | 7.99E-02 | 2.15E-01 | 5.66E-26 | 6.88E-26 | 2.38E-47 | 6.13E-47 |
7 | 4.33E-01 | 1.65E+00 | 0 | 0 | 0 | 0 |
8 | 1.14E-13 | 6.26E-13 | 1.32E-52 | 1.65E-32 | 1.36E-86 | 4.54E-86 |
9 | -12712 | 2.15E+02 | -9922.6 | 5.49E+02 | 12596 | 4.05E-12 |
10 | 5.62E-02 | 5.98E-02 | 0 | 0 | 0 | 0 |
11 | 3.45E+00 | 1.38E+00 | 4.32E-15 | 6.49E-16 | 4.32E-15 | 6.49E-16 |
12 | 7.67E+00 | 2.78E+00 | 2.21E+01 | 2.11E+01 | 0 | 0 |
13 | 1.39E-13 | 7.61E-13 | 5.14E-24 | 2.70E-23 | 1.61E-32 | 1.18E-33 |
14 | 3.96E-02 | 1.83E-01 | 3.00E-03 | 1.65E-02 | 2.09E-32 | 4.56E-32 |
טבלה 5: השוואת ביצועים בין OFPA, CFPA, ו-OCFPA, בבעיות של 30 מימדים.
5.3 השפעת גודל האוכלוסייה על יכולת החיפוש של שלושת האלגוריתמים.
השווינו בין יכולות החיפוש של OFPA, FPA, ו-OCFPA, בארבע ניסויים באוכלוסיות של 20, 50, 80 ו-100 פרטים, והתוצאות מפורטות בטבלה 6. מהתוצאות עולה שבפונקציות מס’ 1 עד 14, ביצועיו של OCFPA היו טובים משל FPA בכל ארבעת הניסויים. אולם רמת הדיוק של FPA ושל יורדת ככל שהאוכלוסייה גדלה. מכאן נובע שאוכלוסייה גדולה מדי מצריכה שימוש תדיר בהערכות כשירות ומונעת מהאלגוריתם להגיע לנקודת האופטימום הכללית. אך גם אוכלוסיה קטנה מדי עלולה לפגוע ביכולת החיפוש בגלל הירידה במגוון האוכלוסייה. לכן, בחירת אוכלוסיה בגודל המתאים חיונית לשיפור ההשפעה המיטבית.
20 פרטים | 50 פרטים | |||||||||||||||||||||||
FPA | OCFPA | FPA | OCFPA | |||||||||||||||||||||
מס’ פונקציה | ממוצע | סטיית תקן | ממוצע | סטיית תקן | ממוצע | סטיית תקן | ממוצע | סטיית תקן | ||||||||||||||||
1 | 1.56E-25 | 3.20E-25 | 1.09E-86 | 3.27E-86 | 1.26E-12 | 6.73E-13 | 1.69E-35 | 5.05E-35 | ||||||||||||||||
2 | 3.37E-02 | 1.56E-02 | 1.70E-03 | 9.08E-04 | 1.44E-02 | 4.40E-03 | 5.60E-03 | 2.00E-03 | ||||||||||||||||
3 | 6.89E-22 | 2.10E-21 | 2.09E-81 | 7.67E-81 | 2.53E-09 | 1.56E-09 | 1.41E-32 | 2.87E-32 | ||||||||||||||||
4 | 2.41E+01 | 1.81E+01 | 1.08E+01 | 7.11E+00 | 1.97E+01 | 2.52E+00 | 1.04E+01 | 1.13E-01 | ||||||||||||||||
5 | 5.51E-17 | 6.12E-17 | 2.38E-47 | 6.13E-47 | 3.70E-07 | 1.40E-07 | 3.11E-20 | 6.40E-20 | ||||||||||||||||
6 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | ||||||||||||||||
7 | 5.94E-21 | 3.25E-20 | 1.36E-86 | 4.54E-86 | 1.60E-13 | 7.74E-14 | 5.87E-37 | 1.62E-36 | ||||||||||||||||
8 | -10398 | 4.92E+02 | 12569 | 4.05E-12 | -8989.7 | 3.33E+02 | -12569 | 2.07E-01 | ||||||||||||||||
9 | 4.12E+01 | 9.59E+00 | 0 | 0 | 5.76E-01 | 9.18E+00 | 0 | 0 | ||||||||||||||||
10 | 1.40E-03 | 3.20E-03 | 0 | 0 | 2.85E-08 | 8.15E-08 | 0 | 0 | ||||||||||||||||
11 | 8.21E-01 | 6.40E-01 | 4.32E-15 | 6.49E-16 | 2.62E-04 | 3.11E-04 | 2.56E-12 | 2.05E-12 | ||||||||||||||||
12 | 2.22E+01 | 5.08E+00 | 0 | 0 | 4.63E+01 | 7.92E+00 | 0 | 0 | ||||||||||||||||
13 | 1.35E-27 | 2.01E-27 | 1.61E-32 | 1.18E-33 | 6.41E-12 | 1.23E-11 | 1.57E-32 | 6.24E-35 | ||||||||||||||||
14 | 1.47E-24 | 7.99E-24 | 2.09E-32 | 2.09E-32 | 7.05E-13 | 8.28-13 | 1.69E-35 | 5.05E-35 | ||||||||||||||||
30 מימדים, 20,000 בדיקות כשירות
80 פרטים | 100 פרטים | |||||||||||||||||||||||
FPA | OCFPA | FPA | OCFPA | |||||||||||||||||||||
מס’ פונקציה | ממוצע | סטיית תקן | ממוצע | סטיית תקן | ממוצע | סטיית תקן | ממוצע | סטיית תקן | ||||||||||||||||
1 | 4.14E-07 | 1.32E-07 | 3.62E-20 | 3.27E-86 | 5.37E-01 | 1.83E-05 | 2.62E-15 | 3.61E-15 | ||||||||||||||||
2 | 2.40E-02 | 4.50E-03 | 1.29E-02 | 9.08E-04 | 3.20E-02 | 8.60E-03 | 1.74E-02 | 6.00E-03 | ||||||||||||||||
3 | 1.10E-03 | 5.27E-04 | 7.69E-17 | 7.67E-81 | 1.25E-01 | 3.22E-02 | 8.32E-12 | 1.62E-11 | ||||||||||||||||
4 | 2.22E+01 | 2.85E+00 | 6.32E+00 | 7.11E+00 | 2.49E+01 | 2.99E+00 | 1.32E+01 | 9.82E+00 | ||||||||||||||||
5 | 4.09E-04 | 4.09E-04 | 5.74E-12 | 6.13E-47 | 5.40E-03 | 9.98E-04 | 1.02E-08 | 1.93E-08 | ||||||||||||||||
6 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | ||||||||||||||||
7 | 5.95E-08 | 2.26E-08 | 1.86E-21 | 4.71E-21 | 6.39E-06 | 1.83E-06 | 7.03E-16 | 1.46E-15 | ||||||||||||||||
8 | -8711.7 | 3.47E+02 | 12569- | 2.80E-12 | -8518.8 | 2.52E+02 | 12569- | 2.62E-04 | ||||||||||||||||
9 | 6.94E+01 | 1.02E+01 | 2.77E-11 | 1.52E-10 | 5.59E-04 | 2.40E+04 | 6.43E-10 | 3.46E-09 | ||||||||||||||||
10 | 2.02E-05 | 3.37E-05 | 3.56E-14 | 8.80E-14 | 6.22E-01 | 3.38E-01 | 7.72E-06 | 4.17E-05 | ||||||||||||||||
11 | 8.53E-02 | 6.44E-02 | 1.97E-06 | 2.01E-06 | 6.26E+01 | 7.58E+00 | 1.01E-04 | 4.85E-05 | ||||||||||||||||
12 | 5.75E+01 | 8.36E+00 | 1.18E-15 | 5.51E-15 | 4.63E+01 | 7.92E+00 | 4.07E-11 | 1.67E-10 | ||||||||||||||||
13 | 1.08E-06 | 9.97E-07 | 4.68E-21 | 9.92E-21 | 3.12E-05 | 2.54E-05 | 5.42E-16 | 1.03E-15 | ||||||||||||||||
14 | 1.01E-06 | 7.37E-07 | 8.25E-19 | 3.03E-18 | 1.30E-04 | 7.19E-05 | 2.10E-13 | 3.02E-13 | ||||||||||||||||
30 מימדים, 20,000 בדיקות כשירות
טבלה 6: השוואה בין ביצועי הלוגריתמים באוכלוסיות בגדלים שונים.
5.4 השפעת מספר המימדים על ביצועי האלגוריתמים
ככל שהממדים רבים יותר, הבעיה מורכבת יותר, ולכן בדקנו את יכולות המיטוב של OCFPA על מספרי מימדים שונים: 10 מימדים ו10,000 מבחני כשירות; 50 מימדים ו-30,000 מבחני כשירות; 75 מימדים ו-45,000 מבחני כשירות; ו-100 מימדים ו-60,000 מבחני כשירות. בכל ארבעת המצבים הן FPA והן OCFPA הגיעו לפתרון המיטבי 0 לפונקציה מס’ 6, אבל בכל שאר הפונקציות OCFPA הצטיין יותר. כמו כן, הוא הצטיין למדיי בדיוק ההתכנסות ובמהירות המיטבית. . מכאן נובע ששילוב שתי השיטות האלה שיפרה בהרבה את יכולת החיפוש של ה-FPA גם בפתרון בעיות רבות מימדים.
10, מימדים, 10,000 בדיקות כשירות | 50 מימדים, 30,000 בדיקות כשירות | ||||||||
FPA | OCFPA | FPA | OCFPA | ||||||
מס’ הפונקציה | ממוצע | סטיית תקן | ממוצע | סטיית תקן | ממוצע | סטיית תקן | ממוצע | סטיית תקן | |
1 | 4.69E-37 | 2.17E-36 | 3.06E-76 | 1.48E-75 | 1.06E-25 | 1.23E-25 | 8.84E-83 | 2.25E-62 | |
2 | 3.20E-03 | 1.70E-03 | 1.20E-03 | 5.71E-04 | 9.16E-02 | 3.36E-02 | 2.10E-03 | 9.92E-04 | |
3 | 1.09E-34 | 2.89E-34 | 1.58E-73 | 4.13E-73 | 9.09E-22 | 2.67E-21 | 1.23E-58 | 4.42E-58 | |
4 | 1.32E+01 | 7.27E-01 | 1.33E-01 | 7.27E-01 | 7.68E+01 | 3.64E+01 | 3.65E+01 | 1.25E-01 | |
5 | 6.49E-20 | 1.12E-19 | 4.92E-43 | 1.12E-42 | 6.15E-18 | 4.15E-18 | 7.85E-33 | 3.97E-32 | |
6 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | |
7 | 2.83E-38 | 1.15E-38 | 6.13E-77 | 3.03E-76 | 3.19E-26 | 4.74E-26 | 5.75E-62 | 3.11E-61 | |
8 | -4143.8 | 6.12E+01 | 4189.9– | 2.77E-12 | -15278 | 9.06E+02 | 20949– | 3.43E-01 | |
9 | 2.77E+00 | 9.58E-01 | 0 | 0 | 8.04E+01 | 1.96E+01 | 0 | 0 | |
10 | 5.35E-02 | 3.32E-02 | 0 | 0 | 2.70E-03 | 4.70E-03 | 0 | 0 | |
11 | 7.70E0-02 | 2.93E-01 | 4.20E-15 | 9.01E-16 | 1.44E+00 | 4.44E-01 | 4.32E-15 | 6.48E-16 | |
12 | 2.81E+00 | 1.02E+00 | 0 | 0 | 5.41E+01 | 2.43E+01 | 0 | 0 | |
13 | 4.83E-32 | 5.31E-33 | 4.72E-32 | 2.95E-34 | 4.10E-03 | 2.27E-02 | 8.15E-19 | 4.46E-18 | |
14 | 5.49E-33 | 4.22E-33 | 3.12E-33 | 8.38E-33 | 3.00E-03 | 1.65E-02 | 4.25E-33 | 8.76E-33 | |
75 מימדים, 45,000 בדיקות כשירות | 100 מימדים, 60,000 בדיקות כשירות | ||||||||
FPA | OCFPA | FPA | OCFPA | ||||||
מס’ הפונקציה | |||||||||
1 | 6.30E-28 | 2.09E-27 | 1.57E-91 | 5.32E-91 | 3.07E-30 | 3.79E-90 | 1.10E-118 | 5.90E-118 | |
2 | 1.64E-01 | 3.86E-02 | 1.40E-03 | 8.59E-04 | 2.60E-01 | 6.04E-02 | 1.30E-03 | 9.24E-04 | |
3 | 5.17E-25 | 5.90E-25 | 1.11E-85 | 6.09E-85 | 7.28E-27 | 7.76E-27 | 2.90E-117 | 1.0E-116 | |
4 | 1.48E+02 | 5.53E+01 | 5.79E+01 | 1.61E+01 | 1.91E+02 | 5.37E+01 | 6.87E+01 | 2.75E+01 | |
5 | 1.67E-20 | 7.22E-21 | 6.12E-50 | 1.85E-49 | 1.92E-22 | 7.67 | |||
6 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | |
7 | 9.11E-29 | 1.46E-28 | 1.11E-91 | 5.82E-91 | 1.88E-29 | 9.77E-29 | 4.91E-119 | 2.72E-118 | |
8 | -22236 | 1.54E+03 | 31424– | 5.36E-01 | -29152 | 1.68E+03 | 41898– | 5.16E-02 | |
9 | 1.43E+02 | 3.28E+01 | 0 | 0 | 1.75E+02 | 4.11E+01 | 0 | 0 | |
10 | 4.00E-03 | 1.35E-02 | 0 | 0 | 2.50E-03 | 8.00E-03 | 0 | 0 | |
11 | 1.63E+00 | 2.62E-01 | 4.32E-15 | 6.48E-16 | 2.07E+01 | 3.14E-01 | 4.32E-15 | 6.48E-16 | |
12 | 6.08E+01 | 1.19E+01 | 0 | 0 | 7.99E+01 | 2.19E+01 | 0 | 0 | |
13 | |||||||||
14 | |||||||||
טבלה 7: השוואת ביצועים במימדים שונים, באוכלוסיה של 20 פרטים.
5.4 השוואה לביצועי אלגוריתמים אבולוציוניים מתקדמים.
הוכחנו את עדיפותו של OCFPA גם על אלגוריתמים כגון CS, GSA, CMAES, OXDE, SGHS, ו-CLPSO. התוצאות מוצגות בטבלאות 8 ו-9. הדרגה חושבה על פי הממוצע וסטיית התקן. טבלה 8 משווה בין הביצועים בפונקציות המבחן האונימודליות. OCFPA הפגין יכולת מיטוב כללית עדיפה מזאת של כל השאר בפונקציות מס’ 1, 2, 3, 5, 7, אולם היה נחות מ-CMAES ומ-OXDE. בפונקציה 6, כל האלגוריתמים הגיעו לפתרון המיטבי 0.
בטבלה 9 מוצגים הביצועים בפונקציות המולטימודאליות. בפונקציות מס’ 8, 9, ו-12, OCFPA הגיע לפתרונות המיטביים הכלליים והצטיין יותר מכל שאר האלגוריתמים. בפונקציה 10, OCFPA וגם CLPSO הגיעו לנקודת האופטימום הכללית 0, ועלו על כל שאר האלגוריתמים. בפונקציה 11 OCFPA הצטיין יותר משאר האלגוריתמים בחיפוש מדויק ובפתרונות איתנים. בפונקציות 13 ו-14, CLPSO עלה מעט על OCFPA, אם כי בפונקציה 13, CKPSO, OCFPA ו-OXDE הגיעו לאותה רמת דיוק, כמו גם CMAES בפונקציה 14.
איורים 2 ו-3 מציגים את עקומות הביצועים של OCFPA ושל שאר האלגוריתמים בפונקציות שונות. גם מהם עולה ש OCFPA עולה על האלגוריתמים המשוכללים האלה בכל הנוגע למהירות הפיתרון והדיוק ברוב הפונקציות.
איורים 4 ו-5 הם תרשימי קופסה-ושפם (box-and-whisker plot) של קבוצות הפתרונות המיטביים ב-30 נסיונות נפרדים לפונקציות האונימודליות 1, 2,5, ו-7, ולפונקציות המולטימודליות 8, 9, 10, ו-11. מהן עולה שלאלגוריתם שלנו היו פחות חריגות (outliers ) ופיזור נמוך יותר, מה שמעיד על יציבותו הרבה.
מס’ הפונקציה | CS | GSA | CMAES | OXDE | SGHS | CLPSO | OCFPA | |
1 | ממוצע | 6.64E-32 | 1.27E-16 | 1.57E-29 | 3.32E-61 | 1.47E-10 | 2.61E-40 | 1.09E-86 |
סטיית תקן | 1.41E-31 | 4.04E-17 | 2.22E-30 | 8.22E-61 | 8.53E-11 | 3.43E-40 | 3.27E-86 | |
דרגה | 4 | 6 | 5 | 2 | 7 | 3 | 1 | |
2 | ממוצע | 1.23E-01 | 6.10E-02 | 3.97E-02 | 1.17E-02 | 7.20E-03 | 3.90E-03 | 1.70E-03 |
סטיית תקן | 5.79E-02 | 1.50E-02 | 1.32E-02 | 7.90E-03 | 3.40E-03 | 1.10E-03 | 9.08E-04 | |
דרגה | 7 | 5 | 6 | 4 | 3 | 2 | 1 | |
3 | ממוצע | 1.16E-27 | 3.33E+03 | 5.73E-24 | 2.41E-58 | 2.97E-02 | 1.42E-38 | 2.09E-81 |
סטיית תקן | 3.92E-27 | 2.77E+03 | 4.72E-25 | 4.68E-58 | 1.27E-01 | 1.65E-38 | 7.67E-81 | |
דרגה | 4 | 7 | 5 | 2 | 6 | 3 | 1 | |
4 | ממוצע | 2.70E+01 | 2.29E+01 | 2.65E-01 | 7.97E-01 | 9.23E+01 | 2.93E+01 | 1.08E+01 |
סטיית תקן | 3.35E+01 | 2.34E+01 | 1.62E+00 | 2.34E+01 | 2.72E+01 | 7.11E+00 | ||
דרגה | 5 | 4 | 1 | 2 | 7 | 6 | 3 | |
5 | ממוצע | 3.42E-20 | 5.32E-08 | 1.36E-02 | 1.11E-37 | 4.61E-05 | 7.89E-26 | 2.38E-47 |
סטיית תקן | 3.42E-19 | 7.64E-09 | 5.85E-02 | 1.80E-37 | 1.17E-05 | 5.70E-26 | 6.13E-47 | |
דרגה | 4 | 5 | 7 | 2 | 6 | 3 | 1 | |
6 | ממוצע | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
סטיית תקן | 0 | 0 | 0 | 0 | 0 | 0 | 0 | |
דרגה | 1 | 1 | 1 | 1 | 1 | 1 | 1 | |
7 | ממוצע | 4.69E-33 | 1.18E-15 | 2.90E-28 | 7.03E-60 | 5.09E-04 | 2.54E-41 | 1.33E-87 |
סטיית תקן | 1.58E-32 | 4.09E-16 | 3.59E-29 | 3.79E-59 | 2.80E-03 | 3.55E-41 | 4.61E-87 | |
דרגה | 4 | 6 | 5 | 2 | 7 | 3 | 1 |
טבלה 8: השוואת ביצועים בין OCFPA לאלגוריתמים האבולוציוניים בפונקציות אונימודליות בבעיות של 30 מימדים.
מס’ הפונקציה | CS | GSA | CMAES | OXDE | SGHS | CLPSO | OCFPA | |
8 | ממוצע | 11461- | -2427.8 | -7045.7 | 12514- | 12547- | 12542- | -12596 |
סטיית תקן | 422.65 | 515.24 | 641.36 | 103.09 | 124.88 | 5.09E+01 | 4.06E-12 | |
דרגה | 5 | 7 | 6 | 4 | 2 | 3 | 1 | |
9 | ממוצע | 1.30E-02 | 1.8E-03 | 2.46E-04 | 1.11E-02 | 4.40E-02 | 0 | 0 |
סטיית תקן | 1.73E-02 | 4.90E-03 | 1.40E-03 | 1.76E-02 | 4.06E-02 | 0 | 0 | |
דרגה | 4 | 6 | 7 | 5 | 3 | 2 | 1 | |
10 | ממוצע | 1.30E-02 | 1.80E | 1.94E-01 | 9.16E-01 | 1.03E-05 | 9.77E-15 | 4.32E-15 |
סטיית תקן | 1.73E-02 | 4.90E-03 | 2.27E-01 | 8.67E-01 | 3.31E-06 | 2.91E-15 | 6.49E-16 | |
דרגה | 6 | 4 | 3 | 5 | 7 | 1 | 1 | |
11 | ממוצע | 5.61E+00 | 9.45E-09 | 1.94E+01 | 9.16E-01 | 1.03E-05 | 9.77E-15 | 4.32E-15 |
סטיית תקן | 1.97E+00 | 1.70E-09 | 2.27E-01 | 2.27E-01 | 3.31E-06 | 2.91E-15 | 6.49E-16 | |
דרגה | 6 | 3 | 7 | 5 | 4 | 2 | 1 | |
12 | ממוצע | 1.80E+01 | 4.41E+01 | 2.43E+02 | 2.19E+01 | 2.67E-01 | 2.00E-01 | 0 |
סטיית תקן | 7.37+00 | 9.39E+00 | 4.53E+01 | 5.54E+00 | 6.92E-01 | 4.07E-01 | 0 | |
דרגה | 4 | 6 | 7 | 5 | 3 | 2 | 1 | |
13 | ממוצע | 1.04E-02 | 3.50E-03 | 9.27E-01 | 1.64E-32 | 2.29E-12 | 1.57E-32 | 1.61E-32 |
סטיית תקן | 3.16E-02 | 1.89E-02 | 9.96E-01 | 1.14E-33 | 2.64E-12 | 5.56E-32 | 1.18E-32 | |
דרגה | 6 | 5 | 7 | 3 | 4 | 1 | 2 | |
14 | ממוצע | 4.77E-02 | 1.38E-17 | 6.05E-30 | 3.79E-32 | 2.94E-11 | 1.50E-33 | 2.09E-32 |
סטיית תקן | 1.10E-01 | 3.78E-18 | 7.91E-31 | 1.51E-31 | 2.22E-11 | 0 | 4.56E-32 | |
דרגה | 7 | 5 | 4 | 3 | 6 | 1 | 2 |
טבלה 9: השוואת ביצועים של OCFPA והאלגוריתמים האבולוציוניים בפונקציות מולטימודליות בבעיות של 30 מימדים
5.6 ניתוח סטטיסטי לא-פרמטרי
בעזרת מבחן הדרגות המסומנות של וילקוקסון, ערכנו השוואה מזווגת (pairwise comparison) בין ביצועי האלגוריתמים כדי לגלות את עוצמת ההבדלים בתוצאות הסופיות, ביותר מ-30 נסיונות בלתי תלויים. התוצאות מוצגות בטבלה 10. קבענו את סף המובהקות ל-0.05, והשווינו אליו את ערכי p. מהטבלה עולה כי בהשוואה בין CS ל-OCFPA, בין GSA ל-OCFPA ובין SGHS ל-OFCPA, p היה קטן בהרבה מ-0.05 ב-13 פונקציות. OXDE ו-CMAES הצטיינו יותר מ-OCFPA רק בפונקציה מס’ 4. CLPSO הצטיין יותר מ-OCFPA רק בפונקציות מס’ 13 ו-14. לסיכום, ניתן לומר שהאלגוריתם שהצענו הפגין ביצועים עדיפים מאלה של האלגוריתמים האבולוציוניים המתקדמים.
CS לעומת OCFPA | GSA לעומת OCFPA | CMAES לעומת OCFPA | ||||||||||
מס’ פונקציה | ערכי p | R+ | R– | ע | ערכי p | R+ | R– | ע | ערכי p | R+ | R– | ע |
1 | 1.73E-06 | 465 | 0 | כן | 1.73E-06 | 465 | 0 | כן | 1.73E-06 | 465 | 0 | כן |
2 | 1.73E-06 | 465 | 0 | כן | 1.73E-06 | 465 | 0 | כן | 1.73E-06 | 465 | 0 | כן |
3 | 1.73E-06 | 465 | 0 | כן | 1.73E-06 | 465 | 0 | כן | 1.73E-06 | 465 | 0 | כן |
4 | 1.09E-01 | 310 | 155 | לא | 4.44E-05 | 431 | 34 | כן | 1.73E-06 | 0 | 465 | לא |
5 | 1.73E-06 | 465 | 0 | כן | 1.73E-06 | 465 | 0 | כן | 1.73E-06 | 465 | 0 | כן |
6 | 1 | 232.5 | 232.5 | ש | 1 | 232.5 | 232.5 | ש’ | 1 | 232.5 | 232.5 | ש |
7 | 1.73E-06 | 465 | 0 | כן | 1.73E-06 | 465 | 0 | כן | 1.73E-06 | 465 | 0 | כן |
8 | 1.73E-06 | 465 | 0 | כן | 1.73E-06 | 465 | 0 | כן | 1.73E-06 | 465 | 0 | כן |
9 | 1.72E-06 | 465 | 0 | כן | 1.73E-06 | 465 | 0 | כן | 1.73E-06 | 465 | 0 | כן |
10 | 2.90E-04 | 419.5 | 45.5 | כן | 6.79E-02 | 289.5 | 175.5 | כן | 1.73E-06 | 247.5 | 217.5 | ש |
11 | 8.00E-05 | 465 | 0 | כן | 1.73E-06 | 465 | 0 | כן | 1.73E-06 | 465 | 0 | כן |
12 | 1.64E-06 | 465 | 0 | כן | 1.73E-06 | 465 | 0 | כן | 1.73E-06 | 465 | 0 | כן |
13 | 2.37E-01 | 455.5 | 9.5 | כן | 1.73E-06 | 465 | 0 | כן | 1.73E-06 | 465 | 0 | כן |
14 | 8.87E-01 | 459 | 6 | כן | 1.73E-06 | 465 | 0 | כן | 1.73E-06 | 465 | 0 | כן |
W | 13 | 13 | 11 | |||||||||
T | 1 | 1 | 2 | |||||||||
L | 0 | 0 | 1 |
OXDE לעומת OCFPA | SGHS לעומת OCFPA | CLPSO לעומת OCFPA | ||||||||||
מס’ פונקציה | ערכי p | R+ | R– | ע | ערכי p | R+ | R– | ע | ערכי p | R+ | R– | ע |
1 | 1.73E-06 | 465 | 0 | כן | 1.73E-06 | 465 | 0 | כן | 1.73E-06 | 465 | 0 | כן |
2 | 1.73E-06 | 465 | 0 | כן | 1.73E-06 | 465 | 0 | כן | 1.92E-06 | 464 | 1 | כן |
3 | 1.73E-06 | 465 | 0 | כן | 1.73E-06 | 465 | 0 | כן | 1.73E-06 | 465 | 0 | כן |
4 | 7.06E-06 | 15 | 450 | לא | 4.44E-05 | 417 | 34 | כן | 2/10E-06 | 382 | 83 | לא |
5 | 1.73E-06 | 465 | 0 | כן | 1.73E-06 | 465 | 0 | כן | 1.73E-06 | 465 | 0 | כן |
6 | 1 | 232.5 | 232.5 | ש | 1 | 232.5 | 232.5 | ש’ | 1 | 232.5 | 232.5 | ש |
7 | 1.73E-06 | 465 | 0 | כן | 1.73E-06 | 465 | 0.5 | כן | 1.73E-06 | 465 | 0 | כן |
8 | 5.90E-03 | 252 | 213 | כן | 1.73E-06 | 464.5 | 0 | כן | 1.04E-02 | 230 | 235 | ש |
9 | 1.72E-06 | 465 | 0 | כן | 1.73E-06 | 465 | 0 | כן | 3.17-01 | 247.5 | 217.5 | ש |
10 | 4.29E-04 | 412.5 | 52.5 | כן | 6.79E-02 | 465 | 175.5 | כן | 1 | 232.5 | 232.5 | ש |
11 | 8.00E-05 | 437.5 | 27.5 | כן | 1.73E-06 | 465 | 0 | כן | 6.83E-07 | 465 | 0 | כן |
12 | 1.64E-06 | 465 | 0 | כן | 1.73E-06 | 465 | 0 | כן | 1.43E-02 | 315 | 150 | כן |
13 | 2.37E-01 | 282 | 183 | ש | 1.73E-06 | 465 | 0 | כן | 4.14E-06 | 52.5 | 412.5 | לא |
14 | 8.87E-01 | 223.5 | 241.5 | ש | 1.73E-06 | 465 | 0 | כן | 1.73E-06 | 85.5 | 379.5 | לא |
W | 13 | 13 | 8 | |||||||||
T | 1 | 1 | 4 | |||||||||
L | 0 | 0 | 2 |
ע: עדיפות ל-OCFPA
R+: סך הדרגות שבהן OCFPA עלה על האלגוריתם האחר;
R–: סך הדרגות שבהן האלגוריתם האחר עלה על OCFPA;
ש: שוויון בביצועים;
לא: עדיפות לאלגוריתם האחר;
W: מס’ הפעמים שבהם OCFPA הצטיין יותר;
T: מס’ הפעמים שבהן היה שוויון בביצועים;
L: מס’ הפעמים שבהן האלגוריתם האחר הצטיין יותר.
טבלה 10: ניתוח סטטיסטי של ביצועי האלגוריתמים בעזרת מבחן הדרגה המסומנת של וילקוקסון.
6. מסקנות
פיתחנו גרסה חדשנית של FPA המסתייעת ב-OL וב-מנגנון אפקט השפמנון לפתרון בעיות מיטוב מורכבות. OCFPA נעזר ב-OL כדי לשפר את יכולת החיפוש המקומי של הFPA הבסיסי באמצעות חילופי מידע מועיל בין וקטורי פתרון שונים בכל מימד של הבעיה. כמו כן, מנגנון אפקט השפמנון מסייע ל-FPA לחרוג מנקודות האופטימום המקומיות, ושפר את מרחב החיפוש של האוכלוסייה כדי לחקור אזורים מבטיחים יותר. שתי האסטרטגיות האלה מסייעות ל-OCFPA להגיע לאיזון נכון בין יכולות החקירה והניצול. תוצאות הניסויים באמצעות פונקציות המבחן הוכיחו את יעילותו של האלגוריתם שהצענו ואת הצלחתו.
אמנם הצלחנו לשלב בהצלחה את ה-OL ב-OCFPA, אולם במחקרים עתידיים יש לבחון אפשרויות להרחבת השימוש ב-OL באמצעות הפעלתה על מקורות מקורות מידע שונים. כמו כן בכוונתו לנצל את ה-FPA המבוסס על OL לפתרון בעיות הנדסיות בעולם הממשי, כגון זיהוי פרמטרים ובחירת מאפיינים (feature selection).
מילות מפתח: אלגוריתם של האבקת פרחים ( Flower Pollination Algorithm, FPA); למידה מאונכת (Orthogonal Learning, OL); מערך מאונך (Orthogonal Array, OA); מנגנון "אפקט השפמנון (Catfish Effect Mechanism); בעיות מיטוב כלליות (Global Optimization Problems); OCFPA
תקציר
4. ...
295.00 ₪
295.00 ₪
FPA הוא שיטת מיטוב חדשנית המבוססת על התנהגויות של פרחים בשעת האבקתם. אולם יש חסרונות המגבילים את שימושה לפתרון בעיות הנדסיות, כגון נטייה להתכנסות מוקדמת (Premature convergence) ויכולת ניצול (exploitation) מוגבלת. אפשר לשפר את יכולת המיטוב של האלגוריתם, יש לשלב במפעיל (operator) ההאבקה המקומי שיטת למידה מאונכת (OL) המבוססת על תכנון ניסוי מאונך (OED). ה-OED יכול לנבא את הצירוף המיטבי של רמות הגורמים ע"י בניית קבוצת מבחן קטנה אך מייצגת על יסוד מערך מאונך. התכונות האלה של ה-OED מאפשרת ל-OL להפיק פתרון מבטיח מכמה מקורות של מידע נסיוני, המכוונים את האוכלוסייה לחפש פתרון בכיוון הגיוני אפשרי. כמו כן, היא מתמקדת באמצעות מנגנון "אפקט השפמנון", על הפרטים הגרועים ביותר בתהליך האיטרציה. המנגנון הזה בוחן מידע חדש בעל ערך ושומר על מגוון עדיף של האוכלוסייה. תוצאות הניסוי בפונקציות הבחינה (benchmark functions) מוכיחות שהאלגוריתם משפר במידה ניכרת את ביצועי ה-FPA המקורי וכושר התחרות שלו גדול מזה של כמה אלגוריתמים משוכללים.
1. מבוא
המדע המודרני מציב אתגרים גדולים בפני שיטות המיטוב המקובלות, כי מאפייני בעיות המיטוב לא-רציפים, לא-לינאריים, מרובי משתנים בלתי תלויים (multivariate) או בלתי קמורים (nonconvex). האלגוריתמים הנוכחיים של אינטליגנציית הנחיל (Swarm intelligence) הם דרכים יעילות לפתרון בעיות מיטוב מורכבות. רוב האלגוריתמים האלה פותחו כחיקוי של דפוסי חיפוש מזון או נדידה של בעלי חיים, או על יסוד תורת האבולוציה. כאלו הם
1. האלגוריתם הגנטי (GA);
2. מיטוב נחיל החלקיקים (PSO);
3. האבולוציה הדיפרנציאלית (DE);
4. ...
295.00 ₪
295.00 ₪