आवश्यकताओं के विश्लेषण: Difference between revisions
No edit summary |
No edit summary |
||
| (9 intermediate revisions by 3 users not shown) | |||
| Line 1: | Line 1: | ||
{{Short description|Engineering process}} | {{Short description|Engineering process}} | ||
{{broader|आवश्यकताएं इंजीनियरिंग}} | {{broader|आवश्यकताएं इंजीनियरिंग}} | ||
[[File:SE Process.jpg|thumb|320px|आवश्यकताओं के विश्लेषण पर | [[File:SE Process.jpg|thumb|320px|आवश्यकताओं के विश्लेषण पर [[प्रणाली अभियांत्रिकी]] परिप्रेक्ष्य।<ref name="SEF01">[http://www.dau.mil/pubscats/PubsCats/SEFGuide%2001-01.pdf ''Systems Engineering Fundamentals''] {{webarchive|url=https://web.archive.org/web/20110722184431/http://www.dau.mil/pubscats/PubsCats/SEFGuide%2001-01.pdf |date=2011-07-22 }} Defense Acquisition University Press, 2001</ref>]] | ||
{{software development process|Core activities}} | {{software development process|Core activities}} | ||
प्रणाली इंजीनियरिंग और [[सॉफ्टवेयर इंजीनियरिंग]] में, आवश्यकताओं का विश्लेषण उन कार्यों पर ध्यान केंद्रित करता है जो नए या परिवर्तित उत्पाद या परियोजना को पूरा करने के लिए आवश्यकता या शर्तों को निर्धारित करते हैं, विभिन्न हितधारकों (कॉर्पोरेट) की संभावित परस्पर विरोधी आवश्यकताओं को ध्यान में रखते हुए, 'विश्लेषण, दस्तावेजीकरण,' सॉफ़्टवेयर या प्रणाली आवश्यकताओं को मान्य और प्रबंधित करना होता है।<ref>{{cite book|isbn=9780471972082|title=Requirements Engineering: Processes and Techniques|url=https://archive.org/details/requirementsengi1998koto|url-access=registration|last1=Kotonya|first1=Gerald|last2=Sommerville|first2=Ian|year=1998|location=Chichester, UK|publisher=John Wiley and Sons}}</ref> | प्रणाली इंजीनियरिंग और [[सॉफ्टवेयर इंजीनियरिंग]] में, आवश्यकताओं का विश्लेषण उन कार्यों पर ध्यान केंद्रित करता है जो नए या परिवर्तित उत्पाद या परियोजना को पूरा करने के लिए आवश्यकता या शर्तों को निर्धारित करते हैं, विभिन्न हितधारकों (कॉर्पोरेट) की संभावित परस्पर विरोधी आवश्यकताओं को ध्यान में रखते हुए, 'विश्लेषण, दस्तावेजीकरण,' सॉफ़्टवेयर या प्रणाली आवश्यकताओं को मान्य और प्रबंधित करना होता है।<ref>{{cite book|isbn=9780471972082|title=Requirements Engineering: Processes and Techniques|url=https://archive.org/details/requirementsengi1998koto|url-access=registration|last1=Kotonya|first1=Gerald|last2=Sommerville|first2=Ian|year=1998|location=Chichester, UK|publisher=John Wiley and Sons}}</ref> | ||
| 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 75: | Line 74: | ||
{{main|लक्ष्य मॉडलिंग}} | {{main|लक्ष्य मॉडलिंग}} | ||
सर्वोत्तम | सर्वोत्तम अभ्यास आवश्यकताओं की संकलित सूची को केवल चिह्न के रूप में लेती हैं और बार-बार पूछती हैं कि क्यों? जब तक वास्तविक व्यावसायिक उद्देश्यों की खोज नहीं हो जाती है। हितधारक और विकासकर्ता इसके बाद यह मापने के लिए परीक्षण तैयार कर सकते हैं कि अब तक प्रत्येक लक्ष्य के किस स्तर को प्राप्त किया गया है। इस तरह के लक्ष्य विशिष्ट लेकिन अनिर्धारित आवश्यकताओं की लंबी सूची की तुलना में अधिक धीरे-धीरे बदलते हैं। एक बार महत्वपूर्ण, मापा लक्ष्यों का छोटा सेट स्थापित हो जाने के बाद, परियोजना के आधा होने से बहुत पहले वास्तविक हितधारक मूल्य देने के लिए तीव्रता से प्रोटोटाइप और लघु पुनरावृत्त विकास चरण आगे बढ़ सकते हैं। | ||
=== प्रोटोटाइप === | === प्रोटोटाइप === | ||
| Line 81: | Line 80: | ||
{{main|सॉफ्टवेयर प्रोटोटाइप}} | {{main|सॉफ्टवेयर प्रोटोटाइप}} | ||
प्रोटोटाइप कंप्यूटर प्रोग्राम है जो किसी अन्य कंप्यूटर प्रोग्राम के गुणों का भाग प्रदर्शित करता है, जिससे उपयोगकर्ता ऐसे अनुप्रयोगों की कल्पना कर सकते हैं जो अभी तक निर्मित नहीं हुआ है। प्रोटोटाइप का लोकप्रिय रूप [[नकली|मॉकअप]] है, जो भविष्य के उपयोगकर्ताओं और अन्य हितधारकों को यह जानने कि "प्रणाली कैसा दिखेगा" में सहायता करता है। प्रोटोटाइप डिजाइन निर्णय लेना सरल बनाते हैं, क्योंकि अनुप्रयोगों के निर्माण से पहले अनुप्रयोगों के पहलुओं को देखा और साझा किया जा सकता है। प्रोटोटाइप के प्रारंभ के साथ उपयोगकर्ताओं और डेवलपर्स के बीच संचार में बड़े सुधार अधिकांशतः देखे गए थे। अनुप्रयोगों के प्रारंभिक विचारों ने बाद में कम बदलाव किए और इसलिए समग्र मूल्य में अधिक कमी आई। | |||
प्रोटोटाइप फ्लैट आरेख (अधिकांशतः | प्रोटोटाइप फ्लैट आरेख (अधिकांशतः [[तार-फ्रेम मॉडल]] के रूप में संदर्भित) या संश्लेषित कार्यक्षमता का उपयोग करके काम करने वाले अनुप्रयोग हो सकते हैं। वायरफ्रेम विभिन्न प्रकार के [[ग्राफ़िक डिज़ाइन]] आरेख में बनाए जाते हैं, और अधिकांशतः डिज़ाइन से सभी रंगों को हटा देते हैं (अर्थात ग्रेस्केल रंग पैलेट का उपयोग करें) ऐसे स्थितियों में जहाँ अंतिम सॉफ़्टवेयर में ग्राफिक डिज़ाइन प्रयुक्त होने की आशा होती है। यह भ्रम को रोकने में सहायता करता है कि क्या प्रोटोटाइप अंतिम दृश्य रूप और अनुप्रयोगों के अनुभव का प्रतिनिधित्व करता है। | ||
=== स्थितियों | |||
=== स्थितियों का प्रयोग करें === | |||
{{main|उदाहरण}} | {{main|उदाहरण}} | ||
उपयोग स्थितियों में प्रणाली के लिए कार्यात्मक आवश्यकताओं के दस्तावेजीकरण के लिए संरचना है, जिसमें सामान्यतः सॉफ्टवेयर सम्मिलित होता है, चाहे वह नया हो या बदला जा रहा हो। प्रत्येक उपयोग स्थितियों परिदृश्यों का समुच्चय प्रदान करता है जो बताता है कि किसी विशिष्ट व्यावसायिक लक्ष्य को प्राप्त करने के लिए प्रणाली को मानव उपयोगकर्ता या अन्य प्रणाली के साथ कैसे इंटरैक्ट करना चाहिए। उपयोग के लिए सामान्यतः तकनीकी शब्दजाल से बचते हैं, इसके अतिरिक्त [[अंतिम उपयोगकर्ता]] या [[डोमेन विशेषज्ञ]] की भाषा को प्राथमिकता देते हैं। उपयोग के स्थिति अधिकांशतः आवश्यकता इंजीनियरों और हितधारकों द्वारा सह-लेखक होते हैं। | |||
उपयोग | उपयोग स्थिति सॉफ्टवेयर या प्रणाली के व्यवहार का वर्णन करने के लिए भ्रामक सरल उपकरण हैं। उपयोग के स्थितियों में उन विधियों का पाठ्य विवरण होता है जिसमें उपयोगकर्ताओं को सॉफ़्टवेयर या प्रणाली के साथ काम करने का लक्ष्य होता है। उपयोग के स्थितियों को प्रणाली की आंतरिक कार्यप्रणाली का वर्णन नहीं करना चाहिए, न ही उन्हें यह बताना चाहिए कि प्रणाली कैसे प्रयुक्त किया जाएगा। इसके अतिरिक्त, वे अनुक्रमिक मान्यताओं के बिना किसी कार्य को करने के लिए आवश्यक कदम दिखाते हैं। | ||
===सॉफ्टवेयर आवश्यकता विनिर्देश === | ===सॉफ्टवेयर आवश्यकता विनिर्देश === | ||
आवश्यकताएँ विनिर्देश वर्तमान राज्य की व्यावसायिक आवश्यकताओं के बारे में खोज निष्कर्षों का संश्लेषण है और इन आवश्यकताओं के मूल्यांकन को निर्धारित करने और निर्दिष्ट करने के लिए, समाधान के क्षेत्र | आवश्यकताएँ विनिर्देश वर्तमान राज्य की व्यावसायिक आवश्यकताओं के बारे में खोज निष्कर्षों का संश्लेषण है और इन आवश्यकताओं के मूल्यांकन को निर्धारित करने और निर्दिष्ट करने के लिए, समाधान के क्षेत्र में फोकस में आवश्यकताओं को पूरा करने के लिए क्या आवश्यक है। खोज, विश्लेषण और विनिर्देश वर्तमान स्थिति से समझ को भविष्य की स्थिति में ले जाते हैं। आवश्यकताएं विनिर्देश भविष्य की स्थिति की पूरी चौड़ाई और गहराई को समझ सकते हैं, या इसे भरने के लिए विशिष्ट अंतराल को लक्षित कर सकते हैं, जैसे प्राथमिकता सॉफ़्टवेयर प्रणाली दोष को ठीक करने और बढ़ाने के लिए होता है। यह देखते हुए कि कोई भी बड़ी व्यावसायिक प्रक्रिया लगभग हमेशा सॉफ्टवेयर और डेटा प्रणाली और प्रौद्योगिकी को नियोजित करती है, आवश्यकता विनिर्देश अधिकांशतः सॉफ्टवेयर प्रणाली के निर्माण, खरीद, क्लाउड कंप्यूटिंग रणनीतियों, उत्पादों या उपकरणों में एम्बेडेड सॉफ़्टवेयर या अन्य तकनीकों से जुड़ा होता है। आवश्यकताओं के विनिर्देश की व्यापक परिभाषा में प्रशिक्षण, प्रलेखन गाइड, कार्मिक, विपणन रणनीति, उपकरण, आपूर्ति आदि जैसे किसी भी समाधान रणनीति या घटक को सम्मिलित किया गया है या उस पर ध्यान केंद्रित किया गया है। | ||
== आवश्यकताओं के प्रकार == | == आवश्यकताओं के प्रकार == | ||
आवश्यकताएँ कई तरह से [[वर्गीकरण]] हैं। तकनीकी प्रबंधन से संबंधित आवश्यकताओं के सामान्य वर्गीकरण निम्नलिखित हैं:<ref name="SEF01"/> | आवश्यकताएँ कई तरह से [[वर्गीकरण]] हैं। तकनीकी प्रबंधन से संबंधित आवश्यकताओं के सामान्य वर्गीकरण निम्नलिखित हैं:<ref name="SEF01"/> | ||
;व्यापार की | ;व्यापार की आवश्यकताएं | ||
: विस्तृत कार्यक्षमता के संदर्भ के बिना व्यापार स्तर के लक्ष्यों का | : विस्तृत कार्यक्षमता के संदर्भ के बिना व्यापार स्तर के लक्ष्यों का विवरण करना। ये सामान्यतः उच्च स्तरीय (सॉफ़्टवेयर और/या हार्डवेयर) क्षमताएं होती हैं जिनकी व्यावसायिक परिणाम प्राप्त करने के लिए आवश्यकता होती है। | ||
;ग्राहक की आवश्यकताएं | ;ग्राहक की आवश्यकताएं | ||
: तथ्य और मान्यताओं के तथ्य जो मिशन के उद्देश्यों, पर्यावरण, बाधाओं और प्रभावशीलता और उपयुक्तता के उपायों (एमओई/एमओएस) के संदर्भ में प्रणाली की अपेक्षाओं को परिभाषित करते हैं। ग्राहक वे हैं जो मुख्य ग्राहक के रूप में ऑपरेटर पर विशेष जोर देने के साथ प्रणाली इंजीनियरिंग के आठ प्राथमिक कार्य करते हैं। संचालन संबंधी आवश्यकताएं मूलभूत आवश्यकता को परिभाषित करेंगी और कम से कम निम्नलिखित सूची में पूछे गए प्रश्नों के उत्तर देंगी:<ref name="SEF01"/>:*ऑपरेशनल | : तथ्य और मान्यताओं के तथ्य जो मिशन के उद्देश्यों, पर्यावरण, बाधाओं और प्रभावशीलता और उपयुक्तता के उपायों (एमओई/एमओएस) के संदर्भ में प्रणाली की अपेक्षाओं को परिभाषित करते हैं। ग्राहक वे हैं जो मुख्य ग्राहक के रूप में ऑपरेटर पर विशेष जोर देने के साथ प्रणाली इंजीनियरिंग के आठ प्राथमिक कार्य करते हैं। संचालन संबंधी आवश्यकताएं मूलभूत आवश्यकता को परिभाषित करेंगी और कम से कम निम्नलिखित सूची में पूछे गए प्रश्नों के उत्तर देंगी:<ref name="SEF01"/> | ||
:* ऑपरेशनल वितरण या तैनाती: [[प्रणाली]] का प्रयोग कहां किया जाएगा? | |||
:*मिशन प्रोफ़ाइल या परिदृश्य: प्रणाली अपने मिशन के उद्देश्य को कैसे पूरा करेगा? | :*मिशन प्रोफ़ाइल या परिदृश्य: प्रणाली अपने मिशन के उद्देश्य को कैसे पूरा करेगा? | ||
:*प्रदर्शन और संबंधित पैरामीटर: मिशन को पूरा करने के लिए महत्वपूर्ण प्रणाली पैरामीटर क्या हैं? | :*प्रदर्शन और संबंधित पैरामीटर: मिशन को पूरा करने के लिए महत्वपूर्ण प्रणाली पैरामीटर क्या हैं? | ||
: * उपयोगिता वातावरण: विभिन्न प्रणाली घटकों का उपयोग कैसे किया जाता है? | :*उपयोगिता वातावरण: विभिन्न प्रणाली घटकों का उपयोग कैसे किया जाता है? | ||
:*प्रभावकारिता आवश्यकताएँ: प्रणाली अपने मिशन को पूरा करने में कितना प्रभावी या कुशल होना चाहिए? | :*प्रभावकारिता आवश्यकताएँ: प्रणाली अपने मिशन को पूरा करने में कितना प्रभावी या कुशल होना चाहिए? | ||
:*परिचालन जीवन चक्र: उपयोगकर्ता द्वारा प्रणाली कब तक उपयोग में रहेगा? | :*परिचालन जीवन चक्र: उपयोगकर्ता द्वारा प्रणाली कब तक उपयोग में रहेगा? | ||
:*पर्यावरण: प्रणाली के प्रभावी ढंग से संचालन के लिए किस वातावरण की अपेक्षा की जाएगी? | :*पर्यावरण: प्रणाली के प्रभावी ढंग से संचालन के लिए किस वातावरण की अपेक्षा की जाएगी? | ||
प्रसिद्ध आवश्यकता वर्गीकरण मॉडल में [[हेवलेट पैकर्ड]] में विकसित [[FURPS]] और | ==== आर्किटेक्चरल आवश्यकताएं ==== | ||
आर्किटेक्चरल आवश्यकताएं बताती हैं कि प्रणाली के आवश्यक [[सिस्टम आर्किटेक्चर|प्रणाली आर्किटेक्चर]] की पहचान करके क्या किया जाना चाहिए। | |||
===== [[संरचना|संरचनात्मक]] आवश्यकताएं ===== | |||
संरचनात्मक आवश्यकताएं बताती हैं कि प्रणाली की आवश्यक संरचना की पहचान करके क्या किया जाना है। | |||
===== [[व्यवहार]] संबंधी आवश्यकताएं ===== | |||
व्यवहार संबंधी आवश्यकताएं बताती हैं कि प्रणाली के आवश्यक व्यवहार की पहचान करके क्या किया जाना है। | |||
==== [[कार्यात्मक आवश्यकता|कार्यात्मक आवश्यकताएं]] ==== | |||
कार्यात्मक आवश्यकताएं बताती हैं कि आवश्यक कार्य, क्रिया या गतिविधि की पहचान करके क्या किया जाना चाहिए जिसे पूरा किया जाना चाहिए। कार्यात्मक आवश्यकताओं के विश्लेषण का उपयोग कार्यात्मक विश्लेषण के लिए उच्च स्तरीय कार्यों के रूप में किया जाएगा।<ref name="SEF01" /> | |||
====== [[गैर-कार्यात्मक आवश्यकता|गैर-कार्यात्मक आवश्यकताएं]] ====== | |||
गैर-कार्यात्मक आवश्यकताएं ऐसी आवश्यकताएं हैं जो मानदंड निर्दिष्ट करती हैं जिनका उपयोग विशिष्ट व्यवहारों के अतिरिक्त प्रणाली के संचालन का न्याय करने के लिए किया जा सकता है। | |||
;प्रदर्शन आवश्यकताएँ: किसी मिशन या कार्य को किस सीमा तक निष्पादित किया जाना चाहिए; सामान्यतः मात्रा, गुणवत्ता, कवरेज, समयबद्धता या तैयारी के संदर्भ में मापा जाता है। आवश्यकताओं के विश्लेषण के समय, प्रणाली जीवन चक्र कारकों के आधार पर सभी पहचाने गए कार्यों में प्रदर्शन (इसे कितनी अच्छी तरह से किया जाना चाहिए) आवश्यकताओं को अंतःक्रियात्मक रूप से विकसित किया जाएगा; और उनके अनुमान में निश्चितता की डिग्री, प्रणाली की सफलता के लिए महत्वपूर्णता की डिग्री और अन्य आवश्यकताओं के साथ उनके संबंध के संदर्भ में विशेषता है।<ref name="SEF01" /> | |||
===== डिजाइन की आवश्यकताएं ===== | |||
:उत्पादों के लिए बिल्ड टू, कोड टू और बाय टू आवश्यकताएं और तकनीकी डेटा पैकेज और तकनीकी मैनुअल में व्यक्त प्रक्रियाओं के लिए आवश्यकताओं को कैसे निष्पादित करें।<ref name="SEF01" /> | |||
===== व्युत्पन्न आवश्यकताएँ ===== | |||
:आवश्यकताएँ जो निहित हैं या उच्च-स्तरीय आवश्यकता से रूपांतरित हैं। उदाहरण के लिए, लंबी दूरी या उच्च गति की आवश्यकता के परिणामस्वरूप कम वजन के लिए डिज़ाइन की आवश्यकता हो सकती है।<ref name="SEF01" /> | |||
====== आवंटित आवश्यकताएं ====== | |||
:एक आवश्यकता जो उच्च-स्तरीय आवश्यकता को कई निचले-स्तर की आवश्यकताओं में विभाजित या अन्यथा आवंटित करके स्थापित की जाती है। उदाहरण: दो उप-प्रणालियों से युक्त 100 पाउंड की वस्तु के परिणामस्वरूप दो निचले स्तर की वस्तुओं के लिए 70 पाउंड और 30 पाउंड वजन की आवश्यकता हो सकती है।<ref name="SEF01" /> | |||
प्रसिद्ध आवश्यकता वर्गीकरण मॉडल में [[हेवलेट पैकर्ड]] में विकसित [[FURPS|फ़र्प्स]] और फ़र्प्स+ सम्मिलित हैं। | |||
== आवश्यकता विश्लेषण | == आवश्यकता विश्लेषण उद्देश्य == | ||
=== हितधारक | === हितधारक उद्देश्य === | ||
स्टीव मैककोनेल, अपनी पुस्तक रैपिड डेवलपमेंट में, ऐसे कई विधियों | स्टीव मैककोनेल, अपनी पुस्तक रैपिड डेवलपमेंट में, ऐसे कई विधियों का विवरण देते हैं, जिनसे उपयोगकर्ता आवश्यकताओं को एकत्रित करने से रोक सकते हैं: | ||
* उपयोगकर्ता यह नहीं समझते हैं कि वे क्या चाहते हैं या उपयोगकर्ताओं को उनकी आवश्यकताओं के बारे में स्पष्ट जानकारी नहीं है | * उपयोगकर्ता यह नहीं समझते हैं कि वे क्या चाहते हैं या उपयोगकर्ताओं को उनकी आवश्यकताओं के बारे में स्पष्ट जानकारी नहीं है | ||
* उपयोगकर्ता लिखित आवश्यकताओं के | * उपयोगकर्ता लिखित आवश्यकताओं के समुच्चय के लिए प्रतिबद्ध नहीं होंगे | ||
* उपयोगकर्ता मूल्य | * उपयोगकर्ता मूल्य और शेड्यूल तय होने के बाद नई आवश्यकताओं पर जोर देते हैं | ||
* उपयोगकर्ताओं के साथ संचार धीमा है | * उपयोगकर्ताओं के साथ संचार धीमा है | ||
* उपयोगकर्ता अधिकांशतः | * उपयोगकर्ता अधिकांशतः समीक्षाओं में भाग नहीं लेते या ऐसा करने में असमर्थ होते हैं | ||
* उपयोगकर्ता तकनीकी रूप से अपरिष्कृत हैं | * उपयोगकर्ता तकनीकी रूप से अपरिष्कृत हैं | ||
* उपयोगकर्ता विकास प्रक्रिया को नहीं समझते हैं | * उपयोगकर्ता विकास प्रक्रिया को नहीं समझते हैं | ||
*उपयोक्ता वर्तमान तकनीक के बारे में नहीं जानते | *उपयोक्ता वर्तमान तकनीक के बारे में नहीं जानते | ||
इससे ऐसी स्थिति हो सकती है जहां प्रणाली या उत्पाद विकास | इससे ऐसी स्थिति हो सकती है जहां प्रणाली या उत्पाद विकास प्रारंभ होने पर भी उपयोगकर्ता की आवश्यकताएं बदलती रहती हैं। | ||
=== इंजीनियर/डेवलपर | === इंजीनियर/डेवलपर उद्देश्य === | ||
आवश्यकताओं के विश्लेषण के समय | आवश्यकताओं के विश्लेषण के समय इंजीनियरों और डेवलपर्स के कारण होने वाली संभावित समस्याएं हैं: | ||
* लेखन कोड के प्रति | * लेखन कोड के प्रति स्वाभाविक झुकाव आवश्यकताओं के विश्लेषण के पूरा होने से पहले कार्यान्वयन की प्रारंभ कर सकता है, संभावित रूप से वास्तविक आवश्यकताओं को पूरा करने के लिए कोड परिवर्तन के परिणामस्वरूप एक बार ज्ञात हो जाता है। | ||
* तकनीकी कर्मियों और अंतिम उपयोगकर्ताओं के पास अलग-अलग शब्दावली हो सकती है। | * तकनीकी कर्मियों और अंतिम उपयोगकर्ताओं के पास अलग-अलग शब्दावली हो सकती है। परिणाम स्वरुप, वे अनुचित विधि से विश्वास कर सकते हैं कि तैयार उत्पाद की आपूर्ति होने तक वे पूर्ण समझौते में हैं। | ||
* इंजीनियर और डेवलपर ग्राहक की आवश्यकता के लिए विशिष्ट प्रणाली विकसित करने के अतिरिक्त | * इंजीनियर और डेवलपर ग्राहक की आवश्यकता के लिए विशिष्ट प्रणाली विकसित करने के अतिरिक्त आवश्यकताओं को वर्तमान प्रणाली या मॉडल के अनुरूप बनाने का प्रयास कर सकते हैं। | ||
=== प्रयास किए गए समाधान === | === प्रयास किए गए समाधान === | ||
संचार समस्याओं के समाधान का | संचार समस्याओं के समाधान का प्रयास व्यवसाय या प्रणाली विश्लेषण में विशेषज्ञों को नियुक्त करना रहा है। | ||
1990 के दशक में | 1990 के दशक में प्रारंभ की गई तकनीक जैसे [[सॉफ्टवेयर प्रोटोटाइप]], [[एकीकृत मॉडलिंग भाषा]] (यूएमएल), केस का उपयोग करें, और फुर्तीली सॉफ्टवेयर डेवलपमेंट भी पिछले विधियों के साथ आने वाली समस्याओं के समाधान के रूप में हैं। | ||
साथ ही, [[एप्लीकेशन सिमुलेशन सॉफ्टवेयर|अनुप्रयोग | साथ ही, [[एप्लीकेशन सिमुलेशन सॉफ्टवेयर|अनुप्रयोग सिमुलेशन सॉफ्टवेयर]] या अनुप्रयोगों डेफ़िनिशन टूल के नए वर्ग ने व्यापार में प्रवेश किया है। ये उपकरण व्यापार उपयोगकर्ताओं और आईटी संगठन के बीच संचार की खाई को पाटने के लिए डिज़ाइन किए गए हैं - और किसी भी कोड के उत्पादन से पहले अनुप्रयोगों को 'परीक्षण विपणन' करने की अनुमति देने के लिए भी। इनमें से सर्वश्रेष्ठ उपकरण प्रदान करते हैं: | ||
* [[इलेक्ट्रॉनिक व्हाइटबोर्ड]] | * [[इलेक्ट्रॉनिक व्हाइटबोर्ड]] अनुप्रयोगों प्रवाह को स्केच करने और विकल्पों का परीक्षण करने के लिए | ||
* व्यापार तर्क और डेटा आवश्यकता को पकड़ने की क्षमता | * व्यापार तर्क और डेटा आवश्यकता को पकड़ने की क्षमता | ||
* उच्च निष्ठा वाले प्रोटोटाइप उत्पन्न करने की क्षमता जो अंतिम | * उच्च निष्ठा वाले प्रोटोटाइप उत्पन्न करने की क्षमता जो अंतिम अनुप्रयोगों की सूक्ष्मता से प्रतिलिपि करते हैं | ||
* अन्तरक्रियाशीलता | * अन्तरक्रियाशीलता | ||
* प्रासंगिक आवश्यकताओं और अन्य टिप्पणियों को जोड़ने की क्षमता | * प्रासंगिक आवश्यकताओं और अन्य टिप्पणियों को जोड़ने की क्षमता | ||
| Line 176: | Line 197: | ||
* [[सॉफ़्टवेयर आवश्यकताएं]] | * [[सॉफ़्टवेयर आवश्यकताएं]] | ||
* सॉफ्टवेयर आवश्यकता विशिष्टता | * सॉफ्टवेयर आवश्यकता विशिष्टता | ||
* [[ | * [[प्रणाली विश्लेषण]] | ||
* [[ | * [[प्रणाली आवश्यकताएं]] | ||
* [[ | * [[प्रणाली आवश्यकताएँ विनिर्देश]] | ||
* [[उपयोगकर्ता-केंद्रित डिजाइन]] | * [[उपयोगकर्ता-केंद्रित डिजाइन]] | ||
{{Div col end}} | {{Div col end}} | ||
| Line 209: | Line 230: | ||
{{Systems Engineering}} | {{Systems Engineering}} | ||
{{DEFAULTSORT:Requirements Analysis}} | {{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: | [[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
| Part of a series on |
| Software development |
|---|
प्रणाली इंजीनियरिंग और सॉफ्टवेयर इंजीनियरिंग में, आवश्यकताओं का विश्लेषण उन कार्यों पर ध्यान केंद्रित करता है जो नए या परिवर्तित उत्पाद या परियोजना को पूरा करने के लिए आवश्यकता या शर्तों को निर्धारित करते हैं, विभिन्न हितधारकों (कॉर्पोरेट) की संभावित परस्पर विरोधी आवश्यकताओं को ध्यान में रखते हुए, 'विश्लेषण, दस्तावेजीकरण,' सॉफ़्टवेयर या प्रणाली आवश्यकताओं को मान्य और प्रबंधित करना होता है।[2]
आवश्यकताओं का विश्लेषण प्रणाली या सॉफ़्टवेयर परियोजना प्रबंधन की सफलता या विफलता के लिए महत्वपूर्ण है।[3] आवश्यकताओं को प्रलेखित, कार्रवाई योग्य, मापने योग्य, परीक्षण योग्य, पता लगाने योग्य, पहचानी गई व्यावसायिक आवश्यकताओं या अवसरों से संबंधित होना चाहिए, और प्रणाली डिज़ाइन के लिए पर्याप्त विवरण के स्तर तक परिभाषित किया जाना चाहिए।
अवलोकन
वैचारिक रूप से, आवश्यकताओं के विश्लेषण में तीन प्रकार की गतिविधियाँ सम्मिलित हैं ।
- आवश्यकताएं प्राप्त करना: (उदाहरण के लिए परियोजना चार्टर या परिभाषा), व्यवसाय प्रक्रिया प्रलेखन, और हितधारक साक्षात्कार। इसे कभी-कभी आवश्यकताएं एकत्र करना या आवश्यकताओं की खोज भी कहा जाता है।
- रिकॉर्डिंग आवश्यकताएँ: आवश्यकताओं को विभिन्न रूपों में प्रलेखित किया जा सकता है, सामान्यतः सारांश सूची सहित और इसमें प्राकृतिक भाषा के आलेख, उपयोग के स्थितियों, उपयोगकर्ता कहानी, प्रक्रिया विनिर्देश और डेटा मॉडल सहित विभिन्न प्रकार के मॉडल सम्मिलित हो सकते हैं।
- आवश्यकताओं का विश्लेषण: यह निर्धारित करना कि बताई गई आवश्यकताएं स्पष्ट, पूर्ण, अनुलिपित, संक्षिप्त, वैध, सुसंगत और स्पष्ट हैं, और किसी भी स्पष्ट संघर्ष को हल करती हैं। विश्लेषण में आकार देने की आवश्यकताएं भी सम्मिलित हो सकती हैं।
आवश्यकता विश्लेषण लंबी और बड़ी प्रक्रिया हो सकती है जिसके समय कई हल्का मनोवैज्ञानिक कौशल सम्मिलित होते हैं। नई प्रणालियाँ पर्यावरण और लोगों के बीच संबंधों को बदलती हैं, इसलिए सभी हितधारकों की पहचान करना, उनकी सभी आवश्यकताओं को ध्यान में रखना और यह सुनिश्चित करना महत्वपूर्ण है कि वे नई प्रणालियों के निहितार्थों को समझें। ग्राहक से आवश्यकताओं को पूरा करने के लिए विश्लेषक कई तकनीकों को नियोजित कर सकते हैं। इनमें परिदृश्यों का विकास (एजाइल सॉफ्टवेयर विकास में उपयोगकर्ता की कहानी के रूप में दर्शाया गया), उपयोग के स्थितियों की पहचान, कार्यस्थल अवलोकन या नृवंशविज्ञान का उपयोग, साक्षात्कार आयोजित करना, या फोकस समूह सम्मिलित हो सकते हैं (अधिक उपयुक्त रूप से आवश्यकता कार्यशालाओं के रूप में इस संदर्भ में नामित, या आवश्यकताओं की समीक्षा सत्र) और आवश्यकताओं की सूची बनाना है। प्रोटोटाइप का उपयोग उदाहरण प्रणाली विकसित करने के लिए किया जा सकता है जिसे हितधारकों को प्रदर्शित किया जा सकता है। जहाँ आवश्यक हो, विश्लेषक हितधारकों की सही आवश्यकताओं को स्थापित करने के लिए इन विधियों के संयोजन को नियोजित करेगा, चुकी व्यावसायिक आवश्यकताओं को पूरा करने वाली प्रणाली का उत्पादन किया जा सके। आवश्यकताओं की गुणवत्ता इन और अन्य विधियों के माध्यम से सुधारी जा सकती है
- दृश्य वांछित अंत-उत्पाद जैसे विज़ुअलाइज़ेशन और सिमुलेशन की अच्छी समझ को बढ़ावा देने वाले टूल का उपयोग करना।
- टेम्प्लेट का लगातार उपयोग आवश्यकताओं को दस्तावेज करने के लिए मॉडल और टेम्पलेट्स का सतत समुच्चय तैयार करना।
- आलेखकरण निर्भरता (परियोजना प्रबंधन)। आवश्यकताओं के साथ-साथ किसी भी धारणा और मण्डली के बीच निर्भरता और अंतर्संबंधों का दस्तावेजीकरण होता है।
आवश्यकता विश्लेषण विषय
हितधारक पहचान
लोगों या संगठनों (कंपनियों, मानक निकायों जैसी कानूनी संस्थाएं) की चर्चा के लिए हितधारक विश्लेषण देखें, जिनका प्रणाली में वैध हित है। वे प्रत्यक्ष या अप्रत्यक्ष रूप से इससे प्रभावित हो सकते हैं।
1990 के दशक में प्रमुख नया जोर हितधारकों की पहचान पर केंद्रित था। यह तीव्रता से मान्यता प्राप्त है कि हितधारक विश्लेषक को नियुक्त करने वाले संगठन तक ही सीमित नहीं हैं। अन्य हितधारकों में सम्मिलित होंगे।
- कोई भी जो प्रणाली संचालित करता है (सामान्य और देखरेख नियंत्रक)
- कोई भी जो प्रणाली से लाभान्वित होता है (कार्यात्मक, राजनीतिक, वित्तीय और सामाजिक लाभार्थी)
- प्रणाली को खरीदने या प्राप्त करने में सम्मिलित कोई भी व्यक्ति। बड़े पैमाने पर व्यापार उत्पाद संगठन में, उत्पाद प्रबंधन, विपणन और कभी-कभी बिक्री उत्पाद के विकास को निर्देशित करने के लिए सरोगेट उपभोक्ताओं (बड़े पैमाने पर व्यापार के ग्राहक) के रूप में कार्य करती है।
- संगठन जो प्रणाली के पहलुओं को विनियमित करते हैं । (वित्तीय, सुरक्षा और अन्य नियामक)
- प्रणाली के विरोध में लोग या संगठन (नकारात्मक हितधारक; दुरुपयोग की स्थितियों भी देखें)
- प्रणाली के लिए जिम्मेदार संगठन जो बनावट के द्वारा प्रणाली के साथ इंटरफेस करते हैं।
- वे संगठन जो उस संगठन के साथ क्षैतिज एकीकरण करते हैं जिसके लिए विश्लेषक प्रणाली डिजाइन कर रहा है।
संयुक्त आवश्यकताएं विकास (जेआरडी) सत्र
आवश्यकताओं में अधिकांशतः क्रॉस-फ़ंक्शनल निहितार्थ होते हैं जो व्यक्तिगत हितधारकों के लिए अज्ञात होते हैं और अधिकांशतः हितधारक साक्षात्कार के समय चूक जाते हैं या अपूर्ण रूप से परिभाषित होते हैं। इन क्रॉस-फंक्शनल निहितार्थों को नियंत्रित वातावरण में जेआरडी सत्र आयोजित करके, प्रशिक्षित फैसिलिटेटर (बिजनेस विश्लेषक) द्वारा सुगम बनाया जा सकता है, जिसमें हितधारक आवश्यकताओं को पूरा करने, उनके विवरणों का विश्लेषण करने और क्रॉस-फंक्शनल निहितार्थों को उजागर करने के लिए चर्चा में भाग लेते हैं। समर्पित मुंशी को चर्चा का दस्तावेजीकरण करने के लिए उपस्थित होना चाहिए, व्यापार विश्लेषक को चर्चा को उस दिशा में ले जाने के लिए मुक्त करना चाहिए जो उपयुक्त आवश्यकताओं को उत्पन्न करता है जो सत्र के उद्देश्य को पूरा करते हैं।
जेआरडी सत्र संयुक्त अनुप्रयोग डिजाइन सत्र के समान हैं। पूर्व में, सत्र आवश्यकताओं को पूरा करते हैं जो डिजाइन को निर्देशित करते हैं, जबकि बाद वाले विशिष्ट डिजाइन सुविधाओं को विशिष्ट आवश्यकताओं की संतुष्टि में प्रयुक्त करने के लिए प्रेरित करते हैं।
अनुबंध-शैली की आवश्यकता सूची
आलेखकरण आवश्यकताओं का पारंपरिक विधियाँ अनुबंध शैली आवश्यकता सूची रहा है। जटिल प्रणाली में ऐसी आवश्यकताओं की सूची सैकड़ों पृष्ठों तक लंबी हो सकती है।
उपयुक्त रूपक खरीदारी की बहुत लंबी सूची होगी। ऐसी सूचियाँ आधुनिक विश्लेषण में बहुत अधिक अनुकूल हैं; क्योंकि वे अपने लक्ष्यों को प्राप्त करने में शानदार रूप से असफल सिद्ध हुए हैं; लेकिन वे आज भी देखे जाते हैं।
ताकत
- आवश्यकताओं की चेकलिस्ट प्रदान करता है।
- परियोजना प्रायोजक(रों) और डेवलपर्स के बीच अनुबंध प्रदान करें।
- बड़ी प्रणाली के लिए उच्च स्तरीय विवरण प्रदान कर सकता है जिससे निचले स्तर की आवश्यकताओं को प्राप्त किया जा सकता है।
कमजोरियां
- ऐसी सूचियाँ सैकड़ों पृष्ठों तक चल सकती हैं। वे वांछित अनुप्रयोगों के पाठक के अनुकूल विवरण के रूप में सेवा करने का लक्ष्य नहीं रखते हैं।
- इस तरह की आवश्यकताएं सभी आवश्यकताओं को सूचीबद्ध करती हैं और इसलिए बहुत कम संदर्भ है। व्यापार विश्लेषक डिजाइन प्रलेखन के साथ आवश्यकताओं के लिए संदर्भ सम्मिलित कर सकता है।
- इस अमूर्तता का उद्देश्य यह वर्णन करना नहीं है कि आवश्यकताएं कैसे फिट होती हैं या एक साथ काम करती हैं।
- सूची आवश्यकताओं के बीच संबंधों और निर्भरताओं को प्रतिबिंबित नहीं कर सकती है। जबकि सूची प्रत्येक व्यक्तिगत आइटम को प्राथमिकता देना सरल बनाती है, आइटम को संदर्भ से बाहर निकालने से संपूर्ण उपयोग स्थितियों या व्यावसायिक आवश्यकता ख़राब हो सकती है।
- वांछित प्रणाली अनुप्रयोग के डिजाइन के निहितार्थों की अच्छी साझा समझ प्राप्त करने के लिए सूची हितधारकों के साथ सावधानीपूर्वक आवश्यकताओं की समीक्षा करने की आवश्यकता को प्रतिस्थापित नहीं करती है।
- केवल सूची बनाने से इसकी पूर्णता की कारण, नहीं होता है। व्यापार विश्लेषक को पर्याप्त रूप से व्यापक सूची खोजने और एकत्र करने के लिए अच्छा विश्वास प्रयास करना चाहिए, और गायब आवश्यकताओं को इंगित करने के लिए हितधारकों पर विश्वास करना चाहिए।
- ये सूचियाँ हितधारकों और डेवलपर्स के बीच आपसी समझ की झूठी भावना उत्पन्न कर सकती हैं; व्यापार विश्लेषक अनुवाद प्रक्रिया के लिए महत्वपूर्ण हैं।
- विकास और परीक्षण की प्रक्रिया प्रारंभ होने से पहले सभी कार्यात्मक आवश्यकताओं को उजागर करना लगभग असंभव है। यदि इन सूचियों को अपरिवर्तनीय अनुबंध के रूप में माना जाता है, तो विकास प्रक्रिया में उभरने वाली आवश्यकताएं विवादास्पद परिवर्तन अनुरोध उत्पन्न कर सकती हैं।
आवश्यकता सूचियों का विकल्प
आवश्यकता सूचियों के विकल्प के रूप में, फुर्तीली सॉफ़्टवेयर डेवलपमेंट रोज़मर्रा की भाषा में आवश्यकताओं का सुझाव देने के लिए उपयोगकर्ता कहानियों का उपयोग करती है।
मापने योग्य लक्ष्य
सर्वोत्तम अभ्यास आवश्यकताओं की संकलित सूची को केवल चिह्न के रूप में लेती हैं और बार-बार पूछती हैं कि क्यों? जब तक वास्तविक व्यावसायिक उद्देश्यों की खोज नहीं हो जाती है। हितधारक और विकासकर्ता इसके बाद यह मापने के लिए परीक्षण तैयार कर सकते हैं कि अब तक प्रत्येक लक्ष्य के किस स्तर को प्राप्त किया गया है। इस तरह के लक्ष्य विशिष्ट लेकिन अनिर्धारित आवश्यकताओं की लंबी सूची की तुलना में अधिक धीरे-धीरे बदलते हैं। एक बार महत्वपूर्ण, मापा लक्ष्यों का छोटा सेट स्थापित हो जाने के बाद, परियोजना के आधा होने से बहुत पहले वास्तविक हितधारक मूल्य देने के लिए तीव्रता से प्रोटोटाइप और लघु पुनरावृत्त विकास चरण आगे बढ़ सकते हैं।
प्रोटोटाइप
प्रोटोटाइप कंप्यूटर प्रोग्राम है जो किसी अन्य कंप्यूटर प्रोग्राम के गुणों का भाग प्रदर्शित करता है, जिससे उपयोगकर्ता ऐसे अनुप्रयोगों की कल्पना कर सकते हैं जो अभी तक निर्मित नहीं हुआ है। प्रोटोटाइप का लोकप्रिय रूप मॉकअप है, जो भविष्य के उपयोगकर्ताओं और अन्य हितधारकों को यह जानने कि "प्रणाली कैसा दिखेगा" में सहायता करता है। प्रोटोटाइप डिजाइन निर्णय लेना सरल बनाते हैं, क्योंकि अनुप्रयोगों के निर्माण से पहले अनुप्रयोगों के पहलुओं को देखा और साझा किया जा सकता है। प्रोटोटाइप के प्रारंभ के साथ उपयोगकर्ताओं और डेवलपर्स के बीच संचार में बड़े सुधार अधिकांशतः देखे गए थे। अनुप्रयोगों के प्रारंभिक विचारों ने बाद में कम बदलाव किए और इसलिए समग्र मूल्य में अधिक कमी आई।
प्रोटोटाइप फ्लैट आरेख (अधिकांशतः तार-फ्रेम मॉडल के रूप में संदर्भित) या संश्लेषित कार्यक्षमता का उपयोग करके काम करने वाले अनुप्रयोग हो सकते हैं। वायरफ्रेम विभिन्न प्रकार के ग्राफ़िक डिज़ाइन आरेख में बनाए जाते हैं, और अधिकांशतः डिज़ाइन से सभी रंगों को हटा देते हैं (अर्थात ग्रेस्केल रंग पैलेट का उपयोग करें) ऐसे स्थितियों में जहाँ अंतिम सॉफ़्टवेयर में ग्राफिक डिज़ाइन प्रयुक्त होने की आशा होती है। यह भ्रम को रोकने में सहायता करता है कि क्या प्रोटोटाइप अंतिम दृश्य रूप और अनुप्रयोगों के अनुभव का प्रतिनिधित्व करता है।
स्थितियों का प्रयोग करें
उपयोग स्थितियों में प्रणाली के लिए कार्यात्मक आवश्यकताओं के दस्तावेजीकरण के लिए संरचना है, जिसमें सामान्यतः सॉफ्टवेयर सम्मिलित होता है, चाहे वह नया हो या बदला जा रहा हो। प्रत्येक उपयोग स्थितियों परिदृश्यों का समुच्चय प्रदान करता है जो बताता है कि किसी विशिष्ट व्यावसायिक लक्ष्य को प्राप्त करने के लिए प्रणाली को मानव उपयोगकर्ता या अन्य प्रणाली के साथ कैसे इंटरैक्ट करना चाहिए। उपयोग के लिए सामान्यतः तकनीकी शब्दजाल से बचते हैं, इसके अतिरिक्त अंतिम उपयोगकर्ता या डोमेन विशेषज्ञ की भाषा को प्राथमिकता देते हैं। उपयोग के स्थिति अधिकांशतः आवश्यकता इंजीनियरों और हितधारकों द्वारा सह-लेखक होते हैं।
उपयोग स्थिति सॉफ्टवेयर या प्रणाली के व्यवहार का वर्णन करने के लिए भ्रामक सरल उपकरण हैं। उपयोग के स्थितियों में उन विधियों का पाठ्य विवरण होता है जिसमें उपयोगकर्ताओं को सॉफ़्टवेयर या प्रणाली के साथ काम करने का लक्ष्य होता है। उपयोग के स्थितियों को प्रणाली की आंतरिक कार्यप्रणाली का वर्णन नहीं करना चाहिए, न ही उन्हें यह बताना चाहिए कि प्रणाली कैसे प्रयुक्त किया जाएगा। इसके अतिरिक्त, वे अनुक्रमिक मान्यताओं के बिना किसी कार्य को करने के लिए आवश्यक कदम दिखाते हैं।
सॉफ्टवेयर आवश्यकता विनिर्देश
आवश्यकताएँ विनिर्देश वर्तमान राज्य की व्यावसायिक आवश्यकताओं के बारे में खोज निष्कर्षों का संश्लेषण है और इन आवश्यकताओं के मूल्यांकन को निर्धारित करने और निर्दिष्ट करने के लिए, समाधान के क्षेत्र में फोकस में आवश्यकताओं को पूरा करने के लिए क्या आवश्यक है। खोज, विश्लेषण और विनिर्देश वर्तमान स्थिति से समझ को भविष्य की स्थिति में ले जाते हैं। आवश्यकताएं विनिर्देश भविष्य की स्थिति की पूरी चौड़ाई और गहराई को समझ सकते हैं, या इसे भरने के लिए विशिष्ट अंतराल को लक्षित कर सकते हैं, जैसे प्राथमिकता सॉफ़्टवेयर प्रणाली दोष को ठीक करने और बढ़ाने के लिए होता है। यह देखते हुए कि कोई भी बड़ी व्यावसायिक प्रक्रिया लगभग हमेशा सॉफ्टवेयर और डेटा प्रणाली और प्रौद्योगिकी को नियोजित करती है, आवश्यकता विनिर्देश अधिकांशतः सॉफ्टवेयर प्रणाली के निर्माण, खरीद, क्लाउड कंप्यूटिंग रणनीतियों, उत्पादों या उपकरणों में एम्बेडेड सॉफ़्टवेयर या अन्य तकनीकों से जुड़ा होता है। आवश्यकताओं के विनिर्देश की व्यापक परिभाषा में प्रशिक्षण, प्रलेखन गाइड, कार्मिक, विपणन रणनीति, उपकरण, आपूर्ति आदि जैसे किसी भी समाधान रणनीति या घटक को सम्मिलित किया गया है या उस पर ध्यान केंद्रित किया गया है।
आवश्यकताओं के प्रकार
आवश्यकताएँ कई तरह से वर्गीकरण हैं। तकनीकी प्रबंधन से संबंधित आवश्यकताओं के सामान्य वर्गीकरण निम्नलिखित हैं:[1]
- व्यापार की आवश्यकताएं
- विस्तृत कार्यक्षमता के संदर्भ के बिना व्यापार स्तर के लक्ष्यों का विवरण करना। ये सामान्यतः उच्च स्तरीय (सॉफ़्टवेयर और/या हार्डवेयर) क्षमताएं होती हैं जिनकी व्यावसायिक परिणाम प्राप्त करने के लिए आवश्यकता होती है।
- ग्राहक की आवश्यकताएं
- तथ्य और मान्यताओं के तथ्य जो मिशन के उद्देश्यों, पर्यावरण, बाधाओं और प्रभावशीलता और उपयुक्तता के उपायों (एमओई/एमओएस) के संदर्भ में प्रणाली की अपेक्षाओं को परिभाषित करते हैं। ग्राहक वे हैं जो मुख्य ग्राहक के रूप में ऑपरेटर पर विशेष जोर देने के साथ प्रणाली इंजीनियरिंग के आठ प्राथमिक कार्य करते हैं। संचालन संबंधी आवश्यकताएं मूलभूत आवश्यकता को परिभाषित करेंगी और कम से कम निम्नलिखित सूची में पूछे गए प्रश्नों के उत्तर देंगी:[1]
- ऑपरेशनल वितरण या तैनाती: प्रणाली का प्रयोग कहां किया जाएगा?
- मिशन प्रोफ़ाइल या परिदृश्य: प्रणाली अपने मिशन के उद्देश्य को कैसे पूरा करेगा?
- प्रदर्शन और संबंधित पैरामीटर: मिशन को पूरा करने के लिए महत्वपूर्ण प्रणाली पैरामीटर क्या हैं?
- उपयोगिता वातावरण: विभिन्न प्रणाली घटकों का उपयोग कैसे किया जाता है?
- प्रभावकारिता आवश्यकताएँ: प्रणाली अपने मिशन को पूरा करने में कितना प्रभावी या कुशल होना चाहिए?
- परिचालन जीवन चक्र: उपयोगकर्ता द्वारा प्रणाली कब तक उपयोग में रहेगा?
- पर्यावरण: प्रणाली के प्रभावी ढंग से संचालन के लिए किस वातावरण की अपेक्षा की जाएगी?
आर्किटेक्चरल आवश्यकताएं
आर्किटेक्चरल आवश्यकताएं बताती हैं कि प्रणाली के आवश्यक प्रणाली आर्किटेक्चर की पहचान करके क्या किया जाना चाहिए।
संरचनात्मक आवश्यकताएं
संरचनात्मक आवश्यकताएं बताती हैं कि प्रणाली की आवश्यक संरचना की पहचान करके क्या किया जाना है।
व्यवहार संबंधी आवश्यकताएं
व्यवहार संबंधी आवश्यकताएं बताती हैं कि प्रणाली के आवश्यक व्यवहार की पहचान करके क्या किया जाना है।
कार्यात्मक आवश्यकताएं
कार्यात्मक आवश्यकताएं बताती हैं कि आवश्यक कार्य, क्रिया या गतिविधि की पहचान करके क्या किया जाना चाहिए जिसे पूरा किया जाना चाहिए। कार्यात्मक आवश्यकताओं के विश्लेषण का उपयोग कार्यात्मक विश्लेषण के लिए उच्च स्तरीय कार्यों के रूप में किया जाएगा।[1]
गैर-कार्यात्मक आवश्यकताएं
गैर-कार्यात्मक आवश्यकताएं ऐसी आवश्यकताएं हैं जो मानदंड निर्दिष्ट करती हैं जिनका उपयोग विशिष्ट व्यवहारों के अतिरिक्त प्रणाली के संचालन का न्याय करने के लिए किया जा सकता है।
- प्रदर्शन आवश्यकताएँ
- किसी मिशन या कार्य को किस सीमा तक निष्पादित किया जाना चाहिए; सामान्यतः मात्रा, गुणवत्ता, कवरेज, समयबद्धता या तैयारी के संदर्भ में मापा जाता है। आवश्यकताओं के विश्लेषण के समय, प्रणाली जीवन चक्र कारकों के आधार पर सभी पहचाने गए कार्यों में प्रदर्शन (इसे कितनी अच्छी तरह से किया जाना चाहिए) आवश्यकताओं को अंतःक्रियात्मक रूप से विकसित किया जाएगा; और उनके अनुमान में निश्चितता की डिग्री, प्रणाली की सफलता के लिए महत्वपूर्णता की डिग्री और अन्य आवश्यकताओं के साथ उनके संबंध के संदर्भ में विशेषता है।[1]
डिजाइन की आवश्यकताएं
- उत्पादों के लिए बिल्ड टू, कोड टू और बाय टू आवश्यकताएं और तकनीकी डेटा पैकेज और तकनीकी मैनुअल में व्यक्त प्रक्रियाओं के लिए आवश्यकताओं को कैसे निष्पादित करें।[1]
व्युत्पन्न आवश्यकताएँ
- आवश्यकताएँ जो निहित हैं या उच्च-स्तरीय आवश्यकता से रूपांतरित हैं। उदाहरण के लिए, लंबी दूरी या उच्च गति की आवश्यकता के परिणामस्वरूप कम वजन के लिए डिज़ाइन की आवश्यकता हो सकती है।[1]
आवंटित आवश्यकताएं
- एक आवश्यकता जो उच्च-स्तरीय आवश्यकता को कई निचले-स्तर की आवश्यकताओं में विभाजित या अन्यथा आवंटित करके स्थापित की जाती है। उदाहरण: दो उप-प्रणालियों से युक्त 100 पाउंड की वस्तु के परिणामस्वरूप दो निचले स्तर की वस्तुओं के लिए 70 पाउंड और 30 पाउंड वजन की आवश्यकता हो सकती है।[1]
प्रसिद्ध आवश्यकता वर्गीकरण मॉडल में हेवलेट पैकर्ड में विकसित फ़र्प्स और फ़र्प्स+ सम्मिलित हैं।
आवश्यकता विश्लेषण उद्देश्य
हितधारक उद्देश्य
स्टीव मैककोनेल, अपनी पुस्तक रैपिड डेवलपमेंट में, ऐसे कई विधियों का विवरण देते हैं, जिनसे उपयोगकर्ता आवश्यकताओं को एकत्रित करने से रोक सकते हैं:
- उपयोगकर्ता यह नहीं समझते हैं कि वे क्या चाहते हैं या उपयोगकर्ताओं को उनकी आवश्यकताओं के बारे में स्पष्ट जानकारी नहीं है
- उपयोगकर्ता लिखित आवश्यकताओं के समुच्चय के लिए प्रतिबद्ध नहीं होंगे
- उपयोगकर्ता मूल्य और शेड्यूल तय होने के बाद नई आवश्यकताओं पर जोर देते हैं
- उपयोगकर्ताओं के साथ संचार धीमा है
- उपयोगकर्ता अधिकांशतः समीक्षाओं में भाग नहीं लेते या ऐसा करने में असमर्थ होते हैं
- उपयोगकर्ता तकनीकी रूप से अपरिष्कृत हैं
- उपयोगकर्ता विकास प्रक्रिया को नहीं समझते हैं
- उपयोक्ता वर्तमान तकनीक के बारे में नहीं जानते
इससे ऐसी स्थिति हो सकती है जहां प्रणाली या उत्पाद विकास प्रारंभ होने पर भी उपयोगकर्ता की आवश्यकताएं बदलती रहती हैं।
इंजीनियर/डेवलपर उद्देश्य
आवश्यकताओं के विश्लेषण के समय इंजीनियरों और डेवलपर्स के कारण होने वाली संभावित समस्याएं हैं:
- लेखन कोड के प्रति स्वाभाविक झुकाव आवश्यकताओं के विश्लेषण के पूरा होने से पहले कार्यान्वयन की प्रारंभ कर सकता है, संभावित रूप से वास्तविक आवश्यकताओं को पूरा करने के लिए कोड परिवर्तन के परिणामस्वरूप एक बार ज्ञात हो जाता है।
- तकनीकी कर्मियों और अंतिम उपयोगकर्ताओं के पास अलग-अलग शब्दावली हो सकती है। परिणाम स्वरुप, वे अनुचित विधि से विश्वास कर सकते हैं कि तैयार उत्पाद की आपूर्ति होने तक वे पूर्ण समझौते में हैं।
- इंजीनियर और डेवलपर ग्राहक की आवश्यकता के लिए विशिष्ट प्रणाली विकसित करने के अतिरिक्त आवश्यकताओं को वर्तमान प्रणाली या मॉडल के अनुरूप बनाने का प्रयास कर सकते हैं।
प्रयास किए गए समाधान
संचार समस्याओं के समाधान का प्रयास व्यवसाय या प्रणाली विश्लेषण में विशेषज्ञों को नियुक्त करना रहा है।
1990 के दशक में प्रारंभ की गई तकनीक जैसे सॉफ्टवेयर प्रोटोटाइप, एकीकृत मॉडलिंग भाषा (यूएमएल), केस का उपयोग करें, और फुर्तीली सॉफ्टवेयर डेवलपमेंट भी पिछले विधियों के साथ आने वाली समस्याओं के समाधान के रूप में हैं।
साथ ही, अनुप्रयोग सिमुलेशन सॉफ्टवेयर या अनुप्रयोगों डेफ़िनिशन टूल के नए वर्ग ने व्यापार में प्रवेश किया है। ये उपकरण व्यापार उपयोगकर्ताओं और आईटी संगठन के बीच संचार की खाई को पाटने के लिए डिज़ाइन किए गए हैं - और किसी भी कोड के उत्पादन से पहले अनुप्रयोगों को 'परीक्षण विपणन' करने की अनुमति देने के लिए भी। इनमें से सर्वश्रेष्ठ उपकरण प्रदान करते हैं:
- इलेक्ट्रॉनिक व्हाइटबोर्ड अनुप्रयोगों प्रवाह को स्केच करने और विकल्पों का परीक्षण करने के लिए
- व्यापार तर्क और डेटा आवश्यकता को पकड़ने की क्षमता
- उच्च निष्ठा वाले प्रोटोटाइप उत्पन्न करने की क्षमता जो अंतिम अनुप्रयोगों की सूक्ष्मता से प्रतिलिपि करते हैं
- अन्तरक्रियाशीलता
- प्रासंगिक आवश्यकताओं और अन्य टिप्पणियों को जोड़ने की क्षमता
- दूरस्थ और वितरित उपयोगकर्ताओं के लिए सिमुलेशन चलाने और बातचीत करने की क्षमता
यह भी देखें
- व्यावसायिक विश्लेषण
- व्यापार विश्लेषण ज्ञान का निकाय (बाबोक)
- व्यावसायिक प्रक्रिया रीइंजीनियरिंग
- रचनात्मक संक्षिप्त
- मॉडलिंग की दिनांक
- संक्षेप डिज़ाइन
- कार्यकारी आवश्यकताएं
- सूचान प्रौद्योगिकी
- मॉडल संचालित इंजीनियरिंग
- मॉडल परिवर्तन भाषा
- आकलन की आवश्यकता है
- गैर-कार्यात्मक आवश्यकताएं
- प्रक्रिया संरचना
- प्रक्रिया मॉडलिंग
- उत्पाद फिट विश्लेषण
- आवश्यकता निकालना
- आवश्यकताएँ इंजीनियरिंग विशेषज्ञ समूह
- आवश्यकता प्रबंधन
- आवश्यकताएँ पता लगाने की क्षमता
- खोज आधारित सॉफ्टवेयर इंजीनियरिंग
- सॉफ्टवेयर प्रोटोटाइप
- सॉफ़्टवेयर आवश्यकताएं
- सॉफ्टवेयर आवश्यकता विशिष्टता
- प्रणाली विश्लेषण
- प्रणाली आवश्यकताएं
- प्रणाली आवश्यकताएँ विनिर्देश
- उपयोगकर्ता-केंद्रित डिजाइन
संदर्भ
- ↑ 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
- ↑ Kotonya, Gerald; Sommerville, Ian (1998). Requirements Engineering: Processes and Techniques. Chichester, UK: John Wiley and Sons. ISBN 9780471972082.
- ↑ 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.
ग्रन्थसूची
- Brian Berenbach; Daniel Paulish; Juergen Katzmeier; Arnold Rudorfer (2009). Software & Systems Requirements Engineering: In Practice. New York: McGraw-Hill Professional. ISBN 978-0-07-160547-2.
- Hay, David C. (2003). Requirements Analysis: From Business Views to Architecture (1st ed.). Upper Saddle River, NJ: Prentice Hall. ISBN 0-13-028228-6.
- Laplante, Phil (2009). Requirements Engineering for Software and Systems (1st ed.). Redmond, WA: CRC Press. ISBN 978-1-4200-6467-4.
- McConnell, Steve (1996). Rapid Development: Taming Wild Software Schedules (1st ed.). Redmond, WA: Microsoft Press. ISBN 1-55615-900-5.
- Nuseibeh, B.; Easterbrook, S. (2000). Requirements engineering: a roadmap (PDF). ICSE'00. Proceedings of the conference on the future of Software engineering. pp. 35–46. CiteSeerX 10.1.1.131.3116. doi:10.1145/336512.336523. ISBN 1-58113-253-0.
- Andrew Stellman & Jennifer Greene (2005). Applied Software Project Management. Cambridge, MA: O'Reilly Media. ISBN 0-596-00948-8.
- Karl Wiegers & Joy Beatty (2013). Software Requirements (3rd ed.). Redmond, WA: Microsoft Press. ISBN 978-0-7356-7966-5.
बाहरी संबंध
- Peer-reviewed Encyclopedia Entry on Requirements Engineering and Analysis
- Defense Acquisition University Stakeholder Requirements Definition Process[dead link]---Stakeholder Requirements Definition Process at the Wayback Machine (archived December 23, 2015)
- MIL-HDBK 520 Systems Requirements Document Guidance