आवश्यकताओं के विश्लेषण: Difference between revisions

From Vigyanwiki
No edit summary
No edit summary
 
(3 intermediate revisions by 3 users not shown)
Line 1: Line 1:
{{Short description|Engineering process}}
{{Short description|Engineering process}}
{{broader|आवश्यकताएं इंजीनियरिंग}}
{{broader|आवश्यकताएं इंजीनियरिंग}}
Line 13: Line 12:
  | chapter = Chapter 2: Software Requirements  | chapter-url = http://www.computer.org/portal/web/swebok/html/ch2
  | chapter = Chapter 2: Software Requirements  | chapter-url = http://www.computer.org/portal/web/swebok/html/ch2
  | quote = It is widely acknowledged within the software industry that software engineering projects are ''critically vulnerable when these activities are performed poorly.
  | quote = It is widely acknowledged within the software industry that software engineering projects are ''critically vulnerable when these activities are performed poorly.
}}</ref> आवश्यकताओं को प्रलेखित, कार्रवाई योग्य, मापने योग्य, परीक्षण योग्य, पता लगाने योग्य, पहचानी गई व्यावसायिक आवश्यकताओं या अवसरों से संबंधित होना चाहिए, और प्रणाली डिज़ाइन के लिए पर्याप्त विवरण के स्तर तक परिभाषित किया जाना चाहिए। '''आवश्यकताओं को प्रलेखित, कार्रवाई योग्य, मापने योग्य, परीक्षण योग्य, पता लगाने योग्य, पहचानी गई व्यावसायिक आवश्यकताओं या अवसरों से संबंधित होना चाहिए, और प्रणाली डिज़ाइन के लिए पर्याप्त विवरण के स्तर तक परिभाषित किया जाना चाहिए।'''
}}</ref> आवश्यकताओं को प्रलेखित, कार्रवाई योग्य, मापने योग्य, परीक्षण योग्य, पता लगाने योग्य, पहचानी गई व्यावसायिक आवश्यकताओं या अवसरों से संबंधित होना चाहिए, और प्रणाली डिज़ाइन के लिए पर्याप्त विवरण के स्तर तक परिभाषित किया जाना चाहिए।


== अवलोकन ==
== अवलोकन ==
वैचारिक रूप से, आवश्यकताओं के विश्लेषण में तीन प्रकार की गतिविधियाँ सम्मिलित हैं ।
वैचारिक रूप से, आवश्यकताओं के विश्लेषण में तीन प्रकार की गतिविधियाँ सम्मिलित हैं ।
*आवश्यकताएं प्राप्त करना: ([[उदाहरण]] के लिए परियोजना चार्टर या परिभाषा), व्यवसाय प्रक्रिया प्रलेखन, और हितधारक [[साक्षात्कार]]। इसे कभी-कभी आवश्यकताएं एकत्र करना या आवश्यकताओं की खोज भी कहा जाता है।
*आवश्यकताएं प्राप्त करना: ([[उदाहरण]] के लिए परियोजना चार्टर या परिभाषा), व्यवसाय प्रक्रिया प्रलेखन, और हितधारक [[साक्षात्कार]]। इसे कभी-कभी आवश्यकताएं एकत्र करना या आवश्यकताओं की खोज भी कहा जाता है।
*रिकॉर्डिंग आवश्यकताएँ: आवश्यकताओं को विभिन्न रूपों में प्रलेखित किया जा सकता है, सामान्यतः सारांश सूची सहित और इसमें प्राकृतिक भाषा के आलेख ,उपयोग के स्थितियों , उपयोगकर्ता कहानी, प्रक्रिया विनिर्देश और डेटा मॉडल सहित विभिन्न प्रकार के मॉडल सम्मिलित हो सकते हैं।
*रिकॉर्डिंग आवश्यकताएँ: आवश्यकताओं को विभिन्न रूपों में प्रलेखित किया जा सकता है, सामान्यतः सारांश सूची सहित और इसमें प्राकृतिक भाषा के आलेख, उपयोग के स्थितियों, उपयोगकर्ता कहानी, प्रक्रिया विनिर्देश और डेटा मॉडल सहित विभिन्न प्रकार के मॉडल सम्मिलित हो सकते हैं।
* आवश्यकताओं का विश्लेषण: यह निर्धारित करना कि बताई गई आवश्यकताएं स्पष्ट, पूर्ण, अनुलिपित, संक्षिप्त, वैध, सुसंगत और स्पष्ट हैं, और किसी भी स्पष्ट संघर्ष को हल करना। विश्लेषण में आकार देने की आवश्यकताएं भी सम्मिलित हो सकती हैं।
* आवश्यकताओं का विश्लेषण: यह निर्धारित करना कि बताई गई आवश्यकताएं स्पष्ट, पूर्ण, अनुलिपित, संक्षिप्त, वैध, सुसंगत और स्पष्ट हैं, और किसी भी स्पष्ट संघर्ष को हल करती हैं। विश्लेषण में आकार देने की आवश्यकताएं भी सम्मिलित हो सकती हैं।


आवश्यकता विश्लेषण लंबी और बड़ी प्रक्रिया हो सकती है जिसके समय कई हल्का मनोवैज्ञानिक कौशल सम्मिलित होते हैं। नई प्रणालियाँ पर्यावरण और लोगों के बीच संबंधों को बदलती हैं, इसलिए सभी हितधारकों की पहचान करना, उनकी सभी आवश्यकताओं को ध्यान में रखना और यह सुनिश्चित करना महत्वपूर्ण है कि वे नई प्रणालियों के निहितार्थों को समझें। ग्राहक से आवश्यकताओं को पूरा करने के लिए विश्लेषक कई तकनीकों को नियोजित कर सकते हैं। इनमें परिदृश्यों का विकास (एजाइल सॉफ्टवेयर विकास में उपयोगकर्ता की कहानी के रूप में दर्शाया गया), उपयोग के स्थितियों की पहचान, कार्यस्थल अवलोकन या [[नृवंशविज्ञान]] का उपयोग, साक्षात्कार आयोजित करना, या [[फोकस समूह]] सम्मिलित हो सकते हैं (अधिक उपयुक्त रूप से आवश्यकता कार्यशालाओं के रूप में इस संदर्भ में नामित, या आवश्यकताओं की समीक्षा सत्र) और आवश्यकताओं की सूची बनाना है। [[प्रोटोटाइप]] का उपयोग एक उदाहरण प्रणाली विकसित करने के लिए किया जा सकता है जिसे हितधारकों को प्रदर्शित किया जा सकता है। जहाँ आवश्यक हो, विश्लेषक हितधारकों की सही आवश्यकताओं को स्थापित करने के लिए इन विधियों के संयोजन को नियोजित करेगा, चुकी व्यावसायिक आवश्यकताओं को पूरा करने वाली प्रणाली का उत्पादन किया जा सके। आवश्यकताओं की गुणवत्ता इन और अन्य विधियों के माध्यम से सुधारी जा सकती है
आवश्यकता विश्लेषण लंबी और बड़ी प्रक्रिया हो सकती है जिसके समय कई हल्का मनोवैज्ञानिक कौशल सम्मिलित होते हैं। नई प्रणालियाँ पर्यावरण और लोगों के बीच संबंधों को बदलती हैं, इसलिए सभी हितधारकों की पहचान करना, उनकी सभी आवश्यकताओं को ध्यान में रखना और यह सुनिश्चित करना महत्वपूर्ण है कि वे नई प्रणालियों के निहितार्थों को समझें। ग्राहक से आवश्यकताओं को पूरा करने के लिए विश्लेषक कई तकनीकों को नियोजित कर सकते हैं। इनमें परिदृश्यों का विकास (एजाइल सॉफ्टवेयर विकास में उपयोगकर्ता की कहानी के रूप में दर्शाया गया), उपयोग के स्थितियों की पहचान, कार्यस्थल अवलोकन या [[नृवंशविज्ञान]] का उपयोग, साक्षात्कार आयोजित करना, या [[फोकस समूह]] सम्मिलित हो सकते हैं (अधिक उपयुक्त रूप से आवश्यकता कार्यशालाओं के रूप में इस संदर्भ में नामित, या आवश्यकताओं की समीक्षा सत्र) और आवश्यकताओं की सूची बनाना है। [[प्रोटोटाइप]] का उपयोग उदाहरण प्रणाली विकसित करने के लिए किया जा सकता है जिसे हितधारकों को प्रदर्शित किया जा सकता है। जहाँ आवश्यक हो, विश्लेषक हितधारकों की सही आवश्यकताओं को स्थापित करने के लिए इन विधियों के संयोजन को नियोजित करेगा, चुकी व्यावसायिक आवश्यकताओं को पूरा करने वाली प्रणाली का उत्पादन किया जा सके। आवश्यकताओं की गुणवत्ता इन और अन्य विधियों के माध्यम से सुधारी जा सकती है
* दृश्य वांछित अंत-उत्पाद जैसे विज़ुअलाइज़ेशन और सिमुलेशन की अच्छी समझ को बढ़ावा देने वाले टूल का उपयोग करना।
* दृश्य वांछित अंत-उत्पाद जैसे विज़ुअलाइज़ेशन और सिमुलेशन की अच्छी समझ को बढ़ावा देने वाले टूल का उपयोग करना।
* टेम्प्लेट का लगातार उपयोग आवश्यकताओं को दस्तावेज करने के लिए मॉडल और टेम्पलेट्स का सतत समुच्चय तैयार करना।
* टेम्प्लेट का लगातार उपयोग आवश्यकताओं को दस्तावेज करने के लिए मॉडल और टेम्पलेट्स का सतत समुच्चय तैयार करना।
Line 32: Line 31:
लोगों या संगठनों (कंपनियों, मानक निकायों जैसी कानूनी संस्थाएं) की चर्चा के लिए [[हितधारक विश्लेषण]] देखें, जिनका प्रणाली में वैध हित है। वे प्रत्यक्ष या अप्रत्यक्ष रूप से इससे प्रभावित हो सकते हैं।
लोगों या संगठनों (कंपनियों, मानक निकायों जैसी कानूनी संस्थाएं) की चर्चा के लिए [[हितधारक विश्लेषण]] देखें, जिनका प्रणाली में वैध हित है। वे प्रत्यक्ष या अप्रत्यक्ष रूप से इससे प्रभावित हो सकते हैं।


1990 के दशक में एक प्रमुख नया जोर हितधारकों की पहचान पर केंद्रित था। यह तीव्रता से मान्यता प्राप्त है कि हितधारक विश्लेषक को नियुक्त करने वाले संगठन तक ही सीमित नहीं हैं। अन्य हितधारकों में सम्मिलित होंगे।
1990 के दशक में प्रमुख नया जोर हितधारकों की पहचान पर केंद्रित था। यह तीव्रता से मान्यता प्राप्त है कि हितधारक विश्लेषक को नियुक्त करने वाले संगठन तक ही सीमित नहीं हैं। अन्य हितधारकों में सम्मिलित होंगे।
* कोई भी जो प्रणाली संचालित करता है (सामान्य और रखरखाव नियंत्रक)
* कोई भी जो प्रणाली संचालित करता है (सामान्य और देखरेख नियंत्रक)
* कोई भी जो प्रणाली से लाभान्वित होता है (कार्यात्मक, राजनीतिक, वित्तीय और सामाजिक लाभार्थी)
* कोई भी जो प्रणाली से लाभान्वित होता है (कार्यात्मक, राजनीतिक, वित्तीय और सामाजिक लाभार्थी)
* प्रणाली को खरीदने या प्राप्त करने में सम्मिलित कोई भी व्यक्ति। बड़े पैमाने पर बाजार उत्पाद संगठन में, उत्पाद प्रबंधन, विपणन और कभी-कभी बिक्री उत्पाद के विकास को निर्देशित करने के लिए सरोगेट उपभोक्ताओं (बड़े पैमाने पर बाजार के ग्राहक) के रूप में कार्य करती है।
* प्रणाली को खरीदने या प्राप्त करने में सम्मिलित कोई भी व्यक्ति। बड़े पैमाने पर व्यापार उत्पाद संगठन में, उत्पाद प्रबंधन, विपणन और कभी-कभी बिक्री उत्पाद के विकास को निर्देशित करने के लिए सरोगेट उपभोक्ताओं (बड़े पैमाने पर व्यापार के ग्राहक) के रूप में कार्य करती है।
* संगठन जो प्रणाली के पहलुओं को विनियमित करते हैं । (वित्तीय, सुरक्षा और अन्य नियामक)
* संगठन जो प्रणाली के पहलुओं को विनियमित करते हैं । (वित्तीय, सुरक्षा और अन्य नियामक)
* प्रणाली के विरोध में लोग या संगठन (नकारात्मक हितधारक; [[दुरुपयोग का मामला|दुरुपयोग की स्थितियों]] भी देखें)
* प्रणाली के विरोध में लोग या संगठन (नकारात्मक हितधारक; [[दुरुपयोग का मामला|दुरुपयोग की स्थितियों]] भी देखें)
Line 42: Line 41:


=== संयुक्त आवश्यकताएं विकास (जेआरडी) सत्र ===
=== संयुक्त आवश्यकताएं विकास (जेआरडी) सत्र ===
आवश्यकताओं में अधिकांशतः क्रॉस-फ़ंक्शनल निहितार्थ होते हैं जो व्यक्तिगत हितधारकों के लिए अज्ञात होते हैं और अधिकांशतः हितधारक साक्षात्कार के समय चूक जाते हैं या अपूर्ण रूप से परिभाषित होते हैं। इन क्रॉस-फंक्शनल निहितार्थों को एक नियंत्रित वातावरण में जेआरडी सत्र आयोजित करके, एक प्रशिक्षित फैसिलिटेटर (बिजनेस विश्लेषक) द्वारा सुगम बनाया जा सकता है, जिसमें हितधारक आवश्यकताओं को पूरा करने, उनके विवरणों का विश्लेषण करने और क्रॉस-फंक्शनल निहितार्थों को उजागर करने के लिए चर्चा में भाग लेते हैं। समर्पित मुंशी को चर्चा का दस्तावेजीकरण करने के लिए उपस्थित होना चाहिए, व्यापार विश्लेषक को चर्चा को उस दिशा में ले जाने के लिए मुक्त करना चाहिए जो उपयुक्त आवश्यकताओं को उत्पन्न करता है जो सत्र के उद्देश्य को पूरा करते हैं।
आवश्यकताओं में अधिकांशतः क्रॉस-फ़ंक्शनल निहितार्थ होते हैं जो व्यक्तिगत हितधारकों के लिए अज्ञात होते हैं और अधिकांशतः हितधारक साक्षात्कार के समय चूक जाते हैं या अपूर्ण रूप से परिभाषित होते हैं। इन क्रॉस-फंक्शनल निहितार्थों को नियंत्रित वातावरण में जेआरडी सत्र आयोजित करके, प्रशिक्षित फैसिलिटेटर (बिजनेस विश्लेषक) द्वारा सुगम बनाया जा सकता है, जिसमें हितधारक आवश्यकताओं को पूरा करने, उनके विवरणों का विश्लेषण करने और क्रॉस-फंक्शनल निहितार्थों को उजागर करने के लिए चर्चा में भाग लेते हैं। समर्पित मुंशी को चर्चा का दस्तावेजीकरण करने के लिए उपस्थित होना चाहिए, व्यापार विश्लेषक को चर्चा को उस दिशा में ले जाने के लिए मुक्त करना चाहिए जो उपयुक्त आवश्यकताओं को उत्पन्न करता है जो सत्र के उद्देश्य को पूरा करते हैं।


जेआरडी सत्र संयुक्त अनुप्रयोग डिजाइन सत्र के समान हैं। पूर्व में, सत्र आवश्यकताओं को पूरा करते हैं जो डिजाइन को निर्देशित करते हैं, जबकि बाद वाले विशिष्ट डिजाइन [[सुविधा]]ओं को विशिष्ट आवश्यकताओं की संतुष्टि में प्रयुक्त करने के लिए प्रेरित करते हैं।
जेआरडी सत्र संयुक्त अनुप्रयोग डिजाइन सत्र के समान हैं। पूर्व में, सत्र आवश्यकताओं को पूरा करते हैं जो डिजाइन को निर्देशित करते हैं, जबकि बाद वाले विशिष्ट डिजाइन [[सुविधा]]ओं को विशिष्ट आवश्यकताओं की संतुष्टि में प्रयुक्त करने के लिए प्रेरित करते हैं।
Line 53: Line 52:
==== ताकत ====
==== ताकत ====


* आवश्यकताओं की एक चेकलिस्ट प्रदान करता है।
* आवश्यकताओं की चेकलिस्ट प्रदान करता है।
* परियोजना प्रायोजक(रों) और डेवलपर्स के बीच अनुबंध प्रदान करें।
* परियोजना प्रायोजक(रों) और डेवलपर्स के बीच अनुबंध प्रदान करें।
* बड़ी प्रणाली के लिए एक उच्च स्तरीय विवरण प्रदान कर सकता है जिससे निचले स्तर की आवश्यकताओं को प्राप्त किया जा सकता है।
* बड़ी प्रणाली के लिए उच्च स्तरीय विवरण प्रदान कर सकता है जिससे निचले स्तर की आवश्यकताओं को प्राप्त किया जा सकता है।


==== कमजोरियां ====
==== कमजोरियां ====
Line 62: Line 61:
* इस तरह की आवश्यकताएं सभी आवश्यकताओं को सूचीबद्ध करती हैं और इसलिए बहुत कम संदर्भ है। व्यापार विश्लेषक डिजाइन प्रलेखन के साथ आवश्यकताओं के लिए संदर्भ सम्मिलित कर सकता है।
* इस तरह की आवश्यकताएं सभी आवश्यकताओं को सूचीबद्ध करती हैं और इसलिए बहुत कम संदर्भ है। व्यापार विश्लेषक डिजाइन प्रलेखन के साथ आवश्यकताओं के लिए संदर्भ सम्मिलित कर सकता है।
** इस अमूर्तता का उद्देश्य यह वर्णन करना नहीं है कि आवश्यकताएं कैसे फिट होती हैं या एक साथ काम करती हैं।
** इस अमूर्तता का उद्देश्य यह वर्णन करना नहीं है कि आवश्यकताएं कैसे फिट होती हैं या एक साथ काम करती हैं।
** सूची आवश्यकताओं के बीच संबंधों और निर्भरताओं को प्रतिबिंबित नहीं कर सकती है। जबकि एक सूची प्रत्येक व्यक्तिगत आइटम को प्राथमिकता देना सरल बनाती है, एक आइटम को संदर्भ से बाहर निकालने से संपूर्ण उपयोग स्थितियों या व्यावसायिक आवश्यकता ख़राब हो सकती है।
** सूची आवश्यकताओं के बीच संबंधों और निर्भरताओं को प्रतिबिंबित नहीं कर सकती है। जबकि सूची प्रत्येक व्यक्तिगत आइटम को प्राथमिकता देना सरल बनाती है, आइटम को संदर्भ से बाहर निकालने से संपूर्ण उपयोग स्थितियों या व्यावसायिक आवश्यकता ख़राब हो सकती है।
** वांछित प्रणाली अनुप्रयोग के डिजाइन के निहितार्थों की अच्छी साझा समझ प्राप्त करने के लिए सूची हितधारकों के साथ सावधानीपूर्वक आवश्यकताओं की समीक्षा करने की आवश्यकता को प्रतिस्थापित नहीं करती है।
** वांछित प्रणाली अनुप्रयोग के डिजाइन के निहितार्थों की अच्छी साझा समझ प्राप्त करने के लिए सूची हितधारकों के साथ सावधानीपूर्वक आवश्यकताओं की समीक्षा करने की आवश्यकता को प्रतिस्थापित नहीं करती है।
* केवल सूची बनाने से इसकी पूर्णता की कारण, नहीं होता है। व्यापार विश्लेषक को पर्याप्त रूप से व्यापक सूची खोजने और एकत्र करने के लिए एक अच्छा विश्वास प्रयास करना चाहिए, और गायब आवश्यकताओं को इंगित करने के लिए हितधारकों पर विश्वास करना चाहिए।
* केवल सूची बनाने से इसकी पूर्णता की कारण, नहीं होता है। व्यापार विश्लेषक को पर्याप्त रूप से व्यापक सूची खोजने और एकत्र करने के लिए अच्छा विश्वास प्रयास करना चाहिए, और गायब आवश्यकताओं को इंगित करने के लिए हितधारकों पर विश्वास करना चाहिए।
* ये सूचियाँ हितधारकों और डेवलपर्स के बीच आपसी समझ की झूठी भावना उत्पन्न कर सकती हैं; व्यापार विश्लेषक अनुवाद प्रक्रिया के लिए महत्वपूर्ण हैं।
* ये सूचियाँ हितधारकों और डेवलपर्स के बीच आपसी समझ की झूठी भावना उत्पन्न कर सकती हैं; व्यापार विश्लेषक अनुवाद प्रक्रिया के लिए महत्वपूर्ण हैं।
* विकास और परीक्षण की प्रक्रिया प्रारंभ होने से पहले सभी कार्यात्मक आवश्यकताओं को उजागर करना लगभग असंभव है। यदि इन सूचियों को एक अपरिवर्तनीय अनुबंध के रूप में माना जाता है, तो विकास प्रक्रिया में उभरने वाली आवश्यकताएं विवादास्पद परिवर्तन अनुरोध उत्पन्न कर सकती हैं।
* विकास और परीक्षण की प्रक्रिया प्रारंभ होने से पहले सभी कार्यात्मक आवश्यकताओं को उजागर करना लगभग असंभव है। यदि इन सूचियों को अपरिवर्तनीय अनुबंध के रूप में माना जाता है, तो विकास प्रक्रिया में उभरने वाली आवश्यकताएं विवादास्पद परिवर्तन अनुरोध उत्पन्न कर सकती हैं।


==== आवश्यकता सूचियों का विकल्प ====
==== आवश्यकता सूचियों का विकल्प ====
Line 75: Line 74:
{{main|लक्ष्य मॉडलिंग}}
{{main|लक्ष्य मॉडलिंग}}


सर्वोत्तम अभ्यास आवश्यकताओं की संकलित सूची को केवल चिह्न के रूप में लेती हैं और बार-बार पूछती हैं कि क्यों? जब तक वास्तविक व्यावसायिक उद्देश्यों की खोज नहीं हो जाती है। हितधारक और विकासकर्ता इसके बाद यह मापने के लिए परीक्षण तैयार कर सकते हैं कि अब तक प्रत्येक लक्ष्य के किस स्तर को प्राप्त किया गया है। इस तरह के लक्ष्य विशिष्ट लेकिन अनिर्धारित आवश्यकताओं की लंबी सूची की तुलना में अधिक धीरे-धीरे बदलते हैं। एक बार महत्वपूर्ण, मापा लक्ष्यों का एक छोटा सेट स्थापित हो जाने के बाद, परियोजना के आधा होने से बहुत पहले वास्तविक हितधारक मूल्य देने के लिए तीव्रता से प्रोटोटाइप और लघु पुनरावृत्त विकास चरण आगे बढ़ सकते हैं।
सर्वोत्तम अभ्यास आवश्यकताओं की संकलित सूची को केवल चिह्न के रूप में लेती हैं और बार-बार पूछती हैं कि क्यों? जब तक वास्तविक व्यावसायिक उद्देश्यों की खोज नहीं हो जाती है। हितधारक और विकासकर्ता इसके बाद यह मापने के लिए परीक्षण तैयार कर सकते हैं कि अब तक प्रत्येक लक्ष्य के किस स्तर को प्राप्त किया गया है। इस तरह के लक्ष्य विशिष्ट लेकिन अनिर्धारित आवश्यकताओं की लंबी सूची की तुलना में अधिक धीरे-धीरे बदलते हैं। एक बार महत्वपूर्ण, मापा लक्ष्यों का छोटा सेट स्थापित हो जाने के बाद, परियोजना के आधा होने से बहुत पहले वास्तविक हितधारक मूल्य देने के लिए तीव्रता से प्रोटोटाइप और लघु पुनरावृत्त विकास चरण आगे बढ़ सकते हैं।


=== प्रोटोटाइप ===
=== प्रोटोटाइप ===
Line 81: Line 80:
{{main|सॉफ्टवेयर प्रोटोटाइप}}
{{main|सॉफ्टवेयर प्रोटोटाइप}}


प्रोटोटाइप कंप्यूटर प्रोग्राम है जो किसी अन्य कंप्यूटर प्रोग्राम के गुणों का भाग प्रदर्शित करता है, जिससे उपयोगकर्ता ऐसे अनुप्रयोगों की कल्पना कर सकते हैं जो अभी तक निर्मित नहीं हुआ है। प्रोटोटाइप का एक लोकप्रिय रूप [[नकली|मॉकअप]] है, जो भविष्य के उपयोगकर्ताओं और अन्य हितधारकों को यह जानने कि "प्रणाली कैसा दिखेगा" में सहायता करता है '''कि प्रणाली कैसा दिखेगा'''। प्रोटोटाइप डिजाइन निर्णय लेना सरल बनाते हैं, क्योंकि अनुप्रयोगों के निर्माण से पहले अनुप्रयोगों के पहलुओं को देखा और साझा किया जा सकता है। प्रोटोटाइप के प्रारंभ के साथ उपयोगकर्ताओं और डेवलपर्स के बीच संचार में बड़े सुधार अधिकांशतः देखे गए थे। अनुप्रयोगों के प्रारंभिक विचारों ने बाद में कम बदलाव किए और इसलिए समग्र मूल्य में अधिक कमी आई।  
प्रोटोटाइप कंप्यूटर प्रोग्राम है जो किसी अन्य कंप्यूटर प्रोग्राम के गुणों का भाग प्रदर्शित करता है, जिससे उपयोगकर्ता ऐसे अनुप्रयोगों की कल्पना कर सकते हैं जो अभी तक निर्मित नहीं हुआ है। प्रोटोटाइप का लोकप्रिय रूप [[नकली|मॉकअप]] है, जो भविष्य के उपयोगकर्ताओं और अन्य हितधारकों को यह जानने कि "प्रणाली कैसा दिखेगा" में सहायता करता है। प्रोटोटाइप डिजाइन निर्णय लेना सरल बनाते हैं, क्योंकि अनुप्रयोगों के निर्माण से पहले अनुप्रयोगों के पहलुओं को देखा और साझा किया जा सकता है। प्रोटोटाइप के प्रारंभ के साथ उपयोगकर्ताओं और डेवलपर्स के बीच संचार में बड़े सुधार अधिकांशतः देखे गए थे। अनुप्रयोगों के प्रारंभिक विचारों ने बाद में कम बदलाव किए और इसलिए समग्र मूल्य में अधिक कमी आई।  


प्रोटोटाइप फ्लैट आरेख (अधिकांशतः [[तार-फ्रेम मॉडल]] के रूप में संदर्भित) या संश्लेषित कार्यक्षमता का उपयोग करके काम करने वाले अनुप्रयोग हो सकते हैं। वायरफ्रेम विभिन्न प्रकार के [[ग्राफ़िक डिज़ाइन]] आरेख में बनाए जाते हैं, और अधिकांशतः डिज़ाइन से सभी रंगों को हटा देते हैं (अर्थात ग्रेस्केल रंग पैलेट का उपयोग करें) ऐसे स्थितियों में जहाँ अंतिम सॉफ़्टवेयर में ग्राफिक डिज़ाइन प्रयुक्त होने की आशा होती है। यह भ्रम को रोकने में सहायता करता है कि क्या प्रोटोटाइप अंतिम दृश्य रूप और अनुप्रयोगों के अनुभव का प्रतिनिधित्व करता है।  
प्रोटोटाइप फ्लैट आरेख (अधिकांशतः [[तार-फ्रेम मॉडल]] के रूप में संदर्भित) या संश्लेषित कार्यक्षमता का उपयोग करके काम करने वाले अनुप्रयोग हो सकते हैं। वायरफ्रेम विभिन्न प्रकार के [[ग्राफ़िक डिज़ाइन]] आरेख में बनाए जाते हैं, और अधिकांशतः डिज़ाइन से सभी रंगों को हटा देते हैं (अर्थात ग्रेस्केल रंग पैलेट का उपयोग करें) ऐसे स्थितियों में जहाँ अंतिम सॉफ़्टवेयर में ग्राफिक डिज़ाइन प्रयुक्त होने की आशा होती है। यह भ्रम को रोकने में सहायता करता है कि क्या प्रोटोटाइप अंतिम दृश्य रूप और अनुप्रयोगों के अनुभव का प्रतिनिधित्व करता है।  




Line 91: Line 90:
{{main|उदाहरण}}
{{main|उदाहरण}}


एक उपयोग स्थितियों में प्रणाली के लिए कार्यात्मक आवश्यकताओं के दस्तावेजीकरण के लिए एक संरचना है, जिसमें सामान्यतः सॉफ्टवेयर सम्मिलित होता है, चाहे वह नया हो या बदला जा रहा हो। प्रत्येक उपयोग स्थितियों परिदृश्यों का समुच्चय प्रदान करता है जो बताता है कि किसी विशिष्ट व्यावसायिक लक्ष्य को प्राप्त करने के लिए प्रणाली को मानव उपयोगकर्ता या अन्य प्रणाली के साथ कैसे इंटरैक्ट करना चाहिए। उपयोग के लिए सामान्यतः तकनीकी शब्दजाल से बचते हैं, इसके अतिरिक्त [[अंतिम उपयोगकर्ता]] या [[डोमेन विशेषज्ञ]] की भाषा को प्राथमिकता देते हैं। उपयोग के स्थिति अधिकांशतः आवश्यकता इंजीनियरों और हितधारकों द्वारा सह-लेखक होते हैं।
उपयोग स्थितियों में प्रणाली के लिए कार्यात्मक आवश्यकताओं के दस्तावेजीकरण के लिए संरचना है, जिसमें सामान्यतः सॉफ्टवेयर सम्मिलित होता है, चाहे वह नया हो या बदला जा रहा हो। प्रत्येक उपयोग स्थितियों परिदृश्यों का समुच्चय प्रदान करता है जो बताता है कि किसी विशिष्ट व्यावसायिक लक्ष्य को प्राप्त करने के लिए प्रणाली को मानव उपयोगकर्ता या अन्य प्रणाली के साथ कैसे इंटरैक्ट करना चाहिए। उपयोग के लिए सामान्यतः तकनीकी शब्दजाल से बचते हैं, इसके अतिरिक्त [[अंतिम उपयोगकर्ता]] या [[डोमेन विशेषज्ञ]] की भाषा को प्राथमिकता देते हैं। उपयोग के स्थिति अधिकांशतः आवश्यकता इंजीनियरों और हितधारकों द्वारा सह-लेखक होते हैं।


उपयोग स्थिति सॉफ्टवेयर या प्रणाली के व्यवहार का वर्णन करने के लिए भ्रामक सरल उपकरण हैं। उपयोग के स्थितियों में उन विधियों का एक पाठ्य विवरण होता है जिसमें उपयोगकर्ताओं को सॉफ़्टवेयर या प्रणाली के साथ काम करने का लक्ष्य होता है। उपयोग के स्थितियों को प्रणाली की आंतरिक कार्यप्रणाली का वर्णन नहीं करना चाहिए, न ही उन्हें यह बताना चाहिए कि प्रणाली कैसे प्रयुक्त किया जाएगा। इसके अतिरिक्त, वे अनुक्रमिक मान्यताओं के बिना किसी कार्य को करने के लिए आवश्यक कदम दिखाते हैं।
उपयोग स्थिति सॉफ्टवेयर या प्रणाली के व्यवहार का वर्णन करने के लिए भ्रामक सरल उपकरण हैं। उपयोग के स्थितियों में उन विधियों का पाठ्य विवरण होता है जिसमें उपयोगकर्ताओं को सॉफ़्टवेयर या प्रणाली के साथ काम करने का लक्ष्य होता है। उपयोग के स्थितियों को प्रणाली की आंतरिक कार्यप्रणाली का वर्णन नहीं करना चाहिए, न ही उन्हें यह बताना चाहिए कि प्रणाली कैसे प्रयुक्त किया जाएगा। इसके अतिरिक्त, वे अनुक्रमिक मान्यताओं के बिना किसी कार्य को करने के लिए आवश्यक कदम दिखाते हैं।


===सॉफ्टवेयर आवश्यकता विनिर्देश ===
===सॉफ्टवेयर आवश्यकता विनिर्देश ===
Line 136: Line 135:


====== आवंटित आवश्यकताएं ======
====== आवंटित आवश्यकताएं ======
:एक आवश्यकता जो एक उच्च-स्तरीय आवश्यकता को कई निचले-स्तर की आवश्यकताओं में विभाजित या अन्यथा आवंटित करके स्थापित की जाती है। उदाहरण: दो उप-प्रणालियों से युक्त 100 पाउंड की वस्तु के परिणामस्वरूप दो निचले स्तर की वस्तुओं के लिए 70 पाउंड और 30 पाउंड वजन की आवश्यकता हो सकती है।<ref name="SEF01" />
:एक आवश्यकता जो उच्च-स्तरीय आवश्यकता को कई निचले-स्तर की आवश्यकताओं में विभाजित या अन्यथा आवंटित करके स्थापित की जाती है। उदाहरण: दो उप-प्रणालियों से युक्त 100 पाउंड की वस्तु के परिणामस्वरूप दो निचले स्तर की वस्तुओं के लिए 70 पाउंड और 30 पाउंड वजन की आवश्यकता हो सकती है।<ref name="SEF01" />


प्रसिद्ध आवश्यकता वर्गीकरण मॉडल में [[हेवलेट पैकर्ड]] में विकसित [[FURPS|फ़र्प्स]] और फ़र्प्स+ सम्मिलित हैं।
प्रसिद्ध आवश्यकता वर्गीकरण मॉडल में [[हेवलेट पैकर्ड]] में विकसित [[FURPS|फ़र्प्स]] और फ़र्प्स+ सम्मिलित हैं।
Line 145: Line 144:
स्टीव मैककोनेल, अपनी पुस्तक रैपिड डेवलपमेंट में, ऐसे कई विधियों का विवरण देते हैं, जिनसे उपयोगकर्ता आवश्यकताओं को एकत्रित करने से रोक सकते हैं:
स्टीव मैककोनेल, अपनी पुस्तक रैपिड डेवलपमेंट में, ऐसे कई विधियों का विवरण देते हैं, जिनसे उपयोगकर्ता आवश्यकताओं को एकत्रित करने से रोक सकते हैं:
* उपयोगकर्ता यह नहीं समझते हैं कि वे क्या चाहते हैं या उपयोगकर्ताओं को उनकी आवश्यकताओं के बारे में स्पष्ट जानकारी नहीं है
* उपयोगकर्ता यह नहीं समझते हैं कि वे क्या चाहते हैं या उपयोगकर्ताओं को उनकी आवश्यकताओं के बारे में स्पष्ट जानकारी नहीं है
* उपयोगकर्ता लिखित आवश्यकताओं के एक समुच्चय के लिए प्रतिबद्ध नहीं होंगे
* उपयोगकर्ता लिखित आवश्यकताओं के समुच्चय के लिए प्रतिबद्ध नहीं होंगे
* उपयोगकर्ता मूल्य और शेड्यूल तय होने के बाद नई आवश्यकताओं पर जोर देते हैं
* उपयोगकर्ता मूल्य और शेड्यूल तय होने के बाद नई आवश्यकताओं पर जोर देते हैं
* उपयोगकर्ताओं के साथ संचार धीमा है
* उपयोगकर्ताओं के साथ संचार धीमा है
Line 156: Line 155:
=== इंजीनियर/डेवलपर उद्देश्य  ===
=== इंजीनियर/डेवलपर उद्देश्य  ===
आवश्यकताओं के विश्लेषण के समय इंजीनियरों और डेवलपर्स के कारण होने वाली संभावित समस्याएं हैं:
आवश्यकताओं के विश्लेषण के समय इंजीनियरों और डेवलपर्स के कारण होने वाली संभावित समस्याएं हैं:
* लेखन कोड के प्रति एक स्वाभाविक झुकाव आवश्यकताओं के विश्लेषण के पूरा होने से पहले कार्यान्वयन की प्रारंभ कर सकता है, संभावित रूप से वास्तविक आवश्यकताओं को पूरा करने के लिए कोड परिवर्तन के परिणामस्वरूप एक बार ज्ञात हो जाता है।
* लेखन कोड के प्रति स्वाभाविक झुकाव आवश्यकताओं के विश्लेषण के पूरा होने से पहले कार्यान्वयन की प्रारंभ कर सकता है, संभावित रूप से वास्तविक आवश्यकताओं को पूरा करने के लिए कोड परिवर्तन के परिणामस्वरूप एक बार ज्ञात हो जाता है।
* तकनीकी कर्मियों और अंतिम उपयोगकर्ताओं के पास अलग-अलग शब्दावली हो सकती है। परिणाम स्वरुप , वे गलत तरीके से विश्वास कर सकते हैं कि तैयार उत्पाद की आपूर्ति होने तक वे पूर्ण समझौते में हैं।
* तकनीकी कर्मियों और अंतिम उपयोगकर्ताओं के पास अलग-अलग शब्दावली हो सकती है। परिणाम स्वरुप, वे अनुचित विधि से विश्वास कर सकते हैं कि तैयार उत्पाद की आपूर्ति होने तक वे पूर्ण समझौते में हैं।
* इंजीनियर और डेवलपर ग्राहक की आवश्यकता के लिए विशिष्ट प्रणाली विकसित करने के अतिरिक्त आवश्यकताओं को मौजूदा प्रणाली या मॉडल के अनुरूप बनाने का प्रयास कर सकते हैं।
* इंजीनियर और डेवलपर ग्राहक की आवश्यकता के लिए विशिष्ट प्रणाली विकसित करने के अतिरिक्त आवश्यकताओं को वर्तमान प्रणाली या मॉडल के अनुरूप बनाने का प्रयास कर सकते हैं।


=== प्रयास किए गए समाधान ===
=== प्रयास किए गए समाधान ===
संचार समस्याओं के समाधान का एक प्रयास व्यवसाय या प्रणाली विश्लेषण में विशेषज्ञों को नियुक्त करना रहा है।
संचार समस्याओं के समाधान का प्रयास व्यवसाय या प्रणाली विश्लेषण में विशेषज्ञों को नियुक्त करना रहा है।


1990 के दशक में प्रारंभ की गई तकनीक जैसे [[सॉफ्टवेयर प्रोटोटाइप]], [[एकीकृत मॉडलिंग भाषा]] (यूएमएल), केस का उपयोग करें, और फुर्तीली सॉफ्टवेयर डेवलपमेंट भी पिछले विधियों के साथ आने वाली समस्याओं के समाधान के रूप में हैं।
1990 के दशक में प्रारंभ की गई तकनीक जैसे [[सॉफ्टवेयर प्रोटोटाइप]], [[एकीकृत मॉडलिंग भाषा]] (यूएमएल), केस का उपयोग करें, और फुर्तीली सॉफ्टवेयर डेवलपमेंट भी पिछले विधियों के साथ आने वाली समस्याओं के समाधान के रूप में हैं।


साथ ही, [[एप्लीकेशन सिमुलेशन सॉफ्टवेयर|अनुप्रयोग सिमुलेशन सॉफ्टवेयर]] या अनुप्रयोगों डेफ़िनिशन टूल के एक नए वर्ग ने व्यापार में प्रवेश किया है। ये उपकरण व्यापार उपयोगकर्ताओं और आईटी संगठन के बीच संचार की खाई को पाटने के लिए डिज़ाइन किए गए हैं - और किसी भी कोड के उत्पादन से पहले अनुप्रयोगों को 'परीक्षण विपणन' करने की अनुमति देने के लिए भी। इनमें से सर्वश्रेष्ठ उपकरण प्रदान करते हैं:
साथ ही, [[एप्लीकेशन सिमुलेशन सॉफ्टवेयर|अनुप्रयोग सिमुलेशन सॉफ्टवेयर]] या अनुप्रयोगों डेफ़िनिशन टूल के नए वर्ग ने व्यापार में प्रवेश किया है। ये उपकरण व्यापार उपयोगकर्ताओं और आईटी संगठन के बीच संचार की खाई को पाटने के लिए डिज़ाइन किए गए हैं - और किसी भी कोड के उत्पादन से पहले अनुप्रयोगों को 'परीक्षण विपणन' करने की अनुमति देने के लिए भी। इनमें से सर्वश्रेष्ठ उपकरण प्रदान करते हैं:
* [[इलेक्ट्रॉनिक व्हाइटबोर्ड]] अनुप्रयोगों प्रवाह को स्केच करने और विकल्पों का परीक्षण करने के लिए
* [[इलेक्ट्रॉनिक व्हाइटबोर्ड]] अनुप्रयोगों प्रवाह को स्केच करने और विकल्पों का परीक्षण करने के लिए
* व्यापार तर्क और डेटा आवश्यकता को पकड़ने की क्षमता
* व्यापार तर्क और डेटा आवश्यकता को पकड़ने की क्षमता
Line 198: Line 197:
* [[सॉफ़्टवेयर आवश्यकताएं]]
* [[सॉफ़्टवेयर आवश्यकताएं]]
* सॉफ्टवेयर आवश्यकता विशिष्टता
* सॉफ्टवेयर आवश्यकता विशिष्टता
* [[सिस्टम विश्लेषण]]
* [[प्रणाली विश्लेषण]]
* [[सिस्टम आवश्यकताएं]]
* [[प्रणाली आवश्यकताएं]]
* [[सिस्टम आवश्यकताएँ विनिर्देश]]
* [[प्रणाली आवश्यकताएँ विनिर्देश]]
* [[उपयोगकर्ता-केंद्रित डिजाइन]]
* [[उपयोगकर्ता-केंद्रित डिजाइन]]
{{Div col end}}
{{Div col end}}
Line 231: Line 230:
{{Systems Engineering}}
{{Systems Engineering}}


{{DEFAULTSORT:Requirements Analysis}}[[Category: प्रणाली अभियांत्रिकी]] [[Category: सॉफ़्टवेयर आवश्यकताएँ|*]] [[Category: व्यावसायिक विश्लेषण]]
{{DEFAULTSORT:Requirements Analysis}}  


[[pl:Wymaganie (inżynieria)#Analiza wymagań lub inżynieria wymagań]]
[[pl:Wymaganie (inżynieria)#Analiza wymagań lub inżynieria wymagań]]


 
[[Category:All articles with dead external links|Requirements Analysis]]
 
[[Category:Articles with dead external links from June 2021|Requirements Analysis]]
[[Category: Machine Translated Page]]
[[Category:Articles with hatnote templates targeting a nonexistent page|Requirements Analysis]]
[[Category:Created On 16/02/2023]]
[[Category:Collapse templates|Requirements Analysis]]
[[Category:Commons category link is locally defined|Requirements Analysis]]
[[Category:Created On 16/02/2023|Requirements Analysis]]
[[Category:Lua-based templates|Requirements Analysis]]
[[Category:Machine Translated Page|Requirements Analysis]]
[[Category:Multi-column templates|Requirements Analysis]]
[[Category:Navigational boxes| ]]
[[Category:Navigational boxes without horizontal lists|Requirements Analysis]]
[[Category:Pages using div col with small parameter|Requirements Analysis]]
[[Category:Pages with script errors|Requirements Analysis]]
[[Category:Short description with empty Wikidata description|Requirements Analysis]]
[[Category:Sidebars with styles needing conversion|Requirements Analysis]]
[[Category:Template documentation pages|Documentation/doc]]
[[Category:Templates Translated in Hindi|Requirements Analysis]]
[[Category:Templates Vigyan Ready|Requirements Analysis]]
[[Category:Templates generating microformats|Requirements Analysis]]
[[Category:Templates that add a tracking category|Requirements Analysis]]
[[Category:Templates that are not mobile friendly|Requirements Analysis]]
[[Category:Templates that generate short descriptions|Requirements Analysis]]
[[Category:Templates using TemplateData|Requirements Analysis]]
[[Category:Templates using under-protected Lua modules|Requirements Analysis]]
[[Category:Webarchive template wayback links|Requirements Analysis]]
[[Category:Wikipedia fully protected templates|Div col]]
[[Category:Wikipedia metatemplates|Requirements Analysis]]
[[Category:प्रणाली अभियांत्रिकी|Requirements Analysis]]
[[Category:व्यावसायिक विश्लेषण|Requirements Analysis]]
[[Category:सॉफ़्टवेयर आवश्यकताएँ|*]]

Latest revision as of 20:04, 4 March 2023

आवश्यकताओं के विश्लेषण पर प्रणाली अभियांत्रिकी परिप्रेक्ष्य।[1]

प्रणाली इंजीनियरिंग और सॉफ्टवेयर इंजीनियरिंग में, आवश्यकताओं का विश्लेषण उन कार्यों पर ध्यान केंद्रित करता है जो नए या परिवर्तित उत्पाद या परियोजना को पूरा करने के लिए आवश्यकता या शर्तों को निर्धारित करते हैं, विभिन्न हितधारकों (कॉर्पोरेट) की संभावित परस्पर विरोधी आवश्यकताओं को ध्यान में रखते हुए, 'विश्लेषण, दस्तावेजीकरण,' सॉफ़्टवेयर या प्रणाली आवश्यकताओं को मान्य और प्रबंधित करना होता है।[2]

आवश्यकताओं का विश्लेषण प्रणाली या सॉफ़्टवेयर परियोजना प्रबंधन की सफलता या विफलता के लिए महत्वपूर्ण है।[3] आवश्यकताओं को प्रलेखित, कार्रवाई योग्य, मापने योग्य, परीक्षण योग्य, पता लगाने योग्य, पहचानी गई व्यावसायिक आवश्यकताओं या अवसरों से संबंधित होना चाहिए, और प्रणाली डिज़ाइन के लिए पर्याप्त विवरण के स्तर तक परिभाषित किया जाना चाहिए।

अवलोकन

वैचारिक रूप से, आवश्यकताओं के विश्लेषण में तीन प्रकार की गतिविधियाँ सम्मिलित हैं ।

  • आवश्यकताएं प्राप्त करना: (उदाहरण के लिए परियोजना चार्टर या परिभाषा), व्यवसाय प्रक्रिया प्रलेखन, और हितधारक साक्षात्कार। इसे कभी-कभी आवश्यकताएं एकत्र करना या आवश्यकताओं की खोज भी कहा जाता है।
  • रिकॉर्डिंग आवश्यकताएँ: आवश्यकताओं को विभिन्न रूपों में प्रलेखित किया जा सकता है, सामान्यतः सारांश सूची सहित और इसमें प्राकृतिक भाषा के आलेख, उपयोग के स्थितियों, उपयोगकर्ता कहानी, प्रक्रिया विनिर्देश और डेटा मॉडल सहित विभिन्न प्रकार के मॉडल सम्मिलित हो सकते हैं।
  • आवश्यकताओं का विश्लेषण: यह निर्धारित करना कि बताई गई आवश्यकताएं स्पष्ट, पूर्ण, अनुलिपित, संक्षिप्त, वैध, सुसंगत और स्पष्ट हैं, और किसी भी स्पष्ट संघर्ष को हल करती हैं। विश्लेषण में आकार देने की आवश्यकताएं भी सम्मिलित हो सकती हैं।

आवश्यकता विश्लेषण लंबी और बड़ी प्रक्रिया हो सकती है जिसके समय कई हल्का मनोवैज्ञानिक कौशल सम्मिलित होते हैं। नई प्रणालियाँ पर्यावरण और लोगों के बीच संबंधों को बदलती हैं, इसलिए सभी हितधारकों की पहचान करना, उनकी सभी आवश्यकताओं को ध्यान में रखना और यह सुनिश्चित करना महत्वपूर्ण है कि वे नई प्रणालियों के निहितार्थों को समझें। ग्राहक से आवश्यकताओं को पूरा करने के लिए विश्लेषक कई तकनीकों को नियोजित कर सकते हैं। इनमें परिदृश्यों का विकास (एजाइल सॉफ्टवेयर विकास में उपयोगकर्ता की कहानी के रूप में दर्शाया गया), उपयोग के स्थितियों की पहचान, कार्यस्थल अवलोकन या नृवंशविज्ञान का उपयोग, साक्षात्कार आयोजित करना, या फोकस समूह सम्मिलित हो सकते हैं (अधिक उपयुक्त रूप से आवश्यकता कार्यशालाओं के रूप में इस संदर्भ में नामित, या आवश्यकताओं की समीक्षा सत्र) और आवश्यकताओं की सूची बनाना है। प्रोटोटाइप का उपयोग उदाहरण प्रणाली विकसित करने के लिए किया जा सकता है जिसे हितधारकों को प्रदर्शित किया जा सकता है। जहाँ आवश्यक हो, विश्लेषक हितधारकों की सही आवश्यकताओं को स्थापित करने के लिए इन विधियों के संयोजन को नियोजित करेगा, चुकी व्यावसायिक आवश्यकताओं को पूरा करने वाली प्रणाली का उत्पादन किया जा सके। आवश्यकताओं की गुणवत्ता इन और अन्य विधियों के माध्यम से सुधारी जा सकती है

  • दृश्य वांछित अंत-उत्पाद जैसे विज़ुअलाइज़ेशन और सिमुलेशन की अच्छी समझ को बढ़ावा देने वाले टूल का उपयोग करना।
  • टेम्प्लेट का लगातार उपयोग आवश्यकताओं को दस्तावेज करने के लिए मॉडल और टेम्पलेट्स का सतत समुच्चय तैयार करना।
  • आलेखकरण निर्भरता (परियोजना प्रबंधन)। आवश्यकताओं के साथ-साथ किसी भी धारणा और मण्डली के बीच निर्भरता और अंतर्संबंधों का दस्तावेजीकरण होता है।

आवश्यकता विश्लेषण विषय

हितधारक पहचान

लोगों या संगठनों (कंपनियों, मानक निकायों जैसी कानूनी संस्थाएं) की चर्चा के लिए हितधारक विश्लेषण देखें, जिनका प्रणाली में वैध हित है। वे प्रत्यक्ष या अप्रत्यक्ष रूप से इससे प्रभावित हो सकते हैं।

1990 के दशक में प्रमुख नया जोर हितधारकों की पहचान पर केंद्रित था। यह तीव्रता से मान्यता प्राप्त है कि हितधारक विश्लेषक को नियुक्त करने वाले संगठन तक ही सीमित नहीं हैं। अन्य हितधारकों में सम्मिलित होंगे।

  • कोई भी जो प्रणाली संचालित करता है (सामान्य और देखरेख नियंत्रक)
  • कोई भी जो प्रणाली से लाभान्वित होता है (कार्यात्मक, राजनीतिक, वित्तीय और सामाजिक लाभार्थी)
  • प्रणाली को खरीदने या प्राप्त करने में सम्मिलित कोई भी व्यक्ति। बड़े पैमाने पर व्यापार उत्पाद संगठन में, उत्पाद प्रबंधन, विपणन और कभी-कभी बिक्री उत्पाद के विकास को निर्देशित करने के लिए सरोगेट उपभोक्ताओं (बड़े पैमाने पर व्यापार के ग्राहक) के रूप में कार्य करती है।
  • संगठन जो प्रणाली के पहलुओं को विनियमित करते हैं । (वित्तीय, सुरक्षा और अन्य नियामक)
  • प्रणाली के विरोध में लोग या संगठन (नकारात्मक हितधारक; दुरुपयोग की स्थितियों भी देखें)
  • प्रणाली के लिए जिम्मेदार संगठन जो बनावट के द्वारा प्रणाली के साथ इंटरफेस करते हैं।
  • वे संगठन जो उस संगठन के साथ क्षैतिज एकीकरण करते हैं जिसके लिए विश्लेषक प्रणाली डिजाइन कर रहा है।

संयुक्त आवश्यकताएं विकास (जेआरडी) सत्र

आवश्यकताओं में अधिकांशतः क्रॉस-फ़ंक्शनल निहितार्थ होते हैं जो व्यक्तिगत हितधारकों के लिए अज्ञात होते हैं और अधिकांशतः हितधारक साक्षात्कार के समय चूक जाते हैं या अपूर्ण रूप से परिभाषित होते हैं। इन क्रॉस-फंक्शनल निहितार्थों को नियंत्रित वातावरण में जेआरडी सत्र आयोजित करके, प्रशिक्षित फैसिलिटेटर (बिजनेस विश्लेषक) द्वारा सुगम बनाया जा सकता है, जिसमें हितधारक आवश्यकताओं को पूरा करने, उनके विवरणों का विश्लेषण करने और क्रॉस-फंक्शनल निहितार्थों को उजागर करने के लिए चर्चा में भाग लेते हैं। समर्पित मुंशी को चर्चा का दस्तावेजीकरण करने के लिए उपस्थित होना चाहिए, व्यापार विश्लेषक को चर्चा को उस दिशा में ले जाने के लिए मुक्त करना चाहिए जो उपयुक्त आवश्यकताओं को उत्पन्न करता है जो सत्र के उद्देश्य को पूरा करते हैं।

जेआरडी सत्र संयुक्त अनुप्रयोग डिजाइन सत्र के समान हैं। पूर्व में, सत्र आवश्यकताओं को पूरा करते हैं जो डिजाइन को निर्देशित करते हैं, जबकि बाद वाले विशिष्ट डिजाइन सुविधाओं को विशिष्ट आवश्यकताओं की संतुष्टि में प्रयुक्त करने के लिए प्रेरित करते हैं।

अनुबंध-शैली की आवश्यकता सूची

आलेखकरण आवश्यकताओं का पारंपरिक विधियाँ अनुबंध शैली आवश्यकता सूची रहा है। जटिल प्रणाली में ऐसी आवश्यकताओं की सूची सैकड़ों पृष्ठों तक लंबी हो सकती है।

उपयुक्त रूपक खरीदारी की बहुत लंबी सूची होगी। ऐसी सूचियाँ आधुनिक विश्लेषण में बहुत अधिक अनुकूल हैं; क्योंकि वे अपने लक्ष्यों को प्राप्त करने में शानदार रूप से असफल सिद्ध हुए हैं; लेकिन वे आज भी देखे जाते हैं।

ताकत

  • आवश्यकताओं की चेकलिस्ट प्रदान करता है।
  • परियोजना प्रायोजक(रों) और डेवलपर्स के बीच अनुबंध प्रदान करें।
  • बड़ी प्रणाली के लिए उच्च स्तरीय विवरण प्रदान कर सकता है जिससे निचले स्तर की आवश्यकताओं को प्राप्त किया जा सकता है।

कमजोरियां

  • ऐसी सूचियाँ सैकड़ों पृष्ठों तक चल सकती हैं। वे वांछित अनुप्रयोगों के पाठक के अनुकूल विवरण के रूप में सेवा करने का लक्ष्य नहीं रखते हैं।
  • इस तरह की आवश्यकताएं सभी आवश्यकताओं को सूचीबद्ध करती हैं और इसलिए बहुत कम संदर्भ है। व्यापार विश्लेषक डिजाइन प्रलेखन के साथ आवश्यकताओं के लिए संदर्भ सम्मिलित कर सकता है।
    • इस अमूर्तता का उद्देश्य यह वर्णन करना नहीं है कि आवश्यकताएं कैसे फिट होती हैं या एक साथ काम करती हैं।
    • सूची आवश्यकताओं के बीच संबंधों और निर्भरताओं को प्रतिबिंबित नहीं कर सकती है। जबकि सूची प्रत्येक व्यक्तिगत आइटम को प्राथमिकता देना सरल बनाती है, आइटम को संदर्भ से बाहर निकालने से संपूर्ण उपयोग स्थितियों या व्यावसायिक आवश्यकता ख़राब हो सकती है।
    • वांछित प्रणाली अनुप्रयोग के डिजाइन के निहितार्थों की अच्छी साझा समझ प्राप्त करने के लिए सूची हितधारकों के साथ सावधानीपूर्वक आवश्यकताओं की समीक्षा करने की आवश्यकता को प्रतिस्थापित नहीं करती है।
  • केवल सूची बनाने से इसकी पूर्णता की कारण, नहीं होता है। व्यापार विश्लेषक को पर्याप्त रूप से व्यापक सूची खोजने और एकत्र करने के लिए अच्छा विश्वास प्रयास करना चाहिए, और गायब आवश्यकताओं को इंगित करने के लिए हितधारकों पर विश्वास करना चाहिए।
  • ये सूचियाँ हितधारकों और डेवलपर्स के बीच आपसी समझ की झूठी भावना उत्पन्न कर सकती हैं; व्यापार विश्लेषक अनुवाद प्रक्रिया के लिए महत्वपूर्ण हैं।
  • विकास और परीक्षण की प्रक्रिया प्रारंभ होने से पहले सभी कार्यात्मक आवश्यकताओं को उजागर करना लगभग असंभव है। यदि इन सूचियों को अपरिवर्तनीय अनुबंध के रूप में माना जाता है, तो विकास प्रक्रिया में उभरने वाली आवश्यकताएं विवादास्पद परिवर्तन अनुरोध उत्पन्न कर सकती हैं।

आवश्यकता सूचियों का विकल्प

आवश्यकता सूचियों के विकल्प के रूप में, फुर्तीली सॉफ़्टवेयर डेवलपमेंट रोज़मर्रा की भाषा में आवश्यकताओं का सुझाव देने के लिए उपयोगकर्ता कहानियों का उपयोग करती है।

मापने योग्य लक्ष्य

सर्वोत्तम अभ्यास आवश्यकताओं की संकलित सूची को केवल चिह्न के रूप में लेती हैं और बार-बार पूछती हैं कि क्यों? जब तक वास्तविक व्यावसायिक उद्देश्यों की खोज नहीं हो जाती है। हितधारक और विकासकर्ता इसके बाद यह मापने के लिए परीक्षण तैयार कर सकते हैं कि अब तक प्रत्येक लक्ष्य के किस स्तर को प्राप्त किया गया है। इस तरह के लक्ष्य विशिष्ट लेकिन अनिर्धारित आवश्यकताओं की लंबी सूची की तुलना में अधिक धीरे-धीरे बदलते हैं। एक बार महत्वपूर्ण, मापा लक्ष्यों का छोटा सेट स्थापित हो जाने के बाद, परियोजना के आधा होने से बहुत पहले वास्तविक हितधारक मूल्य देने के लिए तीव्रता से प्रोटोटाइप और लघु पुनरावृत्त विकास चरण आगे बढ़ सकते हैं।

प्रोटोटाइप

प्रोटोटाइप कंप्यूटर प्रोग्राम है जो किसी अन्य कंप्यूटर प्रोग्राम के गुणों का भाग प्रदर्शित करता है, जिससे उपयोगकर्ता ऐसे अनुप्रयोगों की कल्पना कर सकते हैं जो अभी तक निर्मित नहीं हुआ है। प्रोटोटाइप का लोकप्रिय रूप मॉकअप है, जो भविष्य के उपयोगकर्ताओं और अन्य हितधारकों को यह जानने कि "प्रणाली कैसा दिखेगा" में सहायता करता है। प्रोटोटाइप डिजाइन निर्णय लेना सरल बनाते हैं, क्योंकि अनुप्रयोगों के निर्माण से पहले अनुप्रयोगों के पहलुओं को देखा और साझा किया जा सकता है। प्रोटोटाइप के प्रारंभ के साथ उपयोगकर्ताओं और डेवलपर्स के बीच संचार में बड़े सुधार अधिकांशतः देखे गए थे। अनुप्रयोगों के प्रारंभिक विचारों ने बाद में कम बदलाव किए और इसलिए समग्र मूल्य में अधिक कमी आई।

प्रोटोटाइप फ्लैट आरेख (अधिकांशतः तार-फ्रेम मॉडल के रूप में संदर्भित) या संश्लेषित कार्यक्षमता का उपयोग करके काम करने वाले अनुप्रयोग हो सकते हैं। वायरफ्रेम विभिन्न प्रकार के ग्राफ़िक डिज़ाइन आरेख में बनाए जाते हैं, और अधिकांशतः डिज़ाइन से सभी रंगों को हटा देते हैं (अर्थात ग्रेस्केल रंग पैलेट का उपयोग करें) ऐसे स्थितियों में जहाँ अंतिम सॉफ़्टवेयर में ग्राफिक डिज़ाइन प्रयुक्त होने की आशा होती है। यह भ्रम को रोकने में सहायता करता है कि क्या प्रोटोटाइप अंतिम दृश्य रूप और अनुप्रयोगों के अनुभव का प्रतिनिधित्व करता है।



स्थितियों का प्रयोग करें

उपयोग स्थितियों में प्रणाली के लिए कार्यात्मक आवश्यकताओं के दस्तावेजीकरण के लिए संरचना है, जिसमें सामान्यतः सॉफ्टवेयर सम्मिलित होता है, चाहे वह नया हो या बदला जा रहा हो। प्रत्येक उपयोग स्थितियों परिदृश्यों का समुच्चय प्रदान करता है जो बताता है कि किसी विशिष्ट व्यावसायिक लक्ष्य को प्राप्त करने के लिए प्रणाली को मानव उपयोगकर्ता या अन्य प्रणाली के साथ कैसे इंटरैक्ट करना चाहिए। उपयोग के लिए सामान्यतः तकनीकी शब्दजाल से बचते हैं, इसके अतिरिक्त अंतिम उपयोगकर्ता या डोमेन विशेषज्ञ की भाषा को प्राथमिकता देते हैं। उपयोग के स्थिति अधिकांशतः आवश्यकता इंजीनियरों और हितधारकों द्वारा सह-लेखक होते हैं।

उपयोग स्थिति सॉफ्टवेयर या प्रणाली के व्यवहार का वर्णन करने के लिए भ्रामक सरल उपकरण हैं। उपयोग के स्थितियों में उन विधियों का पाठ्य विवरण होता है जिसमें उपयोगकर्ताओं को सॉफ़्टवेयर या प्रणाली के साथ काम करने का लक्ष्य होता है। उपयोग के स्थितियों को प्रणाली की आंतरिक कार्यप्रणाली का वर्णन नहीं करना चाहिए, न ही उन्हें यह बताना चाहिए कि प्रणाली कैसे प्रयुक्त किया जाएगा। इसके अतिरिक्त, वे अनुक्रमिक मान्यताओं के बिना किसी कार्य को करने के लिए आवश्यक कदम दिखाते हैं।

सॉफ्टवेयर आवश्यकता विनिर्देश

आवश्यकताएँ विनिर्देश वर्तमान राज्य की व्यावसायिक आवश्यकताओं के बारे में खोज निष्कर्षों का संश्लेषण है और इन आवश्यकताओं के मूल्यांकन को निर्धारित करने और निर्दिष्ट करने के लिए, समाधान के क्षेत्र में फोकस में आवश्यकताओं को पूरा करने के लिए क्या आवश्यक है। खोज, विश्लेषण और विनिर्देश वर्तमान स्थिति से समझ को भविष्य की स्थिति में ले जाते हैं। आवश्यकताएं विनिर्देश भविष्य की स्थिति की पूरी चौड़ाई और गहराई को समझ सकते हैं, या इसे भरने के लिए विशिष्ट अंतराल को लक्षित कर सकते हैं, जैसे प्राथमिकता सॉफ़्टवेयर प्रणाली दोष को ठीक करने और बढ़ाने के लिए होता है। यह देखते हुए कि कोई भी बड़ी व्यावसायिक प्रक्रिया लगभग हमेशा सॉफ्टवेयर और डेटा प्रणाली और प्रौद्योगिकी को नियोजित करती है, आवश्यकता विनिर्देश अधिकांशतः सॉफ्टवेयर प्रणाली के निर्माण, खरीद, क्लाउड कंप्यूटिंग रणनीतियों, उत्पादों या उपकरणों में एम्बेडेड सॉफ़्टवेयर या अन्य तकनीकों से जुड़ा होता है। आवश्यकताओं के विनिर्देश की व्यापक परिभाषा में प्रशिक्षण, प्रलेखन गाइड, कार्मिक, विपणन रणनीति, उपकरण, आपूर्ति आदि जैसे किसी भी समाधान रणनीति या घटक को सम्मिलित किया गया है या उस पर ध्यान केंद्रित किया गया है।

आवश्यकताओं के प्रकार

आवश्यकताएँ कई तरह से वर्गीकरण हैं। तकनीकी प्रबंधन से संबंधित आवश्यकताओं के सामान्य वर्गीकरण निम्नलिखित हैं:[1]

व्यापार की आवश्यकताएं
विस्तृत कार्यक्षमता के संदर्भ के बिना व्यापार स्तर के लक्ष्यों का विवरण करना। ये सामान्यतः उच्च स्तरीय (सॉफ़्टवेयर और/या हार्डवेयर) क्षमताएं होती हैं जिनकी व्यावसायिक परिणाम प्राप्त करने के लिए आवश्यकता होती है।
ग्राहक की आवश्यकताएं
तथ्य और मान्यताओं के तथ्य जो मिशन के उद्देश्यों, पर्यावरण, बाधाओं और प्रभावशीलता और उपयुक्तता के उपायों (एमओई/एमओएस) के संदर्भ में प्रणाली की अपेक्षाओं को परिभाषित करते हैं। ग्राहक वे हैं जो मुख्य ग्राहक के रूप में ऑपरेटर पर विशेष जोर देने के साथ प्रणाली इंजीनियरिंग के आठ प्राथमिक कार्य करते हैं। संचालन संबंधी आवश्यकताएं मूलभूत आवश्यकता को परिभाषित करेंगी और कम से कम निम्नलिखित सूची में पूछे गए प्रश्नों के उत्तर देंगी:[1]
  • ऑपरेशनल वितरण या तैनाती: प्रणाली का प्रयोग कहां किया जाएगा?
  • मिशन प्रोफ़ाइल या परिदृश्य: प्रणाली अपने मिशन के उद्देश्य को कैसे पूरा करेगा?
  • प्रदर्शन और संबंधित पैरामीटर: मिशन को पूरा करने के लिए महत्वपूर्ण प्रणाली पैरामीटर क्या हैं?
  • उपयोगिता वातावरण: विभिन्न प्रणाली घटकों का उपयोग कैसे किया जाता है?
  • प्रभावकारिता आवश्यकताएँ: प्रणाली अपने मिशन को पूरा करने में कितना प्रभावी या कुशल होना चाहिए?
  • परिचालन जीवन चक्र: उपयोगकर्ता द्वारा प्रणाली कब तक उपयोग में रहेगा?
  • पर्यावरण: प्रणाली के प्रभावी ढंग से संचालन के लिए किस वातावरण की अपेक्षा की जाएगी?

आर्किटेक्चरल आवश्यकताएं

आर्किटेक्चरल आवश्यकताएं बताती हैं कि प्रणाली के आवश्यक प्रणाली आर्किटेक्चर की पहचान करके क्या किया जाना चाहिए।

संरचनात्मक आवश्यकताएं

संरचनात्मक आवश्यकताएं बताती हैं कि प्रणाली की आवश्यक संरचना की पहचान करके क्या किया जाना है।

व्यवहार संबंधी आवश्यकताएं

व्यवहार संबंधी आवश्यकताएं बताती हैं कि प्रणाली के आवश्यक व्यवहार की पहचान करके क्या किया जाना है।

कार्यात्मक आवश्यकताएं

कार्यात्मक आवश्यकताएं बताती हैं कि आवश्यक कार्य, क्रिया या गतिविधि की पहचान करके क्या किया जाना चाहिए जिसे पूरा किया जाना चाहिए। कार्यात्मक आवश्यकताओं के विश्लेषण का उपयोग कार्यात्मक विश्लेषण के लिए उच्च स्तरीय कार्यों के रूप में किया जाएगा।[1]

गैर-कार्यात्मक आवश्यकताएं

गैर-कार्यात्मक आवश्यकताएं ऐसी आवश्यकताएं हैं जो मानदंड निर्दिष्ट करती हैं जिनका उपयोग विशिष्ट व्यवहारों के अतिरिक्त प्रणाली के संचालन का न्याय करने के लिए किया जा सकता है।

प्रदर्शन आवश्यकताएँ
किसी मिशन या कार्य को किस सीमा तक निष्पादित किया जाना चाहिए; सामान्यतः मात्रा, गुणवत्ता, कवरेज, समयबद्धता या तैयारी के संदर्भ में मापा जाता है। आवश्यकताओं के विश्लेषण के समय, प्रणाली जीवन चक्र कारकों के आधार पर सभी पहचाने गए कार्यों में प्रदर्शन (इसे कितनी अच्छी तरह से किया जाना चाहिए) आवश्यकताओं को अंतःक्रियात्मक रूप से विकसित किया जाएगा; और उनके अनुमान में निश्चितता की डिग्री, प्रणाली की सफलता के लिए महत्वपूर्णता की डिग्री और अन्य आवश्यकताओं के साथ उनके संबंध के संदर्भ में विशेषता है।[1]
डिजाइन की आवश्यकताएं
उत्पादों के लिए बिल्ड टू, कोड टू और बाय टू आवश्यकताएं और तकनीकी डेटा पैकेज और तकनीकी मैनुअल में व्यक्त प्रक्रियाओं के लिए आवश्यकताओं को कैसे निष्पादित करें।[1]
व्युत्पन्न आवश्यकताएँ
आवश्यकताएँ जो निहित हैं या उच्च-स्तरीय आवश्यकता से रूपांतरित हैं। उदाहरण के लिए, लंबी दूरी या उच्च गति की आवश्यकता के परिणामस्वरूप कम वजन के लिए डिज़ाइन की आवश्यकता हो सकती है।[1]
आवंटित आवश्यकताएं
एक आवश्यकता जो उच्च-स्तरीय आवश्यकता को कई निचले-स्तर की आवश्यकताओं में विभाजित या अन्यथा आवंटित करके स्थापित की जाती है। उदाहरण: दो उप-प्रणालियों से युक्त 100 पाउंड की वस्तु के परिणामस्वरूप दो निचले स्तर की वस्तुओं के लिए 70 पाउंड और 30 पाउंड वजन की आवश्यकता हो सकती है।[1]

प्रसिद्ध आवश्यकता वर्गीकरण मॉडल में हेवलेट पैकर्ड में विकसित फ़र्प्स और फ़र्प्स+ सम्मिलित हैं।

आवश्यकता विश्लेषण उद्देश्य

हितधारक उद्देश्य

स्टीव मैककोनेल, अपनी पुस्तक रैपिड डेवलपमेंट में, ऐसे कई विधियों का विवरण देते हैं, जिनसे उपयोगकर्ता आवश्यकताओं को एकत्रित करने से रोक सकते हैं:

  • उपयोगकर्ता यह नहीं समझते हैं कि वे क्या चाहते हैं या उपयोगकर्ताओं को उनकी आवश्यकताओं के बारे में स्पष्ट जानकारी नहीं है
  • उपयोगकर्ता लिखित आवश्यकताओं के समुच्चय के लिए प्रतिबद्ध नहीं होंगे
  • उपयोगकर्ता मूल्य और शेड्यूल तय होने के बाद नई आवश्यकताओं पर जोर देते हैं
  • उपयोगकर्ताओं के साथ संचार धीमा है
  • उपयोगकर्ता अधिकांशतः समीक्षाओं में भाग नहीं लेते या ऐसा करने में असमर्थ होते हैं
  • उपयोगकर्ता तकनीकी रूप से अपरिष्कृत हैं
  • उपयोगकर्ता विकास प्रक्रिया को नहीं समझते हैं
  • उपयोक्ता वर्तमान तकनीक के बारे में नहीं जानते

इससे ऐसी स्थिति हो सकती है जहां प्रणाली या उत्पाद विकास प्रारंभ होने पर भी उपयोगकर्ता की आवश्यकताएं बदलती रहती हैं।

इंजीनियर/डेवलपर उद्देश्य

आवश्यकताओं के विश्लेषण के समय इंजीनियरों और डेवलपर्स के कारण होने वाली संभावित समस्याएं हैं:

  • लेखन कोड के प्रति स्वाभाविक झुकाव आवश्यकताओं के विश्लेषण के पूरा होने से पहले कार्यान्वयन की प्रारंभ कर सकता है, संभावित रूप से वास्तविक आवश्यकताओं को पूरा करने के लिए कोड परिवर्तन के परिणामस्वरूप एक बार ज्ञात हो जाता है।
  • तकनीकी कर्मियों और अंतिम उपयोगकर्ताओं के पास अलग-अलग शब्दावली हो सकती है। परिणाम स्वरुप, वे अनुचित विधि से विश्वास कर सकते हैं कि तैयार उत्पाद की आपूर्ति होने तक वे पूर्ण समझौते में हैं।
  • इंजीनियर और डेवलपर ग्राहक की आवश्यकता के लिए विशिष्ट प्रणाली विकसित करने के अतिरिक्त आवश्यकताओं को वर्तमान प्रणाली या मॉडल के अनुरूप बनाने का प्रयास कर सकते हैं।

प्रयास किए गए समाधान

संचार समस्याओं के समाधान का प्रयास व्यवसाय या प्रणाली विश्लेषण में विशेषज्ञों को नियुक्त करना रहा है।

1990 के दशक में प्रारंभ की गई तकनीक जैसे सॉफ्टवेयर प्रोटोटाइप, एकीकृत मॉडलिंग भाषा (यूएमएल), केस का उपयोग करें, और फुर्तीली सॉफ्टवेयर डेवलपमेंट भी पिछले विधियों के साथ आने वाली समस्याओं के समाधान के रूप में हैं।

साथ ही, अनुप्रयोग सिमुलेशन सॉफ्टवेयर या अनुप्रयोगों डेफ़िनिशन टूल के नए वर्ग ने व्यापार में प्रवेश किया है। ये उपकरण व्यापार उपयोगकर्ताओं और आईटी संगठन के बीच संचार की खाई को पाटने के लिए डिज़ाइन किए गए हैं - और किसी भी कोड के उत्पादन से पहले अनुप्रयोगों को 'परीक्षण विपणन' करने की अनुमति देने के लिए भी। इनमें से सर्वश्रेष्ठ उपकरण प्रदान करते हैं:

  • इलेक्ट्रॉनिक व्हाइटबोर्ड अनुप्रयोगों प्रवाह को स्केच करने और विकल्पों का परीक्षण करने के लिए
  • व्यापार तर्क और डेटा आवश्यकता को पकड़ने की क्षमता
  • उच्च निष्ठा वाले प्रोटोटाइप उत्पन्न करने की क्षमता जो अंतिम अनुप्रयोगों की सूक्ष्मता से प्रतिलिपि करते हैं
  • अन्तरक्रियाशीलता
  • प्रासंगिक आवश्यकताओं और अन्य टिप्पणियों को जोड़ने की क्षमता
  • दूरस्थ और वितरित उपयोगकर्ताओं के लिए सिमुलेशन चलाने और बातचीत करने की क्षमता

यह भी देखें


संदर्भ

  1. 1.0 1.1 1.2 1.3 1.4 1.5 1.6 1.7 Systems Engineering Fundamentals Archived 2011-07-22 at the Wayback Machine Defense Acquisition University Press, 2001
  2. Kotonya, Gerald; Sommerville, Ian (1998). Requirements Engineering: Processes and Techniques. Chichester, UK: John Wiley and Sons. ISBN 9780471972082.
  3. Alain Abran; James W. Moore; Pierre Bourque; Robert Dupuis, eds. (March 2005). "Chapter 2: Software Requirements". Guide to the software engineering body of knowledge (2004 ed.). Los Alamitos, CA: IEEE Computer Society Press. ISBN 0-7695-2330-7. Retrieved 2007-02-08. It is widely acknowledged within the software industry that software engineering projects are critically vulnerable when these activities are performed poorly.


ग्रन्थसूची


बाहरी संबंध