सॉफ़्टवेयर आवश्यकताएं

सॉफ़्टवेयर आवश्यकताएँ लक्ष्य प्रणाली की सुविधाओं और कार्यक्षमताओं का विवरण हैं। आवश्यकताएँ सॉफ़्टवेयर उत्पाद से उपयोगकर्ताओं की अपेक्षाओं को व्यक्त करती हैं। आवश्यकताएं स्पष्ट या छिपी हुई, ज्ञात या अज्ञात, अपेक्षित या ग्राहक के दृष्टिकोण से अप्रत्याशित हो सकती हैं।

आवश्यकता इंजीनियरिंग

क्लाइंट से सॉफ़्टवेयर आवश्यकताओं को इकट्ठा करने की प्रक्रिया, उनका विश्लेषण और उन्हें आवश्यकता इंजीनियरिंग के रूप में जाना जाता है।

आवश्यकता इंजीनियरिंग का लक्ष्य परिष्कृत और वर्णनात्मक 'सिस्टम आवश्यकताएँ विशिष्टता' दस्तावेज़ को विकसित और बनाए रखना है।

आवश्यकता इंजीनियरिंग प्रक्रिया

यह चार चरणों वाली प्रक्रिया है, जिसमें शामिल हैं -

  • व्यवहार्यता अध्ययन
  • आवश्यक भीड़ जुटना
  • सॉफ्टवेयर की आवश्यकता विशिष्टता
  • सॉफ्टवेयर की आवश्यकता सत्यापन

आइए प्रक्रिया को संक्षेप में देखें -

व्यवहार्यता अध्ययन

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

इस जानकारी का संदर्भ देते हुए, विश्लेषक इस बारे में विस्तृत अध्ययन करते हैं कि क्या वांछित प्रणाली और इसकी कार्यक्षमता विकसित करने के लिए संभव है।

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

इस चरण का आउटपुट एक व्यवहार्यता अध्ययन रिपोर्ट होनी चाहिए जिसमें इस परियोजना के लिए पर्याप्त टिप्पणियां और सिफारिशें होनी चाहिए या नहीं, इस बारे में प्रबंधन को सलाह देनी चाहिए।

आवश्यक भीड़ जुटना

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

सॉफ्टवेयर की आवश्यकता विशिष्टता

एसआरएस विभिन्न विश्लेषकों से आवश्यकताओं को एकत्र करने के बाद सिस्टम विश्लेषक द्वारा बनाया गया एक दस्तावेज है।

एसआरएस परिभाषित करता है कि हार्डवेयर, बाहरी इंटरफेस, ऑपरेशन की गति, सिस्टम की प्रतिक्रिया समय, विभिन्न प्लेटफार्मों पर सॉफ्टवेयर की पोर्टेबिलिटी, क्रैश होने के बाद रिकवरी की गति, सुरक्षा, गुणवत्ता, सीमाएं आदि के साथ बातचीत कैसे करेगी।

क्लाइंट से प्राप्त आवश्यकताओं को प्राकृतिक भाषा में लिखा जाता है। यह तकनीकी भाषा में आवश्यकताओं का दस्तावेजीकरण करने के लिए सिस्टम एनालिस्ट की जिम्मेदारी है ताकि वे सॉफ्टवेयर डेवलपमेंट टीम द्वारा समझे और उपयोगी हो सकें।

SRS को निम्नलिखित विशेषताओं के साथ आना चाहिए:

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

सॉफ्टवेयर की आवश्यकता सत्यापन

आवश्यकता विनिर्देशों के विकसित होने के बाद, इस दस्तावेज़ में उल्लिखित आवश्यकताओं को मान्य किया गया है। उपयोगकर्ता अवैध, अव्यवहारिक समाधान के लिए पूछ सकता है या विशेषज्ञ आवश्यकताओं की गलत व्याख्या कर सकते हैं। इससे कली में नहीं फंसने पर लागत में भारी वृद्धि होती है। निम्नलिखित शर्तों के खिलाफ आवश्यकताओं की जाँच की जा सकती है -

  • यदि उन्हें व्यावहारिक रूप से लागू किया जा सकता है
  • यदि वे वैध हैं और सॉफ्टवेयर की कार्यक्षमता और डोमेन के अनुसार
  • अगर कोई अस्पष्टताएं हैं
  • यदि वे पूर्ण हैं
  • यदि उनका प्रदर्शन किया जा सकता है

आवश्यकता प्रक्रिया प्रक्रिया

आवश्यकता सम्‍मिलन प्रक्रिया का उपयोग फोलोविंज आरेख के उपयोग से किया जा सकता है:

  • Requirements gathering - डेवलपर्स क्लाइंट और अंतिम उपयोगकर्ताओं के साथ चर्चा करते हैं और सॉफ्टवेयर से उनकी अपेक्षाओं को जानते हैं।
  • Organizing Requirements - डेवलपर्स महत्व, तात्कालिकता और सुविधा के क्रम में आवश्यकताओं को प्राथमिकता और व्यवस्थित करते हैं।
  • Negotiation & discussion - यदि आवश्यकताएं अस्पष्ट हैं या विभिन्न हितधारकों की आवश्यकताओं में कुछ संघर्ष हैं, यदि वे हैं, तो यह तब बातचीत की जाती है और हितधारकों के साथ चर्चा की जाती है। आवश्यकताओं को प्राथमिकता दी जा सकती है और यथोचित समझौता किया जा सकता है।

    आवश्यकताएं विभिन्न हितधारकों से आती हैं। अस्पष्टता और संघर्षों को दूर करने के लिए, उन्हें स्पष्टता और शुद्धता के लिए चर्चा की जाती है। अवास्तविक आवश्यकताओं को यथोचित रूप से समझौता किया जाता है।

  • Documentation - सभी औपचारिक और अनौपचारिक, कार्यात्मक और गैर-कार्यात्मक आवश्यकताओं को दस्तावेज और अगले चरण के प्रसंस्करण के लिए उपलब्ध कराया गया है।

आवश्यकता तकनीक तकनीक

आवश्यकताएँ एलिफ़ेचर, क्लाइंट सिस्टम, अंतिम उपयोगकर्ताओं, सिस्टम उपयोगकर्ताओं और अन्य लोगों के साथ संचार करके एक इच्छित सॉफ़्टवेयर सिस्टम की आवश्यकताओं का पता लगाने की प्रक्रिया है, जिनकी सॉफ़्टवेयर सिस्टम विकास में हिस्सेदारी है।

आवश्यकताओं की खोज करने के विभिन्न तरीके हैं

साक्षात्कार

आवश्यकताओं को इकट्ठा करने के लिए साक्षात्कार मजबूत माध्यम हैं। संगठन कई प्रकार के साक्षात्कार आयोजित कर सकता है जैसे:

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

सर्वेक्षण

संगठन आगामी प्रणाली से उनकी अपेक्षा और आवश्यकताओं के बारे में पूछताछ करके विभिन्न हितधारकों के बीच सर्वेक्षण कर सकता है।

प्रश्नावली

वस्तुनिष्ठ प्रश्नों और संबंधित विकल्पों के पूर्व-निर्धारित सेट के साथ एक दस्तावेज उत्तर देने के लिए सभी हितधारकों को सौंप दिया जाता है, जिन्हें एकत्र और संकलित किया जाता है।

इस तकनीक की कमी है, यदि प्रश्नावली में कुछ मुद्दे के लिए विकल्प का उल्लेख नहीं किया गया है, तो समस्या को अस्वीकार कर दिया जा सकता है।

कार्य का विश्लेषण

इंजीनियरों और डेवलपर्स की टीम उस ऑपरेशन का विश्लेषण कर सकती है जिसके लिए नई प्रणाली की आवश्यकता है। यदि क्लाइंट के पास निश्चित संचालन करने के लिए पहले से ही कुछ सॉफ़्टवेयर हैं, तो इसका अध्ययन किया जाता है और प्रस्तावित प्रणाली की आवश्यकताओं को एकत्र किया जाता है।

डोमेन विश्लेषण

हर सॉफ्टवेयर किसी न किसी डोमेन की श्रेणी में आता है। डोमेन के विशेषज्ञ लोग सामान्य और विशिष्ट आवश्यकताओं के विश्लेषण के लिए एक बड़ी मदद हो सकते हैं।

बुद्धिशीलता

विभिन्न हितधारकों के बीच एक अनौपचारिक बहस होती है और उनके सभी इनपुट आगे की आवश्यकताओं के विश्लेषण के लिए दर्ज किए जाते हैं।

प्रोटोटाइप

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

अवलोकन

विशेषज्ञों की टीम ग्राहक के संगठन या कार्यस्थल का दौरा करती है। वे मौजूदा स्थापित प्रणालियों के वास्तविक कामकाज का निरीक्षण करते हैं। वे क्लाइंट के अंत में वर्कफ़्लो का निरीक्षण करते हैं और निष्पादन की समस्याओं से कैसे निपटा जाता है। टीम खुद कुछ निष्कर्ष निकालती है जो सॉफ़्टवेयर से अपेक्षित आवश्यकताओं को बनाने में सहायता करती है।

सॉफ्टवेयर आवश्यकताएँ लक्षण

सॉफ्टवेयर आवश्यकताओं को इकट्ठा करना संपूर्ण सॉफ्टवेयर डेवलपमेंट प्रोजेक्ट की नींव है। इसलिए उन्हें स्पष्ट, सही और अच्छी तरह से परिभाषित होना चाहिए।

एक पूर्ण सॉफ्टवेयर आवश्यकता विनिर्देशों होना चाहिए:

  • Clear
  • Correct
  • Consistent
  • Coherent
  • Comprehensible
  • Modifiable
  • Verifiable
  • Prioritized
  • Unambiguous
  • Traceable
  • विश्वसनीय स्रोत

सॉफ़्टवेयर आवश्यकताएं

हमें यह समझने की कोशिश करनी चाहिए कि आवश्यकता के चरण में किस प्रकार की आवश्यकताएं उत्पन्न हो सकती हैं और सॉफ्टवेयर सिस्टम से किस प्रकार की अपेक्षाएं हैं।

मोटे तौर पर सॉफ्टवेयर आवश्यकताओं को दो श्रेणियों में वर्गीकृत किया जाना चाहिए:

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

आवश्यकताएँ, जो सॉफ्टवेयर के कार्यात्मक पहलू से संबंधित हैं, इस श्रेणी में आती हैं।

वे सॉफ्टवेयर सिस्टम के भीतर और बाहर कार्यों और कार्यक्षमता को परिभाषित करते हैं।

उदाहरण -

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

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

आवश्यकताएँ, जो सॉफ्टवेयर के कार्यात्मक पहलू से संबंधित नहीं हैं, इस श्रेणी में आती हैं। वे सॉफ़्टवेयर के निहित या अपेक्षित लक्षण हैं, जो उपयोगकर्ता की धारणा बनाते हैं।

गैर-कार्यात्मक आवश्यकताओं में शामिल हैं -

  • Security
  • Logging
  • Storage
  • Configuration
  • Performance
  • Cost
  • Interoperability
  • Flexibility
  • आपदा बहाली
  • Accessibility

आवश्यकताओं को तार्किक रूप से वर्गीकृत किया गया है

  • Must Have : उनके बिना सॉफ्टवेयर को ऑपरेशनल नहीं कहा जा सकता।
  • Should have : सॉफ्टवेयर की कार्यक्षमता को बढ़ाना।
  • Could have : सॉफ्टवेयर अभी भी इन आवश्यकताओं के साथ ठीक से काम कर सकता है।
  • Wish list : ये आवश्यकताएँ सॉफ़्टवेयर के किसी भी उद्देश्य के लिए नहीं हैं।

सॉफ्टवेयर विकसित करते समय, 'होना चाहिए' को लागू किया जाना चाहिए, 'होना चाहिए' हितधारकों और नकार के साथ बहस का विषय है, जबकि सॉफ्टवेयर अपडेट के लिए 'इच्छा' और 'इच्छा सूची' को रखा जा सकता है।

उपयोगकर्ता इंटरफ़ेस आवश्यकताओं

यूआई किसी भी सॉफ्टवेयर या हार्डवेयर या हाइब्रिड सिस्टम का एक महत्वपूर्ण हिस्सा है। एक सॉफ्टवेयर व्यापक रूप से स्वीकार किया जाता है अगर यह है -

  • चलाने में आसान
  • जवाब में त्वरित
  • प्रभावी ढंग से परिचालन त्रुटियों से निपटने
  • सरल अभी तक सुसंगत उपयोगकर्ता इंटरफ़ेस प्रदान करना

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

  • सामग्री प्रस्तुति
  • आसान नेविगेशन
  • सरल इंटरफ़ेस
  • Responsive
  • लगातार यूआई तत्वों
  • प्रतिपुष्टि व्यवस्था
  • डिफ़ॉल्ट सेटिंग्स
  • उद्देश्यपूर्ण लेआउट
  • रंग और बनावट का रणनीतिक उपयोग।
  • मदद की जानकारी दें
  • उपयोगकर्ता केंद्रित दृष्टिकोण
  • समूह आधारित दृश्य सेटिंग्स।

सॉफ्टवेयर सिस्टम विश्लेषक

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

सिस्टम विश्लेषकों की निम्नलिखित जिम्मेदारियाँ हैं:

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

सॉफ्टवेयर मेट्रिक्स और माप

सॉफ्टवेयर के मापन को सॉफ्टवेयर की विभिन्न विशेषताओं और पहलुओं की मात्रा और प्रतीक के रूप में समझा जा सकता है।

सॉफ्टवेयर मेट्रिक्स सॉफ्टवेयर प्रक्रिया और सॉफ्टवेयर उत्पाद के विभिन्न पहलुओं के लिए उपाय प्रदान करते हैं।

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

टॉम डेमार्को (एक सॉफ्टवेयर इंजीनियर) के अनुसार, "आप जो माप नहीं सकते उसे नियंत्रित नहीं कर सकते।" उनके कहने से, यह बहुत स्पष्ट है कि सॉफ्टवेयर उपाय कितने महत्वपूर्ण हैं।

आइए हम कुछ सॉफ्टवेयर मैट्रिक्स देखें:

  • Size Metrics - LOC (कोड की पंक्तियाँ), जिसे ज्यादातर केएलओसी के रूप में चिह्नित हजारों वितरित स्रोत कोड लाइनों में गणना की जाती है।

    समारोह बिंदु गणना सॉफ्टवेयर द्वारा प्रदान की गई कार्यक्षमता का माप है। फंक्शन प्वाइंट काउंट सॉफ्टवेयर के कार्यात्मक पहलू के आकार को परिभाषित करता है।

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

    विकास प्रक्रिया में पाए जाने वाले दोषों की संख्या और क्लाइंट द्वारा क्लाइंट-एंड में वितरित किए जाने या वितरित किए जाने के बाद ग्राहक द्वारा बताए गए दोषों की संख्या, उत्पाद की गुणवत्ता को परिभाषित करते हैं।

  • Process Metrics - एसडीएलसी के विभिन्न चरणों में, उपयोग किए जाने वाले तरीके और उपकरण, कंपनी के मानक और विकास का प्रदर्शन सॉफ्टवेयर प्रोसेस मेट्रिक्स हैं।
  • Resource Metrics - प्रयास, समय और विभिन्न संसाधनों का उपयोग किया जाता है, संसाधन मापन के लिए मैट्रिक्स का प्रतिनिधित्व करता है।