सॉफ्टवेयर विश्लेषण और डिजाइन उपकरण
सॉफ़्टवेयर विश्लेषण और डिज़ाइन में सभी गतिविधियाँ शामिल हैं, जो कार्यान्वयन में आवश्यकता विनिर्देश के परिवर्तन में मदद करती हैं। आवश्यकता विनिर्देशों को सॉफ्टवेयर से सभी कार्यात्मक और गैर-कार्यात्मक अपेक्षाएं निर्दिष्ट हैं। ये आवश्यकता विनिर्देश मानव पठनीय और समझने योग्य दस्तावेजों के आकार में आते हैं, जिनके लिए कंप्यूटर का कोई लेना-देना नहीं है।
सॉफ्टवेयर विश्लेषण और डिजाइन मध्यवर्ती चरण है, जो मानव-पठनीय आवश्यकताओं को वास्तविक कोड में बदलने में मदद करता है।
आइए सॉफ्टवेयर डिजाइनरों द्वारा उपयोग किए जाने वाले कुछ विश्लेषण और डिज़ाइन टूल देखें:
आंकड़ा प्रवाह आरेख
डेटा प्रवाह आरेख एक सूचना प्रणाली में डेटा के प्रवाह का चित्रमय प्रतिनिधित्व है। यह आने वाले डेटा प्रवाह, आउटगोइंग डेटा प्रवाह और संग्रहीत डेटा को चित्रित करने में सक्षम है। सिस्टम में डेटा कैसे प्रवाहित होता है, इस बारे में DFD ने कुछ भी उल्लेख नहीं किया है।
DFD और फ़्लोचार्ट के बीच एक प्रमुख अंतर है। फ्लोचार्ट कार्यक्रम मॉड्यूल में नियंत्रण के प्रवाह को दर्शाता है। DFDs विभिन्न स्तरों पर प्रणाली में डेटा के प्रवाह को दर्शाते हैं। 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 DFD और अधिक विशिष्ट, स्तर 1 DFD में टूट गया है। स्तर 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: जैसा कि सॉफ्टवेयर देखता है