सॉफ्टवेयर इंजीनियरिंग - त्वरित गाइड
आइए पहले समझते हैं कि सॉफ्टवेयर इंजीनियरिंग किस उद्देश्य के लिए है। यह शब्द दो शब्दों से बना है, सॉफ्टवेयर और इंजीनियरिंग।
Software केवल एक प्रोग्राम कोड से अधिक है। एक कार्यक्रम एक निष्पादन योग्य कोड है, जो कुछ कम्प्यूटेशनल उद्देश्य को पूरा करता है। सॉफ्टवेयर को निष्पादन योग्य प्रोग्रामिंग कोड, संबद्ध पुस्तकालयों और दस्तावेज़ों का संग्रह माना जाता है। सॉफ्टवेयर, जब एक विशिष्ट आवश्यकता के लिए बनाया जाता हैsoftware product.
Engineering दूसरी ओर, सभी विकसित उत्पादों के बारे में है, अच्छी तरह से परिभाषित, वैज्ञानिक सिद्धांतों और विधियों का उपयोग करते हुए।
Software engineeringअच्छी तरह से परिभाषित वैज्ञानिक सिद्धांतों, विधियों और प्रक्रियाओं का उपयोग करके सॉफ्टवेयर उत्पाद के विकास से जुड़ी एक इंजीनियरिंग शाखा है। सॉफ्टवेयर इंजीनियरिंग का परिणाम एक कुशल और विश्वसनीय सॉफ्टवेयर उत्पाद है।
परिभाषाएं
IEEE सॉफ्टवेयर इंजीनियरिंग को परिभाषित करता है:
(1) सॉफ्टवेयर के विकास, संचालन और रखरखाव के लिए एक व्यवस्थित, अनुशासित, मात्रात्मक दृष्टिकोण का अनुप्रयोग; यह है, सॉफ्टवेयर के लिए इंजीनियरिंग के आवेदन।
(२) उपर्युक्त कथन के अनुसार दृष्टिकोण का अध्ययन।
फ्रिट्ज़ बाउर, एक जर्मन कंप्यूटर वैज्ञानिक, सॉफ्टवेयर इंजीनियरिंग को परिभाषित करता है:
सॉफ्टवेयर इंजीनियरिंग आर्थिक रूप से सॉफ्टवेयर प्राप्त करने के लिए साउंड इंजीनियरिंग सिद्धांतों की स्थापना और उपयोग है जो विश्वसनीय है और वास्तविक मशीनों पर कुशलता से काम करता है।
सॉफ्टवेयर विकास
सॉफ्टवेयर इंजीनियरिंग सिद्धांतों और विधियों का उपयोग करके एक सॉफ्टवेयर उत्पाद विकसित करने की प्रक्रिया को कहा जाता है software evolution. इसमें सॉफ़्टवेयर का प्रारंभिक विकास और इसके रखरखाव और अपडेट शामिल हैं, जब तक वांछित सॉफ़्टवेयर उत्पाद विकसित नहीं किया जाता है, जो अपेक्षित आवश्यकताओं को पूरा करता है।
विकास आवश्यकता एकत्रित करने की प्रक्रिया से शुरू होता है। जिसके बाद डेवलपर्स इच्छित सॉफ़्टवेयर का एक प्रोटोटाइप बनाते हैं और उपयोगकर्ताओं को सॉफ़्टवेयर उत्पाद विकास के प्रारंभिक चरण में अपनी प्रतिक्रिया प्राप्त करने के लिए दिखाते हैं। उपयोगकर्ता परिवर्तन का सुझाव देते हैं, जिस पर लगातार कई अपडेट और रखरखाव भी बदलते रहते हैं। यह प्रक्रिया मूल सॉफ़्टवेयर में तब तक बदलती है, जब तक वांछित सॉफ़्टवेयर पूरा नहीं हो जाता।
उपयोगकर्ता के हाथ में वांछित सॉफ्टवेयर होने के बाद भी, अग्रिम तकनीक और बदलती आवश्यकताएं सॉफ्टवेयर उत्पाद को तदनुसार बदलने के लिए मजबूर करती हैं। खरोंच से सॉफ्टवेयर बनाना और आवश्यकता के साथ एक-एक पर जाना संभव नहीं है। एकमात्र व्यवहार्य और किफायती समाधान मौजूदा सॉफ़्टवेयर को अपडेट करना है ताकि यह नवीनतम आवश्यकताओं से मेल खाए।
सॉफ्टवेयर विकास कानून
लेहमैन ने सॉफ्टवेयर विकास के लिए कानून दिए हैं। उन्होंने सॉफ्टवेयर को तीन अलग-अलग श्रेणियों में विभाजित किया:
- S-type (static-type) - यह एक सॉफ्टवेयर है, जो परिभाषित विनिर्देशों और समाधानों के अनुसार सख्ती से काम करता है । समाधान और इसे प्राप्त करने की विधि, दोनों को कोडिंग से पहले तुरंत समझा जाता है। एस-टाइप सॉफ्टवेयर कम से कम परिवर्तनों के अधीन है इसलिए यह सबसे सरल है। उदाहरण के लिए, गणितीय गणना के लिए कैलकुलेटर प्रोग्राम।
- P-type (practical-type) - यह एक सॉफ्टवेयर है जिसमें प्रक्रियाओं का संग्रह है । यह वास्तव में परिभाषित किया गया है कि क्या प्रक्रियाएं कर सकती हैं इस सॉफ्टवेयर में, विशिष्टताओं का वर्णन किया जा सकता है, लेकिन समाधान तुरंत स्पष्ट नहीं है। उदाहरण के लिए, गेमिंग सॉफ्टवेयर।
- E-type (embedded-type) - यह सॉफ्टवेयर वास्तविक दुनिया के वातावरण की आवश्यकता के रूप में बारीकी से काम करता है। इस सॉफ्टवेयर में उच्च स्तर का विकास है क्योंकि वास्तविक दुनिया की स्थितियों में कानूनों, करों आदि में विभिन्न परिवर्तन हैं। उदाहरण के लिए, ऑनलाइन ट्रेडिंग सॉफ्टवेयर।
ई-टाइप सॉफ्टवेयर विकास
लेहमैन ने ई-टाइप सॉफ्टवेयर विकास के लिए आठ कानून दिए हैं -
- Continuing change - एक ई-टाइप सॉफ्टवेयर सिस्टम को वास्तविक दुनिया के परिवर्तनों के अनुकूल होना चाहिए, अन्यथा यह उत्तरोत्तर कम उपयोगी हो जाता है।
- Increasing complexity - जैसा कि ई-टाइप सॉफ्टवेयर सिस्टम विकसित होता है, इसकी जटिलता तब तक बढ़ जाती है जब तक कि इसे बनाए रखने या कम करने के लिए काम नहीं किया जाता है।
- Conservation of familiarity - सॉफ्टवेयर के साथ परिचित या इसे कैसे विकसित किया गया था, इसके बारे में ज्ञान, किसी भी कीमत पर क्यों विकसित किया गया था, किसी भी कीमत पर बनाए रखा जाना चाहिए, ताकि सिस्टम में बदलाव को लागू किया जा सके।
- Continuing growth- कुछ व्यावसायिक समस्या को हल करने के उद्देश्य से ई-प्रकार प्रणाली के लिए, व्यवसाय के जीवन शैली में परिवर्तन के अनुसार परिवर्तनों को लागू करने का इसका आकार बढ़ता है।
- Reducing quality - एक ई-टाइप सॉफ्टवेयर सिस्टम गुणवत्ता में तब तक गिरावट करता है जब तक कि इसे कठोर रूप से बनाए रखा जाए और एक बदलते परिचालन वातावरण के अनुकूल बनाया जाए।
- Feedback systems- ई-टाइप सॉफ्टवेयर सिस्टम मल्टी-लूप, मल्टी-लेवल फीडबैक सिस्टम का गठन करते हैं और इन्हें सफलतापूर्वक संशोधित या बेहतर बनाने के लिए इलाज किया जाना चाहिए।
- Self-regulation - ई-प्रकार प्रणाली विकास प्रक्रियाएं उत्पाद के वितरण और सामान्य के करीब प्रक्रिया उपायों के साथ स्व-विनियमन हैं।
- Organizational stability - एक विकसित ई-प्रकार प्रणाली में औसत प्रभावी वैश्विक गतिविधि दर उत्पाद के जीवनकाल में अपरिवर्तनीय है।
सॉफ्टवेयर प्रतिमान
सॉफ्टवेयर प्रतिमान उन तरीकों और चरणों का उल्लेख करते हैं, जो सॉफ्टवेयर डिजाइन करते समय लिए जाते हैं। आज कई तरीके प्रस्तावित हैं और काम में हैं, लेकिन हमें यह देखने की जरूरत है कि सॉफ्टवेयर इंजीनियरिंग में ये प्रतिमान कहां खड़े हैं। इन्हें विभिन्न श्रेणियों में जोड़ा जा सकता है, हालांकि इनमें से प्रत्येक एक दूसरे में निहित है:
प्रोग्रामिंग प्रतिमान सॉफ्टवेयर डिजाइन प्रतिमान का एक उपसमुच्चय है जो आगे सॉफ्टवेयर विकास प्रतिमान का एक उपसमुच्चय है।
सॉफ्टवेयर विकास प्रतिमान
इस प्रतिमान को सॉफ्टवेयर इंजीनियरिंग प्रतिमान के रूप में जाना जाता है, जहां सॉफ्टवेयर के विकास से संबंधित सभी इंजीनियरिंग अवधारणाओं को लागू किया जाता है। इसमें विभिन्न शोध और आवश्यकता एकत्र करना शामिल है जो सॉफ्टवेयर उत्पाद को बनाने में मदद करता है। यह मिश्रण है -
- आवश्यक भीड़ जुटना
- सॉफ्टवेर डिज़ाइन
- Programming
सॉफ्टवेयर डिजाइन प्रतिमान
यह प्रतिमान सॉफ्टवेयर विकास का एक हिस्सा है और इसमें शामिल हैं -
- Design
- Maintenance
- Programming
प्रोग्रामिंग प्रतिमान
यह प्रतिमान सॉफ्टवेयर विकास के प्रोग्रामिंग पहलू से निकटता से संबंधित है। यह भी शामिल है -
- Coding
- Testing
- Integration
सॉफ्टवेयर इंजीनियरिंग की आवश्यकता
उपयोगकर्ता की आवश्यकताओं और पर्यावरण जिस पर सॉफ्टवेयर काम कर रहा है, में परिवर्तन की उच्च दर के कारण सॉफ्टवेयर इंजीनियरिंग की आवश्यकता उत्पन्न होती है।
- Large software - एक घर या इमारत की तुलना में एक दीवार बनाना आसान है, इसी तरह, सॉफ्टवेयर का आकार बड़ा होने के कारण इसे एक वैज्ञानिक प्रक्रिया देने के लिए कदम उठाना पड़ता है।
- Scalability- यदि सॉफ़्टवेयर प्रक्रिया वैज्ञानिक और इंजीनियरिंग अवधारणाओं पर आधारित नहीं थी, तो किसी मौजूदा सॉफ़्टवेयर को फिर से बनाना आसान होगा।
- Cost- जैसा कि हार्डवेयर उद्योग ने अपने कौशल को दिखाया है और विशाल विनिर्माण ने कंप्यूटर और इलेक्ट्रॉनिक हार्डवेयर की कीमत को कम कर दिया है। लेकिन उचित प्रक्रिया के अनुकूल न होने पर सॉफ्टवेयर की लागत अधिक रहती है।
- Dynamic Nature- सॉफ़्टवेयर का हमेशा बढ़ता और परिवर्तित होना स्वाभाविक रूप से उस वातावरण पर निर्भर करता है जिसमें उपयोगकर्ता काम करता है। यदि सॉफ़्टवेयर की प्रकृति हमेशा बदल रही है, तो मौजूदा में नई वृद्धि करने की आवश्यकता है। यह वह जगह है जहाँ सॉफ्टवेयर इंजीनियरिंग एक अच्छी भूमिका निभाता है।
- Quality Management- सॉफ्टवेयर विकास की बेहतर प्रक्रिया बेहतर और गुणवत्तापूर्ण सॉफ्टवेयर उत्पाद प्रदान करती है।
अच्छे सॉफ्टवेयर के लक्षण
एक सॉफ्टवेयर उत्पाद का अंदाजा इससे लगाया जा सकता है कि यह क्या प्रदान करता है और इसका कितना अच्छा उपयोग किया जा सकता है। इस सॉफ्टवेयर को निम्न आधारों पर संतुष्ट होना चाहिए:
- Operational
- Transitional
- Maintenance
अच्छी तरह से इंजीनियर और तैयार किए गए सॉफ़्टवेयर में निम्नलिखित विशेषताएं होने की उम्मीद है:
आपरेशनल
यह हमें बताता है कि ऑपरेशंस में सॉफ्टवेयर कितना अच्छा काम करता है इस पर मापा जा सकता है:
- Budget
- Usability
- Efficiency
- Correctness
- Functionality
- Dependability
- Security
- Safety
संक्रमणकालीन
सॉफ्टवेयर के एक प्लेटफॉर्म से दूसरे प्लेटफॉर्म पर ले जाने पर यह पहलू महत्वपूर्ण है:
- Portability
- Interoperability
- Reusability
- Adaptability
रखरखाव
यह पहलू इस बात की जानकारी देता है कि किसी सॉफ्टवेयर में हमेशा बदलते परिवेश में खुद को बनाए रखने की क्षमता कितनी अच्छी है:
- Modularity
- Maintainability
- Flexibility
- Scalability
संक्षेप में, सॉफ्टवेयर इंजीनियरिंग कंप्यूटर विज्ञान की एक शाखा है, जो कुशल, टिकाऊ, स्केलेबल, इन-बजट और ऑन-टाइम सॉफ्टवेयर उत्पादों के उत्पादन के लिए आवश्यक अच्छी तरह से परिभाषित इंजीनियरिंग अवधारणाओं का उपयोग करती है।
सॉफ्टवेयर डेवलपमेंट लाइफ साइकिल, एसडीएलसी शॉर्ट के लिए, एक अच्छी तरह से परिभाषित, सॉफ्टवेयर इंजीनियरिंग में चरणों का संरचित अनुक्रम है, जिसका उद्देश्य सॉफ़्टवेयर उत्पाद विकसित करना है।
एसडीएलसी गतिविधियाँ
SDLC एक सॉफ्टवेयर उत्पाद को कुशलतापूर्वक डिजाइन और विकसित करने के लिए निम्नलिखित चरणों की एक श्रृंखला प्रदान करता है। एसडीएलसी ढांचे में निम्नलिखित चरण शामिल हैं:
संचार
यह पहला चरण है जहां उपयोगकर्ता वांछित सॉफ़्टवेयर उत्पाद के लिए अनुरोध करता है। वह सेवा प्रदाता से संपर्क करता है और शर्तों पर बातचीत करने की कोशिश करता है। वह लिखित रूप में संगठन प्रदान करने वाली सेवा के लिए अपने अनुरोध को प्रस्तुत करता है।
आवश्यक भीड़ जुटना
इस कदम के बाद सॉफ्टवेयर डेवलपमेंट टीम प्रोजेक्ट को आगे बढ़ाने का काम करती है। टीम समस्या क्षेत्र से विभिन्न हितधारकों के साथ विचार-विमर्श करती है और उनकी आवश्यकताओं पर अधिक से अधिक जानकारी लाने का प्रयास करती है। आवश्यकताओं को उपयोगकर्ता आवश्यकताओं, सिस्टम आवश्यकताओं और कार्यात्मक आवश्यकताओं में चिंतन और अलग किया जाता है। आवश्यकताओं को कई प्रथाओं का उपयोग करके एकत्र किया गया है -
- मौजूदा या अप्रचलित प्रणाली और सॉफ्टवेयर का अध्ययन,
- उपयोगकर्ताओं और डेवलपर्स के साक्षात्कार आयोजित करना,
- डेटाबेस का जिक्र या
- प्रश्नावली से उत्तर एकत्रित करना।
व्यवहार्यता अध्ययन
आवश्यकता एकत्र करने के बाद, टीम सॉफ्टवेयर प्रक्रिया की किसी न किसी योजना के साथ आती है। इस चरण में टीम विश्लेषण करती है कि क्या उपयोगकर्ता की सभी आवश्यकताओं को पूरा करने के लिए एक सॉफ्टवेयर बनाया जा सकता है और यदि सॉफ्टवेयर के उपयोगी होने की कोई संभावना नहीं है। यह पता चला है, अगर परियोजना वित्तीय, व्यावहारिक और तकनीकी रूप से संगठन के लिए संभव है। कई एल्गोरिदम उपलब्ध हैं, जो डेवलपर्स को एक सॉफ्टवेयर परियोजना की व्यवहार्यता को समाप्त करने में मदद करते हैं।
प्रणाली विश्लेषण
इस कदम पर डेवलपर्स अपनी योजना का एक रोडमैप तय करते हैं और परियोजना के लिए उपयुक्त सर्वश्रेष्ठ सॉफ्टवेयर मॉडल को लाने की कोशिश करते हैं। सिस्टम विश्लेषण में सॉफ्टवेयर उत्पाद सीमाओं को समझना, सिस्टम से संबंधित समस्याओं को सीखना या मौजूदा सिस्टम में पहले से किए जाने वाले बदलाव, संगठन और कर्मियों पर परियोजना के प्रभाव को पहचानना और संबोधित करना आदि शामिल हैं। प्रोजेक्ट टीम प्रोजेक्ट के दायरे का विश्लेषण करती है और शेड्यूल की योजना बनाती है और तदनुसार संसाधनों।
सॉफ्टवेर डिज़ाइन
अगला कदम डेस्क पर आवश्यकताओं और विश्लेषण के पूरे ज्ञान को लाना और सॉफ्टवेयर उत्पाद को डिजाइन करना है। उपयोगकर्ताओं से जानकारी और आवश्यकता एकत्र करने के चरण में एकत्रित जानकारी इस चरण के इनपुट हैं। इस चरण का आउटपुट दो डिज़ाइनों के रूप में आता है; तार्किक डिजाइन और भौतिक डिजाइन। इंजीनियर मेटा-डेटा और डेटा शब्दकोश, तार्किक आरेख, डेटा-प्रवाह आरेख और कुछ मामलों में छद्म कोड का उत्पादन करते हैं।
कोडन
इस चरण को प्रोग्रामिंग चरण के रूप में भी जाना जाता है। सॉफ्टवेयर डिजाइन का कार्यान्वयन उपयुक्त प्रोग्रामिंग भाषा में प्रोग्राम कोड लिखने और कुशलता से त्रुटि-मुक्त निष्पादन योग्य प्रोग्राम विकसित करने के संदर्भ में शुरू होता है।
परिक्षण
एक अनुमान कहता है कि संपूर्ण सॉफ्टवेयर विकास प्रक्रिया का 50% परीक्षण किया जाना चाहिए। त्रुटियां सॉफ़्टवेयर को अपने स्तर से हटाने के लिए महत्वपूर्ण स्तर को बर्बाद कर सकती हैं। डेवलपर्स द्वारा कोडिंग करते समय सॉफ्टवेयर परीक्षण किया जाता है और मॉड्यूल परीक्षण, कार्यक्रम परीक्षण, उत्पाद परीक्षण, इन-हाउस परीक्षण और उपयोगकर्ता के अंत में उत्पाद का परीक्षण जैसे कोड के विभिन्न स्तरों पर विशेषज्ञों द्वारा परीक्षण किया जाता है। त्रुटियों की शीघ्र खोज और उनका उपाय विश्वसनीय सॉफ्टवेयर की कुंजी है।
एकीकरण
सॉफ्टवेयर को पुस्तकालयों, डेटाबेस और अन्य कार्यक्रम (नों) के साथ एकीकृत करने की आवश्यकता हो सकती है। एसडीएलसी का यह चरण बाहरी दुनिया की संस्थाओं के साथ सॉफ्टवेयर के एकीकरण में शामिल है।
कार्यान्वयन
इसका अर्थ है उपयोगकर्ता मशीनों पर सॉफ़्टवेयर स्थापित करना। कई बार, सॉफ़्टवेयर को उपयोगकर्ता के अंत में पोस्ट-इंस्टॉलेशन कॉन्फ़िगरेशन की आवश्यकता होती है। पोर्टेबिलिटी और अनुकूलन क्षमता के लिए सॉफ्टवेयर का परीक्षण किया जाता है और कार्यान्वयन के दौरान एकीकरण से संबंधित मुद्दों को हल किया जाता है।
संचालन और अनुरक्षण
यह चरण अधिक दक्षता और कम त्रुटियों के संदर्भ में सॉफ़्टवेयर ऑपरेशन की पुष्टि करता है। यदि आवश्यक हो, तो उपयोगकर्ताओं को प्रशिक्षित किया जाता है, या सॉफ़्टवेयर को कैसे संचालित किया जाए और सॉफ़्टवेयर को कैसे चालू रखा जाए, इस पर प्रलेखन के साथ सहायता की जाती है। उपयोगकर्ता अंत पर्यावरण या प्रौद्योगिकी में हो रहे परिवर्तनों के अनुसार कोड को अपडेट करके सॉफ्टवेयर को समय पर बनाए रखा जाता है। इस चरण में छिपी बग और वास्तविक दुनिया की अज्ञात समस्याओं से चुनौतियों का सामना करना पड़ सकता है।
स्वभाव
जैसे ही समय बीतता है, सॉफ्टवेयर प्रदर्शन के मोर्चे पर घट सकता है। यह पूरी तरह से अप्रचलित हो सकता है या तीव्र उन्नयन की आवश्यकता हो सकती है। इसलिए सिस्टम के एक बड़े हिस्से को खत्म करने के लिए दबाव की जरूरत होती है। इस चरण में डेटा को संग्रहीत करना और आवश्यक सॉफ्टवेयर घटक शामिल हैं, सिस्टम को बंद करना, डिस्पेंसिंग गतिविधि की योजना बनाना और उचित अंत के सिस्टम समय पर सिस्टम को समाप्त करना।
सॉफ्टवेयर विकास प्रतिमान
सॉफ्टवेयर डेवलपमेंट प्रतिमान डेवलपर को सॉफ्टवेयर विकसित करने की रणनीति का चयन करने में मदद करता है। एक सॉफ्टवेयर डेवलपमेंट प्रतिमान के पास उपकरणों, विधियों और प्रक्रियाओं का अपना सेट होता है, जो स्पष्ट रूप से व्यक्त किया जाता है और सॉफ्टवेयर विकास जीवन चक्र को परिभाषित करता है। कुछ सॉफ्टवेयर विकास प्रतिमान या प्रक्रिया मॉडल निम्नानुसार परिभाषित किए गए हैं:
झरना मॉडल
वॉटरफॉल मॉडल सॉफ्टवेयर डेवलपमेंट प्रतिमान का सबसे सरल मॉडल है। यह कहता है कि SDLC के सभी चरण रैखिक रूप से एक के बाद एक कार्य करेंगे। यानी, जब पहला चरण समाप्त हो जाता है तो केवल दूसरा चरण शुरू होगा और इसी तरह से।
यह मॉडल मानता है कि पिछले चरण में योजनाबद्ध तरीके से सब कुछ किया जाता है और लिया जाता है और अगले चरण में उत्पन्न होने वाले पिछले मुद्दों के बारे में सोचने की आवश्यकता नहीं है। यदि पिछले चरण में कुछ समस्याएँ हैं, तो यह मॉडल सुचारू रूप से काम नहीं करता है। मॉडल की अनुक्रमिक प्रकृति हमें वापस जाने और हमारे कार्यों को पूर्ववत या फिर से करने की अनुमति नहीं देती है।
यह मॉडल सबसे उपयुक्त है जब डेवलपर्स ने पहले से ही इसी तरह के सॉफ्टवेयर को डिजाइन और विकसित किया है और इसके सभी डोमेन के बारे में जानते हैं।
Iterative मॉडल
यह मॉडल पुनरावृत्तियों में सॉफ़्टवेयर विकास प्रक्रिया का नेतृत्व करता है। यह एसडीएलसी प्रक्रिया के हर चक्र के बाद हर चरण को दोहराते हुए चक्रीय तरीके से विकास की प्रक्रिया को प्रोजेक्ट करता है।
सॉफ्टवेयर को पहले बहुत छोटे पैमाने पर विकसित किया जाता है और सभी चरणों का पालन किया जाता है जिसे ध्यान में रखा जाता है। फिर, प्रत्येक अगले पुनरावृत्ति पर, अधिक सुविधाएँ और मॉड्यूल डिज़ाइन किए गए, कोडित, परीक्षण किए गए और सॉफ़्टवेयर में जोड़े गए। हर चक्र एक सॉफ्टवेयर का निर्माण करता है, जो अपने आप में पूर्ण होता है और इसमें पहले वाले की तुलना में अधिक विशेषताएं और क्षमताएं होती हैं।
प्रत्येक पुनरावृत्ति के बाद, प्रबंधन टीम जोखिम प्रबंधन पर काम कर सकती है और अगली पुनरावृत्ति की तैयारी कर सकती है। क्योंकि एक चक्र में संपूर्ण सॉफ़्टवेयर प्रक्रिया का छोटा हिस्सा शामिल होता है, इसलिए विकास प्रक्रिया को प्रबंधित करना आसान होता है, लेकिन यह अधिक संसाधनों का उपभोग करता है।
सर्पिल मॉडल
सर्पिल मॉडल, पुनरावृत्त मॉडल और एसडीएलसी मॉडल में से एक का संयोजन है। यह देखा जा सकता है जैसे कि आप एक एसडीएलसी मॉडल चुनते हैं और इसे चक्रीय प्रक्रिया (पुनरावृत्ति मॉडल) के साथ जोड़ते हैं।
यह मॉडल जोखिम मानता है, जो अक्सर अधिकांश अन्य मॉडलों द्वारा अप्रकाशित हो जाता है। मॉडल एक पुनरावृत्ति की शुरुआत में सॉफ्टवेयर के उद्देश्यों और बाधाओं को निर्धारित करने के साथ शुरू होता है। अगला चरण सॉफ्टवेयर के प्रोटोटाइप का है। इसमें जोखिम विश्लेषण शामिल है। तब सॉफ्टवेयर के निर्माण के लिए एक मानक एसडीएलसी मॉडल का उपयोग किया जाता है। अगले पुनरावृत्ति की योजना के चौथे चरण में तैयार किया गया है।
वी - मॉडल
झरने के मॉडल की बड़ी खामी यह है कि हम अगले चरण में ही चलते हैं जब पिछले एक खत्म हो जाता है और बाद के चरणों में कुछ गलत पाया जाता है तो वापस जाने का कोई मौका नहीं था। वी-मॉडल रिवर्स चरण में प्रत्येक चरण में सॉफ्टवेयर के परीक्षण के साधन प्रदान करता है।
प्रत्येक चरण में, परीक्षण योजना और परीक्षण मामले उस चरण की आवश्यकता के अनुसार उत्पाद को सत्यापित करने और सत्यापित करने के लिए बनाए जाते हैं। उदाहरण के लिए, आवश्यकता पड़ने के चरण में परीक्षण टीम आवश्यकताओं के अनुरूप सभी परीक्षण मामलों को तैयार करती है। बाद में, जब उत्पाद विकसित होता है और परीक्षण के लिए तैयार होता है, तो इस स्तर के परीक्षण मामले इस स्तर पर आवश्यकताओं के प्रति इसकी वैधता के खिलाफ सॉफ्टवेयर को सत्यापित करते हैं।
इससे सत्यापन और सत्यापन दोनों समानांतर हो जाते हैं। इस मॉडल को सत्यापन और सत्यापन मॉडल के रूप में भी जाना जाता है।
बिग बैंग मॉडल
यह मॉडल अपने रूप में सबसे सरल मॉडल है। इसके लिए थोड़ी प्लानिंग, बहुत सारी प्रोग्रामिंग और बहुत सारे फंड्स की जरूरत होती है। यह मॉडल ब्रह्मांड के बड़े धमाके के आसपास परिकल्पित है। जैसा कि वैज्ञानिकों का कहना है कि बड़ी धमाके के बाद बहुत सी आकाशगंगाएँ, ग्रह और तारे एक घटना के रूप में विकसित हुए। इसी तरह, यदि हम बहुत सारी प्रोग्रामिंग और फंडों को एक साथ रखते हैं, तो आप सर्वश्रेष्ठ सॉफ्टवेयर उत्पाद प्राप्त कर सकते हैं।
इस मॉडल के लिए, बहुत कम मात्रा में नियोजन की आवश्यकता होती है। यह किसी भी प्रक्रिया का पालन नहीं करता है, या कभी-कभी ग्राहक आवश्यकताओं और भविष्य की जरूरतों के बारे में निश्चित नहीं होता है। तो इनपुट आवश्यकताएं मनमानी हैं।
यह मॉडल बड़ी सॉफ्टवेयर परियोजनाओं के लिए उपयुक्त नहीं है, लेकिन सीखने और प्रयोग करने के लिए अच्छा है।
एसडीएलसी और इसके विभिन्न मॉडलों पर गहराई से पढ़ने के लिए, यहां क्लिक करें।
सॉफ्टवेयर विकास में लगी आईटी कंपनी के जॉब पैटर्न को दो भागों में विभाजित किया जा सकता है:
- सॉफ्टवेयर निर्माण
- सॉफ्टवेयर परियोजना प्रबंधन
एक परियोजना अच्छी तरह से परिभाषित कार्य है, जो एक लक्ष्य को प्राप्त करने के लिए किए गए कई कार्यों का एक संग्रह है (उदाहरण के लिए, सॉफ्टवेयर विकास और वितरण)। एक परियोजना के रूप में विशेषता हो सकती है:
- प्रत्येक परियोजना का एक अनूठा और विशिष्ट लक्ष्य हो सकता है।
- परियोजना नियमित गतिविधि या दिन-प्रतिदिन के संचालन नहीं है।
- प्रोजेक्ट एक शुरुआती समय और अंत समय के साथ आता है।
- परियोजना तब समाप्त होती है जब इसका लक्ष्य प्राप्त हो जाता है इसलिए यह एक संगठन के जीवनकाल में एक अस्थायी चरण है।
- परियोजना को समय, जनशक्ति, वित्त, सामग्री और ज्ञान-बैंक के संदर्भ में पर्याप्त संसाधनों की आवश्यकता है।
सॉफ्टवेयर प्रोजेक्ट
एक सॉफ़्टवेयर प्रोजेक्ट आवश्यकता सॉफ्टवेयर से लेकर परीक्षण और रखरखाव तक की पूरी प्रक्रिया है, जो निष्पादन पद्धति के अनुसार, निर्धारित सॉफ़्टवेयर उत्पाद को प्राप्त करने के लिए निर्धारित अवधि में किया जाता है।
सॉफ्टवेयर परियोजना प्रबंधन की आवश्यकता
सॉफ्टवेयर को एक अमूर्त उत्पाद कहा जाता है। सॉफ्टवेयर विकास विश्व व्यापार में सभी तरह की नई धारा है और सॉफ्टवेयर उत्पादों के निर्माण में बहुत कम अनुभव है। अधिकांश सॉफ्टवेयर उत्पाद ग्राहक की आवश्यकताओं को पूरा करने के लिए दर्जी हैं। सबसे महत्वपूर्ण यह है कि अंतर्निहित तकनीक इतनी बार और तेजी से बदलती है और एक उत्पाद के अनुभव को दूसरे पर लागू नहीं किया जा सकता है। इस तरह के सभी व्यवसाय और पर्यावरण संबंधी बाधाएं सॉफ्टवेयर विकास में जोखिम लाती हैं इसलिए सॉफ्टवेयर परियोजनाओं को कुशलता से प्रबंधित करना आवश्यक है।
ऊपर की छवि सॉफ्टवेयर परियोजनाओं के लिए ट्रिपल बाधाओं को दिखाती है। गुणवत्ता के उत्पाद को वितरित करने के लिए सॉफ्टवेयर संगठन का एक अनिवार्य हिस्सा है, ग्राहक के बजट की कमी के भीतर लागत को बनाए रखना और परियोजना को निर्धारित अनुसार वितरित करना। कई कारक हैं, दोनों आंतरिक और बाहरी, जो इस त्रिभुज बाधा त्रिकोण को प्रभावित कर सकते हैं। तीन कारकों में से कोई भी अन्य दो को गंभीर रूप से प्रभावित कर सकता है।
इसलिए, बजट और समय की कमी के साथ उपयोगकर्ता की आवश्यकताओं को शामिल करने के लिए सॉफ्टवेयर परियोजना प्रबंधन आवश्यक है।
सॉफ्टवेयर प्रोजेक्ट मैनेजर
एक सॉफ्टवेयर प्रोजेक्ट मैनेजर वह व्यक्ति होता है जो सॉफ्टवेयर प्रोजेक्ट को निष्पादित करने की जिम्मेदारी लेता है। सॉफ्टवेयर प्रोजेक्ट मैनेजर को SDLC के सभी चरणों के बारे में अच्छी तरह से पता है कि सॉफ्टवेयर किस माध्यम से जाएगा। परियोजना प्रबंधक सीधे अंतिम उत्पाद के निर्माण में सीधे तौर पर शामिल नहीं हो सकता है, लेकिन वह उत्पादन में शामिल गतिविधियों को नियंत्रित और प्रबंधित करता है।
एक परियोजना प्रबंधक विकास की प्रक्रिया की बारीकी से निगरानी करता है, विभिन्न योजनाओं को तैयार करता है और उन पर अमल करता है, आवश्यक और पर्याप्त संसाधनों की व्यवस्था करता है, लागत, बजट, संसाधन, समय, गुणवत्ता और ग्राहक संतुष्टि के मुद्दों के समाधान के लिए सभी टीम के सदस्यों के बीच संचार बनाए रखता है।
आइए हम कुछ जिम्मेदारियों को देखते हैं जो एक परियोजना प्रबंधक के कंधे हैं -
लोगों को सम्भालना
- प्रोजेक्ट लीडर के रूप में कार्य करें
- हितधारकों के साथ लेसियन
- मानव संसाधनों का प्रबंधन
- रिपोर्टिंग पदानुक्रम आदि की स्थापना
प्रबंध परियोजना
- प्रोजेक्ट स्कोप को परिभाषित करना और स्थापित करना
- परियोजना प्रबंधन गतिविधियों का प्रबंधन
- प्रगति और प्रदर्शन की निगरानी करना
- हर चरण में जोखिम विश्लेषण
- समस्याओं से बचने या बाहर आने के लिए आवश्यक कदम उठाएं
- परियोजना के प्रवक्ता के रूप में कार्य करें
सॉफ्टवेयर प्रबंधन गतिविधियाँ
सॉफ्टवेयर परियोजना प्रबंधन में कई गतिविधियां शामिल हैं, जिसमें परियोजना की योजना, सॉफ्टवेयर उत्पाद का दायरा तय करना, विभिन्न शर्तों में लागत का अनुमान, कार्यों और घटनाओं का समय निर्धारण, और संसाधन प्रबंधन शामिल हैं। परियोजना प्रबंधन गतिविधियों में शामिल हो सकते हैं:
- Project Planning
- Scope Management
- Project Estimation
कार्य की योजना
सॉफ्टवेयर प्रोजेक्ट प्लानिंग कार्य है, जो वास्तव में सॉफ्टवेयर के उत्पादन शुरू होने से पहले किया जाता है। यह सॉफ्टवेयर उत्पादन के लिए है, लेकिन इसमें कोई ठोस गतिविधि शामिल नहीं है जिसका सॉफ्टवेयर उत्पादन के साथ कोई संबंध है; बल्कि यह कई प्रक्रियाओं का एक सेट है, जो सॉफ्टवेयर उत्पादन की सुविधा देता है। परियोजना की योजना में निम्नलिखित शामिल हो सकते हैं:
स्कोप प्रबंधन
यह परियोजना के दायरे को परिभाषित करता है; इसमें सभी गतिविधियों को शामिल किया गया है, एक सुपुर्द करने योग्य सॉफ़्टवेयर उत्पाद बनाने के लिए प्रक्रिया की आवश्यकता है। स्कोप प्रबंधन आवश्यक है क्योंकि यह परियोजना को स्पष्ट रूप से परिभाषित करता है कि परियोजना में क्या किया जाएगा और क्या नहीं किया जाएगा। यह सीमित और मात्रात्मक कार्यों को शामिल करने के लिए परियोजना बनाता है, जिसे आसानी से प्रलेखित किया जा सकता है और बदले में लागत और समय से बचा जाता है।
प्रोजेक्ट स्कोप प्रबंधन के दौरान, यह आवश्यक है -
- दायरे को परिभाषित करें
- इसका सत्यापन और नियंत्रण तय करें
- प्रबंधन की आसानी के लिए परियोजना को विभिन्न छोटे भागों में विभाजित करें।
- दायरा सत्यापित करें
- कार्यक्षेत्र में परिवर्तनों को शामिल करके गुंजाइश को नियंत्रित करें
परियोजना का अनुमान
एक प्रभावी प्रबंधन के लिए विभिन्न उपायों का सटीक अनुमान बहुत जरूरी है। सही अनुमान के साथ प्रबंधक अधिक कुशलतापूर्वक और प्रभावी ढंग से परियोजना का प्रबंधन और नियंत्रण कर सकते हैं।
परियोजना के अनुमान में निम्नलिखित शामिल हो सकते हैं:
- Software size estimation
सॉफ़्टवेयर आकार का अनुमान या तो KLOC (कोड की किलो लाइन) या सॉफ्टवेयर में फ़ंक्शन बिंदुओं की संख्या की गणना करके लगाया जा सकता है। कोड की लाइनें कोडिंग प्रथाओं पर निर्भर करती हैं और फ़ंक्शन बिंदु उपयोगकर्ता या सॉफ़्टवेयर आवश्यकता के अनुसार भिन्न होते हैं।
- Effort estimation
प्रबंधकों को सॉफ्टवेयर का उत्पादन करने के लिए आवश्यक कर्मियों की आवश्यकता और मानव-घंटे के संदर्भ में प्रयासों का अनुमान है। प्रयास के आकलन के लिए सॉफ्टवेयर का आकार ज्ञात होना चाहिए। यह या तो प्रबंधकों के अनुभव से प्राप्त किया जा सकता है, संगठन के ऐतिहासिक डेटा या सॉफ़्टवेयर आकार को कुछ मानक सूत्रों का उपयोग करके प्रयासों में परिवर्तित किया जा सकता है।
- Time estimation
एक बार आकार और प्रयासों का अनुमान लगाया जाता है, सॉफ़्टवेयर का उत्पादन करने के लिए आवश्यक समय का अनुमान लगाया जा सकता है। आवश्यक प्रयासों को सॉफ्टवेयर के विभिन्न घटकों की आवश्यकता विनिर्देशों और अन्योन्याश्रयता के अनुसार उप श्रेणियों में अलग किया गया है। सॉफ्टवेयर कार्यों को वर्क ब्रेकथ्रू स्ट्रक्चर (WBS) द्वारा छोटे कार्यों, गतिविधियों या घटनाओं में विभाजित किया जाता है। कार्य दिन के आधार पर या कैलेंडर महीनों में निर्धारित किए जाते हैं।
सभी कार्यों को घंटों या दिनों में पूरा करने के लिए आवश्यक समय का योग परियोजना को पूरा करने के लिए लगाया गया कुल समय है।
- Cost estimation
इसे सभी में सबसे कठिन माना जा सकता है क्योंकि यह पिछले किसी भी की तुलना में अधिक तत्वों पर निर्भर करता है। परियोजना लागत का आकलन करने के लिए, इस पर विचार करना आवश्यक है -
- सॉफ्टवेयर का आकार
- सॉफ्टवेयर की गुणवत्ता
- Hardware
- अतिरिक्त सॉफ्टवेयर या उपकरण, लाइसेंस आदि।
- कार्य-विशिष्ट कौशल के साथ कुशल कर्मचारी
- यात्रा में शामिल
- Communication
- प्रशिक्षण और समर्थन
परियोजना का अनुमान तकनीक
हमने परियोजना के आकलन जैसे आकार, प्रयास, समय और लागत से जुड़े विभिन्न मापदंडों पर चर्चा की।
परियोजना प्रबंधक दो व्यापक रूप से मान्यता प्राप्त तकनीकों का उपयोग करके सूचीबद्ध कारकों का अनुमान लगा सकते हैं -
अपघटन तकनीक
यह तकनीक सॉफ्टवेयर को विभिन्न रचनाओं के उत्पाद के रूप में मानती है।
दो मुख्य मॉडल हैं -
- Line of Code सॉफ़्टवेयर उत्पाद में कोड की संख्या की ओर से अनुमान लगाया जाता है।
- Function Points सॉफ़्टवेयर उत्पाद में फ़ंक्शन बिंदुओं की संख्या के आधार पर अनुमान लगाया जाता है।
अनुभवजन्य अनुमान तकनीक
यह तकनीक अनुमान लगाने के लिए आनुभविक रूप से व्युत्पन्न सूत्रों का उपयोग करती है। ये सूत्र एलओसी या एफपी पर आधारित होते हैं।
- Putnam Model
यह मॉडल लॉरेंस एच। पुत्नाम द्वारा बनाया गया है, जो नॉर्डेन की आवृत्ति वितरण (रेले वक्र) पर आधारित है। सॉफ्टवेयर के आकार के साथ जरूरी पुटनाम मॉडल का समय और प्रयास।
- COCOMO
COCOMO बैरी डब्ल्यू। बोहम द्वारा विकसित COnstructive COst MOdel के लिए है। यह सॉफ्टवेयर उत्पाद को सॉफ्टवेयर की तीन श्रेणियों में विभाजित करता है: कार्बनिक, अर्ध-अलग और एम्बेडेड।
परियोजना निर्धारण
किसी प्रोजेक्ट में प्रोजेक्ट शेड्यूलिंग से तात्पर्य निर्दिष्ट गतिविधियों के साथ किए जाने वाले सभी गतिविधियों के रोडमैप और प्रत्येक गतिविधि के लिए आवंटित समय स्लॉट से है। प्रोजेक्ट मैनेजर विभिन्न कार्यों को परिभाषित करते हैं, और मील के पत्थर को प्रोजेक्ट करते हैं और विभिन्न कारकों को ध्यान में रखते हुए उन्हें व्यवस्थित करते हैं। वे अनुसूची में महत्वपूर्ण पथ में निहित कार्यों की तलाश करते हैं, जिन्हें विशिष्ट तरीके से पूरा करना आवश्यक है (क्योंकि कार्य निर्भरता का) और सख्ती से आवंटित समय के भीतर। महत्वपूर्ण पथ से बाहर होने वाले कार्यों की व्यवस्था से परियोजना की सभी अनुसूची पर प्रभाव पड़ने की संभावना कम है।
किसी परियोजना के निर्धारण के लिए, यह आवश्यक है -
- छोटे, प्रबंधनीय रूप में परियोजना के कार्यों को तोड़ दें
- विभिन्न कार्यों का पता लगाएं और उन्हें सहसंबंधित करें
- प्रत्येक कार्य के लिए आवश्यक समय सीमा का अनुमान लगाना
- कार्य-इकाइयों में समय विभाजित करें
- प्रत्येक कार्य के लिए पर्याप्त संख्या में कार्य-इकाइयों को असाइन करें
- शुरू से अंत तक परियोजना के लिए आवश्यक कुल समय की गणना करें
संसाधन प्रबंधन
सॉफ्टवेयर उत्पाद विकसित करने के लिए उपयोग किए जाने वाले सभी तत्वों को उस परियोजना के लिए संसाधन माना जा सकता है। इसमें मानव संसाधन, उत्पादक उपकरण और सॉफ्टवेयर लाइब्रेरी शामिल हो सकते हैं।
संसाधन सीमित मात्रा में उपलब्ध हैं और संपत्ति के पूल के रूप में संगठन में रहते हैं। संसाधनों की कमी परियोजना के विकास को बाधित करती है और यह समय से पीछे रह सकती है। अतिरिक्त संसाधनों को आवंटित करने से अंत में विकास लागत बढ़ जाती है। इसलिए परियोजना के लिए पर्याप्त संसाधनों का अनुमान लगाना और उन्हें आवंटित करना आवश्यक है।
संसाधन प्रबंधन में शामिल हैं -
- परियोजना टीम बनाकर और प्रत्येक टीम के सदस्य को जिम्मेदारियां आवंटित करके उचित संगठन परियोजना को परिभाषित करना
- किसी विशेष चरण में आवश्यक संसाधनों का निर्धारण और उनकी उपलब्धता
- आवश्यक होने पर संसाधन अनुरोध उत्पन्न करके संसाधनों का प्रबंधन करें और जब उन्हें अधिक आवश्यकता न हो तो उन्हें आवंटित करें।
परियोजना जोखिम प्रबंधन
जोखिम प्रबंधन में परियोजना में अनुमानित और गैर-अनुमानित जोखिम के लिए पहचान, विश्लेषण और प्रावधान करने से संबंधित सभी गतिविधियां शामिल हैं। जोखिम में निम्नलिखित शामिल हो सकते हैं:
- इस परियोजना को छोड़ने वाले अनुभवी कर्मचारी और इसमें आने वाले नए कर्मचारी।
- संगठनात्मक प्रबंधन में बदलाव।
- आवश्यकता परिवर्तन या गलत व्याख्या की आवश्यकता।
- आवश्यक समय और संसाधनों का अंडर-आकलन।
- तकनीकी परिवर्तन, पर्यावरण परिवर्तन, व्यापार प्रतियोगिता।
जोखिम प्रबंधन प्रक्रिया
जोखिम प्रबंधन प्रक्रिया में निम्नलिखित गतिविधियाँ शामिल हैं:
- Identification - सभी संभावित जोखिमों पर ध्यान दें, जो परियोजना में हो सकते हैं।
- Categorize - परियोजना पर उनके संभावित प्रभाव के अनुसार ज्ञात जोखिमों को उच्च, मध्यम और निम्न जोखिम तीव्रता में वर्गीकृत करना।
- Manage - विभिन्न चरणों में जोखिमों की घटना की संभावना का विश्लेषण करें। जोखिम से बचने या उसका सामना करने की योजना बनाएं। उनके दुष्प्रभावों को कम करने का प्रयास।
- Monitor - संभावित जोखिमों और उनके शुरुआती लक्षणों की बारीकी से निगरानी करें। उन्हें कम या कम करने के लिए उठाए गए कदमों के प्रभावों की निगरानी करें।
परियोजना निष्पादन और निगरानी
इस चरण में, परियोजना योजनाओं में वर्णित कार्यों को उनके कार्यक्रम के अनुसार निष्पादित किया जाता है।
योजना के अनुसार सब कुछ चल रहा है या नहीं, यह जांचने के लिए निष्पादन की निगरानी की आवश्यकता है। निगरानी जोखिम की संभावना की जांच करने और जोखिम को दूर करने के उपाय करने या विभिन्न कार्यों की स्थिति की रिपोर्ट करने के लिए देख रही है।
इन उपायों में शामिल हैं -
- Activity Monitoring - किसी कार्य के भीतर निर्धारित सभी गतिविधियों पर दिन-प्रतिदिन की निगरानी की जा सकती है। जब किसी कार्य में सभी गतिविधियाँ पूरी हो जाती हैं, तो इसे पूर्ण माना जाता है।
- Status Reports - रिपोर्ट में दी गई समय सीमा के भीतर होने वाली गतिविधियों और कार्यों की स्थिति आम तौर पर एक सप्ताह में होती है। स्थिति को समाप्त, लंबित या कार्य-प्रगति आदि के रूप में चिह्नित किया जा सकता है।
- Milestones Checklist - प्रत्येक परियोजना को कई चरणों में विभाजित किया जाता है जहां एसडीएलसी के चरणों के आधार पर प्रमुख कार्य (मील के पत्थर) किए जाते हैं। यह मील का पत्थर चेकलिस्ट हर कुछ हफ्तों में एक बार तैयार किया जाता है और मील के पत्थर की स्थिति की रिपोर्ट करता है।
परियोजना संचार प्रबंधन
प्रभावी संचार एक परियोजना की सफलता में महत्वपूर्ण भूमिका निभाता है। यह टीम के सदस्यों के साथ-साथ हार्डवेयर आपूर्तिकर्ताओं जैसे परियोजना के अन्य हितधारकों के बीच ग्राहक और संगठन के बीच अंतराल को कम करता है।
संचार मौखिक या लिखित हो सकता है। संचार प्रबंधन प्रक्रिया में निम्नलिखित चरण हो सकते हैं:
- Planning - इस कदम में परियोजना के सभी हितधारकों की पहचान और उनके बीच संचार का तरीका शामिल है। यह भी विचार करता है कि क्या किसी अतिरिक्त संचार सुविधाओं की आवश्यकता है।
- Sharing - योजना के विभिन्न पहलुओं को निर्धारित करने के बाद, प्रबंधक सही समय पर सही व्यक्ति के साथ सही जानकारी साझा करने पर ध्यान केंद्रित करता है। यह परियोजना की प्रगति और उसकी स्थिति के साथ हर एक परियोजना को शामिल करता है।
- Feedback - परियोजना प्रबंधक विभिन्न उपायों और प्रतिक्रिया तंत्र का उपयोग करते हैं और स्थिति और प्रदर्शन रिपोर्ट बनाते हैं। यह तंत्र सुनिश्चित करता है कि विभिन्न हितधारकों से इनपुट उनकी प्रतिक्रिया के रूप में परियोजना प्रबंधक के पास आ रहा है।
- Closure - प्रत्येक बड़ी घटना के अंत में, एसडीएलसी के एक चरण के अंत या स्वयं परियोजना के अंत में, दस्तावेज़ को हार्डकॉपी वितरित करके या प्रभावी संचार के अन्य माध्यम से, ईमेल को भेजकर, हर हितधारक को अपडेट करने के लिए औपचारिक रूप से प्रशासनिक बंद की घोषणा की जाती है।
बंद होने के बाद, टीम अगले चरण या परियोजना पर जाती है।
विन्यास प्रबंधन
कॉन्फ़िगरेशन प्रबंधन उत्पाद की आवश्यकताओं, डिजाइन, कार्यों और विकास के संदर्भ में सॉफ़्टवेयर में परिवर्तनों को ट्रैक करने और नियंत्रित करने की एक प्रक्रिया है।
IEEE इसे "सिस्टम में वस्तुओं को पहचानने और परिभाषित करने, उनके जीवन चक्र में इन वस्तुओं के परिवर्तन को नियंत्रित करने, वस्तुओं की स्थिति को रिकॉर्ड करने और रिपोर्ट करने और अनुरोधों को बदलने और वस्तुओं की पूर्णता और शुद्धता की पुष्टि करने" के रूप में परिभाषित करता है।
आम तौर पर, SRS को अंतिम रूप दिए जाने के बाद उपयोगकर्ता से परिवर्तनों की आवश्यकता की संभावना कम होती है। यदि वे होते हैं, तो परिवर्तनों को केवल उच्च प्रबंधन की पूर्व स्वीकृति के साथ संबोधित किया जाता है, क्योंकि लागत और समय समाप्त होने की संभावना है।
आधारभूत
SDLC का एक चरण यह माना जाता है कि यह आधारभूत है, अर्थात आधार रेखा एक माप है जो किसी चरण की पूर्णता को परिभाषित करता है। जब सभी गतिविधियाँ समाप्त हो जाती हैं और अच्छी तरह से प्रलेखित किया जाता है, तो एक चरण को आधार बनाया जाता है। यदि यह अंतिम चरण नहीं था, तो इसका उत्पादन अगले तत्काल चरण में किया जाएगा।
कॉन्फ़िगरेशन प्रबंधन संगठन प्रशासन का एक अनुशासन है, जो किसी भी बदलाव (प्रक्रिया, आवश्यकता, तकनीकी, रणनीतिक आदि) के होने के बाद एक चरण के आधारभूत होने के बाद होता है। सीएम सॉफ्टवेयर में किए गए किसी भी बदलाव की जांच करते रहते हैं।
परिवर्तन नियंत्रण
परिवर्तन नियंत्रण कॉन्फ़िगरेशन प्रबंधन का कार्य है, जो यह सुनिश्चित करता है कि सॉफ्टवेयर सिस्टम में किए गए सभी परिवर्तन सुसंगत हैं और संगठनात्मक नियमों और विनियमों के अनुसार किए गए हैं।
उत्पाद के विन्यास में बदलाव निम्न चरणों से होकर गुजरता है -
Identification- आंतरिक या बाहरी स्रोत से एक परिवर्तन अनुरोध आता है। जब परिवर्तन अनुरोध औपचारिक रूप से पहचाना जाता है, तो यह ठीक से प्रलेखित है।
Validation - परिवर्तन अनुरोध की वैधता की जाँच की जाती है और इसकी हैंडलिंग प्रक्रिया की पुष्टि की जाती है।
Analysis- परिवर्तन अनुरोध के प्रभाव का विश्लेषण अनुसूची, लागत और आवश्यक प्रयासों के संदर्भ में किया जाता है। सिस्टम पर भावी परिवर्तन के समग्र प्रभाव का विश्लेषण किया जाता है।
Control- यदि संभावित परिवर्तन या तो सिस्टम में बहुत अधिक संस्थाओं को प्रभावित करता है या यह अपरिहार्य है, तो सिस्टम में बदलाव को शामिल करने से पहले उच्च अधिकारियों की स्वीकृति लेना अनिवार्य है। यह तय किया जाता है कि परिवर्तन निगमन के लायक है या नहीं। यदि ऐसा नहीं है, तो औपचारिक रूप से परिवर्तन अनुरोध को अस्वीकार कर दिया जाता है।
Execution - यदि पिछला चरण परिवर्तन अनुरोध को निष्पादित करने के लिए निर्धारित करता है, तो यह चरण परिवर्तन को निष्पादित करने के लिए उचित कार्रवाई करता है, यदि आवश्यक हो तो पूरी तरह से संशोधन करता है।
Close request- परिवर्तन को सही कार्यान्वयन और बाकी सिस्टम के साथ विलय करने के लिए सत्यापित किया गया है। सॉफ़्टवेयर में यह नया शामिल परिवर्तन ठीक से प्रलेखित है और अनुरोध औपचारिक रूप से बंद है।
परियोजना प्रबंधन उपकरण
परियोजना के आकार के संबंध में जोखिम और अनिश्चितता परियोजना के आकार के संबंध में कई गुना बढ़ जाती है, यहां तक कि जब परियोजना निर्धारित पद्धति के अनुसार विकसित की जाती है।
ऐसे उपकरण उपलब्ध हैं, जो प्रभावी परियोजना प्रबंधन के लिए सहायता करते हैं। कुछ वर्णित हैं -
गैंट चार्ट
गैंट चार्ट्स हेनरी गैंट (1917) द्वारा तैयार किए गए थे। यह समयावधि के संबंध में परियोजना अनुसूची का प्रतिनिधित्व करता है। यह एक क्षैतिज बार चार्ट है जिसमें प्रोजेक्ट गतिविधियों के लिए निर्धारित गतिविधियों और समय का प्रतिनिधित्व करने वाले बार हैं।
पीईआरटी चार्ट
PERT (प्रोग्राम इवैल्यूएशन एंड रिव्यू टेक्नीक) चार्ट एक टूल है जो प्रोजेक्ट को नेटवर्क आरेख के रूप में दर्शाता है। यह समानांतर और लगातार दोनों तरह से परियोजना की मुख्य घटनाओं का रेखांकन करने में सक्षम है। एक के बाद एक होने वाली घटनाएँ, पिछले एक के बाद की घटना की निर्भरता दर्शाती हैं।
घटनाओं को गिने हुए नोड्स के रूप में दिखाया गया है। वे परियोजना में कार्यों के अनुक्रम को दर्शाते हुए लेबल वाले तीरों से जुड़े हुए हैं।
संसाधन हिस्टोग्राम
यह एक ग्राफिकल टूल है जिसमें प्रोजेक्ट इवेंट (या चरण) के लिए समय पर आवश्यक संसाधनों (आमतौर पर कुशल कर्मचारी) की संख्या का प्रतिनिधित्व करने वाले बार या चार्ट होते हैं। संसाधन हिस्टोग्राम कर्मचारियों की योजना और समन्वय के लिए एक प्रभावी उपकरण है।
महत्वपूर्ण पथ विश्लेषण
यह उपकरण परियोजना में अन्योन्याश्रित कार्यों को पहचानने में उपयोगी है। यह परियोजना को सफलतापूर्वक पूरा करने के लिए सबसे छोटे मार्ग या महत्वपूर्ण मार्ग का पता लगाने में भी मदद करता है। PERT आरेख की तरह, प्रत्येक घटना को एक विशिष्ट समय सीमा आवंटित की जाती है। यह उपकरण घटना की निर्भरता को दर्शाता है कि एक घटना पूरी होने पर ही आगे बढ़ सकती है।
घटनाओं को उनके शुरुआती संभावित समय के अनुसार व्यवस्थित किया जाता है। स्टार्ट और एंड नोड के बीच का रास्ता महत्वपूर्ण पथ है जिसे और कम नहीं किया जा सकता है और सभी घटनाओं को एक ही क्रम में निष्पादित करने की आवश्यकता होती है।
सॉफ़्टवेयर आवश्यकताएँ लक्ष्य प्रणाली की सुविधाओं और कार्यक्षमताओं का विवरण हैं। आवश्यकताएँ सॉफ़्टवेयर उत्पाद से उपयोगकर्ताओं की अपेक्षाओं को व्यक्त करती हैं। आवश्यकताएं स्पष्ट या छिपी हुई, ज्ञात या अज्ञात, ग्राहक की दृष्टि से अपेक्षित या अप्रत्याशित हो सकती हैं।
आवश्यकता इंजीनियरिंग
क्लाइंट से सॉफ़्टवेयर आवश्यकताओं को इकट्ठा करने की प्रक्रिया, उनका विश्लेषण और दस्तावेज़ उन्हें आवश्यकता इंजीनियरिंग के रूप में जाना जाता है।
आवश्यकता इंजीनियरिंग का लक्ष्य परिष्कृत और वर्णनात्मक 'सिस्टम आवश्यकताएँ विशिष्टता' दस्तावेज़ को विकसित और बनाए रखना है।
आवश्यकता इंजीनियरिंग प्रक्रिया
यह चार चरणों वाली प्रक्रिया है, जिसमें शामिल हैं -
- व्यवहार्यता अध्ययन
- आवश्यक भीड़ जुटना
- सॉफ्टवेयर की आवश्यकता विशिष्टता
- सॉफ़्टवेयर आवश्यकता सत्यापन
आइए प्रक्रिया को संक्षेप में देखें -
व्यवहार्यता अध्ययन
जब ग्राहक वांछित उत्पाद को विकसित करने के लिए संगठन से संपर्क करता है, तो यह मोटे तौर पर इस विचार के साथ आता है कि सॉफ़्टवेयर को क्या कार्य करना चाहिए और सॉफ़्टवेयर से सभी सुविधाओं की अपेक्षा की जाती है।
इस जानकारी का संदर्भ देते हुए, विश्लेषक इस बारे में विस्तृत अध्ययन करते हैं कि क्या वांछित प्रणाली और इसकी कार्यक्षमता विकसित करने के लिए संभव है।
यह व्यवहार्यता अध्ययन संगठन के लक्ष्य की ओर केंद्रित है। यह अध्ययन विश्लेषण करता है कि क्या सॉफ्टवेयर उत्पाद को कार्यान्वयन, संगठन में परियोजना के योगदान, लागत की कमी और संगठन के मूल्यों और उद्देश्यों के अनुसार व्यावहारिक रूप से भौतिक रूप से विकसित किया जा सकता है। यह प्रयोज्यता, रखरखाव, उत्पादकता और एकीकरण क्षमता जैसे परियोजना और उत्पाद के तकनीकी पहलुओं की पड़ताल करता है।
इस चरण का आउटपुट एक व्यवहार्यता अध्ययन रिपोर्ट होना चाहिए जिसमें इस परियोजना के लिए प्रबंधन के लिए पर्याप्त टिप्पणियां और सिफारिशें होनी चाहिए या नहीं।
आवश्यक भीड़ जुटना
यदि व्यवहार्यता रिपोर्ट परियोजना को शुरू करने की दिशा में सकारात्मक है, तो अगला चरण उपयोगकर्ता से आवश्यकताओं को इकट्ठा करने के साथ शुरू होता है। एनालिस्ट और इंजीनियर क्लाइंट और एंड-यूजर्स के साथ संवाद करते हैं ताकि उन्हें यह पता चल सके कि सॉफ्टवेयर क्या प्रदान करना चाहिए और वे कौन से फीचर शामिल करना चाहते हैं।
सॉफ्टवेयर की आवश्यकता विशिष्टता
एसआरएस विभिन्न विश्लेषकों से आवश्यकताओं को एकत्र करने के बाद सिस्टम विश्लेषक द्वारा बनाया गया एक दस्तावेज है।
एसआरएस परिभाषित करता है कि हार्डवेयर, बाहरी इंटरफेस, ऑपरेशन की गति, सिस्टम की प्रतिक्रिया समय, विभिन्न प्लेटफार्मों में सॉफ़्टवेयर की पोर्टेबिलिटी, क्रैश होने के बाद वसूली की गति, सुरक्षा, गुणवत्ता, सीमाएं आदि के साथ बातचीत कैसे करेगी।
क्लाइंट से प्राप्त आवश्यकताओं को प्राकृतिक भाषा में लिखा जाता है। यह तकनीकी भाषा में आवश्यकताओं को दस्तावेज करने के लिए सिस्टम विश्लेषक की जिम्मेदारी है ताकि वे सॉफ्टवेयर डेवलपमेंट टीम द्वारा समझे और उपयोगी हो सकें।
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 (कोड की पंक्तियाँ), जो कि ज्यादातर वितरित स्रोत कोड लाइनों में से हजारों में गणना की जाती हैं, जिन्हें KLOC के रूप में दर्शाया गया है।
समारोह बिंदु गणना सॉफ्टवेयर द्वारा प्रदान की गई कार्यक्षमता का माप है। फंक्शन प्वाइंट काउंट सॉफ्टवेयर के कार्यात्मक पहलू के आकार को परिभाषित करता है।
- Complexity Metrics - मैककेब की साइक्लोमैटिक जटिलता एक कार्यक्रम में स्वतंत्र पथों की संख्या की ऊपरी सीमा को निर्धारित करती है, जिसे कार्यक्रम या इसके मॉड्यूल की जटिलता के रूप में माना जाता है। यह नियंत्रण प्रवाह ग्राफ का उपयोग करके ग्राफ सिद्धांत अवधारणाओं के संदर्भ में दर्शाया गया है।
Quality Metrics - दोष, उनके प्रकार और कारण, परिणाम, गंभीरता की तीव्रता और उनके निहितार्थ उत्पाद की गुणवत्ता को परिभाषित करते हैं।
विकास की प्रक्रिया में पाए जाने वाले दोषों की संख्या और क्लाइंट द्वारा क्लाइंट-एंड पर वितरित किए जाने के बाद ग्राहक द्वारा बताए गए दोषों की संख्या, उत्पाद की गुणवत्ता को परिभाषित करते हैं।
- Process Metrics - एसडीएलसी के विभिन्न चरणों में, उपयोग किए जाने वाले तरीके और उपकरण, कंपनी के मानक और विकास का प्रदर्शन सॉफ्टवेयर प्रोसेस मेट्रिक्स हैं।
- Resource Metrics - प्रयास, समय और उपयोग किए जाने वाले विभिन्न संसाधन, संसाधन मापन के लिए मीट्रिक का प्रतिनिधित्व करते हैं।
सॉफ्टवेयर डिजाइन उपयोगकर्ता की आवश्यकताओं को कुछ उपयुक्त रूप में बदलने की एक प्रक्रिया है, जो प्रोग्रामर को सॉफ्टवेयर कोडिंग और कार्यान्वयन में मदद करता है।
उपयोगकर्ता की आवश्यकताओं का आकलन करने के लिए, SRS (सॉफ्टवेयर रिक्वायरमेंट स्पेसिफिकेशन) दस्तावेज बनाया जाता है, जबकि कोडिंग और कार्यान्वयन के लिए, सॉफ्टवेयर शब्दों में अधिक विशिष्ट और विस्तृत आवश्यकताओं की आवश्यकता होती है। इस प्रक्रिया का उत्पादन सीधे प्रोग्रामिंग भाषाओं में कार्यान्वयन में किया जा सकता है।
सॉफ्टवेयर डिजाइन SDLC (सॉफ्टवेयर डिजाइन लाइफ साइकिल) में पहला कदम है, जो एकाग्रता को समस्या डोमेन से समाधान डोमेन तक ले जाता है। यह निर्दिष्ट करने की कोशिश करता है कि एसआरएस में उल्लिखित आवश्यकताओं को कैसे पूरा किया जाए।
सॉफ्टवेयर डिजाइन के स्तर
सॉफ्टवेयर डिजाइन के परिणाम के तीन स्तर मिलते हैं:
- Architectural Design - आर्किटेक्चरल डिज़ाइन सिस्टम का उच्चतम सार संस्करण है। यह सॉफ्टवेयर को एक प्रणाली के रूप में पहचानता है जिसमें कई घटक एक दूसरे के साथ बातचीत करते हैं। इस स्तर पर, डिजाइनरों को प्रस्तावित समाधान डोमेन का विचार मिलता है।
- High-level Design- उच्च-स्तरीय डिज़ाइन उप-सिस्टम और मॉड्यूल के कम-सार दृश्य में वास्तुशिल्प डिजाइन की 'एकल इकाई-कई घटक' अवधारणा को तोड़ता है और एक-दूसरे के साथ उनकी बातचीत को दर्शाता है। उच्च-स्तरीय डिज़ाइन इस बात पर केंद्रित है कि कैसे अपने सभी घटकों के साथ सिस्टम को मॉड्यूल के रूप में लागू किया जा सकता है। यह प्रत्येक उप-प्रणाली के मॉड्यूलर संरचना और उनके संबंध और एक दूसरे के बीच बातचीत को पहचानता है।
- Detailed Design- पिछले दो डिजाइनों में एक प्रणाली और इसके उप-प्रणालियों के रूप में देखे जाने वाले कार्यान्वयन भाग के साथ विस्तृत डिजाइन संबंधित है। यह मॉड्यूल और उनके कार्यान्वयन के लिए अधिक विस्तृत है। यह प्रत्येक मॉड्यूल की तार्किक संरचना और अन्य मॉड्यूल के साथ संवाद करने के लिए उनके इंटरफेस को परिभाषित करता है।
मॉड्यूलर
मॉडर्नाइजेशन एक सॉफ्टवेयर सिस्टम को कई असतत और स्वतंत्र मॉड्यूल में विभाजित करने की एक तकनीक है, जो स्वतंत्र रूप से कार्य को पूरा करने में सक्षम होने की उम्मीद करते हैं। ये मॉड्यूल पूरे सॉफ्टवेयर के लिए बुनियादी निर्माण के रूप में काम कर सकते हैं। डिज़ाइनर ऐसे मॉड्यूल डिज़ाइन करते हैं, जिन्हें वे अलग और स्वतंत्र रूप से निष्पादित और / या संकलित कर सकते हैं।
मॉड्यूलर डिजाइन अनायास ही 'डिवाइड एंड कॉन को जीत' की समस्या को सुलझाने की रणनीति का पालन करता है, क्योंकि सॉफ्टवेयर के मॉड्यूलर डिजाइन के साथ कई अन्य लाभ जुड़े होते हैं।
संशोधन का लाभ:
- छोटे घटकों को बनाए रखना आसान होता है
- कार्यक्रम को कार्यात्मक पहलुओं के आधार पर विभाजित किया जा सकता है
- कार्यक्रम में अमूर्त स्तर का वांछित स्तर लाया जा सकता है
- उच्च सामंजस्य वाले घटकों को फिर से उपयोग किया जा सकता है
- समवर्ती निष्पादन को संभव बनाया जा सकता है
- सुरक्षा पहलू से वांछित
संगामिति
समय के साथ, सभी सॉफ्टवेयर क्रमिक रूप से निष्पादित होने के लिए होते हैं। अनुक्रमिक निष्पादन से हमारा मतलब है कि किसी भी समय सक्रिय किए जा रहे कार्यक्रम के केवल एक हिस्से को लागू करने के बाद कोडित निर्देश को एक के बाद एक निष्पादित किया जाएगा। कहें, एक सॉफ्टवेयर में कई मॉड्यूल होते हैं, तो निष्पादन के किसी भी समय सभी मॉड्यूल में से केवल एक ही सक्रिय पाया जा सकता है।
सॉफ्टवेयर डिजाइन में, समरूपता को क्रियान्वयन की कई स्वतंत्र इकाइयों में सॉफ्टवेयर को विभाजित करके कार्यान्वित किया जाता है, जैसे मॉड्यूल और उन्हें समानांतर में निष्पादित करना। दूसरे शब्दों में, संगामिति एक दूसरे के समानांतर कोड के एक से अधिक भाग को निष्पादित करने के लिए सॉफ्टवेयर को क्षमता प्रदान करती है।
प्रोग्रामर और डिजाइनरों के लिए उन मॉड्यूल को पहचानना आवश्यक है, जिन्हें समानांतर निष्पादन बनाया जा सकता है।
उदाहरण
वर्ड प्रोसेसर में वर्तनी जांच सुविधा सॉफ्टवेयर का एक मॉड्यूल है, जो वर्ड प्रोसेसर के साथ-साथ चलता है।
युग्मन और सामंजस्य
जब एक सॉफ्टवेयर प्रोग्राम को संशोधित किया जाता है, तो इसके कार्यों को कुछ विशेषताओं के आधार पर कई मॉड्यूल में विभाजित किया जाता है। जैसा कि हम जानते हैं, मॉड्यूल कुछ कार्यों को प्राप्त करने के लिए निर्देशों को एक साथ रखा जाता है। हालांकि, उन्हें एकल इकाई के रूप में माना जाता है, लेकिन साथ काम करने के लिए एक-दूसरे को संदर्भित कर सकते हैं। ऐसे उपाय हैं जिनके द्वारा मॉड्यूल के एक डिजाइन की गुणवत्ता और उनके बीच की बातचीत को मापा जा सकता है। इन उपायों को युग्मन और सामंजस्य कहा जाता है।
एकजुटता
सामंजस्य एक उपाय है जो एक मॉड्यूल के तत्वों के भीतर इंट्रा-निर्भरता की डिग्री को परिभाषित करता है। अधिक से अधिक सामंजस्य, बेहतर कार्यक्रम डिजाइन है।
सात प्रकार के सामंजस्य हैं, अर्थात् -
- Co-incidental cohesion -यह अनियोजित और यादृच्छिक सामंजस्य है, जो मॉड्यूलरीकरण के लिए कार्यक्रम को छोटे मॉड्यूल में तोड़ने का परिणाम हो सकता है। क्योंकि यह अनियोजित है, यह प्रोग्रामरों को भ्रम की स्थिति में डाल सकता है और आम तौर पर स्वीकार नहीं किया जाता है।
- Logical cohesion - जब तार्किक रूप से वर्गीकृत तत्वों को एक मॉड्यूल में एक साथ रखा जाता है, तो इसे तार्किक सामंजस्य कहा जाता है।
- emporal Cohesion - जब मॉड्यूल के तत्वों को ऐसे व्यवस्थित किया जाता है कि उन्हें समय पर एक समान बिंदु पर संसाधित किया जाता है, तो इसे अस्थायी सामंजस्य कहा जाता है।
- Procedural cohesion - जब मॉड्यूल के तत्वों को एक साथ रखा जाता है, जो किसी कार्य को करने के लिए क्रमिक रूप से निष्पादित होते हैं, तो इसे प्रक्रियात्मक सामंजस्य कहा जाता है।
- Communicational cohesion - जब मॉड्यूल के तत्वों को एक साथ समूहित किया जाता है, जो क्रमिक रूप से निष्पादित होते हैं और समान डेटा (सूचना) पर काम करते हैं, तो इसे संचारी विभाजन कहा जाता है।
- Sequential cohesion - जब मॉड्यूल के तत्वों को समूहीकृत किया जाता है क्योंकि एक तत्व का आउटपुट दूसरे और इसी तरह इनपुट के रूप में कार्य करता है, इसे क्रमिक सामंजस्य कहा जाता है।
- Functional cohesion - इसे सामंजस्य की उच्चतम डिग्री माना जाता है, और यह बहुत अपेक्षित है। कार्यात्मक सामंजस्य में मॉड्यूल के तत्वों को समूहीकृत किया जाता है क्योंकि वे सभी एक अच्छी तरह से परिभाषित फ़ंक्शन में योगदान करते हैं। इसका पुन: उपयोग भी किया जा सकता है।
युग्मन
युग्मन एक उपाय है जो एक कार्यक्रम के मॉड्यूल के बीच अंतर-निर्भरता के स्तर को परिभाषित करता है। यह बताता है कि मॉड्यूल किस स्तर पर हस्तक्षेप करते हैं और एक दूसरे के साथ बातचीत करते हैं। कपलिंग जितना कम होगा, कार्यक्रम उतना ही बेहतर होगा।
युग्मन के पाँच स्तर हैं, अर्थात् -
- Content coupling - जब एक मॉड्यूल दूसरे मॉड्यूल की सामग्री को सीधे एक्सेस या संशोधित या संदर्भित कर सकता है, तो इसे सामग्री स्तर युग्मन कहा जाता है।
- Common coupling- जब कई मॉड्यूल ने कुछ वैश्विक डेटा तक पहुंच को पढ़ा और लिखा है, तो इसे सामान्य या वैश्विक युग्मन कहा जाता है।
- Control coupling- दो मॉड्यूल को कंट्रोल-कपल कहा जाता है यदि उनमें से एक अन्य मॉड्यूल के कार्य को तय करता है या निष्पादन के अपने प्रवाह को बदलता है।
- Stamp coupling- जब कई मॉड्यूल सामान्य डेटा संरचना साझा करते हैं और इसके विभिन्न भाग पर काम करते हैं, तो इसे स्टैंप युग्मन कहा जाता है।
- Data coupling- डेटा युग्मन तब होता है जब दो मॉड्यूल डेटा (पैरामीटर के रूप में) पास करने के माध्यम से एक दूसरे के साथ बातचीत करते हैं। यदि एक मॉड्यूल पैरामीटर के रूप में डेटा संरचना को पास करता है, तो प्राप्त मॉड्यूल को अपने सभी घटकों का उपयोग करना चाहिए।
आदर्श रूप से, कोई युग्मन सबसे अच्छा नहीं माना जाता है।
डिजाइन सत्यापन
सॉफ्टवेयर डिजाइन प्रक्रिया का आउटपुट डिजाइन प्रलेखन, छद्म कोड, विस्तृत तर्क आरेख, प्रक्रिया आरेख, और सभी कार्यात्मक या गैर-कार्यात्मक आवश्यकताओं का विस्तृत विवरण है।
अगला चरण, जो कि सॉफ्टवेयर का कार्यान्वयन है, ऊपर उल्लिखित सभी आउटपुट पर निर्भर करता है।
फिर अगले चरण पर आगे बढ़ने से पहले आउटपुट को सत्यापित करना आवश्यक हो जाता है। किसी भी गलती का जल्दी पता चल जाता है, बेहतर यह है कि उत्पाद के परीक्षण तक इसका पता नहीं लगाया जा सकता है। यदि डिज़ाइन चरण के आउटपुट औपचारिक संकेतन रूप में हैं, तो सत्यापन के लिए उनके संबद्ध उपकरणों का उपयोग किया जाना चाहिए अन्यथा सत्यापन और सत्यापन के लिए पूरी तरह से डिज़ाइन समीक्षा का उपयोग किया जा सकता है।
संरचित सत्यापन दृष्टिकोण से, समीक्षक उन दोषों का पता लगा सकते हैं जो कुछ स्थितियों को देखने के कारण हो सकते हैं। एक अच्छा डिजाइन समीक्षा अच्छे सॉफ्टवेयर डिजाइन, सटीकता और गुणवत्ता के लिए महत्वपूर्ण है।
सॉफ्टवेयर विश्लेषण और डिजाइन में सभी गतिविधियां शामिल हैं, जो कार्यान्वयन में आवश्यकता विनिर्देश के परिवर्तन में मदद करती हैं। आवश्यकता विनिर्देशों को सॉफ्टवेयर से सभी कार्यात्मक और गैर-कार्यात्मक अपेक्षाएं निर्दिष्ट हैं। ये आवश्यकता विनिर्देश मानव पठनीय और समझने योग्य दस्तावेजों के आकार में आते हैं, जिनके लिए कंप्यूटर का कोई लेना-देना नहीं है।
सॉफ्टवेयर विश्लेषण और डिजाइन मध्यवर्ती चरण है, जो मानव-पठनीय आवश्यकताओं को वास्तविक कोड में बदलने में मदद करता है।
आइए सॉफ्टवेयर डिजाइनरों द्वारा उपयोग किए जाने वाले कुछ विश्लेषण और डिज़ाइन टूल देखें:
आंकड़ा प्रवाह आरेख
डेटा प्रवाह आरेख एक सूचना प्रणाली में डेटा के प्रवाह का चित्रमय प्रतिनिधित्व है। यह आने वाले डेटा प्रवाह, आउटगोइंग डेटा प्रवाह और संग्रहीत डेटा को चित्रित करने में सक्षम है। सिस्टम के माध्यम से डेटा कैसे बहता है, इस बारे में DFD ने कुछ भी उल्लेख नहीं किया है।
DFD और फ़्लोचार्ट के बीच एक प्रमुख अंतर है। फ्लोचार्ट कार्यक्रम मॉड्यूल में नियंत्रण के प्रवाह को दर्शाता है। डीएफडी विभिन्न स्तरों पर प्रणाली में डेटा के प्रवाह को दर्शाते हैं। DFD में कोई नियंत्रण या शाखा तत्व नहीं होते हैं।
DFD के प्रकार
डेटा फ्लो डायग्राम या तो लॉजिकल हैं या फिजिकल।
- Logical DFD - इस प्रकार का DFD सिस्टम प्रक्रिया पर ध्यान केंद्रित करता है, और सिस्टम में डेटा का प्रवाह करता है। उदाहरण के लिए बैंकिंग सॉफ्टवेयर सिस्टम में, विभिन्न संस्थाओं के बीच डेटा कैसे ले जाया जाता है।
- Physical DFD- इस प्रकार का DFD दिखाता है कि सिस्टम में डेटा प्रवाह वास्तव में कैसे लागू किया जाता है। यह अधिक विशिष्ट है और कार्यान्वयन के करीब है।
DFD घटक
DFD घटकों के निम्नलिखित सेट का उपयोग करके डेटा के स्रोत, गंतव्य, भंडारण और प्रवाह का प्रतिनिधित्व कर सकता है -
- Entities- संस्थाएँ सूचना डेटा का स्रोत और गंतव्य हैं। संस्थाओं को उनके संबंधित नामों के साथ एक आयतों द्वारा दर्शाया जाता है।
- Process - डेटा पर की गई गतिविधियों और कार्रवाई को सर्कल या गोल-धार आयतों द्वारा दर्शाया जाता है।
- Data Storage - डेटा स्टोरेज के दो वैरिएंट हैं - इसे या तो दोनों पक्षों की अनुपस्थिति के साथ एक आयत के रूप में दर्शाया जा सकता है या केवल एक तरफ के साथ एक ओपन साइडेड आयत के रूप में गायब हो सकता है।
- Data Flow- डेटा का मूवमेंट नुकीले तीर द्वारा दिखाया गया है। डेटा आंदोलन को तीर के आधार से गंतव्य के रूप में तीर के सिर की ओर अपने स्रोत के रूप में दिखाया गया है।
DFD के स्तर
- Level 0- उच्चतम अमूर्त स्तर DFD स्तर 0 DFD के रूप में जाना जाता है, जो संपूर्ण सूचना प्रणाली को सभी अंतर्निहित विवरणों को छिपाने वाले एक आरेख के रूप में दर्शाता है। स्तर 0 DFDs को संदर्भ स्तर DFDs के रूप में भी जाना जाता है।
- Level 1- लेवल 0 डीएफडी अधिक विशिष्ट, लेवल 1 डीएफडी में टूट जाता है। स्तर 1 DFD प्रणाली में बुनियादी मॉड्यूल और विभिन्न मॉड्यूल के बीच डेटा के प्रवाह को दर्शाया गया है। स्तर 1 DFD में बुनियादी प्रक्रियाओं और सूचना के स्रोतों का भी उल्लेख किया गया है।
Level 2 - इस स्तर पर, DFD दिखाता है कि स्तर 1 में वर्णित मॉड्यूल के अंदर डेटा कैसे बहता है।
उच्च स्तर के DFDs को विशिष्ट स्तर के डीएफडी में तबदील किया जा सकता है जब तक कि विनिर्देश के वांछित स्तर को प्राप्त न कर लिया जाए।
संरचना चार्ट
संरचना चार्ट डेटा फ्लो आरेख से प्राप्त चार्ट है। यह DFD की तुलना में अधिक विस्तार से सिस्टम का प्रतिनिधित्व करता है। यह पूरी प्रणाली को सबसे कम कार्यात्मक मॉड्यूल में तोड़ता है, सिस्टम के प्रत्येक मॉड्यूल के कार्यों और उप-कार्यों का वर्णन करता है, जो डीएफडी से अधिक विवरण में हैं।
संरचना चार्ट मॉड्यूल के पदानुक्रमित संरचना का प्रतिनिधित्व करता है। प्रत्येक परत पर एक विशिष्ट कार्य किया जाता है।
यहाँ संरचना चार्ट के निर्माण में उपयोग किए गए प्रतीक हैं -
- Module- यह प्रक्रिया या सबरूटीन या कार्य का प्रतिनिधित्व करता है। एक नियंत्रण मॉड्यूल एक से अधिक उप-मॉड्यूल के लिए शाखाएं। लाइब्रेरी मॉड्यूल किसी भी मॉड्यूल से पुनः प्रयोग करने योग्य और अमूल्य हैं।
- Condition- यह मॉड्यूल के आधार पर छोटे हीरे द्वारा दर्शाया गया है। यह दर्शाता है कि नियंत्रण मॉड्यूल कुछ स्थिति के आधार पर किसी भी उप-दिनचर्या का चयन कर सकता है।
- Jump - एक तीर को मॉड्यूल के अंदर इंगित करते हुए दर्शाया गया है कि नियंत्रण उप-मॉड्यूल के बीच में कूद जाएगा।
- Loop- एक घुमावदार तीर मॉड्यूल में लूप का प्रतिनिधित्व करता है। लूप द्वारा कवर किए गए सभी उप-मॉड्यूल मॉड्यूल के निष्पादन को दोहराते हैं।
- Data flow - अंत में खाली सर्कल के साथ एक निर्देशित तीर डेटा प्रवाह का प्रतिनिधित्व करता है।
- Control flow - अंत में भरे हुए सर्कल के साथ एक निर्देशित तीर नियंत्रण प्रवाह का प्रतिनिधित्व करता है।
HIPO आरेख
HIPO (पदानुक्रमित इनपुट प्रक्रिया आउटपुट) आरेख प्रणाली का विश्लेषण करने और प्रलेखन के साधन प्रदान करने के लिए दो संगठित विधि का एक संयोजन है। HIPO मॉडल को वर्ष 1970 में IBM द्वारा विकसित किया गया था।
HIPO आरेख सॉफ्टवेयर सिस्टम में मॉड्यूल के पदानुक्रम का प्रतिनिधित्व करता है। सिस्टम कार्यों के उच्च-स्तरीय दृश्य प्राप्त करने के लिए विश्लेषक HIPO आरेख का उपयोग करता है। यह एक पदानुक्रमित तरीके से कार्यों को उप-कार्यों में विघटित करता है। इसमें सिस्टम द्वारा निष्पादित कार्यों को दर्शाया गया है।
HIPO आरेख प्रलेखन उद्देश्य के लिए अच्छे हैं। उनका ग्राफिकल प्रतिनिधित्व डिजाइनरों और प्रबंधकों के लिए सिस्टम संरचना के सचित्र विचार प्राप्त करना आसान बनाता है।
आईपीओ (इनपुट प्रक्रिया आउटपुट) आरेख के विपरीत, जो एक मॉड्यूल में नियंत्रण और डेटा के प्रवाह को दर्शाता है, HIPO डेटा प्रवाह या नियंत्रण प्रवाह के बारे में कोई जानकारी प्रदान नहीं करता है।
उदाहरण
HIPO आरेख के दोनों भाग, पदानुक्रमित प्रस्तुति और IPO चार्ट सॉफ्टवेयर प्रोग्राम की संरचना डिजाइन के साथ-साथ उसी के प्रलेखन के लिए उपयोग किया जाता है।
संरचित अंग्रेजी
अधिकांश प्रोग्रामर सॉफ्टवेयर की बड़ी तस्वीर से अनजान हैं, इसलिए वे केवल इस बात पर भरोसा करते हैं कि उनके प्रबंधक उन्हें क्या करने के लिए कहते हैं। यह प्रोग्रामर को सटीक अभी तक तेज कोड विकसित करने के लिए सटीक जानकारी प्रदान करने के लिए उच्च सॉफ्टवेयर प्रबंधन की जिम्मेदारी है।
तरीकों के अन्य रूप, जो ग्राफ़ या आरेखों का उपयोग करते हैं, कभी-कभी अलग-अलग लोगों द्वारा अलग-अलग व्याख्या की जाती है।
इसलिए, सॉफ़्टवेयर के विश्लेषक और डिज़ाइनर स्ट्रक्चर्ड इंग्लिश जैसे टूल के साथ आते हैं। यह कुछ भी नहीं है कि इसे कोड करने के लिए क्या आवश्यक है और इसे कैसे कोड करना है, इसका वर्णन है। संरचित अंग्रेजी प्रोग्रामर को त्रुटि मुक्त कोड लिखने में मदद करती है।
अन्य प्रकार के तरीके, जो ग्राफ़ या आरेखों का उपयोग करते हैं, कभी-कभी अलग-अलग लोगों द्वारा अलग-अलग व्याख्या की जाती है। यहाँ, स्ट्रक्चर्ड इंग्लिश और स्यूडो-कोड दोनों उस समझ अंतर को कम करने की कोशिश करते हैं।
संरचित अंग्रेजी है यह संरचित प्रोग्रामिंग प्रतिमान में सादे अंग्रेजी शब्दों का उपयोग करता है। यह अंतिम कोड नहीं है, लेकिन एक तरह का विवरण है जिसे कोड की आवश्यकता है और इसे कैसे कोड करना है। निम्नलिखित संरचित प्रोग्रामिंग के कुछ टोकन हैं।
IF-THEN-ELSE,
DO-WHILE-UNTIL
विश्लेषक समान चर और डेटा नाम का उपयोग करते हैं, जो डेटा शब्दकोश में संग्रहीत होते हैं, जिससे कोड लिखना और समझना बहुत सरल हो जाता है।
उदाहरण
हम ऑनलाइन खरीदारी के माहौल में ग्राहक प्रमाणीकरण का एक ही उदाहरण लेते हैं। ग्राहक को प्रमाणित करने की यह प्रक्रिया संरचित अंग्रेजी में इस प्रकार लिखी जा सकती है:
Enter Customer_Name
SEEK Customer_Name in Customer_Name_DB file
IF Customer_Name found THEN
Call procedure USER_PASSWORD_AUTHENTICATE()
ELSE
PRINT error message
Call procedure NEW_CUSTOMER_REQUEST()
ENDIF
स्ट्रक्चर्ड इंग्लिश में लिखा गया कोड दिन-प्रतिदिन की इंग्लिश की तरह होता है। इसे सीधे सॉफ्टवेयर कोड के रूप में लागू नहीं किया जा सकता है। संरचित अंग्रेजी प्रोग्रामिंग भाषा से स्वतंत्र है।
छद्म कोड
छद्म कोड को प्रोग्रामिंग भाषा के अधिक करीब लिखा जाता है। इसे संवर्धित प्रोग्रामिंग भाषा के रूप में माना जा सकता है, टिप्पणियों और विवरणों से भरा हुआ।
छद्म कोड चर घोषणा से बचा जाता है, लेकिन वे कुछ वास्तविक प्रोग्रामिंग भाषा के निर्माण का उपयोग करके लिखे जाते हैं, जैसे सी, फोरट्रान, पास्कल आदि।
छद्म कोड में संरचित अंग्रेजी की तुलना में अधिक प्रोग्रामिंग विवरण हैं। यह कार्य करने की एक विधि प्रदान करता है, जैसे कि कोई कंप्यूटर कोड निष्पादित कर रहा हो।
उदाहरण
एन संख्या तक फाइबोनैचि को मुद्रित करने का कार्यक्रम।
void function Fibonacci
Get value of n;
Set value of a to 1;
Set value of b to 1;
Initialize I to 0
for (i=0; i< n; i++)
{
if a greater than b
{
Increase b by a;
Print b;
}
else if b greater than a
{
increase a by b;
print a;
}
}
निर्णय सारणी
निर्णय तालिका एक संरचित सारणीबद्ध प्रारूप में, उन्हें संबोधित करने के लिए की जाने वाली स्थितियों और संबंधित क्रियाओं का प्रतिनिधित्व करती है।
यह डिबग और त्रुटियों को रोकने के लिए एक शक्तिशाली उपकरण है। यह समूह को एक ही तालिका में समान जानकारी में मदद करता है और फिर तालिकाओं के संयोजन से यह आसान और सुविधाजनक निर्णय लेने में मदद करता है।
निर्णय तालिका बनाना
निर्णय तालिका बनाने के लिए, डेवलपर को मूल चार चरणों का पालन करना चाहिए:
- संबोधित की जाने वाली सभी संभावित स्थितियों को पहचानें
- सभी पहचान की गई स्थितियों के लिए कार्य निर्धारित करें
- अधिकतम संभव नियम बनाएँ
- प्रत्येक नियम के लिए क्रिया को परिभाषित करें
निर्णय तालिका को अंतिम उपयोगकर्ताओं द्वारा सत्यापित किया जाना चाहिए और हाल ही में डुप्लिकेट नियमों और कार्यों को समाप्त करके सरल बनाया जा सकता है।
उदाहरण
आइए हम अपनी इंटरनेट कनेक्टिविटी के साथ दिन-प्रतिदिन की समस्या का एक सरल उदाहरण लें। हम उन सभी समस्याओं की पहचान करके शुरू करते हैं जो इंटरनेट और उनके संबंधित संभावित समाधानों को शुरू करते समय उत्पन्न हो सकती हैं।
हम स्तंभ स्थितियों और स्तंभ क्रियाओं के अंतर्गत संभावित क्रियाओं के अंतर्गत सभी संभावित समस्याओं को सूचीबद्ध करते हैं।
स्थितियां / कार्रवाई | नियमों | ||||||||
---|---|---|---|---|---|---|---|---|---|
शर्तेँ | कनेक्टेड दिखाता है | एन | एन | एन | एन | Y | Y | Y | Y |
पिंग काम कर रहा है | एन | एन | Y | Y | एन | एन | Y | Y | |
वेबसाइट खोलता है | Y | एन | Y | एन | Y | एन | Y | एन | |
कार्रवाई | नेटवर्क केबल की जाँच करें | एक्स | |||||||
इंटरनेट राउटर की जाँच करें | एक्स | एक्स | एक्स | एक्स | |||||
वेब ब्राउज़र को पुनरारंभ करें | एक्स | ||||||||
सेवा प्रदाता से संपर्क करें | एक्स | एक्स | एक्स | एक्स | एक्स | एक्स | |||
कोई क्रिया न करना |
इकाई-संबंध मॉडल
एंटिटी-रिलेशनशिप मॉडल एक प्रकार का डेटाबेस मॉडल है जो वास्तविक विश्व संस्थाओं की धारणा और उनके बीच संबंध पर आधारित है। हम ईआर डेटाबेस मॉडल पर वास्तविक विश्व परिदृश्य को मैप कर सकते हैं। ईआर मॉडल अपनी विशेषताओं, बाधाओं का एक समूह और उनके बीच संबंध के साथ संस्थाओं का एक समूह बनाता है।
ईआर मॉडल डेटाबेस के वैचारिक डिजाइन के लिए सबसे अच्छा उपयोग किया जाता है। ईआर मॉडल को निम्नानुसार दर्शाया जा सकता है:
Entity - ईआर मॉडल में एक इकाई एक वास्तविक दुनिया है, जिसमें कुछ गुण हैं attributes। हर विशेषता को इसके मूल्यों के संगत सेट द्वारा परिभाषित किया जाता है, जिसे कहा जाता हैdomain।
उदाहरण के लिए, एक स्कूल डेटाबेस पर विचार करें। यहां, एक छात्र एक इकाई है। विद्यार्थी की विभिन्न विशेषताएं हैं जैसे नाम, आईडी, आयु और वर्ग आदि।
Relationship - संस्थाओं के बीच तार्किक संघ कहा जाता है relationship। रिश्तों को विभिन्न तरीकों से संस्थाओं के साथ मैप किया जाता है। मानचित्रण कार्डिनैलिटी दो संस्थाओं के बीच संघों की संख्या को परिभाषित करती है।
कार्डिनैलिटी मैपिंग:
- एक से एक
- अनेको के लिये एक
- एक से कई
- कई कई
डेटा शब्दकोश
डेटा शब्दकोश डेटा के बारे में जानकारी का केंद्रीकृत संग्रह है। यह डेटा के अर्थ और उत्पत्ति को संग्रहीत करता है, अन्य डेटा के साथ इसका संबंध, उपयोग के लिए डेटा प्रारूप आदि। डेटा शब्दकोश में उपयोगकर्ता और सॉफ्टवेयर डिजाइनरों की सुविधा के लिए सभी नामों की कठोर परिभाषाएं हैं।
डेटा डिक्शनरी को अक्सर मेटा-डेटा (डेटा के बारे में डेटा) रिपॉजिटरी के रूप में संदर्भित किया जाता है। यह सॉफ्टवेयर प्रोग्राम के DFD (डेटा फ्लो डायग्राम) मॉडल के साथ बनाया गया है और जब भी DFD को बदला या अपडेट किया जाता है, तो इसे अपडेट किए जाने की उम्मीद है।
डेटा शब्दकोश की आवश्यकता
सॉफ्टवेयर को डिजाइन और कार्यान्वित करते समय डेटा को शब्दकोष के माध्यम से संदर्भित किया जाता है। डेटा शब्दकोश अस्पष्टता के किसी भी संभावना को हटा देता है। यह प्रोग्रामर और डिजाइनरों के काम को प्रोग्राम में हर जगह समान ऑब्जेक्ट संदर्भ का उपयोग करते हुए सिंक्रनाइज़ रखने में मदद करता है।
डेटा डिक्शनरी एक ही स्थान पर संपूर्ण डेटाबेस सिस्टम के लिए प्रलेखन का एक तरीका प्रदान करता है। DFD का सत्यापन डेटा शब्दकोश का उपयोग करके किया जाता है।
अंतर्वस्तु
डेटा शब्दकोश में निम्नलिखित के बारे में जानकारी होनी चाहिए
- डाटा प्रवाह
- डेटा संरचना
- डेटा तत्व
- डेटा स्टोर
- डाटा प्रासेसिंग
डीएफडी के माध्यम से डेटा प्रवाह का वर्णन किया गया है जैसा कि पहले अध्ययन किया गया था और जैसा कि वर्णित है, बीजीय रूप में दर्शाया गया है।
= | की रचना |
---|---|
{} | दुहराव |
() | ऐच्छिक |
+ | तथा |
[/] | या |
उदाहरण
पता = घर का नंबर + (सड़क / क्षेत्र) + शहर + राज्य
कोर्स आईडी = कोर्स नंबर + कोर्स का नाम + कोर्स स्तर + कोर्स ग्रेड
डेटा तत्व
डेटा तत्वों में निम्नलिखित विवरण के साथ डेटा और नियंत्रण आइटम, आंतरिक या बाहरी डेटा स्टोर आदि के नाम और विवरण शामिल हैं:
- प्राथमिक नाम
- माध्यमिक नाम (उपनाम)
- उपयोग-मामला (कैसे और कहाँ उपयोग करें)
- सामग्री विवरण (अधिसूचना आदि)
- अनुपूरक सूचना (पूर्व निर्धारित मूल्य, अड़चन आदि)
डेटा भंडार
यह उन सूचनाओं को संग्रहीत करता है जहां से डेटा सिस्टम में प्रवेश करता है और सिस्टम से बाहर मौजूद रहता है। डेटा स्टोर में शामिल हो सकते हैं -
- Files
- सॉफ्टवेयर के लिए आंतरिक।
- सॉफ्टवेयर के लिए बाहरी लेकिन एक ही मशीन पर।
- सॉफ्टवेयर और सिस्टम के लिए बाहरी, विभिन्न मशीन पर स्थित है।
- Tables
- नामकरण परंपरा
- अनुक्रमण संपत्ति
डाटा प्रासेसिंग
डेटा प्रोसेसिंग दो प्रकार की होती है:
- Logical: जैसा कि उपयोगकर्ता इसे देखता है
- Physical: जैसा कि सॉफ्टवेयर देखता है
सॉफ्टवेयर डिजाइन सॉफ्टवेयर कार्यान्वयन में सॉफ्टवेयर आवश्यकताओं की अवधारणा के लिए एक प्रक्रिया है। सॉफ़्टवेयर डिज़ाइन उपयोगकर्ता की आवश्यकताओं को चुनौतियों के रूप में लेता है और इष्टतम समाधान खोजने की कोशिश करता है। जबकि सॉफ्टवेयर की परिकल्पना की जा रही है, एक योजना चलाई गई है ताकि इच्छित समाधान को लागू करने के लिए सर्वोत्तम संभव डिज़ाइन मिल सके।
सॉफ्टवेयर डिजाइन के कई प्रकार हैं। आइए हम उनका संक्षिप्त रूप से अध्ययन करें:
संरचित डिजाइन
संरचित डिजाइन समाधान के कई सुव्यवस्थित तत्वों में समस्या का एक अवधारणा है। यह मूल रूप से समाधान डिजाइन के साथ संबंध है। संरचित डिज़ाइन का लाभ यह है, यह बेहतर समझ देता है कि समस्या को कैसे हल किया जा रहा है। संरचित डिजाइन भी डिजाइनर के लिए समस्या को और अधिक सटीक रूप से ध्यान केंद्रित करने के लिए सरल बनाता है।
संरचित डिजाइन ज्यादातर 'फूट डालो और जीतो' की रणनीति पर आधारित है जहां एक समस्या को कई छोटी समस्याओं में तोड़ दिया जाता है और प्रत्येक छोटी समस्या को व्यक्तिगत रूप से हल किया जाता है जब तक कि पूरी समस्या हल न हो जाए।
समाधान मॉड्यूल के माध्यम से समस्या के छोटे टुकड़े हल किए जाते हैं। संरचित डिजाइन जोर देते हैं कि सटीक समाधान प्राप्त करने के लिए इन मॉड्यूल को अच्छी तरह से व्यवस्थित किया जाए।
ये मॉड्यूल पदानुक्रम में व्यवस्थित होते हैं। वे एक-दूसरे से संवाद करते हैं। एक अच्छी संरचित डिजाइन हमेशा कई मॉड्यूलों के बीच संचार के कुछ नियमों का पालन करती है, जैसे -
Cohesion - सभी कार्यात्मक रूप से संबंधित तत्वों का समूह।
Coupling - विभिन्न मॉड्यूल के बीच संचार।
एक अच्छी संरचित डिजाइन में उच्च सामंजस्य और कम युग्मन की व्यवस्था होती है।
उन्मुख डिजाइन
फ़ंक्शन-ओरिएंटेड डिज़ाइन में, सिस्टम कई छोटे उप-प्रणालियों से युक्त होता है जिन्हें फ़ंक्शन के रूप में जाना जाता है। ये कार्य प्रणाली में महत्वपूर्ण कार्य करने में सक्षम हैं। सिस्टम को सभी कार्यों के शीर्ष दृश्य के रूप में माना जाता है।
फंक्शन ओरिएंटेड डिज़ाइन संरचित डिज़ाइन के कुछ गुणों को विरासत में देता है जहाँ कार्यप्रणाली का विभाजन और जीत होती है।
यह डिज़ाइन तंत्र पूरे सिस्टम को छोटे कार्यों में विभाजित करता है, जो जानकारी और उनके संचालन को छिपाकर अमूर्तता का साधन प्रदान करता है .. ये कार्यात्मक मॉड्यूल वैश्विक स्तर पर उपलब्ध जानकारी के गुजरने और उपयोग करने के माध्यम से आपस में जानकारी साझा कर सकते हैं।
कार्यों की एक और विशेषता यह है कि जब कोई प्रोग्राम किसी फ़ंक्शन को कॉल करता है, तो फ़ंक्शन प्रोग्राम की स्थिति को बदल देता है, जो कभी-कभी अन्य मॉड्यूल द्वारा स्वीकार्य नहीं होता है। फंक्शन ओरिएंटेड डिज़ाइन अच्छी तरह से काम करता है जहाँ सिस्टम स्थिति मायने नहीं रखती है और प्रोग्राम / फंक्शन इनपुट पर काम करते हैं बजाय स्टेट पर।
डिज़ाइन प्रक्रिया
- पूरे सिस्टम को देखा जाता है कि डेटा प्रवाह आरेख के माध्यम से सिस्टम में डेटा कैसे बहता है।
- डीएफडी में दर्शाया गया है कि फ़ंक्शन पूरे सिस्टम के डेटा और स्थिति को कैसे बदलता है।
- पूरी प्रणाली तार्किक रूप से सिस्टम में उनके संचालन के आधार पर कार्यों के रूप में जानी जाने वाली छोटी इकाइयों में टूट जाती है।
- प्रत्येक फ़ंक्शन को तब बड़े पैमाने पर वर्णित किया जाता है।
ऑब्जेक्ट ओरिएंटेड डिज़ाइन
ऑब्जेक्ट ओरिएंटेड डिज़ाइन सॉफ्टवेयर सिस्टम में शामिल फ़ंक्शंस के बजाय संस्थाओं और उनकी विशेषताओं के आसपास काम करता है। यह डिजाइन रणनीति संस्थाओं और इसकी विशेषताओं पर केंद्रित है। सॉफ्टवेयर सॉल्यूशन की पूरी अवधारणा संलग्न संस्थाओं के चारों ओर घूमती है।
आइये देखते हैं ऑब्जेक्ट ओरिएंटेड डिज़ाइन की महत्वपूर्ण अवधारणाएँ:
- Objects - समाधान डिजाइन में शामिल सभी संस्थाओं को वस्तुओं के रूप में जाना जाता है। उदाहरण के लिए, व्यक्ति, बैंक, कंपनी और ग्राहकों को वस्तुओं के रूप में माना जाता है। प्रत्येक इकाई में कुछ विशेषताएं जुड़ी होती हैं और विशेषताओं पर प्रदर्शन करने के लिए कुछ तरीके होते हैं।
Classes - एक वर्ग एक वस्तु का सामान्यीकृत वर्णन है। एक वस्तु एक वर्ग का एक उदाहरण है। क्लास सभी विशेषताओं को परिभाषित करता है, जिसमें एक वस्तु हो सकती है और विधियाँ, जो वस्तु की कार्यक्षमता को परिभाषित करती हैं।
समाधान डिजाइन में, विशेषताओं को चर के रूप में संग्रहीत किया जाता है और कार्यविधियों को तरीकों या प्रक्रियाओं के माध्यम से परिभाषित किया जाता है।
- Encapsulation - OOD में, विशेषताओं (डेटा चर) और विधियों (डेटा पर संचालन) को एक साथ बंडल किया जाता है जिसे एनकैप्सुलेशन कहा जाता है। एनकैप्सुलेशन न केवल एक वस्तु की महत्वपूर्ण जानकारी को एक साथ बंडल करता है, बल्कि बाहरी दुनिया से डेटा और विधियों तक पहुंच को प्रतिबंधित करता है। इसे सूचना छिपाना कहते हैं।
- Inheritance - OOD समान वर्गों को श्रेणीबद्ध तरीके से स्टैक करने की अनुमति देता है जहां निम्न या उप-वर्ग अपने तत्काल सुपर क्लास से अनुमत चर और विधियों का आयात, कार्यान्वयन और पुन: उपयोग कर सकते हैं। OOD की इस संपत्ति को विरासत के रूप में जाना जाता है। इससे विशिष्ट वर्ग को परिभाषित करना और विशिष्ट लोगों से सामान्यीकृत कक्षाएं बनाना आसान हो जाता है।
- Polymorphism - OOD भाषाएँ एक ऐसा तंत्र प्रदान करती हैं जहाँ समान कार्य करने वाली विधियाँ लेकिन तर्कों में भिन्न होती हैं, उन्हें समान नाम दिया जा सकता है। इसे बहुरूपता कहा जाता है, जो एकल इंटरफ़ेस को विभिन्न प्रकारों के लिए कार्य करने की अनुमति देता है। फ़ंक्शन को कैसे लागू किया जाता है, इसके आधार पर, कोड का संबंधित भाग निष्पादित हो जाता है।
डिज़ाइन प्रक्रिया
सॉफ़्टवेयर डिज़ाइन प्रक्रिया को अच्छी तरह से परिभाषित चरणों की श्रृंखला के रूप में माना जा सकता है। हालाँकि यह डिज़ाइन एप्रोच (फ़ंक्शन ओरिएंटेड या ऑब्जेक्ट ओरिएंटेड) के अनुसार बदलता रहता है, फिर भी इसमें निम्नलिखित चरण शामिल हो सकते हैं:
- एक समाधान डिज़ाइन आवश्यकता या पिछले उपयोग किए गए सिस्टम और / या सिस्टम अनुक्रम आरेख से बनाया गया है।
- विशेषता विशेषताओं में समानता की ओर से वस्तुओं की पहचान की जाती है और उन्हें कक्षाओं में वर्गीकृत किया जाता है।
- वर्ग पदानुक्रम और उनके बीच संबंध परिभाषित किया गया है।
- एप्लिकेशन की रूपरेखा परिभाषित की गई है।
सॉफ्टवेयर डिजाइन दृष्टिकोण
सॉफ्टवेयर डिजाइनिंग के लिए यहां दो सामान्य दृष्टिकोण हैं:
शीर्ष नीचे डिजाइन
हम जानते हैं कि एक प्रणाली एक से अधिक उप-प्रणालियों से बनी होती है और इसमें कई घटक होते हैं। इसके अलावा, इन उप-प्रणालियों और घटकों में उप-प्रणाली और घटकों के सेट पर हो सकता है और सिस्टम में पदानुक्रमित संरचना बनाता है।
टॉप-डाउन डिज़ाइन पूरे सॉफ्टवेयर सिस्टम को एक इकाई के रूप में लेता है और फिर कुछ विशेषताओं के आधार पर एक से अधिक उप-प्रणाली या घटक को प्राप्त करने के लिए इसे विघटित करता है। प्रत्येक उप-प्रणाली या घटक को तब एक प्रणाली के रूप में माना जाता है और आगे विघटित किया जाता है। यह प्रक्रिया तब तक चलती रहती है जब तक कि टॉप-डाउन पदानुक्रम में सिस्टम का निम्नतम स्तर हासिल नहीं हो जाता।
टॉप-डाउन डिज़ाइन सिस्टम के एक सामान्यीकृत मॉडल से शुरू होता है और इसके अधिक विशिष्ट भाग को परिभाषित करता रहता है। जब सभी घटकों की रचना की जाती है तो पूरी प्रणाली अस्तित्व में आती है।
जब सॉफ़्टवेयर समाधान को खरोंच से डिज़ाइन करने की आवश्यकता होती है तो शीर्ष-डाउन डिज़ाइन अधिक उपयुक्त होता है और विशिष्ट विवरण अज्ञात होते हैं।
बॉटम-अप डिज़ाइन
नीचे का डिज़ाइन मॉडल सबसे विशिष्ट और बुनियादी घटकों के साथ शुरू होता है। यह बुनियादी या निचले स्तर के घटकों का उपयोग करके उच्च स्तर के घटकों की रचना के साथ आगे बढ़ता है। यह तब तक उच्च स्तर के घटक बनाता रहता है जब तक कि वांछित प्रणाली एक एकल घटक के रूप में विकसित नहीं होती है। प्रत्येक उच्च स्तर के साथ, अमूर्तता की मात्रा बढ़ जाती है।
बॉटम-अप रणनीति तब अधिक उपयुक्त होती है जब किसी सिस्टम को कुछ मौजूदा सिस्टम से बनाने की जरूरत होती है, जहां नए सिस्टम में बेसिक प्राइमेटिव्स का इस्तेमाल किया जा सकता है।
दोनों, टॉप-डाउन और बॉटम-अप दृष्टिकोण व्यक्तिगत रूप से व्यावहारिक नहीं हैं। इसके बजाय, दोनों का एक अच्छा संयोजन उपयोग किया जाता है।
उपयोगकर्ता इंटरफ़ेस फ्रंट-एंड एप्लिकेशन व्यू है, जिसमें उपयोगकर्ता सॉफ्टवेयर का उपयोग करने के लिए बातचीत करता है। उपयोगकर्ता यूजर इंटरफेस के माध्यम से सॉफ्टवेयर के साथ-साथ हार्डवेयर में हेरफेर और नियंत्रण कर सकता है। आज, यूजर इंटरफेस लगभग हर उस जगह पर पाया जाता है जहां डिजिटल तकनीक मौजूद है, कंप्यूटर, मोबाइल फोन, कार, संगीत खिलाड़ी, हवाई जहाज, जहाज आदि से।
उपयोगकर्ता इंटरफ़ेस सॉफ़्टवेयर का हिस्सा है और इसे इस तरह से डिज़ाइन किया गया है कि इससे सॉफ़्टवेयर की उपयोगकर्ता जानकारी प्रदान करने की उम्मीद है। यूआई मानव-कंप्यूटर संपर्क के लिए मौलिक मंच प्रदान करता है।
यूआई अंतर्निहित हार्डवेयर और सॉफ्टवेयर संयोजन के आधार पर चित्रमय, पाठ-आधारित, ऑडियो-वीडियो आधारित हो सकता है। यूआई हार्डवेयर या सॉफ्टवेयर या दोनों का संयोजन हो सकता है।
यदि इसका यूजर इंटरफेस है तो सॉफ्टवेयर अधिक लोकप्रिय हो जाता है:
- Attractive
- उपयोग करने के लिए सरल
- कम समय में उत्तरदायी
- समझने के लिए स्पष्ट
- सभी इंटरफेसिंग स्क्रीन पर संगत
यूआई को मोटे तौर पर दो श्रेणियों में बांटा गया है:
- कमांड लाइन इंटरफेस
- ग्राफिकल यूज़र इंटरफ़ेस
कमांड लाइन इंटरफ़ेस (सीएलआई)
वीडियो प्रदर्शन मॉनिटर के अस्तित्व में आने तक CLI कंप्यूटर के साथ सहभागिता का एक बड़ा साधन रहा है। सीएलआई कई तकनीकी उपयोगकर्ताओं और प्रोग्रामर की पहली पसंद है। सीएलआई न्यूनतम इंटरफ़ेस है जो एक सॉफ्टवेयर अपने उपयोगकर्ताओं को प्रदान कर सकता है।
सीएलआई एक कमांड प्रॉम्प्ट प्रदान करता है, वह स्थान जहां उपयोगकर्ता कमांड टाइप करता है और सिस्टम को फीड करता है। उपयोगकर्ता को कमांड के सिंटैक्स और इसके उपयोग को याद रखना होगा। पहले सीएलआई को उपयोगकर्ता त्रुटियों को प्रभावी ढंग से संभालने के लिए प्रोग्राम नहीं किया गया था।
एक निर्देश निर्देशों के सेट के लिए एक पाठ-आधारित संदर्भ है, जिसे सिस्टम द्वारा निष्पादित किए जाने की उम्मीद है। मैक्रोज़, स्क्रिप्ट जैसी विधियाँ हैं जो उपयोगकर्ता के लिए काम करना आसान बनाती हैं।
GUI की तुलना में CLI कंप्यूटर संसाधन की कम मात्रा का उपयोग करता है।
सीएलआई तत्व
एक पाठ-आधारित कमांड लाइन इंटरफ़ेस में निम्नलिखित तत्व हो सकते हैं:
Command Prompt- यह टेक्स्ट-आधारित नोटिफ़ायर है जो ज्यादातर उस संदर्भ को दिखाता है जिसमें उपयोगकर्ता काम कर रहा है। यह सॉफ्टवेयर सिस्टम द्वारा उत्पन्न होता है।
Cursor- टाइप करते समय चरित्र की स्थिति का प्रतिनिधित्व करने के लिए यह एक छोटी क्षैतिज रेखा या पंक्ति की ऊँचाई का एक ऊर्ध्वाधर बार है। कर्सर ज्यादातर निमिष अवस्था में पाया जाता है। यह उपयोगकर्ता द्वारा कुछ लिखने या हटाने के बाद चलता है।
Command- एक कमांड एक निष्पादन योग्य निर्देश है। इसके एक या अधिक पैरामीटर हो सकते हैं। कमांड निष्पादन पर आउटपुट स्क्रीन पर इनलाइन दिखाया गया है। जब आउटपुट उत्पन्न होता है, तो कमांड प्रॉम्प्ट अगली पंक्ति में प्रदर्शित होता है।
ग्राफिकल यूज़र इंटरफ़ेस
ग्राफिकल यूजर इंटरफेस सिस्टम के साथ बातचीत करने के लिए उपयोगकर्ता को ग्राफिकल साधन प्रदान करता है। GUI हार्डवेयर और सॉफ्टवेयर दोनों का संयोजन हो सकता है। GUI का उपयोग करके, उपयोगकर्ता सॉफ्टवेयर की व्याख्या करता है।
आमतौर पर, GUI CLI की तुलना में अधिक संसाधन खपत वाला है। प्रौद्योगिकी को आगे बढ़ाने के साथ, प्रोग्रामर और डिजाइनर जटिल जीयूआई डिजाइन बनाते हैं जो अधिक दक्षता, सटीकता और गति के साथ काम करते हैं।
जीयूआई तत्व
जीयूआई सॉफ्टवेयर या हार्डवेयर के साथ बातचीत करने के लिए घटकों का एक समूह प्रदान करता है।
हर चित्रमय घटक प्रणाली के साथ काम करने का एक तरीका प्रदान करता है। जीयूआई प्रणाली में निम्नलिखित तत्व होते हैं जैसे:
Window- ऐसा क्षेत्र जहां आवेदन की सामग्री प्रदर्शित की जाती है। विंडो में सामग्री को आइकनों या सूचियों के रूप में प्रदर्शित किया जा सकता है, यदि विंडो फ़ाइल संरचना का प्रतिनिधित्व करती है। उपयोगकर्ता के लिए एक खोज विंडो में फ़ाइल सिस्टम में नेविगेट करना आसान है। विंडोज को स्क्रीन के आकार में छोटा, आकार परिवर्तन या अधिकतम किया जा सकता है। उन्हें स्क्रीन पर कहीं भी ले जाया जा सकता है। एक विंडो में एक ही एप्लिकेशन की एक और विंडो हो सकती है, जिसे चाइल्ड विंडो कहा जाता है।
Tabs - यदि कोई एप्लिकेशन स्वयं के कई उदाहरणों को निष्पादित करने की अनुमति देता है, तो वे स्क्रीन पर अलग-अलग विंडो के रूप में दिखाई देते हैं। Tabbed Document Interfaceएक ही विंडो में कई दस्तावेज़ खोलने के लिए आया है। यह इंटरफ़ेस एप्लिकेशन में वरीयता पैनल देखने में भी मदद करता है। सभी आधुनिक वेब-ब्राउज़र इस सुविधा का उपयोग करते हैं।
Menu- मेनू एक मानक कमांड का एक सरणी है, जिसे एक साथ समूहीकृत किया गया है और एप्लिकेशन विंडो के अंदर एक दृश्य जगह (आमतौर पर शीर्ष) पर रखा गया है। मेनू को माउस क्लिक पर प्रदर्शित या छिपाने के लिए प्रोग्राम किया जा सकता है।
Icon- एक आइकन एक संबंधित एप्लिकेशन का प्रतिनिधित्व करने वाला छोटा चित्र है। जब इन आइकन पर क्लिक किया जाता है या डबल क्लिक किया जाता है, तो एप्लिकेशन विंडो खुल जाती है। आइकन छोटे चित्रों के रूप में एक सिस्टम पर स्थापित एप्लिकेशन और प्रोग्राम प्रदर्शित करता है।
Cursor- माउस, टच पैड, डिजिटल पेन जैसे इंटरेक्टिव डिवाइस को GUI में कर्सर के रूप में दर्शाया गया है। स्क्रीन पर कर्सर लगभग वास्तविक समय में हार्डवेयर से निर्देशों का पालन करता है। GUI सिस्टम में कर्सर को पॉइंटर्स भी कहा जाता है। वे मेनू, विंडोज़ और अन्य एप्लिकेशन सुविधाओं का चयन करने के लिए उपयोग किए जाते हैं।
अनुप्रयोग विशिष्ट GUI घटक
किसी अनुप्रयोग के GUI में एक या अधिक सूचीबद्ध GUI तत्व होते हैं:
Application Window - अधिकांश एप्लिकेशन विंडोज़ ऑपरेटिंग सिस्टम द्वारा आपूर्ति किए गए निर्माणों का उपयोग करते हैं, लेकिन कई अपने स्वयं के ग्राहक द्वारा बनाई गई खिड़कियों का उपयोग करने के लिए आवेदन की सामग्री शामिल करते हैं।
Dialogue Box - यह एक बाल खिड़की है जिसमें उपयोगकर्ता के लिए संदेश होता है और कुछ कार्रवाई के लिए अनुरोध किया जाता है। उदाहरण के लिए: अनुप्रयोग किसी फ़ाइल को हटाने के लिए उपयोगकर्ता से पुष्टि प्राप्त करने के लिए एक संवाद उत्पन्न करता है।
Text-Box - उपयोगकर्ता को टेक्स्ट-आधारित डेटा टाइप करने और दर्ज करने के लिए एक क्षेत्र प्रदान करता है।
Buttons - वे वास्तविक जीवन बटन की नकल करते हैं और सॉफ्टवेयर में इनपुट जमा करने के लिए उपयोग किए जाते हैं।
Radio-button- चयन के लिए उपलब्ध विकल्प प्रदर्शित करता है। सभी की पेशकश के बीच केवल एक का चयन किया जा सकता है।
Check-box- सूची-बॉक्स के समान कार्य। जब कोई विकल्प चुना जाता है, तो बॉक्स को चिह्नित के रूप में चिह्नित किया जाता है। चेक बॉक्स द्वारा दर्शाए गए कई विकल्पों का चयन किया जा सकता है।
List-box - चयन के लिए उपलब्ध वस्तुओं की सूची प्रदान करता है। एक से अधिक आइटम का चयन किया जा सकता है।
अन्य प्रभावशाली जीयूआई घटक हैं:
- Sliders
- Combo-box
- Data-grid
- ड्राॅप डाउन लिस्ट
उपयोगकर्ता इंटरफ़ेस डिज़ाइन गतिविधियाँ
उपयोगकर्ता इंटरफ़ेस डिज़ाइन करने के लिए कई गतिविधियाँ की जाती हैं। GUI डिजाइन और कार्यान्वयन की प्रक्रिया एक समान SDLC है। किसी भी मॉडल का उपयोग वाटरफॉल, इटरेटिव या स्पाइरल मॉडल के बीच जीयूआई कार्यान्वयन के लिए किया जा सकता है।
GUI डिजाइन और विकास के लिए उपयोग किया जाने वाला मॉडल इन GUI विशिष्ट चरणों को पूरा करना चाहिए।
GUI Requirement Gathering- डिजाइनर जीयूआई की सभी कार्यात्मक और गैर-कार्यात्मक आवश्यकताओं की सूची पसंद कर सकते हैं। यह उपयोगकर्ता और उनके मौजूदा सॉफ़्टवेयर समाधान से लिया जा सकता है।
User Analysis- डिजाइनर अध्ययन जो सॉफ्टवेयर GUI का उपयोग करने जा रहा है। उपयोगकर्ता के ज्ञान और सक्षमता के स्तर के अनुसार डिज़ाइन विवरण में बदलाव के कारण लक्षित दर्शक मायने रखते हैं। यदि उपयोगकर्ता तकनीकी जानकार है, तो उन्नत और जटिल जीयूआई को शामिल किया जा सकता है। नौसिखिए उपयोगकर्ता के लिए, सॉफ़्टवेयर के कैसे-कैसे पर अधिक जानकारी शामिल है।
Task Analysis- डिजाइनरों को यह विश्लेषण करना होगा कि सॉफ़्टवेयर समाधान द्वारा क्या कार्य किया जाना है। यहां GUI में, यह कोई फर्क नहीं पड़ता कि यह कैसे किया जाएगा। कार्य को एक प्रमुख कार्य लेने और इसे छोटे उप-कार्यों में विभाजित करने के लिए पदानुक्रमित तरीके से दर्शाया जा सकता है। कार्य जीयूआई प्रस्तुति के लिए लक्ष्य प्रदान करते हैं। उप-कार्यों के बीच जानकारी का प्रवाह सॉफ्टवेयर में GUI सामग्री के प्रवाह को निर्धारित करता है।
GUI Design & implementation- डिजाइनर आवश्यकताओं, कार्यों और उपयोगकर्ता पर्यावरण के बारे में जानकारी होने के बाद, जीयूआई और कोड को लागू करते हैं और जीयूआई को पृष्ठभूमि में काम करने या डमी सॉफ़्टवेयर के साथ एम्बेड करते हैं। यह तब डेवलपर्स द्वारा स्व-परीक्षण किया जाता है।
Testing- जीयूआई परीक्षण विभिन्न तरीकों से किया जा सकता है। संगठन में इन-हाउस निरीक्षण, उपयोगकर्ताओं की प्रत्यक्ष भागीदारी और बीटा संस्करण जारी हो सकते हैं। परीक्षण में प्रयोज्य, संगतता, उपयोगकर्ता स्वीकृति आदि शामिल हो सकते हैं।
जीयूआई कार्यान्वयन उपकरण
ऐसे कई उपकरण उपलब्ध हैं जिनके उपयोग से डिजाइनर माउस क्लिक पर संपूर्ण जीयूआई बना सकते हैं। कुछ उपकरणों को सॉफ्टवेयर वातावरण (आईडीई) में एम्बेड किया जा सकता है।
जीयूआई कार्यान्वयन उपकरण जीयूआई नियंत्रण के शक्तिशाली सरणी प्रदान करते हैं। सॉफ्टवेयर अनुकूलन के लिए, डिजाइनर तदनुसार कोड बदल सकते हैं।
GUI उपकरणों के विभिन्न खंड उनके अलग-अलग उपयोग और मंच के अनुसार हैं।
उदाहरण
मोबाइल GUI, कंप्यूटर GUI, टच-स्क्रीन GUI आदि। यहाँ कुछ उपकरणों की सूची दी गई है जो GUI के निर्माण के लिए काम आते हैं:
- FLUID
- AppInventor (Android)
- LucidChart
- Wavemaker
- दृश्य स्टूडियो
उपयोगकर्ता इंटरफ़ेस गोल्डन नियम
निम्नलिखित नियमों को GUI डिजाइन के लिए सुनहरे नियमों के रूप में वर्णित किया गया है, जो कि उनकी पुस्तक (डिजाइनिंग द यूजर इंटरफेस) में श्नीडरमैन और प्लाजेंट द्वारा वर्णित है।
Strive for consistency- समान स्थितियों में कार्यों के लगातार अनुक्रम की आवश्यकता होनी चाहिए। प्रॉम्प्ट, मेन्यू और मदद स्क्रीन में आइडियल शब्दावली का इस्तेमाल किया जाना चाहिए। लगातार आज्ञाओं को नियोजित किया जाना चाहिए।
Enable frequent users to use short-cuts- उपयोग की आवृत्ति के साथ बातचीत की संख्या को कम करने की उपयोगकर्ता की इच्छा बढ़ जाती है। संक्षिप्तिकरण, फ़ंक्शन कुंजियाँ, छिपी हुई कमांड और मैक्रो सुविधाएं एक विशेषज्ञ उपयोगकर्ता के लिए बहुत सहायक हैं।
Offer informative feedback- प्रत्येक ऑपरेटर कार्रवाई के लिए, कुछ सिस्टम फीडबैक होना चाहिए। अक्सर और छोटी क्रियाओं के लिए, प्रतिक्रिया मामूली होनी चाहिए, जबकि असंगत और प्रमुख क्रियाओं के लिए, प्रतिक्रिया अधिक महत्वपूर्ण होनी चाहिए।
Design dialog to yield closure- क्रियाओं के अनुक्रमों को एक शुरुआत, मध्य और अंत वाले समूहों में व्यवस्थित किया जाना चाहिए। क्रियाओं के एक समूह के पूरा होने पर सूचनात्मक प्रतिक्रिया ऑपरेटरों को उपलब्धि की संतुष्टि, राहत की भावना, उनके दिमाग से आकस्मिक योजनाओं और विकल्पों को छोड़ने का संकेत देती है, और यह इंगित करता है कि आगे का रास्ता अगले की तैयारी के लिए स्पष्ट है क्रियाओं का समूह।
Offer simple error handling- जितना संभव हो, सिस्टम को डिज़ाइन करें ताकि उपयोगकर्ता एक गंभीर त्रुटि न करे। यदि कोई त्रुटि होती है, तो सिस्टम को इसका पता लगाने में सक्षम होना चाहिए और त्रुटि से निपटने के लिए सरल, सुगम तंत्र प्रदान करना चाहिए।
Permit easy reversal of actions- यह सुविधा चिंता से राहत देती है, क्योंकि उपयोगकर्ता जानता है कि त्रुटियों को पूर्ववत किया जा सकता है। कार्यों का आसान उलटना अपरिचित विकल्पों की खोज को प्रोत्साहित करता है। प्रतिवर्तीता की इकाइयाँ एकल क्रिया, डेटा प्रविष्टि या क्रियाओं का एक पूर्ण समूह हो सकती हैं।
Support internal locus of control- अनुभवी ऑपरेटर्स इस भावना की दृढ़ता से इच्छा करते हैं कि वे सिस्टम के प्रभारी हैं और सिस्टम उनके कार्यों का जवाब देता है। उत्तरदाताओं के बजाय उपयोगकर्ताओं को कार्यों के आरंभकर्ता बनाने के लिए सिस्टम डिज़ाइन करें।
Reduce short-term memory load - अल्पकालिक मेमोरी में मानव सूचना प्रसंस्करण की सीमा को प्रदर्शित करने के लिए सरल रखने की आवश्यकता होती है, कई पेज डिस्प्ले को समेकित किया जाता है, विंडो-मोशन फ्रीक्वेंसी को कम किया जाता है, और कोड, वर्णक्रमीय और क्रियाओं के अनुक्रम के लिए पर्याप्त प्रशिक्षण समय आवंटित किया जाता है।
शब्द की जटिलता घटनाओं या चीजों की स्थिति के लिए है, जिसमें कई परस्पर जुड़े लिंक और अत्यधिक जटिल संरचनाएं हैं। सॉफ्टवेयर प्रोग्रामिंग में, जैसा कि सॉफ्टवेयर के डिजाइन का एहसास होता है, तत्वों की संख्या और उनके अंतर्संबंध धीरे-धीरे विशाल हो जाते हैं, जिन्हें एक बार में समझना बहुत मुश्किल हो जाता है।
सॉफ्टवेयर डिजाइन जटिलता जटिलता मैट्रिक्स और उपायों का उपयोग किए बिना मूल्यांकन करना मुश्किल है। आइए हम तीन महत्वपूर्ण सॉफ्टवेयर जटिलता उपायों को देखें।
हाल्टेड की जटिलता के उपाय
1977 में, श्री मौरिस हॉवर्ड हैल्स्टेड ने सॉफ्टवेयर जटिलता को मापने के लिए मैट्रिक्स की शुरुआत की। Halstead की मेट्रिक्स कार्यक्रम और इसके उपायों के वास्तविक कार्यान्वयन पर निर्भर करती है, जो ऑपरेटरों और ऑपरेंड्स से सीधे सोर्स कोड से स्थिर तरीके से गणना की जाती हैं। यह C / C ++ / Java स्रोत कोड के परीक्षण समय, शब्दावली, आकार, कठिनाई, त्रुटियों और प्रयासों का मूल्यांकन करने की अनुमति देता है।
हेलस्टेड के अनुसार, "एक कंप्यूटर प्रोग्राम एक एल्गोरिथ्म का कार्यान्वयन है जिसे टोकन का एक संग्रह माना जाता है जिसे या तो ऑपरेटर या ऑपरेंड के रूप में वर्गीकृत किया जा सकता है"। Halstead मेट्रिक्स एक प्रोग्राम को ऑपरेटरों और उनके संबंधित ऑपरेंड के अनुक्रम के रूप में सोचते हैं।
वह मॉड्यूल की जटिलता की जांच करने के लिए विभिन्न संकेतकों को परिभाषित करता है।
पैरामीटर | जिसका अर्थ है |
---|---|
एन 1 | अद्वितीय ऑपरेटरों की संख्या |
एन 2 | अद्वितीय ऑपरेंड की संख्या |
एन 1 | ऑपरेटरों की कुल घटना की संख्या |
एन 2 | ऑपरेंड की कुल घटना की संख्या |
जब हम मीट्रिक दर्शक में इसकी जटिलता का विवरण देखने के लिए स्रोत फ़ाइल का चयन करते हैं, तो निम्न परिणाम मीट्रिक रिपोर्ट में देखा जाता है:
मीट्रिक | जिसका अर्थ है | गणितीय प्रतिनिधित्व |
---|---|---|
n | शब्दावली | n1 + n2 |
एन | आकार | एन 1 + एन 2 |
वी | आयतन | लंबाई * Log2 शब्दावली |
घ | कठिनाई | (n1 / 2) * (N1 / n2) |
इ | प्रयासों | कठिनाई * आयतन |
ख | त्रुटियाँ | मात्रा / 3000 |
टी | परीक्षण का समय | समय = प्रयास / एस, जहां एस = 18 सेकंड। |
चक्रवाती जटिलता के उपाय
प्रत्येक कार्यक्रम में कुछ कार्य और अन्य निर्णय लेने वाले बयानों को निष्पादित करने के लिए कथनों को शामिल किया जाता है, जो तय करते हैं कि किन कथनों को निष्पादित करने की आवश्यकता है। ये निर्णय लेने वाले निर्माण कार्यक्रम के प्रवाह को बदलते हैं।
यदि हम एक ही आकार के दो कार्यक्रमों की तुलना करते हैं, तो अधिक निर्णय लेने वाले बयान अधिक जटिल होंगे क्योंकि कार्यक्रम का नियंत्रण अक्सर कूदता है।
मैककेबे ने 1976 में एक दिए गए सॉफ्टवेयर की जटिलता को निर्धारित करने के लिए साइक्लोमैटिक कॉम्प्लेक्सिटी माप का प्रस्ताव दिया। यह ग्राफ चालित मॉडल है जो कार्यक्रम के निर्णय लेने वाले निर्माणों पर आधारित है, जैसे कि अगर-और, डू-टाइम, रिपीट-अप, स्विच-केस और गोटो स्टेटमेंट।
प्रवाह नियंत्रण ग्राफ बनाने की प्रक्रिया:
- निर्णय लेने वाले निर्माणों द्वारा सीमांकित छोटे ब्लॉकों में कार्यक्रम।
- इनमें से प्रत्येक नोड का प्रतिनिधित्व करने वाले नोड बनाएं।
- निम्नानुसार नोड्स कनेक्ट करें:
यदि नियंत्रण ब्लॉक i से ब्लॉक j तक शाखा कर सकता है
एक आर्क ड्रा करें
एग्जिट नोड से लेकर एंट्री नोड तक
एक आर्क ड्रा करें।
एक प्रोग्राम मॉड्यूल के साइक्लोमैटिक जटिलता की गणना करने के लिए, हम सूत्र का उपयोग करते हैं -
V(G) = e – n + 2
Where
e is total number of edges
n is total number of nodes
उपरोक्त मॉड्यूल की साइक्लोमैटिक जटिलता है
e = 10
n = 8
Cyclomatic Complexity = 10 - 8 + 2
= 4
पी। जोर्गेनसन के अनुसार, एक मॉड्यूल का साइक्लोमैटिक कॉम्प्लेक्सिटी 10 से अधिक नहीं होना चाहिए।
कार्य बिंदु
यह सॉफ्टवेयर के आकार को मापने के लिए व्यापक रूप से उपयोग किया जाता है। फ़ंक्शन बिंदु सिस्टम द्वारा प्रदान की गई कार्यक्षमता पर ध्यान केंद्रित करता है। सॉफ्टवेयर जटिलता को मापने के लिए सिस्टम की विशेषताओं और कार्यक्षमता का उपयोग किया जाता है।
फंक्शन प्वाइंट पांच मापदंडों पर गिना जाता है, जिसे एक्सटर्नल इनपुट, एक्सटर्नल आउटपुट, लॉजिकल इंटरनल फाइल्स, एक्सटर्नल इंटरफेस फाइल्स और एक्सटर्नल इंक्वायरी के नाम से जाना जाता है। सॉफ्टवेयर की जटिलता पर विचार करने के लिए प्रत्येक पैरामीटर को सरल, औसत या जटिल के रूप में वर्गीकृत किया जाता है।
आइए हम फ़ंक्शन बिंदु के पैरामीटर देखते हैं:
बाहरी इनपुट
सिस्टम के प्रत्येक अद्वितीय इनपुट, बाहर से, बाहरी इनपुट के रूप में माना जाता है। इनपुट की विशिष्टता को मापा जाता है, क्योंकि किसी भी दो इनपुट में समान प्रारूप नहीं होने चाहिए। ये इनपुट या तो डेटा या कंट्रोल पैरामीटर हो सकते हैं।
Simple - यदि इनपुट काउंट कम है और कम आंतरिक फ़ाइलों को प्रभावित करता है
Complex - यदि इनपुट काउंट अधिक है और अधिक आंतरिक फ़ाइलों को प्रभावित करता है
Average - सरल और जटिल के बीच में।
बाहरी आउटपुट
सिस्टम द्वारा प्रदान किए गए सभी आउटपुट प्रकार इस श्रेणी में गिने जाते हैं। यदि उनके आउटपुट स्वरूप और / या प्रसंस्करण अद्वितीय हैं, तो आउटपुट अद्वितीय माना जाता है।
Simple - यदि आउटपुट काउंट कम है
Complex - अगर आउटपुट काउंट ज्यादा है
Average - सरल और जटिल के बीच में।
तार्किक आंतरिक फ़ाइलें
हर सॉफ्टवेयर सिस्टम अपनी कार्यात्मक जानकारी बनाए रखने और ठीक से काम करने के लिए आंतरिक फाइलों को बनाए रखता है। ये फ़ाइलें सिस्टम का तार्किक डेटा रखती हैं। इस तार्किक डेटा में कार्यात्मक डेटा और नियंत्रण डेटा दोनों हो सकते हैं।
Simple - यदि रिकॉर्ड प्रकार की संख्या कम है
Complex - यदि रिकॉर्ड प्रकार की संख्या अधिक है
Average - सरल और जटिल के बीच में।
बाहरी इंटरफ़ेस फ़ाइलें
सॉफ़्टवेयर सिस्टम को अपनी फ़ाइलों को कुछ बाहरी सॉफ़्टवेयर के साथ साझा करने की आवश्यकता हो सकती है या इसे प्रसंस्करण के लिए या कुछ फ़ंक्शन के लिए फ़ाइल को पास करने की आवश्यकता हो सकती है। इन सभी फ़ाइलों को बाहरी इंटरफ़ेस फ़ाइलों के रूप में गिना जाता है।
Simple - यदि साझा फ़ाइल में रिकॉर्ड प्रकारों की संख्या कम है
Complex - यदि साझा फ़ाइल में रिकॉर्ड प्रकारों की संख्या अधिक है
Average - सरल और जटिल के बीच में।
बाहरी पूछताछ
एक जांच इनपुट और आउटपुट का संयोजन है, जहां उपयोगकर्ता इनपुट के रूप में पूछताछ करने के लिए कुछ डेटा भेजता है और सिस्टम उपयोगकर्ता को संसाधित किए गए पूछताछ के आउटपुट के साथ प्रतिक्रिया करता है। किसी क्वेरी की जटिलता बाहरी इनपुट और बाहरी आउटपुट से अधिक है। यदि प्रारूप और डेटा के संदर्भ में इसके इनपुट और आउटपुट अद्वितीय हैं, तो क्वेरी को अद्वितीय कहा जाता है।
Simple - यदि क्वेरी को कम प्रोसेसिंग की आवश्यकता होती है और आउटपुट डेटा की थोड़ी मात्रा प्राप्त होती है
Complex - यदि क्वेरी को उच्च प्रक्रिया की आवश्यकता है और बड़ी मात्रा में आउटपुट डेटा प्राप्त करता है
Average - सरल और जटिल के बीच में।
सिस्टम में इन मापदंडों में से प्रत्येक को उनकी कक्षा और जटिलता के अनुसार वेटेज दिया जाता है। नीचे दी गई तालिका में प्रत्येक पैरामीटर को दिए गए वेटेज का उल्लेख है:
पैरामीटर | सरल | औसत | जटिल |
---|---|---|---|
इनपुट | 3 | 4 | 6 |
आउटपुट | 4 | 5 | 7 |
जांच | 3 | 4 | 6 |
फ़ाइलें | 7 | 10 | 15 |
इंटरफेस | 5 | 7 | 10 |
ऊपर दी गई तालिका कच्चे फलन अंक देती है। इन फ़ंक्शन बिंदुओं को पर्यावरण जटिलता के अनुसार समायोजित किया जाता है। सिस्टम को चौदह अलग-अलग विशेषताओं का उपयोग करके वर्णित किया गया है:
- डाटा संचार
- वितरित प्रसंस्करण
- उद़देश्यात्क प्रस्तुति
- ऑपरेशन कॉन्फ़िगरेशन लोड
- लेन-देन की दर
- ऑनलाइन डेटा प्रविष्टि,
- उपयोगकर्ता दक्षता समाप्त करें
- ऑनलाइन अपडेट
- जटिल प्रसंस्करण तर्क
- Re-usability
- स्थापना आसानी
- परिचालन में आसानी
- कई साइटें
- परिवर्तनों को सुविधाजनक बनाने की इच्छा
इन विशेषताओं कारकों को फिर 0 से 5 तक रेट किया गया है, जैसा कि नीचे उल्लेख किया गया है:
- कोई प्रभाव नहीं
- Incidental
- Moderate
- Average
- Significant
- Essential
सभी रेटिंग को तब N के रूप में अभिव्यक्त किया जाता है। N की मान 0 से 70 तक होती है (14 प्रकार की विशेषताओं x 5 प्रकार की रेटिंग)। इसका उपयोग निम्न सूत्र का उपयोग करके जटिलता समायोजन कारक (CAF) की गणना करने के लिए किया जाता है:
CAF = 0.65 + 0.01N
फिर,
Delivered Function Points (FP)= CAF x Raw FP
इस एफपी को तब विभिन्न मैट्रिक्स में उपयोग किया जा सकता है, जैसे:
Cost = $ / एफ.पी.
Quality = त्रुटियां / एफ.पी.
Productivity = एफपी / व्यक्ति-माह
इस अध्याय में, हम सॉफ्टवेयर कार्यान्वयन में प्रोग्रामिंग विधियों, प्रलेखन और चुनौतियों के बारे में अध्ययन करेंगे।
संरचित प्रोग्रामिंग
कोडिंग की प्रक्रिया में, कोड की रेखाएं गुणा करती रहती हैं, इस प्रकार, सॉफ्टवेयर का आकार बढ़ जाता है। धीरे-धीरे, कार्यक्रम के प्रवाह को याद रखना असंभव हो जाता है। यदि कोई यह भूल जाता है कि सॉफ्टवेयर और उसके अंतर्निहित प्रोग्राम, फाइलें, प्रक्रियाएं कैसे बनाई जाती हैं, तो प्रोग्राम को साझा करना, डीबग करना और संशोधित करना बहुत मुश्किल हो जाता है। इसका समाधान संरचित प्रोग्रामिंग है। यह डेवलपर को कोड में सरल कूद का उपयोग करने के बजाय सबरूटीन्स और लूप का उपयोग करने के लिए प्रोत्साहित करता है, जिससे कोड में स्पष्टता आती है और इसकी दक्षता में सुधार होता है संरचित प्रोग्रामिंग प्रोग्रामर को कोडिंग समय को कम करने और कोड को ठीक से व्यवस्थित करने में मदद करता है।
संरचित प्रोग्रामिंग बताती है कि प्रोग्राम को कैसे कोडित किया जाएगा। संरचित प्रोग्रामिंग तीन मुख्य अवधारणाओं का उपयोग करती है:
Top-down analysis- एक सॉफ्टवेयर हमेशा कुछ तर्कसंगत काम करने के लिए बनाया जाता है। इस तर्कसंगत कार्य को सॉफ्टवेयर पार्लरों में समस्या के रूप में जाना जाता है। इस प्रकार यह बहुत महत्वपूर्ण है कि हम समझें कि समस्या को कैसे हल किया जाए। टॉप-डाउन विश्लेषण के तहत, समस्या छोटे टुकड़ों में टूट जाती है जहां हर एक का कोई न कोई महत्व होता है। प्रत्येक समस्या को व्यक्तिगत रूप से हल किया जाता है और समस्या को हल करने के तरीके के बारे में स्पष्ट रूप से बताया जाता है।
Modular Programming- प्रोग्रामिंग करते समय, कोड निर्देशों के छोटे समूह में टूट जाता है। इन समूहों को मॉड्यूल, सबप्रोग्राम या सबरूटीन के रूप में जाना जाता है। टॉप-डाउन विश्लेषण की समझ के आधार पर मॉड्यूलर प्रोग्रामिंग। यह कार्यक्रम में 'गोटो' बयानों का उपयोग करके कूदता को हतोत्साहित करता है, जो अक्सर कार्यक्रम को गैर-पारगम्य बनाता है। कूदना निषिद्ध है और संरचित प्रोग्रामिंग में मॉड्यूलर प्रारूप को प्रोत्साहित किया जाता है।
Structured Coding - टॉप-डाउन विश्लेषण के संदर्भ में, संरचित कोडिंग उप-विभाजनों को उनके निष्पादन के क्रम में कोड की छोटी इकाइयों में विभाजित करता है। संरचित प्रोग्रामिंग नियंत्रण संरचना का उपयोग करती है, जो कार्यक्रम के प्रवाह को नियंत्रित करती है, जबकि संरचित कोडिंग नियंत्रण संरचना का उपयोग करके अपने निर्देशों को निश्चित पैटर्न में व्यवस्थित करती है।
कार्यात्मक प्रोग्रामिंग
कार्यात्मक प्रोग्रामिंग प्रोग्रामिंग भाषा की शैली है, जो गणितीय कार्यों की अवधारणाओं का उपयोग करती है। गणित में एक फ़ंक्शन को हमेशा एक ही तर्क प्राप्त करने पर एक ही परिणाम उत्पन्न करना चाहिए। प्रक्रियात्मक भाषाओं में, प्रोग्राम का प्रवाह प्रक्रियाओं के माध्यम से चलता है, अर्थात प्रोग्राम के नियंत्रण को तथाकथित प्रक्रिया में स्थानांतरित किया जाता है। जबकि नियंत्रण प्रवाह एक प्रक्रिया से दूसरी प्रक्रिया में स्थानांतरित हो रहा है, प्रोग्राम अपनी स्थिति बदलता है।
प्रक्रियात्मक प्रोग्रामिंग में, एक प्रक्रिया के लिए अलग-अलग परिणाम उत्पन्न करना संभव है जब इसे एक ही तर्क के साथ कहा जाता है, क्योंकि कार्यक्रम स्वयं इसे कॉल करते समय अलग-अलग स्थिति में हो सकता है। यह एक संपत्ति के साथ-साथ प्रक्रियात्मक प्रोग्रामिंग की एक खामी है, जिसमें प्रक्रिया निष्पादन का अनुक्रम या समय महत्वपूर्ण हो जाता है।
कार्यात्मक प्रोग्रामिंग गणितीय कार्यों के रूप में गणना का साधन प्रदान करता है, जो कार्यक्रम राज्य के बावजूद परिणाम पैदा करता है। इससे कार्यक्रम के व्यवहार की भविष्यवाणी करना संभव हो जाता है।
कार्यात्मक प्रोग्रामिंग निम्नलिखित अवधारणाओं का उपयोग करता है:
First class and High-order functions - इन कार्यों में किसी अन्य फ़ंक्शन को तर्क के रूप में स्वीकार करने की क्षमता है या वे परिणाम के रूप में अन्य कार्यों को वापस करते हैं।
Pure functions - इन कार्यों में विनाशकारी अपडेट शामिल नहीं हैं, अर्थात, वे किसी भी I / O या मेमोरी को प्रभावित नहीं करते हैं और यदि वे उपयोग में नहीं हैं, तो उन्हें बाकी प्रोग्राम में बाधा डाले बिना आसानी से हटाया जा सकता है।
Recursion- पुनर्संयोजन एक प्रोग्रामिंग तकनीक है जहां एक फ़ंक्शन खुद को कॉल करता है और इसमें प्रोग्राम कोड को दोहराता है जब तक कि कुछ पूर्व-निर्धारित स्थिति से मेल नहीं खाता। रिकर्सन कार्यात्मक प्रोग्रामिंग में लूप बनाने का तरीका है।
Strict evaluation- यह एक तर्क के रूप में एक फ़ंक्शन को दी गई अभिव्यक्ति का मूल्यांकन करने की एक विधि है। कार्यात्मक प्रोग्रामिंग में दो प्रकार के मूल्यांकन के तरीके हैं, सख्त (उत्सुक) या गैर-सख्त (आलसी)। सख्त मूल्यांकन हमेशा फ़ंक्शन को लागू करने से पहले अभिव्यक्ति का मूल्यांकन करता है। गैर-सख्त मूल्यांकन अभिव्यक्ति का मूल्यांकन नहीं करता है जब तक कि इसकी आवश्यकता न हो।
λ-calculus- अधिकांश कार्यात्मक प्रोग्रामिंग भाषाएं λ-पथरी का उपयोग अपने प्रकार के सिस्टम के रूप में करती हैं। λ-अभिव्यक्तियों को उनके मूल्यांकन के रूप में निष्पादित किया जाता है जैसे वे होते हैं।
सामान्य लिस्प, स्काला, हास्केल, एरलंग और एफ # कार्यात्मक प्रोग्रामिंग भाषाओं के कुछ उदाहरण हैं।
प्रोग्रामिंग शैली
प्रोग्रामिंग स्टाइल कोडिंग नियमों से बना है, जिसके बाद सभी प्रोग्रामर को कोड लिखना होता है। जब कई प्रोग्रामर एक ही सॉफ्टवेयर प्रोजेक्ट पर काम करते हैं, तो उन्हें अक्सर किसी अन्य डेवलपर द्वारा लिखित प्रोग्राम कोड के साथ काम करने की आवश्यकता होती है। यह थकाऊ या कई बार असंभव हो जाता है, अगर सभी डेवलपर्स प्रोग्राम को कोड करने के लिए कुछ मानक प्रोग्रामिंग शैली का पालन नहीं करते हैं।
एक उपयुक्त प्रोग्रामिंग शैली में फ़ंक्शन और चर नामों का उपयोग करना शामिल है, जो इच्छित कार्य के लिए प्रासंगिक है, अच्छी तरह से रखा इंडेंटेशन का उपयोग करते हुए, पाठक की सुविधा के लिए टिप्पणी कोड और कोड की समग्र प्रस्तुति। यह प्रोग्राम कोड को सभी के द्वारा पठनीय और समझने योग्य बनाता है, जो बदले में डिबगिंग और त्रुटि को आसान बनाता है। इसके अलावा, उचित कोडिंग शैली प्रलेखन और अपडेशन को आसान बनाने में मदद करती है।
कोडिंग दिशानिर्देश
कोडिंग शैली का अभ्यास संगठनों, ऑपरेटिंग सिस्टम और कोडिंग की भाषा के साथ भिन्न होता है।
निम्नलिखित कोडिंग तत्वों को किसी संगठन के कोडिंग दिशानिर्देशों के तहत परिभाषित किया जा सकता है:
Naming conventions - यह खंड कार्यों, चर, स्थिरांक और वैश्विक चर का नाम कैसे निर्धारित करता है।
Indenting - यह लाइन की शुरुआत में छोड़ी गई जगह है, आमतौर पर 2-8 व्हाट्सएप या सिंगल टैब।
Whitespace - यह आम तौर पर लाइन के अंत में छोड़ा जाता है।
Operators- गणितीय, असाइनमेंट और लॉजिकल ऑपरेटर्स लिखने के नियमों को परिभाषित करता है। उदाहरण के लिए, असाइनमेंट ऑपरेटर '=' में पहले और बाद में "x = 2" जैसा स्थान होना चाहिए।
Control Structures - लिखने के नियम यदि तत्कालीन, केस-स्विच, जबकि-नियंत्रण के लिए और पूरी तरह से प्रवाहित बयानों के लिए और नेस्टेड फैशन में।
Line length and wrapping- परिभाषित करता है कि एक पंक्ति में कितने वर्ण होने चाहिए, अधिकतर एक पंक्ति 80 वर्ण लंबी होती है। रैपिंग परिभाषित करता है कि एक पंक्ति को कैसे लपेटा जाना चाहिए, यदि बहुत लंबा है।
Functions - यह परिभाषित करता है कि पैरामीटर के साथ और बिना कार्यों को कैसे घोषित और लागू किया जाना चाहिए।
Variables - इसमें उल्लेख किया गया है कि विभिन्न डेटा प्रकारों के चर कैसे घोषित और परिभाषित किए जाते हैं।
Comments- यह महत्वपूर्ण कोडिंग घटकों में से एक है, क्योंकि कोड में शामिल टिप्पणियों का वर्णन है कि कोड वास्तव में क्या करता है और अन्य सभी संबंधित विवरण। यह खंड अन्य डेवलपर्स के लिए सहायता दस्तावेज बनाने में भी मदद करता है।
सॉफ्टवेयर प्रलेखन
सॉफ्टवेयर प्रलेखन सॉफ्टवेयर प्रक्रिया का एक महत्वपूर्ण हिस्सा है। एक अच्छी तरह से लिखा दस्तावेज़ सॉफ्टवेयर प्रक्रिया के बारे में जानने के लिए आवश्यक एक महान उपकरण और सूचना भंडार का साधन प्रदान करता है। सॉफ्टवेयर प्रलेखन उत्पाद के उपयोग के बारे में जानकारी भी प्रदान करता है।
एक अच्छी तरह से बनाए रखा प्रलेखन में निम्नलिखित दस्तावेज शामिल होने चाहिए:
Requirement documentation - यह प्रलेखन सॉफ्टवेयर डिजाइनर, डेवलपर और परीक्षण टीम के लिए अपने संबंधित कार्यों को पूरा करने के लिए प्रमुख उपकरण के रूप में काम करता है। इस दस्तावेज़ में इच्छित सॉफ़्टवेयर के सभी कार्यात्मक, गैर-कार्यात्मक और व्यवहार संबंधी विवरण शामिल हैं।
इस दस्तावेज़ का स्रोत पहले से सॉफ़्टवेयर के बारे में डेटा संग्रहीत किया जा सकता है, पहले से ही क्लाइंट के अंत में सॉफ़्टवेयर चला रहा है, ग्राहक का साक्षात्कार, प्रश्नावली और अनुसंधान। आम तौर पर इसे उच्च-अंत सॉफ़्टवेयर प्रबंधन टीम के साथ स्प्रेडशीट या वर्ड प्रोसेसिंग दस्तावेज़ के रूप में संग्रहीत किया जाता है।
यह प्रलेखन सॉफ्टवेयर के विकास के लिए नींव के रूप में काम करता है और सत्यापन और सत्यापन चरणों में प्रमुख रूप से उपयोग किया जाता है। अधिकांश परीक्षण-मामले आवश्यकता प्रलेखन से सीधे निर्मित होते हैं।
Software Design documentation - इन दस्तावेज़ों में सभी आवश्यक जानकारी शामिल हैं, जिन्हें सॉफ़्टवेयर बनाने के लिए आवश्यक है। इसमें शामिल है:(a) उच्च स्तरीय सॉफ्टवेयर आर्किटेक्चर, (b) सॉफ्टवेयर डिजाइन विवरण, (c) डेटा प्रवाह आरेख, (d) डेटाबेस डिजाइन
ये दस्तावेज़ सॉफ़्टवेयर को लागू करने के लिए डेवलपर्स के लिए भंडार के रूप में काम करते हैं। हालांकि ये दस्तावेज़ कार्यक्रम को कोड करने के बारे में कोई विवरण नहीं देते हैं, लेकिन वे सभी आवश्यक जानकारी देते हैं जो कोडिंग और कार्यान्वयन के लिए आवश्यक हैं।
Technical documentation- ये दस्तावेज डेवलपर्स और वास्तविक कोडर द्वारा बनाए रखे जाते हैं। ये दस्तावेज़, एक पूरे के रूप में, कोड के बारे में जानकारी का प्रतिनिधित्व करते हैं। कोड लिखते समय, प्रोग्रामर कोड के उद्देश्य का भी उल्लेख करते हैं, जिन्होंने इसे लिखा था, इसकी आवश्यकता कहां होगी, यह क्या करता है और यह कैसे करता है, कोड क्या अन्य संसाधनों का उपयोग करता है, आदि।
तकनीकी प्रलेखन एक ही कोड पर काम करने वाले विभिन्न प्रोग्रामर के बीच समझ बढ़ाता है। यह कोड की पुन: उपयोग क्षमता को बढ़ाता है। यह डिबगिंग को आसान और ट्रेस करने योग्य बनाता है।
विभिन्न स्वचालित उपकरण उपलब्ध हैं और कुछ प्रोग्रामिंग भाषा के साथ ही आते हैं। उदाहरण के लिए जावा जावा कोड कोड के तकनीकी दस्तावेज तैयार करने के लिए आता है।
User documentation- यह प्रलेखन उपर्युक्त सभी से अलग है। पिछले सभी दस्तावेज़ों को सॉफ्टवेयर और इसकी विकास प्रक्रिया के बारे में जानकारी प्रदान करने के लिए रखा जाता है। लेकिन उपयोगकर्ता प्रलेखन बताता है कि सॉफ्टवेयर उत्पाद को कैसे काम करना चाहिए और वांछित परिणाम प्राप्त करने के लिए इसका उपयोग कैसे किया जाना चाहिए।
इन दस्तावेज़ों में शामिल हो सकते हैं, सॉफ़्टवेयर इंस्टॉलेशन प्रक्रियाएँ, कैसे-कैसे मार्गदर्शिकाएँ, उपयोगकर्ता-मार्गदर्शिकाएँ, स्थापना रद्द करने की विधि और विशेष संदर्भ जैसे अधिक जानकारी प्राप्त करने के लिए अद्यतन करना आदि।
सॉफ्टवेयर कार्यान्वयन चुनौतियां
सॉफ्टवेयर को लागू करते समय विकास टीम के सामने कुछ चुनौतियां हैं। उनमें से कुछ नीचे वर्णित हैं:
Code-reuse- वर्तमान समय की भाषाओं के प्रोग्रामिंग इंटरफेस बहुत परिष्कृत हैं और पुस्तकालय के विशाल कार्यों से सुसज्जित हैं। फिर भी, अंतिम उत्पाद की लागत को नीचे लाने के लिए, संगठन प्रबंधन कोड का फिर से उपयोग करना पसंद करता है, जो पहले किसी अन्य सॉफ़्टवेयर के लिए बनाया गया था। संगतता जाँच और फिर से उपयोग करने के लिए कितना कोड तय करने के लिए प्रोग्रामर द्वारा सामना किए जाने वाले विशाल मुद्दे हैं।
Version Management- हर बार ग्राहक को एक नया सॉफ़्टवेयर जारी किया जाता है, डेवलपर्स को संस्करण और कॉन्फ़िगरेशन से संबंधित प्रलेखन बनाए रखना पड़ता है। इस दस्तावेज़ को अत्यधिक सटीक और समय पर उपलब्ध होने की आवश्यकता है।
Target-Host- सॉफ़्टवेयर प्रोग्राम, जिसे संगठन में विकसित किया जा रहा है, को ग्राहकों के अंत में होस्ट मशीनों के लिए डिज़ाइन करने की आवश्यकता है। लेकिन कई बार, ऐसा सॉफ्टवेयर डिजाइन करना असंभव होता है जो लक्ष्य मशीनों पर काम करता है।
सॉफ़्टवेयर परीक्षण उपयोगकर्ताओं और सिस्टम विशिष्टताओं से एकत्रित आवश्यकताओं के विरुद्ध सॉफ़्टवेयर का मूल्यांकन है। परीक्षण सॉफ्टवेयर विकास जीवन चक्र में चरण स्तर पर या प्रोग्राम कोड में मॉड्यूल स्तर पर आयोजित किया जाता है। सॉफ्टवेयर परीक्षण में सत्यापन और सत्यापन शामिल हैं।
सॉफ्टवेयर सत्यापन
सत्यापन यह जांचने की प्रक्रिया है कि सॉफ्टवेयर उपयोगकर्ता की आवश्यकताओं को पूरा करता है या नहीं। यह SDLC के अंत में किया जाता है। यदि सॉफ़्टवेयर आवश्यकताओं से मेल खाता है जिसके लिए इसे बनाया गया था, तो यह मान्य है।
- सत्यापन सुनिश्चित करता है कि उत्पाद विकास के तहत उपयोगकर्ता की आवश्यकताओं के अनुसार है।
- सत्यापन प्रश्न का उत्तर देता है - "क्या हम उस उत्पाद को विकसित कर रहे हैं जो इस सॉफ़्टवेयर से उपयोगकर्ता की सभी जरूरतों का प्रयास करता है?"।
- सत्यापन उपयोगकर्ता की आवश्यकताओं पर जोर देता है।
सॉफ्टवेयर सत्यापन
सत्यापन यह पुष्टि करने की प्रक्रिया है कि क्या सॉफ्टवेयर व्यावसायिक आवश्यकताओं को पूरा कर रहा है, और उचित विनिर्देशों और कार्यप्रणाली का पालन करते हुए विकसित किया गया है।
- सत्यापन यह सुनिश्चित करता है कि विकसित किया जा रहा उत्पाद डिजाइन विनिर्देशों के अनुसार हो।
- सत्यापन प्रश्न का उत्तर देता है- "क्या हम इस उत्पाद को सभी डिज़ाइन विनिर्देशों का दृढ़ता से पालन करते हुए विकसित कर रहे हैं?"
- सत्यापन डिजाइन और सिस्टम विनिर्देशों पर ध्यान केंद्रित करता है।
परीक्षण के लक्ष्य हैं -
Errors- ये डेवलपर्स द्वारा की गई वास्तविक कोडिंग गलतियाँ हैं। इसके अलावा, सॉफ्टवेयर के आउटपुट और वांछित आउटपुट में अंतर होता है, इसे त्रुटि माना जाता है।
Fault- जब गलती मौजूद हो तो गलती होती है। एक गलती, जिसे बग के रूप में भी जाना जाता है, एक त्रुटि का परिणाम है जो सिस्टम को विफल करने का कारण बन सकता है।
Failure - विफलता को वांछित कार्य करने के लिए सिस्टम की अक्षमता कहा जाता है। विफलता तब होती है जब सिस्टम में गलती मौजूद होती है।
मैनुअल बनाम स्वचालित परीक्षण
परीक्षण या तो मैन्युअल रूप से या स्वचालित परीक्षण उपकरण का उपयोग करके किया जा सकता है:
Manual- यह परीक्षण स्वचालित परीक्षण उपकरणों की मदद के बिना किया जाता है। सॉफ्टवेयर परीक्षक कोड के विभिन्न वर्गों और स्तरों के लिए परीक्षण मामलों को तैयार करता है, परीक्षणों को निष्पादित करता है और प्रबंधक को परिणाम रिपोर्ट करता है।
मैनुअल परीक्षण समय और संसाधन खपत है। परीक्षक को यह पुष्टि करने की आवश्यकता है कि क्या सही परीक्षण मामलों का उपयोग किया जाता है या नहीं। परीक्षण के प्रमुख भाग में मैनुअल परीक्षण शामिल है।
Automatedयह परीक्षण स्वचालित परीक्षण उपकरणों की सहायता से किया गया परीक्षण प्रक्रिया है। स्वचालित परीक्षण उपकरणों का उपयोग करके मैन्युअल परीक्षण की सीमाओं को दूर किया जा सकता है।
इंटरनेट एक्सप्लोरर में एक वेबपेज खोला जा सकता है या नहीं यह जांचने के लिए एक परीक्षण की आवश्यकता है। यह मैन्युअल परीक्षण के साथ आसानी से किया जा सकता है। लेकिन यह जांचने के लिए कि क्या वेब-सर्वर 1 मिलियन उपयोगकर्ताओं का लोड ले सकता है, मैन्युअल रूप से परीक्षण करना काफी असंभव है।
सॉफ्टवेयर और हार्डवेयर उपकरण हैं जो लोड परीक्षण, तनाव परीक्षण, प्रतिगमन परीक्षण करने में परीक्षक की मदद करते हैं।
परीक्षण दृष्टिकोण
टेस्ट दो दृष्टिकोणों के आधार पर आयोजित किए जा सकते हैं -
- कार्यात्मकता परीक्षण
- कार्यान्वयन परीक्षण
जब कार्यक्षमता को वास्तविक क्रियान्वयन के बिना चिंता में परीक्षण किया जा रहा है तो इसे ब्लैक-बॉक्स परीक्षण के रूप में जाना जाता है। दूसरे पक्ष को व्हाइट-बॉक्स परीक्षण के रूप में जाना जाता है जहां न केवल कार्यक्षमता का परीक्षण किया जाता है बल्कि इसे लागू करने के तरीके का भी विश्लेषण किया जाता है।
संपूर्ण परीक्षण एक उत्तम परीक्षण के लिए सबसे अच्छा तरीका है। इनपुट और आउटपुट मान की सीमा में हर एक संभव मूल्य का परीक्षण किया जाता है। मूल्यों की सीमा बड़ी होने पर वास्तविक दुनिया के परिदृश्य में प्रत्येक और हर मूल्य का परीक्षण करना संभव नहीं है।
ब्लैक-बॉक्स परीक्षण
यह कार्यक्रम की कार्यक्षमता का परीक्षण करने के लिए किया जाता है। इसे 'व्यवहार' परीक्षण भी कहा जाता है। इस मामले में परीक्षक के पास इनपुट मूल्यों और संबंधित वांछित परिणामों का एक सेट है। इनपुट प्रदान करने पर, यदि आउटपुट वांछित परिणामों के साथ मेल खाता है, तो प्रोग्राम का परीक्षण 'ओके', और अन्यथा समस्याग्रस्त है।
इस परीक्षण विधि में, कोड का डिज़ाइन और संरचना परीक्षक को ज्ञात नहीं है, और परीक्षण इंजीनियर और अंतिम उपयोगकर्ता सॉफ़्टवेयर पर इस परीक्षण का संचालन करते हैं।
ब्लैक-बॉक्स परीक्षण तकनीक:
Equivalence class- इनपुट को समान वर्गों में विभाजित किया गया है। यदि किसी कक्षा का एक तत्व परीक्षा पास करता है, तो यह माना जाता है कि सभी कक्षा उत्तीर्ण है।
Boundary values- इनपुट को उच्च और निम्न अंत मानों में विभाजित किया गया है। यदि ये मान परीक्षण को पास करते हैं, तो यह माना जाता है कि बीच में सभी मान भी पास हो सकते हैं।
Cause-effect graphing- दोनों पिछले तरीकों में, एक समय में केवल एक इनपुट मूल्य का परीक्षण किया जाता है। कारण (इनपुट) - प्रभाव (आउटपुट) एक परीक्षण तकनीक है जहां इनपुट मूल्यों के संयोजन को एक व्यवस्थित तरीके से परीक्षण किया जाता है।
Pair-wise Testing- सॉफ्टवेयर का व्यवहार कई मापदंडों पर निर्भर करता है। जोड़ीदार परीक्षण में, कई मापदंडों को उनके विभिन्न मूल्यों के लिए जोड़ी-वार परीक्षण किया जाता है।
State-based testing- इनपुट के प्रावधान पर सिस्टम में परिवर्तन होता है। इन प्रणालियों का परीक्षण उनके राज्यों और इनपुट के आधार पर किया जाता है।
सफेद बॉक्स परीक्षण
यह कोड दक्षता या संरचना को बेहतर बनाने के लिए कार्यक्रम और इसके कार्यान्वयन का परीक्षण करने के लिए आयोजित किया जाता है। इसे also स्ट्रक्चरल ’परीक्षण के रूप में भी जाना जाता है।
इस परीक्षण विधि में, कोड के डिज़ाइन और संरचना को परीक्षक को जाना जाता है। कोड के प्रोग्रामर इस टेस्ट को कोड पर आयोजित करते हैं।
नीचे कुछ व्हाइट-बॉक्स परीक्षण तकनीकें दी गई हैं:
Control-flow testing- परीक्षण मामलों को सेट करने के लिए नियंत्रण-प्रवाह परीक्षण का उद्देश्य जो सभी बयानों और शाखा स्थितियों को कवर करता है। शाखा की स्थितियों का परीक्षण सही और गलत दोनों के लिए किया जाता है, ताकि सभी विवरणों को कवर किया जा सके।
Data-flow testing- यह परीक्षण तकनीक कार्यक्रम में शामिल सभी डेटा चर को कवर करने पर जोर देती है। यह परीक्षण करता है कि चर कहां घोषित किए गए थे और परिभाषित किए गए थे और कहां उनका उपयोग किया गया था या बदल दिया गया था।
परीक्षण स्तर
परीक्षण खुद को SDLC के विभिन्न स्तरों पर परिभाषित किया जा सकता है। परीक्षण प्रक्रिया सॉफ्टवेयर विकास के समानांतर चलती है। अगले चरण पर कूदने से पहले, एक चरण का परीक्षण, सत्यापन और सत्यापन किया जाता है।
अलग से परीक्षण केवल यह सुनिश्चित करने के लिए किया जाता है कि सॉफ़्टवेयर में कोई छिपे हुए बग या मुद्दे नहीं हैं। सॉफ्टवेयर का विभिन्न स्तरों पर परीक्षण किया जाता है -
इकाई का परीक्षण
कोडिंग करते समय, प्रोग्रामर प्रोग्राम की उस इकाई पर कुछ परीक्षण करता है ताकि यह पता चल सके कि यह त्रुटि मुक्त है या नहीं। परीक्षण सफेद बॉक्स परीक्षण दृष्टिकोण के तहत किया जाता है। यूनिट परीक्षण से डेवलपर्स को यह तय करने में मदद मिलती है कि कार्यक्रम की अलग-अलग इकाइयां आवश्यकता के अनुसार काम कर रही हैं और त्रुटि मुक्त हैं।
एकीकरण जांच
यहां तक कि अगर सॉफ्टवेयर की इकाइयां व्यक्तिगत रूप से ठीक काम कर रही हैं, तो यह पता लगाने की आवश्यकता है कि क्या इकाइयां एक साथ एकीकृत होने पर भी त्रुटियों के बिना काम करेंगी। उदाहरण के लिए, तर्क पास करना और डेटा अपडेशन आदि।
सिस्टम परीक्षण
सॉफ्टवेयर को उत्पाद के रूप में संकलित किया जाता है और फिर इसे संपूर्ण रूप में परखा जाता है। यह निम्नलिखित परीक्षणों में से एक या अधिक का उपयोग करके पूरा किया जा सकता है:
Functionality testing - आवश्यकता के विरुद्ध सॉफ्टवेयर की सभी कार्यप्रणाली का परीक्षण।
Performance testing- यह परीक्षण साबित करता है कि सॉफ्टवेयर कितना कुशल है। यह वांछित कार्य करने के लिए सॉफ्टवेयर द्वारा लिए गए प्रभावशीलता और औसत समय का परीक्षण करता है। प्रदर्शन परीक्षण लोड परीक्षण और तनाव परीक्षण के माध्यम से किया जाता है जहां सॉफ्टवेयर को विभिन्न उपयोगकर्ता स्थितियों के तहत उच्च उपयोगकर्ता और डेटा लोड के तहत रखा जाता है।
Security & Portability - ये परीक्षण तब किए जाते हैं जब सॉफ्टवेयर विभिन्न प्लेटफार्मों पर काम करने के लिए होता है और व्यक्तियों की संख्या के आधार पर पहुंचता है।
स्वीकृति परीक्षण
जब सॉफ्टवेयर ग्राहक को सौंपने के लिए तैयार हो जाता है तो उसे परीक्षण के अंतिम चरण से गुजरना पड़ता है जहां उपयोगकर्ता-इंटरैक्शन और प्रतिक्रिया के लिए परीक्षण किया जाता है। यह महत्वपूर्ण है क्योंकि भले ही सॉफ़्टवेयर उपयोगकर्ता की सभी आवश्यकताओं से मेल खाता हो और यदि उपयोगकर्ता जिस तरह से प्रकट होता है या काम करता है उसे पसंद नहीं करता है, तो इसे अस्वीकार कर दिया जा सकता है।
Alpha testing- डेवलपर की टीम सिस्टम का उपयोग करके स्वयं अल्फा परीक्षण करती है जैसे कि यह कार्य वातावरण में उपयोग किया जा रहा है। वे यह पता लगाने की कोशिश करते हैं कि उपयोगकर्ता सॉफ़्टवेयर में कुछ कार्रवाई पर कैसे प्रतिक्रिया देगा और सिस्टम को इनपुट पर प्रतिक्रिया कैसे देनी चाहिए।
Beta testing- सॉफ्टवेयर को आंतरिक रूप से जांचने के बाद, इसे केवल परीक्षण उद्देश्य के लिए उपयोगकर्ताओं को उनके उत्पादन वातावरण में उपयोग करने के लिए सौंप दिया जाता है। यह अभी तक वितरित उत्पाद नहीं है। डेवलपर्स को उम्मीद है कि इस स्तर पर उपयोगकर्ता मिनट की समस्याएं लाएंगे, जो भाग लेने के लिए छोड़ दिया गया था।
प्रतिगमन परीक्षण
जब भी किसी सॉफ़्टवेयर उत्पाद को नए कोड, फ़ीचर या कार्यक्षमता के साथ अपडेट किया जाता है, तो यह पता लगाने के लिए अच्छी तरह से परीक्षण किया जाता है कि क्या जोड़े गए कोड का कोई नकारात्मक प्रभाव है या नहीं। इसे प्रतिगमन परीक्षण के रूप में जाना जाता है।
परीक्षण प्रलेखन
परीक्षण दस्तावेज विभिन्न चरणों में तैयार किए जाते हैं -
परीक्षण से पहले
परीक्षण परीक्षण मामलों की पीढ़ी के साथ शुरू होता है। संदर्भ के लिए निम्नलिखित दस्तावेजों की आवश्यकता है -
SRS document - कार्यात्मक आवश्यकताएँ दस्तावेज़
Test Policy document - यह बताता है कि उत्पाद को जारी करने से पहले कितनी दूर परीक्षण करना चाहिए।
Test Strategy document - इसमें परीक्षण टीम, जिम्मेदारी मैट्रिक्स और परीक्षण प्रबंधक और परीक्षण इंजीनियर के अधिकारों / जिम्मेदारी के विस्तार पहलुओं का उल्लेख है।
Traceability Matrix document- यह एसडीएलसी दस्तावेज है, जो आवश्यकता एकत्र करने की प्रक्रिया से संबंधित है। जैसे ही नई आवश्यकताएं आती हैं, उन्हें इस मैट्रिक्स में जोड़ दिया जाता है। ये मैट्रीस परीक्षकों को आवश्यकता के स्रोत को जानने में मदद करते हैं। उन्हें आगे और पीछे का पता लगाया जा सकता है।
जबकि परीक्षण किया जा रहा है
परीक्षण शुरू होने के दौरान निम्नलिखित दस्तावेजों की आवश्यकता हो सकती है और किया जा रहा है:
Test Case document- इस दस्तावेज़ में आयोजित किए जाने वाले परीक्षणों की सूची है। इसमें इकाई परीक्षण योजना, एकीकरण परीक्षण योजना, प्रणाली परीक्षण योजना और स्वीकृति परीक्षण योजना शामिल हैं।
Test description - यह दस्तावेज़ उन्हें निष्पादित करने के लिए सभी परीक्षण मामलों और प्रक्रियाओं का विस्तृत विवरण है।
Test case report - इस दस्तावेज़ में परीक्षण के परिणामस्वरूप परीक्षण मामले की रिपोर्ट है।
Test logs - इस दस्तावेज़ में प्रत्येक परीक्षण मामले की रिपोर्ट के लिए परीक्षण लॉग होते हैं।
परीक्षण के बाद
परीक्षण के बाद निम्नलिखित दस्तावेज तैयार किए जा सकते हैं:
Test summary- यह परीक्षण सारांश सभी परीक्षण रिपोर्ट और लॉग का सामूहिक विश्लेषण है। यह संक्षेप और निष्कर्ष निकालता है कि सॉफ्टवेयर लॉन्च होने के लिए तैयार है या नहीं। सॉफ्टवेयर संस्करण नियंत्रण प्रणाली के तहत जारी किया जाता है अगर यह लॉन्च करने के लिए तैयार है।
परीक्षण बनाम गुणवत्ता नियंत्रण, गुणवत्ता आश्वासन और लेखा परीक्षा
हमें यह समझने की आवश्यकता है कि सॉफ़्टवेयर परीक्षण सॉफ़्टवेयर गुणवत्ता आश्वासन, सॉफ़्टवेयर गुणवत्ता नियंत्रण और सॉफ़्टवेयर ऑडिटिंग से अलग है।
Software quality assurance- ये सॉफ्टवेयर डेवलपमेंट प्रोसेस मॉनिटरिंग साधन हैं, जिनके द्वारा यह आश्वासन दिया जाता है कि संगठन के मानकों के अनुसार सभी उपाय किए जाते हैं। यह मॉनिटरिंग यह सुनिश्चित करने के लिए की जाती है कि उचित सॉफ्टवेयर विकास विधियों का पालन किया गया था।
Software quality control- यह सॉफ्टवेयर उत्पाद की गुणवत्ता को बनाए रखने के लिए एक प्रणाली है। इसमें सॉफ्टवेयर उत्पाद के कार्यात्मक और गैर-कार्यात्मक पहलू शामिल हो सकते हैं, जो संगठन की सद्भावना को बढ़ाते हैं। यह प्रणाली यह सुनिश्चित करती है कि ग्राहक को उनकी आवश्यकता के लिए गुणवत्ता वाला उत्पाद मिल रहा है और उत्पाद 'उपयोग के लिए उपयुक्त' के रूप में प्रमाणित है।
Software audit- यह सॉफ्टवेयर को विकसित करने के लिए संगठन द्वारा उपयोग की जाने वाली प्रक्रिया की समीक्षा है। ऑडिटर्स की एक टीम, विकास टीम से स्वतंत्र सॉफ्टवेयर प्रक्रिया, प्रक्रिया, आवश्यकताओं और एसडीएलसी के अन्य पहलुओं की जांच करती है। सॉफ्टवेयर ऑडिट का उद्देश्य उस सॉफ्टवेयर और उसकी विकास प्रक्रिया की जांच करना है, दोनों मानकों, नियमों और विनियमों के अनुरूप हैं।
सॉफ़्टवेयर रखरखाव व्यापक रूप से अब एसडीएलसी का एक हिस्सा स्वीकार कर लिया गया है। यह सॉफ्टवेयर उत्पाद की डिलीवरी के बाद किए गए सभी संशोधनों और अपडेशन के लिए है। कारणों की संख्या है, संशोधनों की आवश्यकता क्यों है, उनमें से कुछ का संक्षेप में नीचे उल्लेख किया गया है:
Market Conditions - नीतियां, जो समय के साथ बदलती हैं, जैसे कराधान और नई शुरू की गई बाधाएं, जैसे बहीखाता को कैसे बनाए रखना है, संशोधन की आवश्यकता को ट्रिगर कर सकता है।
Client Requirements - समय के साथ, ग्राहक सॉफ्टवेयर में नई सुविधाओं या कार्यों के लिए पूछ सकते हैं।
Host Modifications - यदि किसी भी हार्डवेयर और / या प्लेटफ़ॉर्म (जैसे ऑपरेटिंग सिस्टम) लक्ष्य होस्ट में परिवर्तन करता है, तो अनुकूलन क्षमता बनाए रखने के लिए सॉफ़्टवेयर परिवर्तनों की आवश्यकता होती है।
Organization Changes - अगर क्लाइंट एंड पर कोई बिजनेस लेवल चेंज होता है, जैसे ऑर्गनाइजेशन स्ट्रेंथ में कमी, दूसरी कंपनी का अधिग्रहण करना, नए बिजनेस में ऑर्गनाइजेशन करना, ऑरिजनल सॉफ्टवेयर में बदलाव की जरूरत हो सकती है।
रखरखाव के प्रकार
एक सॉफ्टवेयर जीवनकाल में, इसकी प्रकृति के आधार पर रखरखाव का प्रकार भिन्न हो सकता है। यह सिर्फ एक नियमित रखरखाव कार्य हो सकता है क्योंकि कुछ उपयोगकर्ता द्वारा खोजे गए बग या रखरखाव आकार या प्रकृति के आधार पर यह अपने आप में एक बड़ी घटना हो सकती है। उनकी विशेषताओं के आधार पर रखरखाव के कुछ प्रकार निम्नलिखित हैं:
Corrective Maintenance - इसमें समस्याओं को सही करने या ठीक करने के लिए किए गए संशोधन और अपडेशन शामिल हैं, जो या तो उपयोगकर्ता द्वारा खोजे जाते हैं या उपयोगकर्ता त्रुटि रिपोर्ट द्वारा निष्कर्ष निकाला जाता है।
Adaptive Maintenance - इसमें सॉफ्टवेयर उत्पाद को अद्यतित रखने के लिए लागू किए गए संशोधन और अपडेशन शामिल हैं जो प्रौद्योगिकी और व्यावसायिक वातावरण की निरंतर बदलती दुनिया में हैं।
Perfective Maintenance- इसमें सॉफ्टवेयर में लंबे समय तक प्रयोग करने योग्य बनाए रखने के लिए किए गए संशोधन और अपडेट शामिल हैं। इसमें सॉफ्टवेयर को परिष्कृत करने और उसकी विश्वसनीयता और प्रदर्शन में सुधार के लिए नई सुविधाएँ, नई उपयोगकर्ता आवश्यकताएं शामिल हैं।
Preventive Maintenance- इसमें सॉफ्टवेयर की भविष्य की समस्याओं को रोकने के लिए संशोधन और अपडेशन शामिल हैं। इसका उद्देश्य उन समस्याओं को प्रस्तुत करना है, जो इस समय महत्वपूर्ण नहीं हैं, लेकिन भविष्य में गंभीर मुद्दों का कारण बन सकती हैं।
रखरखाव की लागत
रिपोर्ट बताती है कि रखरखाव की लागत अधिक है। सॉफ्टवेयर रखरखाव के आकलन पर एक अध्ययन में पाया गया कि रखरखाव की लागत पूरे सॉफ्टवेयर प्रक्रिया चक्र की लागत का 67% है।
औसतन, सॉफ़्टवेयर रखरखाव की लागत सभी एसडीएलसी चरणों के 50% से अधिक है। विभिन्न कारक हैं, जो रखरखाव लागत को ट्रिगर करते हैं, जैसे कि उच्च:
रखरखाव लागत को प्रभावित करने वाले वास्तविक-विश्व कारक
- किसी भी सॉफ्टवेयर की मानक आयु 10 से 15 वर्ष तक मानी जाती है।
- पुराने सॉफ्टवेयर, जो कम मेमोरी और स्टोरेज क्षमता वाली धीमी मशीनों पर काम करने के लिए थे, आधुनिक हार्डवेयर पर आने वाले नए सॉफ्टवेयर्स के खिलाफ खुद को चुनौती नहीं दे सकते।
- जैसे-जैसे प्रौद्योगिकी की प्रगति होती है, पुराने सॉफ्टवेयर को बनाए रखना महंगा हो जाता है।
- अधिकांश रखरखाव इंजीनियर नौसिखिया हैं और समस्या को ठीक करने के लिए परीक्षण और त्रुटि विधि का उपयोग करते हैं।
- अक्सर, किए गए परिवर्तन सॉफ्टवेयर की मूल संरचना को आसानी से चोट पहुंचा सकते हैं, जिससे बाद के किसी भी बदलाव के लिए यह कठिन हो जाता है।
- परिवर्तन अक्सर अनजाने में छोड़ दिए जाते हैं जो भविष्य में और अधिक संघर्ष का कारण बन सकते हैं।
रखरखाव लागत को प्रभावित करने वाले सॉफ्टवेयर-एंड कारक
- सॉफ्टवेयर प्रोग्राम की संरचना
- प्रोग्रामिंग भाषा
- बाहरी वातावरण पर निर्भरता
- स्टाफ की विश्वसनीयता और उपलब्धता
रखरखाव की गतिविधियाँ
IEEE अनुक्रमिक रखरखाव प्रक्रिया गतिविधियों के लिए एक ढांचा प्रदान करता है। इसे पुनरावृत्त तरीके से उपयोग किया जा सकता है और इसे बढ़ाया जा सकता है ताकि अनुकूलित वस्तुओं और प्रक्रियाओं को शामिल किया जा सके।
ये गतिविधियाँ निम्नलिखित चरण में से प्रत्येक के साथ हाथ से चलती हैं:
Identification & Tracing- इसमें संशोधन या रखरखाव की आवश्यकता से संबंधित गतिविधियां शामिल हैं। यह उपयोगकर्ता या सिस्टम द्वारा लॉग या त्रुटि संदेशों के माध्यम से रिपोर्ट कर सकता है।
Analysis- सुरक्षा और सुरक्षा निहितार्थ सहित प्रणाली पर इसके प्रभाव के लिए संशोधन का विश्लेषण किया जाता है। यदि संभावित प्रभाव गंभीर है, तो वैकल्पिक समाधान की तलाश की जाती है। आवश्यक संशोधनों का एक सेट तब आवश्यकता विनिर्देशों में भौतिकीकृत होता है। संशोधन / रखरखाव की लागत का विश्लेषण किया जाता है और अनुमान लगाया जाता है।
Design- नए मॉड्यूल, जिन्हें बदलने या संशोधित करने की आवश्यकता होती है, उन्हें पिछले चरण में निर्धारित आवश्यकता विनिर्देशों के विरुद्ध डिज़ाइन किया गया है। सत्यापन और सत्यापन के लिए परीक्षण मामले बनाए जाते हैं।
Implementation - नए मॉड्यूल्स को डिज़ाइन स्टेप में बनाए गए स्ट्रक्चर्ड डिज़ाइन की मदद से कोड किया गया है। प्रत्येक प्रोग्रामर को समानांतर में यूनिट टेस्टिंग करने की उम्मीद है।
System Testing- एकीकरण परीक्षण नव निर्मित मॉड्यूल के बीच किया जाता है। नए मॉड्यूल और सिस्टम के बीच एकीकरण परीक्षण भी किया जाता है। अंत में प्रतिगामी परीक्षण प्रक्रियाओं के बाद प्रणाली को संपूर्ण रूप में जांचा जाता है।
Acceptance Testing- आंतरिक रूप से सिस्टम का परीक्षण करने के बाद, इसे उपयोगकर्ताओं की सहायता से स्वीकृति के लिए परीक्षण किया जाता है। यदि इस स्थिति में, उपयोगकर्ता कुछ समस्याओं की शिकायत करता है जिन्हें वे संबोधित करते हैं या अगले पुनरावृत्ति में संबोधित करने के लिए नोट किया जाता है।
Delivery- स्वीकृति परीक्षण के बाद, सिस्टम को पूरे संगठन में या तो छोटे अपडेट पैकेज या सिस्टम की ताज़ा स्थापना द्वारा तैनात किया जाता है। सॉफ्टवेयर डिलीवर होने के बाद क्लाइंट टेस्टिंग में अंतिम परीक्षण होता है।
उपयोगकर्ता मैनुअल की हार्ड कॉपी के अलावा, यदि आवश्यक हो, तो प्रशिक्षण सुविधा प्रदान की जाती है।
Maintenance management- कॉन्फ़िगरेशन प्रबंधन सिस्टम रखरखाव का एक अनिवार्य हिस्सा है। यह संस्करण, अर्ध-संस्करण या पैच प्रबंधन को नियंत्रित करने के लिए संस्करण नियंत्रण उपकरण के साथ सहायता प्राप्त है।
सॉफ्टवेयर री-इंजीनियरिंग
जब हमें इसकी कार्यक्षमता को प्रभावित किए बिना, इसे वर्तमान बाजार में रखने के लिए सॉफ़्टवेयर को अपडेट करने की आवश्यकता होती है, तो इसे सॉफ़्टवेयर री-इंजीनियरिंग कहा जाता है। यह एक पूरी तरह से प्रक्रिया है जहां सॉफ्टवेयर के डिजाइन को बदल दिया जाता है और कार्यक्रमों को फिर से लिखा जाता है।
विरासत सॉफ्टवेयर बाजार में उपलब्ध नवीनतम तकनीक के साथ ट्यूनिंग नहीं रख सकता है। जैसे ही हार्डवेयर अप्रचलित हो जाता है, सॉफ़्टवेयर का अद्यतन करना सिरदर्द बन जाता है। भले ही सॉफ्टवेयर समय के साथ पुराना हो जाता है, लेकिन इसकी कार्यक्षमता नहीं है।
उदाहरण के लिए, शुरुआत में असिक्स को असेंबली भाषा में विकसित किया गया था। जब भाषा C अस्तित्व में आई, तो Unix C में फिर से इंजीनियर किया गया, क्योंकि असेंबली भाषा में काम करना मुश्किल था।
इसके अलावा, कभी-कभी प्रोग्रामर यह नोटिस करते हैं कि सॉफ्टवेयर के कुछ हिस्सों को दूसरों की तुलना में अधिक रखरखाव की आवश्यकता होती है और उन्हें री-इंजीनियरिंग की भी आवश्यकता होती है।
री-इंजीनियरिंग प्रक्रिया
- Decideक्या फिर से इंजीनियर यह पूरा सॉफ्टवेयर है या इसका एक हिस्सा है?
- Perform मौजूदा सॉफ्टवेयर के विनिर्देशों को प्राप्त करने के लिए, रिवर्स इंजीनियरिंग।
- Restructure Programयदि आवश्यक हुआ। उदाहरण के लिए, फ़ंक्शन-ओरिएंटेड प्रोग्राम्स को ऑब्जेक्ट-ओरिएंटेड प्रोग्राम्स में बदलना।
- Re-structure data जैसी ज़रूरत।
- Apply Forward engineering फिर से इंजीनियर सॉफ्टवेयर प्राप्त करने के लिए अवधारणाओं।
सॉफ्टवेयर री-इंजीनियरिंग में उपयोग किए जाने वाले कुछ महत्वपूर्ण शब्द हैं
रिवर्स इंजीनियरिंग
यह मौजूदा प्रणाली को अच्छी तरह से विश्लेषण करके सिस्टम विनिर्देश प्राप्त करने की एक प्रक्रिया है। इस प्रक्रिया को रिवर्स एसडीएलसी मॉडल के रूप में देखा जा सकता है, अर्थात हम निम्न अमूर्त स्तरों का विश्लेषण करके उच्च अमूर्त स्तर प्राप्त करने का प्रयास करते हैं।
एक मौजूदा प्रणाली पहले से लागू डिज़ाइन है, जिसके बारे में हम कुछ भी नहीं जानते हैं। डिज़ाइनर तब कोड को देखकर रिवर्स इंजीनियरिंग करते हैं और डिज़ाइन प्राप्त करने का प्रयास करते हैं। हाथ में डिजाइन के साथ, वे विनिर्देशों को समाप्त करने का प्रयास करते हैं। इस प्रकार, कोड से सिस्टम विनिर्देश में रिवर्स जा रहा है।
कार्यक्रम का पुनर्गठन
यह मौजूदा सॉफ्टवेयर को फिर से बनाने और फिर से बनाने की एक प्रक्रिया है। यह स्रोत कोड को फिर से व्यवस्थित करने के बारे में है, या तो एक ही प्रोग्रामिंग भाषा में या एक प्रोग्रामिंग भाषा से एक अलग से। पुनर्गठन में स्रोत कोड-पुनर्गठन और डेटा-पुनर्गठन या दोनों हो सकते हैं।
री-स्ट्रक्चरिंग सॉफ्टवेयर की कार्यक्षमता को प्रभावित नहीं करता है लेकिन विश्वसनीयता और स्थिरता को बढ़ाता है। प्रोग्राम घटक, जिसके कारण त्रुटियां बहुत बार होती हैं, उन्हें बदला जा सकता है, या पुन: संरचना के साथ अद्यतन किया जा सकता है।
अप्रचलित हार्डवेयर प्लेटफॉर्म पर सॉफ्टवेयर की निर्भरता को री-स्ट्रक्चरिंग के माध्यम से हटाया जा सकता है।
फॉरवर्ड इंजीनियरिंग
फॉरवर्ड इंजीनियरिंग हाथ में विशिष्टताओं से वांछित सॉफ्टवेयर प्राप्त करने की एक प्रक्रिया है जिसे रिवर्स इंजीनियरिंग के माध्यम से नीचे लाया गया था। यह मानता है कि अतीत में पहले से ही कुछ सॉफ्टवेयर इंजीनियरिंग थी।
फॉरवर्ड इंजीनियरिंग केवल एक अंतर के साथ सॉफ्टवेयर इंजीनियरिंग प्रक्रिया के समान है - यह रिवर्स इंजीनियरिंग के बाद हमेशा किया जाता है।
घटक पुन: प्रयोज्यता
एक घटक सॉफ्टवेयर प्रोग्राम कोड का एक हिस्सा है, जो सिस्टम में एक स्वतंत्र कार्य को निष्पादित करता है। यह स्वयं एक छोटा मॉड्यूल या उप-प्रणाली हो सकती है।
उदाहरण
वेब पर उपयोग की जाने वाली लॉगिन प्रक्रियाओं को घटक के रूप में माना जा सकता है, सॉफ्टवेयर में प्रिंटिंग सिस्टम को सॉफ्टवेयर के घटक के रूप में देखा जा सकता है।
घटकों में उच्च कार्यक्षमता और युग्मन की कम दर है, अर्थात वे स्वतंत्र रूप से काम करते हैं और अन्य मॉड्यूल के आधार पर बिना कार्य कर सकते हैं।
OOP में, ऑब्जेक्ट्स डिज़ाइन किए गए हैं जो उनकी चिंता के लिए बहुत विशिष्ट हैं और कुछ अन्य सॉफ़्टवेयर में उपयोग किए जाने की संभावना कम है।
मॉड्यूलर प्रोग्रामिंग में, मॉड्यूल को विशिष्ट कार्यों को करने के लिए कोडित किया जाता है जो कि अन्य सॉफ्टवेयर प्रोग्रामों की संख्या में उपयोग किए जा सकते हैं।
एक पूरी नई वर्टिकल है, जो सॉफ्टवेयर कंपोनेंट के पुन: उपयोग पर आधारित है, और इसे कंपोनेंट बेस्ड सॉफ्टवेयर इंजीनियरिंग (CBSE) के रूप में जाना जाता है।
पुन: उपयोग विभिन्न स्तरों पर किया जा सकता है
Application level - जहां पूरे एप्लिकेशन को नए सॉफ्टवेयर की उप-प्रणाली के रूप में उपयोग किया जाता है।
Component level - जहां किसी एप्लिकेशन की उप-प्रणाली का उपयोग किया जाता है।
Modules level - जहां कार्यात्मक मॉड्यूल का पुन: उपयोग किया जाता है।
सॉफ्टवेयर घटक इंटरफेस प्रदान करते हैं, जिनका उपयोग विभिन्न घटकों के बीच संचार स्थापित करने के लिए किया जा सकता है।
पुन: उपयोग प्रक्रिया
दो प्रकार की विधि अपनाई जा सकती है: या तो आवश्यकताओं को एक समान रखना और घटकों को समायोजित करना या घटकों को समान रखना और आवश्यकताओं को संशोधित करना।
Requirement Specification - कार्यात्मक और गैर-कार्यात्मक आवश्यकताएं निर्दिष्ट हैं, जो एक सॉफ्टवेयर उत्पाद को मौजूदा सिस्टम, उपयोगकर्ता इनपुट या दोनों की मदद से पालन करना चाहिए।
Design- यह एक मानक एसडीएलसी प्रक्रिया कदम भी है, जहां आवश्यकताओं को सॉफ्टवेयर पार्लरों के संदर्भ में परिभाषित किया गया है। एक पूरे के रूप में प्रणाली की बुनियादी वास्तुकला और इसके उप-सिस्टम बनाए जाते हैं।
Specify Components - सॉफ्टवेयर डिजाइन का अध्ययन करके, डिजाइनर पूरे सिस्टम को छोटे घटकों या उप-प्रणालियों में अलग करते हैं। एक पूर्ण सॉफ्टवेयर डिजाइन एक साथ काम करने वाले घटकों के विशाल समूह के संग्रह में बदल जाता है।
Search Suitable Components - सॉफ्टवेयर घटक रिपॉजिटरी को डिजाइनरों द्वारा मिलान घटक की खोज करने के लिए, कार्यक्षमता और इच्छित सॉफ़्टवेयर आवश्यकताओं के आधार पर संदर्भित किया जाता है।
Incorporate Components - सभी मिलान किए गए घटकों को एक साथ पूरा सॉफ्टवेयर के रूप में आकार देने के लिए पैक किया जाता है।
CASE का मतलब है Computer Aided Software Engineering। इसका मतलब है, विभिन्न स्वचालित सॉफ्टवेयर टूल्स की मदद से सॉफ्टवेयर परियोजनाओं का विकास और रखरखाव।
मामले उपकरण
CASE उपकरण सॉफ़्टवेयर एप्लिकेशन प्रोग्राम के सेट होते हैं, जिनका उपयोग SDLC गतिविधियों को स्वचालित करने के लिए किया जाता है। CASE टूल का उपयोग सॉफ़्टवेयर सिस्टम प्रबंधकों, विश्लेषकों और इंजीनियरों द्वारा सॉफ़्टवेयर सिस्टम विकसित करने के लिए किया जाता है।
सॉफ्टवेयर डेवलपमेंट लाइफ साइकिल के विभिन्न चरणों जैसे कि एनालिसिस टूल, डिज़ाइन टूल, प्रोजेक्ट मैनेजमेंट टूल, डेटाबेस मैनेजमेंट टूल, डॉक्यूमेंटेशन टूल को सरल बनाने के लिए कई CASE टूल उपलब्ध हैं।
CASE उपकरणों का उपयोग वांछित परिणाम उत्पन्न करने के लिए परियोजना के विकास को तेज करता है और सॉफ्टवेयर विकास में अगले चरण के साथ आगे बढ़ने से पहले खामियों को उजागर करने में मदद करता है।
CASE उपकरण के घटक
CASE टूल को एक विशेष SDLC चरण में उनके उपयोग के आधार पर मोटे तौर पर निम्नलिखित भागों में विभाजित किया जा सकता है:
Central Repository- CASE टूल्स के लिए एक केंद्रीय रिपॉजिटरी की आवश्यकता होती है, जो आम, एकीकृत और सुसंगत जानकारी के स्रोत के रूप में काम कर सकती है। केंद्रीय भंडार भंडारण का एक केंद्रीय स्थान है जहां उत्पाद विनिर्देश, आवश्यकता दस्तावेज, संबंधित रिपोर्ट और आरेख, प्रबंधन से संबंधित अन्य उपयोगी जानकारी संग्रहीत की जाती है। सेंट्रल रिपॉजिटरी डेटा डिक्शनरी के रूप में भी काम करती है।
Upper Case Tools - ऊपरी CASE उपकरण SDLC के नियोजन, विश्लेषण और डिजाइन चरणों में उपयोग किए जाते हैं।
Lower Case Tools - लोअर CASE टूल का उपयोग कार्यान्वयन, परीक्षण और रखरखाव में किया जाता है।
Integrated Case Tools - इंटीग्रेटेड CASE टूल SDLC के सभी चरणों में आवश्यकता से लेकर टेस्टिंग और डॉक्यूमेंटेशन में सहायक होते हैं।
यदि उन्हें समान कार्यक्षमता, प्रक्रिया गतिविधियों और अन्य उपकरणों के साथ एकीकृत होने की क्षमता है, तो CASE टूल को एक साथ रखा जा सकता है।
केस टूल्स का स्कोप
CASE टूल का दायरा पूरे SDLC में जाता है।
केस टूल के प्रकार
अब हम संक्षेप में विभिन्न CASE उपकरणों से गुजरते हैं
आरेख उपकरण
इन उपकरणों का उपयोग सिस्टम घटकों, डेटा और नियंत्रण प्रवाह को विभिन्न सॉफ्टवेयर घटकों और सिस्टम संरचना के बीच ग्राफिकल रूप में दर्शाने के लिए किया जाता है। उदाहरण के लिए, अत्याधुनिक फ्लोचार्ट बनाने के लिए फ्लो चार्ट मेकर टूल।
प्रक्रिया मॉडलिंग उपकरण
प्रक्रिया मॉडलिंग सॉफ्टवेयर प्रक्रिया मॉडल बनाने की विधि है, जिसका उपयोग सॉफ्टवेयर को विकसित करने के लिए किया जाता है। प्रक्रिया मॉडलिंग उपकरण प्रबंधकों को एक प्रक्रिया मॉडल चुनने या सॉफ्टवेयर उत्पाद की आवश्यकता के अनुसार इसे संशोधित करने में मदद करते हैं। उदाहरण के लिए, ईपीएफ संगीतकार
परियोजना प्रबंधन उपकरण
इन उपकरणों का उपयोग परियोजना नियोजन, लागत और प्रयास के आकलन, परियोजना निर्धारण और संसाधन नियोजन के लिए किया जाता है। सॉफ्टवेयर परियोजना प्रबंधन में प्रत्येक उल्लिखित कदम के साथ प्रबंधकों को परियोजना निष्पादन का कड़ाई से अनुपालन करना है। परियोजना प्रबंधन उपकरण संगठन में परियोजना की जानकारी को वास्तविक समय में संग्रहीत करने और साझा करने में मदद करते हैं। उदाहरण के लिए, क्रिएटिव प्रो ऑफिस, ट्राक प्रोजेक्ट, बेसकैंप।
प्रलेखन उपकरण
एक सॉफ्टवेयर परियोजना में प्रलेखन सॉफ्टवेयर प्रक्रिया से पहले शुरू होता है, एसडीएलसी के सभी चरणों में और परियोजना के पूरा होने के बाद जाता है।
प्रलेखन उपकरण तकनीकी उपयोगकर्ताओं और अंतिम उपयोगकर्ताओं के लिए दस्तावेज़ उत्पन्न करते हैं। तकनीकी उपयोगकर्ता ज्यादातर विकास टीम के इन-हाउस पेशेवरों हैं, जो सिस्टम मैनुअल, संदर्भ मैनुअल, प्रशिक्षण मैनुअल, इंस्टॉलेशन मैनुअल आदि का उल्लेख करते हैं। अंतिम उपयोगकर्ता दस्तावेज़ उपयोगकर्ता मैनुअल जैसे सिस्टम के कामकाज और कैसे-का वर्णन करते हैं। उदाहरण के लिए, Doxygen, DrExplain, प्रलेखन के लिए Adobe RoboHelp।
विश्लेषण उपकरण
ये उपकरण आवश्यकताओं को इकट्ठा करने में मदद करते हैं, स्वचालित रूप से किसी भी विसंगति, आरेखों में अशुद्धि, डेटा अतिरेक या गलत चूक के लिए जाँच करते हैं। उदाहरण के लिए, स्वीकार करें 360, Accompa, आवश्यकता विश्लेषण के लिए CaseComplete, कुल विश्लेषण के लिए दृश्य विश्लेषक।
डिजाइन उपकरण
ये उपकरण सॉफ्टवेयर डिजाइनरों को सॉफ्टवेयर की ब्लॉक संरचना को डिजाइन करने में मदद करते हैं, जिसे शोधन तकनीकों का उपयोग करके छोटे मॉड्यूल में और तोड़ा जा सकता है। ये उपकरण प्रत्येक मॉड्यूल का विवरण प्रदान करते हैं और मॉड्यूल के बीच इंटरकनेक्ट करते हैं। उदाहरण के लिए, एनिमेटेड सॉफ्टवेयर डिज़ाइन
कॉन्फ़िगरेशन प्रबंधन उपकरण
सॉफ्टवेयर का एक उदाहरण एक संस्करण के तहत जारी किया गया है। विन्यास प्रबंधन उपकरण के साथ सौदा -
- संस्करण और संशोधन प्रबंधन
- आधारभूत विन्यास प्रबंधन
- नियंत्रण प्रबंधन बदलें
CASE उपकरण इसमें स्वचालित ट्रैकिंग, संस्करण प्रबंधन और रिलीज़ प्रबंधन द्वारा मदद करते हैं। उदाहरण के लिए, फॉसिल, गिट, एक्यू आरईवी।
नियंत्रण उपकरण बदलें
इन उपकरणों को विन्यास प्रबंधन उपकरणों के एक भाग के रूप में माना जाता है। वे इसकी आधार रेखा तय होने के बाद या सॉफ्टवेयर के पहली बार जारी होने के बाद सॉफ्टवेयर में किए गए बदलाव से निपटते हैं। CASE उपकरण परिवर्तन ट्रैकिंग, फ़ाइल प्रबंधन, कोड प्रबंधन और बहुत कुछ स्वचालित करते हैं। यह संगठन की परिवर्तन नीति को लागू करने में भी मदद करता है।
प्रोग्रामिंग उपकरण
इन उपकरणों में IDE (इंटीग्रेटेड डेवलपमेंट एनवायरनमेंट), इन-बिल्ट मॉड्यूल लाइब्रेरी और सिमुलेशन टूल्स जैसे प्रोग्रामिंग वातावरण शामिल हैं। ये उपकरण सॉफ्टवेयर उत्पाद के निर्माण में व्यापक सहायता प्रदान करते हैं और इसमें सिमुलेशन और परीक्षण की विशेषताएं शामिल हैं। उदाहरण के लिए, Cscope को C, Eclipse में खोज कोड।
प्रोटोटाइप उपकरण
सॉफ़्टवेयर प्रोटोटाइप, इच्छित सॉफ़्टवेयर उत्पाद का नकली संस्करण है। प्रोटोटाइप उत्पाद का प्रारंभिक रूप और अनुभव प्रदान करता है और वास्तविक उत्पाद के कुछ पहलू का अनुकरण करता है।
प्रोटोटाइप कैस उपकरण अनिवार्य रूप से चित्रमय पुस्तकालयों के साथ आते हैं। वे हार्डवेयर स्वतंत्र उपयोगकर्ता इंटरफ़ेस और डिज़ाइन बना सकते हैं। ये उपकरण मौजूदा जानकारी के आधार पर तेजी से प्रोटोटाइप बनाने में हमारी मदद करते हैं। इसके अलावा, वे सॉफ्टवेयर प्रोटोटाइप का अनुकरण प्रदान करते हैं। उदाहरण के लिए, सेरेना प्रोटोटाइप संगीतकार, मॉकअप बिल्डर।
वेब विकास उपकरण
ये उपकरण वेब पेजों को सभी संबद्ध तत्वों जैसे फॉर्म, टेक्स्ट, स्क्रिप्ट, ग्राफिक आदि के साथ डिजाइन करने में सहायता करते हैं। वेब उपकरण भी विकसित किए जा रहे हैं का लाइव पूर्वावलोकन प्रदान करते हैं और यह पूरा होने के बाद कैसा दिखेगा। उदाहरण के लिए, फोंटेलो, एडोब एज इंस्पेक्ट, फाउंडेशन 3, ब्रैकेट।
गुणवत्ता आश्वासन उपकरण
एक सॉफ्टवेयर संगठन में गुणवत्ता आश्वासन, संगठन मानकों के अनुसार गुणवत्ता के अनुरूपता सुनिश्चित करने के लिए सॉफ्टवेयर उत्पाद को विकसित करने के लिए अपनाई गई इंजीनियरिंग प्रक्रिया और तरीकों की निगरानी कर रहा है। क्यूए उपकरण विन्यास और परिवर्तन नियंत्रण उपकरण और सॉफ्टवेयर परीक्षण उपकरण से मिलकर बनता है। उदाहरण के लिए, सोपटेस्ट, एप्सवॉच, जेमीटर।
रखरखाव के उपकरण
सॉफ्टवेयर रखरखाव में सॉफ्टवेयर उत्पाद में संशोधन शामिल हैं, इसे वितरित करने के बाद। स्वचालित लॉगिंग और त्रुटि रिपोर्टिंग तकनीक, स्वचालित त्रुटि टिकट पीढ़ी और मूल कारण विश्लेषण कुछ CASE उपकरण हैं, जो SDLC के रखरखाव चरण में सॉफ़्टवेयर संगठन की सहायता करते हैं। उदाहरण के लिए, दोष ट्रैकिंग के लिए बुगज़िला, एचपी गुणवत्ता केंद्र।