डेटा फ्लो आर्किटेक्चर

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

घटकों या मॉड्यूल के बीच के कनेक्शन को I / O स्ट्रीम, I / O बफर, पाइप्ड या अन्य प्रकार के कनेक्शन के रूप में लागू किया जा सकता है। डेटा को चक्रव्यूह के साथ ग्राफ टोपोलॉजी में, चक्र के बिना एक रेखीय संरचना में, या एक पेड़ प्रकार की संरचना में प्रवाहित किया जा सकता है।

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

  • बैच अनुक्रमिक
  • पाइप और फिल्टर या गैर-अनुक्रमिक पाइपलाइन मोड
  • प्रक्रिया नियंत्रण

बैच अनुक्रमिक

बैच अनुक्रमिक एक शास्त्रीय डेटा प्रोसेसिंग मॉडल है, जिसमें एक डेटा ट्रांसफ़ॉर्मेशन सबसिस्टम अपने पिछले सबसिस्टम पूरी तरह से होने के बाद ही अपनी प्रक्रिया शुरू कर सकता है -

  • डेटा का प्रवाह एक सबसिस्टम से दूसरे तक डेटा के एक बैच को वहन करता है।

  • मॉड्यूल के बीच संचार अस्थायी मध्यवर्ती फ़ाइलों के माध्यम से आयोजित किया जाता है जिसे क्रमिक उप-प्रणालियों द्वारा हटाया जा सकता है।

  • यह उन अनुप्रयोगों के लिए लागू होता है जहां डेटा बैच होता है, और प्रत्येक सबसिस्टम संबंधित इनपुट फ़ाइलों को पढ़ता है और आउटपुट फाइलें लिखता है।

  • इस वास्तुकला के विशिष्ट अनुप्रयोग में बैंकिंग और यूटिलिटी बिलिंग जैसे व्यावसायिक डेटा प्रसंस्करण शामिल हैं।

लाभ

  • उपतंत्रों पर सरल विभाजन प्रदान करता है।

  • प्रत्येक सबसिस्टम इनपुट डेटा और आउटपुट आउटपुट डेटा पर काम करने वाला एक स्वतंत्र कार्यक्रम हो सकता है।

नुकसान

  • उच्च विलंबता और निम्न प्रवाह प्रदान करता है।

  • समवर्ती और इंटरैक्टिव इंटरफ़ेस प्रदान नहीं करता है।

  • कार्यान्वयन के लिए बाहरी नियंत्रण आवश्यक है।

पाइप और फ़िल्टर वास्तुकला

यह दृष्टिकोण क्रमिक घटक द्वारा डेटा के वृद्धिशील परिवर्तन पर जोर देता है। इस दृष्टिकोण में, डेटा का प्रवाह डेटा द्वारा संचालित होता है और संपूर्ण सिस्टम डेटा स्रोत, फ़िल्टर, पाइप और डेटा सिंक के घटकों में विघटित हो जाता है।

मॉड्यूल के बीच कनेक्शन डेटा स्ट्रीम है जो पहले-पहले / पहले-बाहर बफ़र है जो बाइट्स, वर्णों या इस तरह के किसी अन्य प्रकार की धारा हो सकती है। इस वास्तुकला की मुख्य विशेषता इसका समवर्ती और वृद्ध निष्पादन है।

फ़िल्टर

एक फिल्टर एक स्वतंत्र डेटा स्ट्रीम ट्रांसफार्मर या स्ट्रीम ट्रांसड्यूसर है। यह इनपुट डेटा स्ट्रीम के डेटा को रूपांतरित करता है, इसे संसाधित करता है, और अगले फ़िल्टर को प्रोसेस करने के लिए एक पाइप पर रूपांतरित डेटा स्ट्रीम लिखता है। यह एक वृद्धिशील मोड में काम करता है, जिसमें कनेक्टेड पाइप के माध्यम से डेटा आते ही यह काम करना शुरू कर देता है। दो प्रकार के फिल्टर हैं -active filter तथा passive filter

Active filter

सक्रिय फ़िल्टर कनेक्टेड पाइप को डेटा को खींचने और परिवर्तित डेटा को बाहर निकालने की सुविधा देता है। यह निष्क्रिय पाइप से संचालित होता है, जो खींचने और धक्का देने के लिए पढ़ने / लिखने की व्यवस्था प्रदान करता है। इस मोड का उपयोग UNIX पाइप और फिल्टर तंत्र में किया जाता है।

Passive filter

पैसिव फिल्टर कनेक्टेड पाइप को डेटा को पुश करने और डेटा को बाहर खींचने की सुविधा देता है। यह सक्रिय पाइप से संचालित होता है, जो एक फिल्टर से डेटा खींचता है और अगले फिल्टर में डेटा को धक्का देता है। इसे पढ़ने / लिखने की व्यवस्था प्रदान करनी चाहिए।

लाभ

  • अत्यधिक डेटा प्रोसेसिंग के लिए संगामिति और उच्च थ्रूपुट प्रदान करता है।

  • पुन: प्रयोज्य प्रदान करता है और सिस्टम रखरखाव को सरल करता है।

  • फिल्टर के बीच परिवर्तनशीलता और कम युग्मन प्रदान करता है।

  • पाइप से जुड़े किसी भी दो फिल्टर के बीच स्पष्ट विभाजन प्रदान करके सादगी प्रदान करता है।

  • अनुक्रमिक और समानांतर निष्पादन दोनों का समर्थन करके लचीलापन प्रदान करता है।

नुकसान

  • गतिशील बातचीत के लिए उपयुक्त नहीं है।

  • ASCII स्वरूपों में डेटा के संचरण के लिए एक कम आम भाजक की आवश्यकता होती है।

  • फ़िल्टर के बीच डेटा परिवर्तन का ओवरहेड।

  • किसी समस्या को हल करने के लिए सहकारी रूप से बातचीत करने के लिए फ़िल्टर के लिए एक रास्ता प्रदान नहीं करता है।

  • इस वास्तुकला को गतिशील रूप से कॉन्फ़िगर करना मुश्किल है।

पाइप

पाइप स्टेटलेस हैं और वे बाइनरी या कैरेक्टर स्ट्रीम को ले जाते हैं जो दो फिल्टर के बीच मौजूद हैं। यह एक डेटा स्ट्रीम को एक फिल्टर से दूसरे फ़िल्टर पर ले जा सकता है। पाइप थोड़ी सी प्रासंगिक जानकारी का उपयोग करते हैं और तात्कालिकता के बीच कोई राज्य जानकारी नहीं रखते हैं।

प्रक्रिया नियंत्रण वास्तुकला

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

सबसिस्टम के प्रकार

एक प्रक्रिया नियंत्रण वास्तुकला एक होगा processing unit प्रक्रिया नियंत्रण चर और ए बदलने के लिए controller unit परिवर्तनों की मात्रा की गणना के लिए।

एक नियंत्रक इकाई में निम्नलिखित तत्व होने चाहिए -

  • Controlled Variable- नियंत्रित चर अंतर्निहित प्रणाली के लिए मूल्य प्रदान करता है और सेंसर द्वारा मापा जाना चाहिए। उदाहरण के लिए, क्रूज नियंत्रण प्रणाली में गति।

  • Input Variable- प्रक्रिया के लिए एक इनपुट को मापता है। उदाहरण के लिए, तापमान नियंत्रण प्रणाली में वापसी हवा का तापमान

  • Manipulated Variable - मैनिप्युलेटेड वेरिएबल वैल्यू को कंट्रोलर द्वारा एडजस्ट या बदला जाता है।

  • Process Definition - इसमें कुछ प्रक्रिया चर में हेरफेर करने के लिए तंत्र शामिल हैं।

  • Sensor - प्रक्रिया चर के मूल्यों को नियंत्रित करने के लिए प्रासंगिक रहता है और एक हेरफेर करने के लिए प्रतिक्रिया संदर्भ के रूप में इस्तेमाल किया जा सकता है।

  • Set Point - यह एक नियंत्रित चर के लिए वांछित मूल्य है।

  • Control Algorithm - यह तय करने के लिए प्रयोग किया जाता है कि प्रक्रिया चर को कैसे हेरफेर किया जाए।

उपयेाग क्षेत्र

प्रक्रिया नियंत्रण वास्तुकला निम्नलिखित डोमेन में उपयुक्त है -

  • एंबेडेड सिस्टम सॉफ्टवेयर डिजाइन, जहां सिस्टम को प्रक्रिया नियंत्रण चर डेटा द्वारा हेरफेर किया जाता है।

  • अनुप्रयोग, जिसका उद्देश्य दिए गए संदर्भ मूल्यों पर प्रक्रिया के आउटपुट के निर्दिष्ट गुणों को बनाए रखना है।

  • कार-क्रूज़ कंट्रोल और बिल्डिंग टेम्परेचर कंट्रोल सिस्टम के लिए लागू।

  • ऑटोमोबाइल एंटी-लॉक ब्रेक, परमाणु ऊर्जा संयंत्रों आदि को नियंत्रित करने के लिए रीयल-टाइम सिस्टम सॉफ्टवेयर।