วันศุกร์, ตุลาคม 22, 2553

Output ที่ได้จากกระบวนการ requirements validation ได้แก่

1.รายการปัญหา (Problem list)

เป็นส่วนที่รายงานปัญหาที่ได้มาจากเอกสารความต้องการ (Requirements document) ซึ่งเราควรจะจัดเรียงปัญหาต่างๆ ที่ได้ออกมาเป็นหมวดหมู่

2.ข้อตกลงในกิจกรรม (Agreed actions)

ส่วนนี้เป็นลิสต์ของการกระทำต่างๆ ที่จะตอบสนองต่อปัญหาที่เราเจอในกระบวนการ ซึ่งไม่เสมอไปที่จะมีการกระทำต่างๆกับแก้ปัญหาแบบ 1: 1 บางปัญหาอาจจะต้องใช้หลายการกระทำเพื่อที่จะทำให้สามารถแก้ปัญหาได้

Input ของระบบ Requirements validation process มีดังนี้

1.เอกสารความต้องการ (Requirements document)

ส่วนนี้ควรจะเป็นเอกสารที่สมบูรณ์แล้วซึ่งถูกจัดการให้อยู่ในรูปแบบที่ตรงมาตรฐานขององค์กรนั้น

2.มาตรฐานขององค์กร (Organizational standards)

กระบวนการตรวจสอบต้องสอดคล้องกับมาตรฐานขององค์กร ดังนั้น มาตรฐานขององค์กรจึงเป็นส่วนหนึ่งของ input ของกระบวนการนี้

3.ความรู้ที่เกี่ยวกับองค์กร (Organizational knowledge)

นี่ไม่ได้เป็น input ที่สามรถสัมผัสได้ แต่เป็นส่วนที่สำคัญ บุคคลที่ทำกระบวนการ requirements validation ควรจะมีความรู้ในองค์กรที่จะใช้ระบบที่พัฒนาด้วยเพื่อประโยชน์ในการตรวจสอบความถูกต้อง

การทวนสอบความต้องการ (Requirements Validation)

เป็นขั้นตอนสุดท้ายในกระบวนการ Requirements engineering ซึ่งมีเป้าหมายคือ เพื่อทำให้ความต้องการที่เราเก็บมาถูกต้อง โดย requirements validation จะมุ่งเน้นไปในทางการตรวจสอบ เอกสารความต้องการ (requirements document) ซึ่งรวบรวมความต้องการทุกอย่างของระบบและ ความไม่สมบูรณ์พร้อมทั้งความซ้อนทับของความต้องการถูกกำจัดไปทั้งหมดแล้ว นอกจากนี้การทำ requirements validation เราควรมีคำถามคำถามหนึ่งอยู่ในใจเสมอ นั่นคือ เราได้ความต้องการที่ถูกต้องแล้วหรือยัง เกณฑ์การตรวจสอบความต้องการมี 4 ขั้นตอนคือ    

1.ความถูกต้อง(Validity)
ความต้องการต่าง ๆที่ลูกค้าระบุในเอกสารต้องตรงกับสิ่งที่ลูกค้าต้องการจริงๆ

2. ความสอดคล้อง (Consistency)
ความต้องการต่างๆ จะต้องไม่ขัดแย้งซึ่งกันและกัน

3. ความสมบูรณ์ (Completeness)
รายละเอียดต่าง ๆที่เป็นความต้องการและเงื่อนไขกฎเกณฑ์ทั้งหมด จะต้องถูกระบุอยู่ในเอกสาร

4. ความเป็นจริง (Realism)
ในทางปฏิบัติไม่มีทางใดที่จะบอกได้ว่า ความต้องการต่างๆ ทีระบุในข้อกำหนดสามารถนำมาพัฒนาระบบได้จริง

เอกสารความต้องการ

เอกสารความต้องการประกอบไปด้วย 2 ส่วนคือ

requirements definition และ requirements specification โครงสร้างที่ดีควรจัดแบ่งรายละเอียดออกเป็นบทๆ และมีการอธิบายศัพท์ต่างๆ ที่ใช้ในเอกสาร

บทที่

รายละเอียด

Introduction


 

Glossary


 

System model


 

Functional requirement definition

Non- Functional requirement definition

System evolution


 

Requirement specification

- อธิบายถึงสิ่งต่างๆ ที่จะมีในระบบ และมีการระบุประโยชน์ที่ได้รับ, หน้าที่ต่างๆ ที่มีในระบบ,เป้าหมายของการพัฒนา, วิธีการหรือยุทธวิธีที่จะนำระบบไปใช้ในองค์กร


 

- อธิบายศัพท์ทางเทคนิคที่มีในเอกสาร ซึ่งในการเขียนคำอธิบายจะตั้งสมติฐานว่าผู้อ่านประกอบด้วยผู้มีและไม่มีประสบการณ์


 

- ตัวแบบระบบซึ่งแสดงความสัมพันธ์ของระบบกับสภาพแวดล้อมภายนอก ว่าติดต่อกับองค์กรหรือระบบใดบ้าง มีกระบวนการทำงานอย่างไร

- อธิบายบริการต่างๆ ที่ผู้ใช้ต้องการมีในระบบใหม่ ซึ่งอาจใช้ภาษาธรรมชาติ, แผนภูมิ หรือสัญลักษณ์ที่ผู้ใช้สามารถอ่านเข้าใจได้ง่าย


 

-รายละเอียดข้อจำกัดและเงื่อนไขต่างๆ ที่ระบบต้องพัฒนา เช่น เวลา ขนาดหน่วยความจำ

- รายละเอียดของสมมติฐานที่คาดว่าอาจมีการเปลี่ยนแปลงในระบบ เช่น ความต้องการ, วิวัฒนาการของฮาร์ดแวร์


 

- ระบุรายละเอียด Functional requirement definition specification

เอกสารความต้องการ (Requirements document)

เอกสาร requirements document ไม่ได้เป็นเอกสารที่ใช้ในการออกแบบระบบซอฟต์แวร์ ดังนั้นจึงไม่มีการระบุรายละเอียดวิธีการออกแบบว่าต้องทำอย่างไร หากแต่เป็นสิ่งที่ระบุว่าควรมีอะไรบ้างในซอฟต์แวร์ที่กำลังพัฒนา เอกสารชุดนี้เป็นเครื่องมือสำหรับติดตามการดำเนินงานระหว่างช่วงการค้นหาความต้องการและการออกแบบในขั้นสุดท้าย ซึ่งหมายความว่าความต้องการต่างๆ จะถูกนำมาแปลงเป็นข้อมูลที่ใช้ในการออกแบบระบบและเขียนโปรแกรม

หลักการเขียนรายละเอียดที่อยู่ในเอกสารชุดนี้คือ ต้องมีความสมบูรณ์และข้อมูลต่างๆ ในเอกสารต้องไม่ขัดแย้งกัน คุณสมบัติที่ควรมีใน requirements document คือ

1.ควรมีพฤติกรรมภายนอกที่เกี่ยวข้องกับระบบ

2.ควรมีการระบุเงื่อนไขหรือข้อจำกัดภายในระบบ

3.ควรอยู่ในรูปแบบที่ง่ายสำหรับการแก้ไข

4.สามารถนำมาเป็นเครื่องมืออ้างอิงในระบบ

5.ควรมีการบันทึกรายละเอียดขั้นตอนการทำงานที่เกิดขึ้น รวมถึงวัฏจักรการพัฒนา

6.ควรมีการระบุวิธีการทำงานของระบบ เมื่อมีเหตุการณ์ที่ไม่ต้องการเกิดขึ้น

กระบวนการต่อรอง (requirements negotiation process)

ขั้นตอนวิธีของ กระบวนการต่อรอง (requirements negotiation process) มีดังนี้คือ

1.การตัดสินใจในความต้องการ (Requirements discussion)

ความต้องการที่เป็นปัญหาจะต้องนำไปปรึกษากับผู้เกี่ยวข้องในระบบ ให้พวกเขาได้บ่งบอกถึงความต้องการนั้นๆ ในแง่มุมของเขาให้เราเข้าใจ

2.ลำดับความสำคัญของความต้องการ (Requirements prioritization)

ความต้องการที่ขัดแย้งกัน จะถูกจัดลำดับความสำคัญ เพื่อที่จะกำหนดความต้องการวิกฤต เพื่อช่วยในกระบวนการตัดสินใจ

3.ข้อตกลงของความต้องการ (Requirements agreement)

การวิเคราะห์และต่อรองความต้องการ (Requirements analysis and negotiation)

เป้าหมายของการวิเคราะห์ความต้องการของผู้ใช้ก็คือ เพื่อที่จะค้นหาปัญหาใน เอกสารความต้องการต้นแบบ (draft requirements document) ขณะดำเนินการวิเคราะห์ความต้องการต่างๆ นักวิเคราะห์ต้องพยายามทำความเข้าใจกับปัญหาต่างๆ ขององค์กร

ขั้นตอนต่างๆ ของ requirements analysis process จะมีกิจกรรมที่ต้องดำเนินการซ้ำไปซ้ำมาจนกระทั่งได้ข้อมูลที่ถูกต้องและชัดเจนที่สุด ซึ่งขั้นตอนนี้มีกิจกรรมต่างๆ ดังนี้


 

1. การตรวจสอบความต้องการ (Necessity checking)

สิ่งที่จำเป็นสำหรับความต้องการต่างๆ จะถูกวิเคราะห์ ซึ่งในบางกรณี ความต้องการบางอย่างอาจจะไม่ได้เกี่ยวข้องกับเป้าหมายทางธุรกิจขององค์กร


 

2.การตรวจสอบความสอดคล้องและสมบูรณ์ของความต้องการ (Consistency and completeness checking)

ความต้องการจะถูก ตรวจสอบ(cross-checked) สำหรับ ความสอดคล้องและความสมบูรณ์ ความสอดคล้องหมายความว่าจะต้องไม่มีความต้องการใดที่ขัดแย้งกัน ส่วนความสมบูรณ์หมายความว่า จะต้องไม่มีบริการหรือข้อกำหนดใดๆ ตกหล่นหรือขาดหายไป


 

3. การตรวจสอบความเป็นไปได้ (Feasibility checking)

ความต้องการจะถูกตรวจสอบ เพื่อให้แน่ใจว่า โครงการสามารถจะดำเนินการไปได้ ภายใต้งบประมาณ และ เวลาที่กำหนดไว้

Requirements elicitation process

Requirements elicitation process ประกอบไปด้วยกิจกรรมสำคัญ 4 อย่างได้แก่

1. การต้องจุดมุ่งหมาย (Objective setting)

    วัตถุประสงค์ขององค์กร ซึ่งประกอบไปด้วย เป้าหมายหลักของธุรกิจ และการบรรยายถึงปัญหาที่ต้องการนำมาแก้ไข และข้อจำกัดของระบบเช่น งบประมาณ เวลา ควรจะถูกกำหนดออกมาในขั้นตอนนี้

2. การรู้ข้อมูลเบื้องหลังของระบบ (Background knowledge acquisition)

    นี่เป็นขั้นตอนที่สำคัญมากๆ ซึ่งเป็นขั้นตอนที่ Requirements engineering จะใช้รวบรวมและเข้าใจในข้อมูลพื้นฐานต่างๆ ของระบบ และส่วนนี่ยังใช้บอกด้วยว่า ส่วนในขององค์กรที่ระบบของเราจะถูกนำไปใช้, ข้อมูล application domain ของระบบ และ ระบบที่มีอยู่แล้วในองค์กรซึ่งกำลังใช้อยู่และระบบที่จะเอาระบบที่เราพัฒนาเข้าไปแทนที่

3. การมีความรู้เกี่ยวกับภาพรวมขององค์กร (Knowledge organization)

    ข้อมูลและองค์ความรู้ทั้งหมดที่ถูกเก็บมาใน 2 ส่วนที่แล้วจะถูกทำให้เป็นระบบและจัดเรียง ซึ่งได้แก่ ผู้ที่มีส่วนเกี่ยวข้องในระบบ และบทบาทของบุคคลเหล่านั้น เรียงลำดับความสำคัญเป้าหมายขององค์กร และตัดdomain knowledge ที่ไม่เกี่ยวข้องโดยตรงกับความต้องการของระบบ

4. การรวบรวมความต้องการของผู้มีส่วนได้ส่วนเสียกับระบบ (Stakeholder requirements collection)

    นี่เป็นส่วนที่เรียกว่าการดึงข้อมูลออกมาจริงๆ ซึ่งรวมไปทั้งการปรึกษาผู้ที่เกี่ยวข้องในระบบเกี่ยวกับสิ่งที่บุคคลเหล่านั้นต้องการและการได้มาซึ่งความต้องการต่างๆ ที่มาจาก application domain และจากองค์กรที่ต้องการระบบของเราไปใช้งาน

    

    ผลลัพธ์ของ requirements elicitation process
ควรจะออกมาในรูปแบบของเอกสารความต้องการต้นแบบ (draft requirements document) ที่บรรยายถึงความต้องการของระบบ ซึ่งต่อไปเอกสารนี้จะถูกนำไปวิเคราะห์ เพื่อที่จะค้นหาปัญหาและข้อขัดแย้งของความต้องการต่างๆ ของผู้ใช้ ปัญหาการขัดแย้งของความต้องการ กับปัญหาการทับซ้อนกันของความต้องการเป็นปัญหาที่ไม่สามารถหลบเลี่ยงได้ ดังนั้นจึงต้องมีขัดต้องการต่อรอง เพื่อที่จะแก้ปัญหาดังกล่าวเพิ่มเติมอีกด้วย

องค์ประกอบของ Requirements elicitation ได้

1.ความเข้าใจในขอบเขตของแอปพลิเคชัน (Application domain understanding)

เป็นการทำความเข้าใจเกี่ยวกับขอบเขตหัวข้อของระบบที่เราจะพัฒนา ตัวอย่างเช่นถ้าเราจะพัฒนาระบบจะทำอะไร มีขอบเขตอะไรบ้าง

2.ความเข้าใจในปัญหา (Problem understanding)

เราต้องทำความเข้าใจใน รายละเอียดของปัญหาของลูกค้าที่เราต้องใช้ระบบของเรามาจัดการนั้น ต้องเข้าใจว่าปัญหาหรืออุปสรรคใดๆ ในระบบธุรกิจหรืองานที่ต้องการนำเอาระบบคอมพิวเตอร์ไปแก้ไข คืออะไร

3.เข้าใจในธุรกิจหรือระบบที่ศึกษาอยู่ (Business understanding)

เราต้องเข้าใจว่า ระบบจะทำการปฏิสัมพันธ์ และมีผลต่อระบบธุรกิจในแต่ละส่วนอย่างไร นอกจากระบบจะสามรถช่วยเหลือเป้าหมายในทางธุรกิจของบริษัททั้งหมดได้อย่างไร

4.ความเข้าใจความต้องการ และเงื่อนไขของผู้มีส่วนได้เสียในระบบ (Understanding the needs and constraints of system stakeholders)

ในระบบมีผู้เกี่ยวข้องหลายฝ่าย แต่ละฝ่ายต้องการอะไร มีเงื่อนไขอะไร

การสกัดความต้องการ (Requirements elicitation)

    ในขั้นตอนนี้เราจะสามารถทราบความต้องการต่างๆ โดยผู้พัฒนาระบบต้องไปปรึกษากับลูกค้า จากเอกสารของระบบ ความรู้ต่างๆ ในหัวข้อที่เราจะศึกษา การให้บริการของระบบที่เราจะพัฒนา ความต้องการของประสิทธิภาพของระบบ ข้อจำกัดทางด้านฮาร์ดแวร์ เพื่อที่จะทราบถึงแนวทางในการแก้ปัญหา

Requirements elicitation เป็นส่วนที่สำคัญมาก หากเราไม่สามารถทราบถึงความต้องการที่แท้จริงของลูกค้าแล้ว เมื่อเราพัฒนาระบบออกมา อาจทำให้ลูกค้าไม่พอใจในตัวระบบ

วันพฤหัสบดี, ตุลาคม 21, 2553

วิศวกรรมความต้องการคืออะไร (Requirements engineering )

    การรวบรวมข้อมูลความต้องการต่างๆ ระบบ ไม่ว่าจะเป็น ข้อกำหนดหรือความต้องการต่าง ๆ ของผู้ใช้งาน เอกสารข้อมูล ฮาร์ดแวร์ ข้อบังคับขององค์กร รวมทั้งกฎหมาย ในรูปแบบของ "Engineering" ซึ่งคำว่า "Engineering" ในที่นี้หมายถึง เป็นระบบ และมีการกระทำแบบซ้ำ RE มีความคล้ายคลึงหลายอย่างกับ System Analysis ในหลักการแล้ว System Analysisจะใช้สำหรับวิเคราะห์ ระบบธุรกิจซึ่งจะเจาะจงไปในทางระบบธุรกิจมากกว่าแต่ RE จะเจาะจงทั้งในระบบธุรกิจและระบบคอมพิวเตอร์ด้วย


 

วิศวกรรมซอฟต์แวร์หลักการพื้นฐานของเจ็ด

1 ใช้ชีวิตรอบแบ่งวางแผนการจัดการที่เข้มงวด

ถูกค้นพบโดยสถิติในโครงการซอฟต์แวร์สำเร็จประมาณครึ่งหนึ่งเกิดจากการวางแผนไม่ดีเกิดการจัดตั้งแผนเสียงสามารถเห็นเป็นหลักการพื้นฐานแรกคือการเรียนรู้บทเรียนของรุ่นก่อนของเรานำมา ในการพัฒนาซอฟต์แวร์และการบำรุงรักษาวงจรชีวิตยาวต้องดำเนินการทำงานของคุณสมบัติต่างๆ นี้หมายถึงหลักการพื้นฐานที่ควรวงจรชีวิตของซอฟต์แวร์แบ่งออกเป็นหลายขั้นตอนและสอดคล้องกันดีพัฒนาแผนการทำงานได้และอย่างเคร่งครัดตามแผนพัฒนาซอฟต์แวร์ที่เหมาะสมและบำรุงรักษาประสิทธิภาพการจัดการ Boehm เชื่อว่าซอฟต์แวร์วงจรชีวิตทั้งหมดจะต้องพัฒนาและเข้มงวดหกแผนการซึ่งร่างแผนโครงการ, เหตุการณ์สำคัญแผนการ, แผนควบคุมโครงการแผนควบคุมสินค้าแผนการตรวจสอบการดำเนินงานและวางแผนการบำรุงรักษา ระดับต่างๆของการจัดการจะต้องเคร่งครัดตามแผนการเล่นส่วนหนึ่งของเขาในการจัดการการพัฒนาซอฟต์แวร์และงานบำรุงรักษาจะต้องไม่ได้รับผลกระทบจากลูกค้าหรือเจ้าหน้าที่ระดับสูงของการเดินทางไม่ได้รับอนุญาตจากตาราง

2 ยืนยันในระยะการประเมิน

มาแล้วรู้จักการประกันคุณภาพซอฟต์แวร์ไม่สามารถรอจนกว่าขั้นตอนการเขียนโปรแกรมเพิ่มเติม กล่าวว่าอย่างน้อยสองสาเหตุ : ก่อนที่ส่วนใหญ่ข้อผิดพลาดเกิดจากการเข้ารหัสเช่น Boehm และอื่น ๆ ตามสถิติข้อผิดพลาดการออกแบบคิด 63% ของความผิดพลาดซอฟต์แวร์เข้ารหัสเพียง 37%; ข้อผิดพลาดที่สองพบ คืนมากขึ้นด้วยการแก้ไขค่าใช้จ่ายสูง ดังนั้นในขั้นตอนการตรวจสอบทุกอย่างเคร่งครัดเพื่อตรวจหาซอฟต์แวร์ที่พัฒนาผิดพลาดการเป็นหลักการสำคัญที่ต้องติดตาม

3 การดำเนินการควบคุมสินค้าที่เข้มงวด

ในกระบวนการพัฒนาซอฟต์แวร์ไม่ควรยุ่งเกี่ยวกับความต้องการความต้องการเปลี่ยนแปลงต้องมักจะต้องจ่ายราคาที่สูงขึ้น แต่ในกระบวนการการพัฒนาซอฟต์แวร์จำเป็นต้องเปลี่ยนแปลงแน่นอนเนื่องจากมีการเปลี่ยนแปลงในสภาพแวดล้อมภายนอกเปลี่ยนแปลงที่สอดคล้องกันในผู้ใช้ต้องการ ต้องมีวัตถุประสงค์แน่นอนไม่ยากต่อความต้องการเปลี่ยนแปลงความต้องการของลูกค้า แต่ต้องพึ่งพาวิทยาศาสตร์และเทคโนโลยีการควบคุมสินค้าให้สอดคล้องกับความต้องการนี้ กล่าวคือเมื่อการเปลี่ยนแปลงของความต้องการเพื่อรักษาความสอดคล้องของส่วนประกอบในการกำหนดค่าต่างๆของผลิตภัณฑ์ที่ต้องควบคุมอย่างเคร่งครัดส่วนใหญ่การดำเนินการจัดการการตั้งค่าพื้นฐาน มาตรฐานที่เรียกว่ารู้จักกันเป็นค่าพื้นฐานซึ่งมีผลหลังจากระยะการประเมินองค์ประกอบการกำหนดค่าซอฟต์แวร์ (ผลิตในขั้นตอนต่างๆของเอกสารหรือโปรแกรม code) การจัดการการตั้งค่า Baseline เรียกว่าการควบคุมการเปลี่ยนแปลง : แก้ไขซอฟต์แวร์แนะนำ ๆ โดยเฉพาะที่เกี่ยวข้องกับการเปลี่ยนแปลงที่เสนอการกำหนดค่าพื้นฐานที่จะต้องประเมินตามกฎเข้มงวด, ได้รับการอนุมัติก่อนดำเนินการเปลี่ยนแปลง ไม่แน่นอนที่ต้องการแก้ไขซอฟต์แวร์ (ยังอยู่ในกระบวนการพัฒนาซอฟต์แวร์รวมทั้ง), ฟรีการเปลี่ยนแปลงใน

4 โดยใช้เทคนิคการเขียนโปรแกรมสมัยใหม่

เสนอแนวคิดของวิศวกรรมซอฟต์แวร์ตั้งแต่ต้นคนได้ใช้ในการศึกษาพลังงานหลักของเทคนิคการเขียนโปรแกรมใหม่ โครงสร้างเสนอเทคนิคการเขียนโปรแกรมปลาย 60 ของกลายเป็นคนส่วนใหญ่ยอมรับในการเขียนโปรแกรมเทคนิคขั้นสูง หลังจากการพัฒนาเพิ่มเติมความหลากหลายของการวิเคราะห์โครงสร้าง (SA) และการออกแบบโครงสร้าง (SD) เทคโนโลยี ปฏิบัติแสดงให้เห็นว่าการใช้เทคโนโลยีขั้นสูงสามารถปรับปรุงประสิทธิภาพของการพัฒนาซอฟต์แวร์ แต่ยังปรับปรุงประสิทธิภาพของซอฟต์แวร์การบำรุงรักษา

5 ผลควรตรวจสอบอย่างชัดเจน

ผลิตภัณฑ์ซอฟแวร์ต่างจากผลิตภัณฑ์ทางกายภาพก็ไม่สามารถดูสินค้าตรรกะ Zheng สัมผัส นักพัฒนาซอฟแวร์ (หรือการพัฒนาทีมงาน) สามารถดูความคืบหน้าของงานและยากจนยากที่จะแม่นยำในการวัดที่ให้ซอฟต์แวร์ผลิตภัณฑ์กว่ากระบวนการพัฒนากระบวนการพัฒนาผลิตภัณฑ์ยากในการประเมินผลและการจัดการ เพื่อปรับปรุงการแสดงผลของการพัฒนาซอฟต์แวร์การจัดการที่ดีขึ้นโครงการพัฒนาซอฟต์แวร์ควรเป็นไปตามวัตถุประสงค์และกรอกระยะเวลารวมบทบัญญัติของความรับผิดชอบขององค์กรพัฒนาและมาตรฐานสินค้าซึ่งจะทำให้ผลที่ได้จะชัดเจน Shencha

6 ทีมพัฒนาของเจ้าหน้าที่มีน้อย

หลักการพื้นฐานนี้หมายความว่าซอฟต์แวร์การพัฒนาทีมงานควรจะมีคุณภาพดี แต่จำนวนไม่มากเกินไป ทีมพัฒนาและมีผลต่อคุณภาพและปริมาณของผลิตภัณฑ์ซอฟต์แวร์ที่มีคุณภาพและประสิทธิภาพการพัฒนาปัจจัยสำคัญ การพัฒนาบุคลากรที่มีคุณภาพสูงที่มีประสิทธิภาพมากกว่าที่มีคุณภาพต่ำของประสิทธิภาพการพัฒนาบุคลากรอาจมีหลายครั้งครั้งสิบหลายสูงและซอฟต์แวร์ที่มีคุณภาพสูงที่พัฒนาโดยทีมงานของข้อผิดพลาดน้อยกว่าที่มีคุณภาพต่ำของซอฟต์แวร์ที่พัฒนาโดยทีมงานของข้อผิดพลาด นอกจากนี้กับทีมพัฒนาและเพิ่มจำนวนเป็นผลจากการแลกเปลี่ยนเพื่อหารือเกี่ยวกับปัญหาของค่าใช้จ่ายในการสื่อสารที่ยังเพิ่มขึ้นอย่างรวดเร็ว เมื่อทีมพัฒนาและจำนวน N, เส้นทางการสื่อสารเป็นไปได้ด้วย N (N? / บทความ FONT 1) / 2 จะเห็นเป็นเพิ่ม N จำนวนค่าใช้จ่ายในการสื่อสารจะเพิ่มขึ้นอย่างรวดเร็ว ดังนั้นทีมพัฒนาประกอบด้วยวิศวกรรมน้อย แต่เป็นหลักการพื้นฐานของซอฟต์แวร์

7 ต่อการรับรู้ต้องปรับปรุงการปฏิบัติงานวิศวกรรมซอฟต์แวร์

ตาม 6 หลักการพื้นฐานเราสามารถตามหลักการพื้นฐานของวิศวกรรมซอฟต์แวร์สมัยใหม่วิศวกรรมซอฟต์แวร์เพื่อให้บรรลุการผลิต แต่เหล่านี้หกหลักไม่สามารถรับประกันได้ว่ากระบวนการพัฒนาซอฟต์แวร์และการบำรุงรักษาให้ทันกับความก้าวหน้าเพื่อให้ทันกับเทคโนโลยี ความคืบหน้า l ดังนั้น Boehm ควรเสนอต่อการปรับปรุงการวิศวกรรมซอฟต์แวร์จำเป็นต้องได้รับการยอมรับสำหรับวิศวกรรมซอฟต์แวร์เป็นหลักการพื้นฐานของข้อ VII ตามหลักการนี้ไม่ควรใช้ความคิดริเริ่มเพื่อนำเทคโนโลยีซอฟต์แวร์ใหม่ แต่ยังให้ความสนใจอย่างต่อเนื่องรวมถึงประสบการณ์เช่นความคืบหน้าการรวบรวมข้อมูลและทรัพยากรที่ต้องใช้พิมพ์ผิดพลาดและรายงานปัญหาในการเก็บข้อมูลและอื่นๆ ข้อมูลเหล่านี้ไม่เพียง แต่สามารถใช้ในการประเมินผลกระทบของเทคโนโลยีซอฟต์แวร์ใหม่ แต่ยังสามารถใช้เพื่อระบุต้องเน้นการพัฒนาเครื่องมือซอฟต์แวร์และเทคโนโลยีควรจะให้ความสำคัญ,

Requirement Engineering

1.การจัดการโครงการ

  • เลือกวงจรการพัฒนาซอฟต์แวร์ที่เหมาะสม
  • แผนงานโครงการของข้อกำหนดแบบพื้นฐาน
  • การต่อรองใหม่เมื่อมีการเปลี่ยนแปลงข้อกำหนด
  • ทำเอกสารและจัดการความเสี่ยงที่เกี่ยวข้องกับข้อกำหนด
  • ติดตามความพยายามที่นำมาใช้ในการทำข้อกำหนด

2.วิธีปฏิบัติในการจัดการข้อกำหนด

  • กำหนดกระบวนการควบคุมการเปลี่ยนแปลงข้อกำหนด
  • ตั้งคณะกรรมการควบคุมการเปลี่ยนแปลง
  • วิเคราะห์ผลกระทบจากการเปลี่ยนแปลงข้อกำหนด
  • ติดตามการเปลี่ยนแปลงข้อกำหนดต่อผลิตภัณฑ์ที่กระทบทั้งหมด
  • สร้างเกณฑ์พื้นฐานและเวอร์ชันการควบคุมเอกสารข้อกำหนด
  • รักษาประวัติการเปลี่ยนแปลงข้อกำหนด
  • สืบค้นสถานะของข้อกำหนดแต่ละข้อ วัดความคงที่ของข้อกำหนด
  • ใช้เครื่องมือจัดการข้อกำหนด

3.การตรวจสอบข้อกำหนด

  • ตรวจสอบเอกสารข้อกำหนด
  • เขียนกรณีทดสอบจากข้อกำหนด
  • เขียนคู่มือผู้ใช้
  • กำหนดเกณฑ์การยอมรับ

4.การกำหนดรายละเอียดของข้อกำหนด

  • นำต้นแบบ SRS มาใช้
  • ระบุที่มาของข้อกำหนด
  • ใส่ชื่อให้ข้อกำหนดแต่ละข้อ
  • บันทึกกฎทางธุรกิจ
  • สร้าง Matrix ที่ติดตามข้อกำหนดได้


     

5.การหาข้อกำหนด

  • ระบุกระบวนการพัฒนาข้อกำหนด
  • เขียนวิสัยทัศน์และขอบเขตของโครงการ
  • ระบุระดับของผู้ใช้และลักษณะเฉพาะ
  • เลือกแชมป์ผลิตภัณฑ์ ของผู้ใช้แต่ละระดับ
  • สร้างกลุ่มของผู้ใช้ประเภทต่าง ๆ
  • ให้ตัวแทนของผู้ใช้ระบุ USE Case
  • คงระยะ JAD (Joint Application Development)
  • วิเคราะห์ขั้นตอนการทำงานของผู้ใช้
  • กำหนดคุณลักษณะทางกายภาพและข้อกำหนดที่ไม่มีหน้าที่เฉพาะต่าง ๆ
  • ตรวจสอบรายงานปัญหาอันเกิดจากระบบต่าง ๆ
  • การนำข้อกำหนดจากโครงการอื่นกลับมาใช้ใหม่

6.การจัดการข้อกำหนด

  • กำหนดพื้นฐานของข้อกำหนด
  • ตรวจสอบการเปลี่ยนแปลงของข้อกำหนดที่เสนอ และประเมินผลกระทบที่อาจเกิดขึ้นของการเปลี่ยนแปลงที่เสนอแต่ละข้อก่อนตัดสินใจอนุมัติ
  • รวบรวมการเปลี่ยนแปลงข้อกำหนดที่อนุมัติแล้วเข้าไว้ในโครงการในวิธีที่ควบคุมไว้
  • ทำแผนงานของโครงการให้ทันกับข้อกำหนด
  • ทำการตกลงใหม่ ๆ โดยใช้หลักการจากผลกระทบของข้อกำหนดที่เปลี่ยนแปลงที่ประเมินไว้แล้ว
  • ทำให้ข้อกำหนดแต่ละข้อเป็นไปตามการออกแบบ ซอร์สโค้ด และกรณีทดสอบที่สัมพันธ์กัน
  • สืบค้นสถานะของข้อกำหนดและการเปลี่ยนแปลงตลอดโครงการ

7.การพัฒนาข้อกำหนด

  • ระบุระดับของผู้ใช้ซอฟต์แวร์ที่คาดไว้
  • สอบถามความต้องการจากแต่ละคนซึ่งเป็นตัวแทนของผู้ใช้แต่ละระดับ
  • เข้าใจงานที่แท้จริงและวัตถุประสงค์ของผู้ใช้ รวมทั้งความต้องการทางธุรกิจของงานเหล่านั้น
  • วิเคราะห์ข้อมูลที่ได้รับจากผู้ใช้
  • แบ่งข้อกำหนดตามระดับของระบบเป็นระบบย่อยหลัก และจัดสรรส่วนของข้อกำหนดต่าง ๆเป็นส่วนประกอบของซอฟต์แวร์
  • เข้าใจความสำคัญของคุณลักษณะด้านคุณภาพที่เกี่ยวข้อง
  • จัดลำดับความสำคัญของงานแต่ละงานให้สำเร็จ
  • แปลความต้องการของผู้ใช้ที่รวบรวมได้ เป็นรายละเอียดและรูปแบบที่เป็นลายลักษณ์อักษร
  • ตรวจสอบรายละเอียดของข้อกำหนดเพื่อให้แน่ใจว่ามีความเข้าใจตรงกัน และเพื่อแก้ปัญหาก่อนที่กลุ่มพัฒนาต้องรับปัญหาไปแก้ไข

8.ลักษณะเฉพาะของข้อความของข้อกำหนด

  • ความสมบูรณ์
  • ความถูกต้อง
  • ความเป็นไปได้
  • ความจำเป็น
  • ลำดับความสำคัญ
  • ความชัดเจน
  • สามารถตรวจสอบได้

9.ความเสี่ยงจากกระบวนการของข้อกำหนดที่ไม่ดีพอ

  • ผู้ใช้ไม่ได้มีส่วนร่วมเพียงพอจึงนำไปสู่การไม่ยอมรับผลิตภัณฑ์
  • ข้อกำหนดของผู้ใช้ที่ค่อย ๆ เพิ่มขึ้น ทำให้คุณภาพของซอฟต์แวร์ลดลง
  • ข้อกำหนดที่คลุมเครือ
  • คุณลักษณะที่ไม่จำเป็น
  • รายละเอียดที่น้อยจะทำให้ขาดข้อกำหนดที่สำคัญ
  • การมองข้ามความจำเป็นในระดับผู้ใช้จะทำให้ลูกค้าไม่พอใจ
  • ข้อกำหนดที่อธิบายไม่สมบูรณ์ ทำให้ไม่สามารถวางแผนโครงการที่ถูกต้องและสืบค้นได้


 

10.ระดับของข้อกำหนด

มี 3 ระดับคือ

1. ข้อกำหนดทางธุรกิจ หมายถึง วัตถุประสงค์ระดับสูงของหน่วยงานหรือลูกค้าที่ขอให้มีอยู่ในระบบหรือซอฟต์แวร์ ซึ่งปรากฎในเอกสารที่อธิบายภาพรวมและขอบเขตของโครงการ

2. ข้อกำหนดของผู้ใช้ หมายถึง งานที่ผู้ใช้สามารถทำให้สำเร็จได้ด้วยซอฟต์แวร์ ซึ่งกล่าวถึงในกรณีที่ต้องนำมาใช้งาน หรือการอธิบายถึงสถานการณ์สมมติ (scenario)

3. ข้อกำหนดด้านฟังก์ชัน หมายถึง การทำงานของซอฟต์แวร์ที่ผู้พัฒนาสร้างไว้ในซอฟต์แวร์ เพื่อให้ผู้ใช้ทำงานได้สำเร็จ


 


 

วันพุธ, ตุลาคม 06, 2553

"Windows Live Essentials" (msnเวอร์ชั่นใหม่ล่าสุด)

ทำสิ่งต่างๆได้มากขึ้นกับ Windows ในคอมพิวเตอร์ของคุณได้มากขึ้นด้วยโปรแกรมฟรีจาก Microsoft สำหรับรูปถ่าย ภาพยนตร์ ข้อความด่วน อีเมล์ เครือข่ายการติดต่อ และอีกมากมาย

สามารถดาวน์โหลดได้ที่นี้นะครับ http://explore.live.com/windows-live-essentials?os=other