टीएनएसडीएल

From Vigyanwiki

TNSDL का अर्थ टेलीनोकिया स्पेसिफिकेशंस एंड डिस्क्रिप्शन लैंग्वेज है, TNSDL ITU-T SDL (विशिष्टता और विवरण भाषा)-88 भाषा पर आधारित है। यह विशेष रूप से नोकिया नेटवर्क में उपयोग किया जाता है, मुख्य रूप से टेलिफ़ोन समाशोधन केंद्र के लिए एप्लिकेशन विकसित करने के लिए।

उद्देश्य

टीएनएसडीएल एक सामान्य उद्देश्य वाली प्रक्रियात्मक प्रोग्रामिंग भाषा है। यह अत्यधिक समवर्ती, वितरित प्रणालियों के विकास के लिए विशेष रूप से उपयुक्त है।[1]

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

रचना

टीएनएसडीएल एक बहुत ही सरल, सीखने में आसान प्रोग्रामिंग भाषा है।

मूल बातें

टीएनएसडीएल एक दृढ़ता से टाइप की जाने वाली प्रक्रियात्मक प्रोग्रामिंग भाषा है, इसकी मूल क्षमताएं C (प्रोग्रामिंग भाषा) और पास्कल (प्रोग्रामिंग भाषा) भाषाओं के सामान हैं।

बहु-प्रसंस्करण

TNSDL में क्रिएट कमांड द्वारा प्रोसेस बनाए जाते हैं (यह कुछ हद तक POSIX फोर्क (ऑपरेटिंग सिस्टम) या POSIX थ्रेड्स pthread_create कमांड के समान है।) CREATE कमांड या तो ऑपरेटिंग सिस्टम प्रक्रिया या सहकारी मल्टीटास्किंग बनाता है।

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

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

संदेश देना

टीएनएसडीएल की विशेषता ऐक्टर मॉडल है। प्रक्रियाओं को घटना-संचालित परिमित स्टेट मशीनों के रूप में रचना कि गई है। अंतःप्रक्रम संचार अतुल्यकालिक मैसेज पासिंग द्वारा किया जाता है। OUTPUT कमांड एक संदेश भेजता है, जबकि INPUT विवरण अपेक्षित संदेशों को परिभाषित करता है।

टीएनएसडीएल परिप्रेक्ष्य से टाइमर विलंबित संदेश हैं, सामान्य संदेशों की तरह टाइमर की समाप्ति INPUT स्टेटमेंट द्वारा नियंत्रित की जाती है। SET कमांड प्रारंभ होती है और RESET कमांड टाइमर को निरस्त कर देती है।

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

निम्नलिखित कोड भाग एक सर्वर को प्रदर्शित करता है, जो एक क्वेरी सिग्नल (संदेश) प्राप्त करता है, आवश्यक डेटा प्राप्त करने के लिए एक डेटाबेस प्रक्रिया से संपर्क करता है और अंत में एक उत्तर संकेत भेजता है।

DCL WITHWARMING /* Data to be live-migrated (on platforms supporting "warming") */
  query_process pid; /* PID of query_signal sender */

CONSTANT time_to_wait = 10; /* Timeout of database response */

TIMER db_timeout_timer; /* Timer of database response */

STATE idle; /* Idle state, wait for query signal */
  INPUT query_signal(DCL input_data);
    DCL
      db_query db_query_type;     /* Local variable, stored on stack. */
    TASK query_process := SENDER; /* Sender address saved to specific memory area, which is preserved even on software update.*/
    TASK db_query.field1 := some_procedure(input_data),
         db_query.field2 := input_data.field1;
    OUTPUT db_request_signal(db_query) TO db_process; /* Send request to database process */
    SET(NOW + time_to_wait, db_timeout_timer);        /* Start database response timer */
    NEXTSTATE wait_db;                                /* Enter wait_db state where database response is expected */
ENDSTATE idle;

STATE wait_db;
  INPUT db_response_signal(DCL answer_data);
    RESET(db_timeout_timer) COMMENT 'Database answered in time';
    OUTPUT answer_signal(answer_data.records) TO query_process;
    NEXTSTATE idle;

  INPUT db_timeout_timer; /* Timeout */
    OUTPUT error_signal(error_constant) TO query_process;
    NEXTSTATE idle;
ENDSTATE wait_db;

टिप्पणियाँ:

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

टीएनएसडीएल इनपुट को कई या सभी स्टेट से जोड़ने की अनुमति देता हैं, जरूरत पड़ने पर एक इनपुट संकेतों में स्टेट-विशिष्ट व्यवहार हो सकता है।

STATE idle COMMENT 'Idle state';
  INPUT are_you_busy;
    OUTPUT no TO SENDER;
    NEXTSTATE -; /* No state change */
  /* ... other input handlers */
ENDSTATE idle;

STATE *(idle) COMMENT 'Any state, except idle';
  INPUT are_you_busy;
    OUTPUT yes TO SENDER;
    NEXTSTATE -; /* No state change */
ENDSTATE *(idle);

STATE * COMMENT 'Any state';
  INPUT are_you_alive;
    OUTPUT yes TO SENDER;
    NEXTSTATE -; /* No state change */
ENDSTATE *;


एसडीएल-88 से अंतर

नोकिया ने भाषा में कई संशोधन किए हैं,[2] जिसमें मुख्य रूप से सरलीकरण और परिवर्धन सम्मिलित हैं, जैसे:

  • चैनल और सिग्नल रूट जैसी सुविधाओं को अन्य तंत्रों द्वारा प्रतिस्थापित किया गया है।
  • TNSDL में मॉड्यूल और सेवाओं की अवधारणाओं को जोड़ा गया था (SDL-88 की सेवा अवधारणा TNSDL की सबऑटोमेटन विशेषता के समान है)।
  • कुछ तत्वों का नाम बदल दिया गया है (उदाहरण के लिए प्राथमिकता इनपुट को टीएनएसडीएल में इनपुट आंतरिक कहा जाता है)।
  • TNSDL में MACRO फीचर को छोड़ दिया गया है और WHILE कंस्ट्रक्शन को JOINs का उपयोग किए बिना संरचित तरीके से लूप की अनुमति देने के लिए जोड़ा गया है।

संकलन

टीएनएसडीएल को सीधे मशीन कोड में संकलित नहीं किया जाता है। इसके बजाय TNSDL प्रोग्राम का C (प्रोग्रामिंग भाषा) स्रोत कोड में अनुवाद किया जाता है, टीएनएसडीएल का उत्तरदायित्व संदेश प्रबंधन, स्टेट मशीन परिभाषाओं, समांतर निष्पादन को सिंक्रनाइज़ करना, "डेटा वार्मिंग" इत्यादि को आसानी से और सुरक्षित रूप से कोडित करने की अनुमति देना है। प्रोसेसर-विशिष्ट कोड जनरेशन और निम्न-स्तरीय अनुकूलन का कार्य उपयोग किए गए C कंपाइलर को सौंपा गया है।

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

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

TNSDL अनुवादक एक सांपातिक उपकरण है, विशेष रूप से टीएनएसडीएल के लिए स्रोत कोड (पहुंच योग्यता) विश्लेषक भी विकसित किया गया है।[3]


प्रयोग करें

उच्च-निष्पादन, उच्च-उपलब्धता अनुप्रयोगों के लिए सामान्यतौर पर DX 200, IPA 2800 और Linux प्लेटफॉर्म पर TNSDL का उपयोग किया जाता है।

टीएनएसडीएल एक सक्रिय रूप से उपयोग की जाने वाली और विकसित प्रोग्रामिंग भाषा है जिसका उपयोग हजारों विकासकों (2010 में) द्वारा किया जाता है।[citation needed]

TNSDL का उपयोग मुख्य रूप से नोकिया नेटवर्क में SGSNs, BSCs, मोबाइल स्विचिंग सेंटर, एप्लिकेशन सर्वर दोनों के लिए पारंपरिक सेटअप में और नेटवर्क फ़ंक्शन वर्चुअलाइजेशन समाधानों के वर्चुअल नेटवर्क फ़ंक्शंस (VNF) के रूप में सॉफ़्टवेयर विकसित करने के लिए किया जाता है।

समान प्रोग्रामिंग भाषाएँ

सिंटैक्स में अंतर के बावजूद, संभवतः TNSDL के निकटतम सापेक्ष में से एक गो (प्रोग्रामिंग भाषा) है, दोनों भाषाओं में लाइट-वेट प्रोसेस उनके केंद्र में है। गो का चैनल टीएनएसडीएल इनपुट के समान है और चैनलों पर गो का चुनिंदा बयान बहुत समान प्रोग्रामिंग डिजाइन की अनुमति देता है हालांकि इसमें मतभेद हैं। TNSDL अभिनेताओं के बीच अतुल्यकालिक संचार संदेश का उपयोग करता है, जबकि गो में चैनल या तो तुल्यकालिक या अतुल्यकालिक (बफर) हो सकते हैं। TNSDL एक ही या अलग कंप्यूटर नोड्स पर चलने वाली प्रक्रियाओं के बीच संदेशों को भेजने की अनुमति देता है, उस पहलू में TNSDL एरलांग (प्रोग्रामिंग लैंग्वेज) का सापेक्ष है।

भले ही टीएनएसडीएल में कोई प्रचालक के प्रकारों के लिए परिभाषित कर सकता है और केवल उन प्रचालकों के माध्यम से सुलभ होने के लिए संरचना विशेषताओं की रक्षा कर सकता है, टीएनएसडीएल ऑब्जेक्ट ओरिएंटेड भाषा नहीं है। उस पहलू में यह गैर-ओओपी प्रक्रियात्मक प्रोग्रामिंग भाषाओं, जैसे C (प्रोग्रामिंग भाषा) के परिवार से संबंधित है।

इतिहास

1980 का दशक: के आरंभ में ITU-T SDL में एक ग्राफिकल सिंटैक्स था, शाब्दिक वाक्य-विन्यास बाद में प्रस्तुत किया गया था। नोकिया के भीतर एक संबंधित ग्राफिकल टूल और कोड जनरेटर विकसित किए गए थे।

1990: ITU-T SDL को पाठ-आधारित प्रतिनिधित्व की ओर स्थानांतरित किया गया, SDL-88 विशिष्टता के आधार पर TNSDL का जन्म हुआ, TNSDL SDL-88 का एक सरलीकृत और अत्यधिक अनुकूलित संस्करण है।

संदर्भ

  1. Jeannette M. Wing; Jim Woodcook; Jim Davies, eds. (1999). FM'99 - Formal Methods: World Congress on Formal Methods, 1999, Proceedings. Springer. ISBN 3540665870.
  2. Jyrinki, Tero (1997). "Dynamical analysis of SDL programs with Predicate/Transition nets". Helsinki University of Technology, Digital Systems Laboratory: 22. {{cite journal}}: Cite journal requires |journal= (help)
  3. Husberg, Nisse; Malmqvist, Markus; Jyrinki, Tero (1996). "Emma: A Tool For Analysis of SDL Programs". CiteSeerX 10.1.1.30.3240. {{cite journal}}: Cite journal requires |journal= (help)