संरचना को मापने
सॉफ्टवेयर के संरचनात्मक गुणों का मापन विकास के प्रयासों के साथ-साथ उत्पाद के रखरखाव के आकलन के लिए महत्वपूर्ण है। आवश्यकताओं, डिजाइन और कोड की संरचना उस कठिनाई को समझने में मदद करती है जो एक उत्पाद को दूसरे उत्पाद में परिवर्तित करने, किसी उत्पाद के परीक्षण में या बाहरी आंतरिक उत्पाद उपायों से बाहरी सॉफ़्टवेयर विशेषताओं की भविष्यवाणी करने में उत्पन्न होती है।
संरचनात्मक उपायों के प्रकार
सॉफ्टवेयर की संरचना के तीन भाग हैं। वे हैं -
Control-flow structure - यह वह क्रम है जिसमें निर्देशों को एक कार्यक्रम में निष्पादित किया जाता है।
Data-flow structure - यह डेटा का व्यवहार है क्योंकि यह प्रोग्राम के साथ इंटरैक्ट करता है।
Data structure - यह सूची, कतार, ढेर या अन्य अच्छी तरह से परिभाषित संरचनाओं के साथ-साथ उन्हें बनाने, संशोधित करने या हटाने के लिए डेटा तत्वों का संगठन है।
नियंत्रण-प्रवाह संरचना को मापना
नियंत्रण प्रवाह उपायों को आमतौर पर निर्देशित ग्राफ के साथ मॉडल किया जाता है, जहां प्रत्येक नोड या बिंदु कार्यक्रम के बयान से मेल खाती है, और प्रत्येक चाप या निर्देशित किनारा एक बयान से दूसरे में नियंत्रण के प्रवाह को इंगित करता है। थिसिस ग्राफ को नियंत्रण-प्रवाह ग्राफ या निर्देशित ग्राफ कहा जाता है।
अगर ‘m’ एक संरचनात्मक माप प्रवाह ग्राफ मॉडल के संदर्भ में परिभाषित किया गया है, और यदि कार्यक्रम A प्रोग्राम की तुलना में संरचनात्मक रूप से अधिक जटिल है B, फिर उपाय m(A) से अधिक होना चाहिए m(B)।
डेटा-फ्लो संरचना को मापना
डेटा प्रवाह या सूचना प्रवाह अंतर-मॉड्यूलर हो सकता है (मॉड्यूल के भीतर सूचना का प्रवाह) या इंट्रा-मॉड्यूलर (व्यक्तिगत मॉड्यूल और बाकी सिस्टम के बीच जानकारी का प्रवाह)।
सिस्टम के माध्यम से डेटा किस तरह से बढ़ रहा है, इसके अनुसार, इसे निम्नलिखित में वर्गीकृत किया जा सकता है -
Local direct flow - यदि या तो एक मॉड्यूल दूसरे मॉड्यूल का आह्वान करता है और इसकी जानकारी देता है या आह्वान करने वाला मॉड्यूल फोन करने वाले का परिणाम देता है।
Local indirect flow - यदि आह्वान किया गया मॉड्यूल ऐसी जानकारी लौटाता है जो बाद में एक दूसरे आह्वान किए गए मॉड्यूल में पारित हो जाती है।
Global flow - यदि वैश्विक डेटा संरचना के माध्यम से जानकारी एक मॉड्यूल से दूसरे में प्रवाहित होती है।
हेनरी और काफुरा के अनुसार सूचना प्रवाह जटिलता व्यक्त की जा सकती है,
Information flow complexity (M) = length (M) × fan-in (M) × (fan-out (M))2
कहाँ पे,
Fan-in (M) - एम + पर डेटा प्रवाह की संख्या को समाप्त करने वाले स्थानीय प्रवाह की संख्या जिसमें से जानकारी एम द्वारा पुनर्प्राप्त की जाती है।
Fan–out (M) - एम + से अद्यतन होने वाले डेटा संरचनाओं की संख्या M से निकलने वाले स्थानीय प्रवाह की संख्या।
डेटा संरचना को मापने
डेटा संरचना दोनों हो सकती है local तथा global।
Locally, प्रत्येक डेटा आइटम में संरचना की मात्रा को मापा जाएगा। व्यक्तिगत डेटा संरचनाओं के गुणों का विश्लेषण और मापने के लिए एक ग्राफ-सिद्धांतिक दृष्टिकोण का उपयोग किया जा सकता है। उस सरल डेटा प्रकारों जैसे कि पूर्णांक, वर्ण, और बूलियन को primes के रूप में देखा जाता है और विभिन्न ऑपरेशन जो हमें अधिक जटिल डेटा संरचना बनाने में सक्षम बनाते हैं, पर विचार किया जाता है। डेटा संरचना के उपायों को तब विभिन्न परिचालन से जुड़े अपराधों और मूल्यों के लिए मूल्यों के संदर्भ में श्रेणीबद्ध रूप से परिभाषित किया जा सकता है।
Globally, उपयोगकर्ता-परिभाषित चर की कुल संख्या की गणना की जाएगी।