Cocomo II
Cocomo II (COnstructive COst MOdel II) הוא מודל עלויות קונסטרוקטיבי השני, הוא מודל אלגוריתמי הנועד להערכת עלויות, מאמץ ותכנון זמנים, בעת תכנון של פיתוח תוכנה חדשה. המודל משתמש בנוסחת נסיגה בסיסית עם פרמטרים שנגזרו מפרויקטי עבר ומהפרויקט העכשווי. פותח על ידי בארי בם, פרופסור בהנדסת תוכנה, בעל תואר דוקטור במתמטיקה ובעל תרומה רבה לתחום הנדסת התוכנה. מבין פיתוחיו נמנים: Wideband Delphi, COCOMO.
היסטוריה
עריכהCocomo II פותח לראשונה בשנת 1997 ופורסם בספרו של בארי בוהם "Software Cost Estimation With COCOMO II" בשנת 2000. המודל הוא פיתוח של המודל הקודם Cocomo81 שפורסם בשנת 1981 בספרו של בארי בוהם "Software Engineering Economics". ישנם מספר טכניקות הערכה מקובלות ביניהן:
- מודל עלויות אלגוריתמי
- שיפוט על ידי מומחים
- הערכה באמצעות דמיון
- חוק פרקינסון
- עלות לניצחון- Pricing to win
Cocomo II נמנה אחד מבין המודלים האלגוריתמיים.
מודל זה פותח בעקבות ההתפתחות הטכנולוגית, כאשר שיטות הפיתוח והשימוש בתוכנות השתנו משמעותית, בין השינויים העיקריים:
- מעבר מעיבוד במהלך הלילה במחשב מרכזי באצווה לעיבוד מיידי און-ליין במחשב אישי.
- שימוש גובר בשימוש בתוכנות קיימות ופיתוח תוכנות חדשות באמצעות תוכנות מדף.
- השקעה רבה יותר בעיצוב וארגון תהליך הפיתוח של התוכנה, מאשר בפיתוח התוכנה עצמה.
תתי המודלים
עריכהלמעשה המודל Cocomo II מורכב משלושה תתי מודלים:
- Application-Composition Model- מודל יצירת האפליקציה
מודל המערב את המאמץ ליצירת אב טיפוס המיועד לפתרון בעיות מורכבות כגון- ממשק משתמש, ביצועים או בגרות הטכנולוגיה. המודל מבוסס על application points (לדוגמה- מספר המסכים השונים במערכת). הנחת הבסיס היא שהמערכת נוצרה מקוד שכבר היה קיים בעבר.
- Early Design Model- מודל עיצוב מוקדם
בדיקה של ארכיטקטורות חלופיות אפשריות או אסטרטגיות של פיתוח אינקרמנטלי. בשלב זה עדיין אין מספיק ידע כדי להעריך עלויות. משתמשים בו לאחר שהדרישות כבר הוגדרו אך שלב העיצוב לא התחיל עדיין או נמצא רק בשלבי התחלה.
- Post-Architecture Model- מודל שלאחר הארכיטקטורה
הערכה של גודל התוכנה יכולה להעשות לאחר שהדרישות כבר הוגדרו והפרויקט מוכן לפיתוח. כך יש יותר מידע על הקלטים במערכת וניתן לעשות הערכת עלות מדויקת יותר
הנוסחה
עריכהבמודל COCOMO II המאמץ נמדד כ (PM) כמות הזמן שבן אדם אחד מקדיש עבור פרויקט פיתוח תוכנה-בחודש אחד. מספר זה הוא ללא חופשות וחגים, אך כן כולל סופי שבוע.
- הנוסחה הבסיסית של COCOMO II:
- Effort Applied (E) = A(Size)B [person-month]s
- Size= הערכת גודל התוכנה, ביחידות של KSLOC, כמות שורות הקוד הנדרשת באלפים (תלוי בשפת התכנות).
יכול להיות גם כהערכה של (unadjusted function points (UFP לאחר המרה לשורות קוד וחילוק ב-1000.
- Effort Factor = A -קבוע, גורם התאמת המאמץ (לפי סוג הפרויקט).
- Scaling Factor = B - גורם מעריכי המסביר חיסכון או חוסר חיסכון. אם B<1 הפרויקט מציג יתרונות לגודל- כאשר גודל המוצר הוכפל ב-2, כמות המאמץ גדלה בפחות מכך. אם B=1 זהו מצב מאוזן, זהו מצב שכיח עבור פרויקטים קטנים ומשתמשים ב Application-Composition Model במצב זה. אם B>1 ישנו חיסרון לגודל, בדרך כלל בשל צמיחה של פרויקטים גדולים.
נוסחאות מורכבות יותר יכולות להתחשב במידע רחב יותר, כמו: יכולות המתכנת, ניסיון בפלטפורמה, ניסיון בכלים, מורכבות המוצר, לכידות הצוות, גמישות תכנותית ופרמטרים רבים נוספים.
מתי נשתמש במודל
עריכה- כאשר החלטה פיננסית או כלכלית תלויה בפיתוח תוכנה
- תכנון זמנים ותקציבים של פרויקט
- כאשר קיימת החלטה לגבי העלויות של כל חלק בפרויקט
- כאשר קיימת החלטה מתי לפתח/לעדכן תוכנה
לקריאה נוספת
עריכה- בארי בוהם, Software Engineering Economics, 1997
- בארי בוהם, Software Cost Estimation With COCOMO II, 2000
- פרק על המודל מתוך הספר Software Engineering 7
- COCOMO II Model Definition Manual מתוך Center for Systems and Software Engineering
קישורים חיצוניים
עריכה- Cocomo II בעברית
- cocomo in NASA
- Center for Systems and Software Engineering
- מחשבון Cocomo(הקישור אינו פעיל) באתר של Naval Postgraduate School
- Costar program תוכנה לחישוב עלויות ומאמץ
- COCOMO II