वेरिलॉग में बिहेवियरल मॉडलिंग और टाइमिंग

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

व्यवहार मॉडल के सिमुलेशन के दौरान, 'हमेशा' और 'प्रारंभिक' बयानों द्वारा परिभाषित सभी प्रवाह सिमुलेशन समय 'शून्य' पर एक साथ शुरू होते हैं। प्रारंभिक कथनों को एक बार निष्पादित किया जाता है, और हमेशा कथनों को दोहराव से निष्पादित किया जाता है। इस मॉडल में, रजिस्टर चर a और b को बाइनरी 1 और 0 के साथ क्रमशः सिमुलेशन टाइम 'शून्य' पर आरंभीकृत किया जाता है। प्रारंभिक विवरण तब पूरा हो जाता है और उस सिमुलेशन रन के दौरान फिर से निष्पादित नहीं किया जाता है। इस प्रारंभिक बयान में स्टेटमेंट्स का शुरुआती-अंत ब्लॉक (जिसे अनुक्रमिक ब्लॉक भी कहा जाता है) शामिल है। इस शुरुआत के अंत प्रकार में ब्लॉक, एक शुरू में पहले बी द्वारा पीछा किया जाता है।

व्यवहार मॉडलिंग का उदाहरण

module behave; 
reg [1:0]a,b; 

initial 
begin 
   a = ’b1; 
   b = ’b0; 
end 

always 
begin 
   #50 a = ~a; 
end 

always 
begin 
   #100 b = ~b; 
end 
End module

प्रक्रियात्मक असाइनमेंट

प्रक्रियात्मक असाइनमेंट reg, पूर्णांक, समय और मेमोरी चर को अपडेट करने के लिए हैं। प्रक्रियात्मक असाइनमेंट और निरंतर असाइनमेंट के बीच एक महत्वपूर्ण अंतर है जैसा कि नीचे वर्णित है -

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

प्रक्रियात्मक असाइनमेंट प्रक्रियागत प्रवाह के नियंत्रण के तहत रजिस्टर चर के मूल्य को अपडेट करते हैं जो उन्हें घेरते हैं।

एक प्रक्रियात्मक असाइनमेंट का दाहिना हाथ किसी भी अभिव्यक्ति हो सकता है जो एक मूल्य का मूल्यांकन करता है। हालांकि, दाएं हाथ की ओर के भाग का चयन निरंतर सूचक होना चाहिए। बाईं ओर का पक्ष उस चर को दर्शाता है जो दाएं हाथ से असाइनमेंट प्राप्त करता है। एक प्रक्रियात्मक असाइनमेंट का बायां हाथ निम्नलिखित रूपों में से एक ले सकता है -

  • रजिस्टर, पूर्णांक, वास्तविक या समय चर - इन डेटा प्रकारों में से एक के नाम संदर्भ के लिए एक असाइनमेंट।

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

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

  • स्मृति तत्व - एक स्मृति का एक शब्द। ध्यान दें कि बिट-चयन और भाग-चयन मेमोरी तत्व संदर्भों पर अवैध हैं।

  • उपर्युक्त में से किसी का भी संघटन - पिछले चार रूपों में से किसी का एक संघटन निर्दिष्ट किया जा सकता है, जो प्रभावी रूप से दाएं हाथ की अभिव्यक्ति के परिणाम को विभाजित करता है और विभाजन के विभिन्न भागों को क्रम में, विभाजन भागों को असाइन करता है।

असाइनमेंट में देरी (संश्लेषण के लिए नहीं)

विलंबित असाइनमेंट में स्टेटमेंट निष्पादित होने से पहले समय इकाइयों को पास किया जाता है और लेफ्टहैंड असाइनमेंट बनाया जाता है। इंट्रा-असाइनमेंट देरी के साथ, दाएं पक्ष का तुरंत मूल्यांकन किया जाता है, लेकिन परिणाम बाएं हाथ के असाइनमेंट में जगह देने से पहले mentt की देरी है। यदि कोई अन्य प्रक्रिया itt के दौरान राइट-हैंड साइड सिग्नल बदलती है, तो यह आउटपुट को प्रभावित नहीं करता है। विलंब संश्लेषण उपकरणों द्वारा समर्थित नहीं हैं।

वाक्य - विन्यास

  • Procedural Assignmentचर = अभिव्यक्ति

  • Delayed assignment# #T चर = अभिव्यक्ति;

  • Intra-assignment delayचर = # =t अभिव्यक्ति;

उदाहरण

reg [6:0] sum; reg h, ziltch; 
sum[7] = b[7] ^ c[7]; // execute now. 
ziltch = #15 ckz&h; /* ckz&a evaluated now; ziltch changed 
after 15 time units. */ 

#10 hat = b&c; /* 10 units after ziltch changes, b&c is
evaluated and hat changes. */

असाइनमेंट को अवरुद्ध करना

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

वाक्य - विन्यास

एक अवरुद्ध प्रक्रियात्मक असाइनमेंट के लिए सिंटैक्स निम्नानुसार है -

<lvalue> = <timing_control> <expression>

जहां, लवल्यू एक डेटा प्रकार है जो एक प्रक्रियात्मक असाइनमेंट स्टेटमेंट के लिए मान्य है, = असाइनमेंट ऑपरेटर है, और टाइमिंग कंट्रोल वैकल्पिक इंट्रा असाइनमेंट देरी है। समय नियंत्रण देरी या तो देरी नियंत्रण हो सकता है (उदाहरण के लिए, # 6) या एक घटना नियंत्रण (उदाहरण के लिए, @ (posedge clk))। अभिव्यक्ति दायीं ओर का मूल्य है जो सिम्युलेटर बाईं ओर की ओर स्थित है। प्रक्रियात्मक असाइनमेंट को अवरुद्ध करके उपयोग किए जाने वाले = असाइनमेंट ऑपरेटर का उपयोग प्रक्रियात्मक निरंतर असाइनमेंट और निरंतर असाइनमेंट द्वारा भी किया जाता है।

उदाहरण

rega = 0; 
rega[3] = 1;            // a bit-select 
rega[3:5] = 7;          // a part-select 
mema[address] = 8’hff;  // assignment to a memory element 
{carry, acc} = rega + regb;  // a concatenation

नॉनब्लॉकिंग (आरटीएल) असाइनमेंट

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

वाक्य - विन्यास

गैर-अवरुद्ध प्रक्रियात्मक असाइनमेंट के लिए सिंटैक्स निम्नानुसार है -

<lvalue> <= <timing_control> <expression>

जहां लैवल्यू एक डेटा प्रकार है जो एक प्रक्रियात्मक असाइनमेंट स्टेटमेंट के लिए मान्य है, <= नॉन-ब्लॉकिंग असाइनमेंट ऑपरेटर है, और टाइमिंग कंट्रोल वैकल्पिक इंट्रा-असाइनमेंट टाइमिंग कंट्रोल है। समय पर नियंत्रण में देरी या तो विलंब नियंत्रण या इवेंट नियंत्रण (उदाहरण के लिए, @ (posedge clk)) हो सकती है। दायें हाथ की ओर स्थित भाव दायीं ओर है जो सिम्युलेटर बाईं ओर की ओर स्थित है। नॉन-ब्लॉकिंग असाइनमेंट ऑपरेटर वही ऑपरेटर है जो सिम्युलेटर कम-से-असमान रिलेशनल ऑपरेटर के लिए उपयोग करता है। सिमुलेटर <= ऑपरेटर को एक रिलेशनल ऑपरेटर होने की व्याख्या करता है जब आप इसे एक अभिव्यक्ति में उपयोग करते हैं, और जब आप इसे गैर-अवरुद्ध प्रक्रियात्मक असाइनमेंट निर्माण में उपयोग करते हैं, तो असाइनमेंट ऑपरेटर होने के लिए <= ऑपरेटर की व्याख्या करता है।

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

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

  • समय कदम के अंत में, जिसमें दी गई देरी समाप्त हो गई है या उपयुक्त घटना हुई है, सिम्युलेटर बाईं ओर के मूल्य को असाइन करके असाइनमेंट को निष्पादित करता है।

उदाहरण

module evaluates2(out); 
output out; 
reg a, b, c; 
initial 

begin 
   a = 0; 
   b = 1; 
   c = 0; 
end 
always c = #5 ~c; 
always @(posedge c) 

begin 
   a <= b; 
   b <= a; 
end 
endmodule

शर्तेँ

सशर्त विवरण (या अगर-और स्टेटमेंट) का उपयोग किसी निर्णय को निष्पादित करने के लिए किया जाता है या नहीं।

औपचारिक रूप से, वाक्य रचना इस प्रकार है -

<statement> 
::= if ( <expression> ) <statement_or_null> 
||= if ( <expression> ) <statement_or_null> 
   else <statement_or_null> 
<statement_or_null> 

::= <statement> 
||= ;

<अभिव्यक्ति> का मूल्यांकन किया जाता है; यदि यह सत्य है (जिसका गैर-शून्य ज्ञात मान है), तो पहला कथन निष्पादित होता है। यदि यह गलत है (शून्य मान या मान x या z है), तो पहला कथन निष्पादित नहीं करता है। यदि कोई और कथन है और <अभिव्यक्ति> गलत है, तो दूसरा कथन निष्पादित होता है। चूंकि, शून्य होने के लिए यदि अभिव्यक्ति के संख्यात्मक मान का परीक्षण किया जाता है, तो कुछ शॉर्टकट संभव हैं।

उदाहरण के लिए, निम्नलिखित दो कथन एक ही तर्क व्यक्त करते हैं -

if (expression) 
if (expression != 0)

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

उदाहरण

if (index > 0) 
if (rega > regb) 
   result = rega; 
   else // else applies to preceding if 
   result = regb; 

If that association is not what you want, use a begin-end block statement 
to force the proper association 

if (index > 0) 
begin 

if (rega > regb) 
result = rega; 
end 
   else 
   result = regb;

का निर्माण: अगर- और- अगर

निम्नलिखित निर्माण इतनी बार होता है कि यह एक अलग चर्चा के लायक है।

Example

if (<expression>) 
   <statement> 
   else if (<expression>) 
   <statement> 
   else if (<expression>) 
   <statement> 
   else  
   <statement>

If's का यह क्रम (जिसे if-else-if निर्माण के रूप में जाना जाता है) मल्टी-वे निर्णय लिखने का सबसे सामान्य तरीका है। अभिव्यक्तियों का क्रम में मूल्यांकन किया जाता है; यदि कोई भी अभिव्यक्ति सही है, तो उससे जुड़े कथन को निष्पादित किया जाता है, और यह पूरी श्रृंखला को समाप्त कर देता है। प्रत्येक बयान या तो एक बयान या बयानों का एक ब्लॉक है।

अगर-और-अगर निर्माण का अंतिम हिस्सा 'उपरोक्त में से कोई नहीं' या डिफ़ॉल्ट केस को संभालता है, जहां अन्य शर्तों में से कोई भी संतुष्ट नहीं था। कभी-कभी डिफ़ॉल्ट के लिए कोई स्पष्ट कार्रवाई नहीं होती है; उस स्थिति में, अनुगामी को छोड़ा जा सकता है या इसका उपयोग किसी असंभव स्थिति को पकड़ने के लिए त्रुटि जाँच के लिए किया जा सकता है।

केस का बयान

केस स्टेटमेंट एक विशेष बहु-प्रकार का निर्णय कथन है जो यह परखता है कि क्या एक अभिव्यक्ति कई अन्य अभिव्यक्तियों में से एक से मेल खाती है, और तदनुसार शाखाएं। उदाहरण के लिए केस स्टेटमेंट उपयोगी है, उदाहरण के लिए, माइक्रोप्रोसेसर इंस्ट्रक्शन का डिकोडिंग। केस स्टेटमेंट में निम्नलिखित सिंटैक्स है -

Example

<statement> 
::= case ( <expression> ) <case_item>+ endcase 
||= casez ( <expression> ) <case_item>+ endcase 
||= casex ( <expression> ) <case_item>+ endcase 
<case_item> 
::= <expression> <,<expression>>* : <statement_or_null> 
||= default : <statement_or_null> 
||= default <statement_or_null>

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

सिंटैक्स के अलावा, केस स्टेटमेंट मल्टी-वे से भिन्न होता है अगर-और-अगर दो महत्वपूर्ण तरीकों से निर्माण होता है -

  • अगर-और-अगर निर्माण में सशर्त अभिव्यक्तियाँ एक अभिव्यक्ति की तुलना में कई अन्य के साथ सामान्य हैं, जैसा कि केस स्टेटमेंट में किया गया है।

  • जब एक एक्सप्रेशन में एक्स और जेड मान होते हैं तो केस स्टेटमेंट एक निश्चित परिणाम प्रदान करता है।

लूपिंग स्टेटमेंट्स

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

  • हमेशा लगातार एक बयान पर अमल करता है।

  • रिपीट एक स्टेटमेंट को कई बार तय करता है।

  • किसी कथन को तब तक क्रियान्वित करता है जब तक कि कोई अभिव्यक्ति झूठी न हो जाए। यदि अभिव्यक्ति गलत है, तो कथन को बिल्कुल भी निष्पादित नहीं किया जाता है।

  • तीन-चरणीय प्रक्रिया द्वारा इसके संबद्ध कथन के निष्पादन को नियंत्रित करने के लिए, निम्नानुसार है -

    • एक असाइनमेंट को निष्पादित करता है जो आमतौर पर एक वैरिएबल को इनिशियलाइज़ करने के लिए उपयोग किया जाता है जो निष्पादित छोरों की संख्या को नियंत्रित करता है

    • एक अभिव्यक्ति का मूल्यांकन करता है - यदि परिणाम शून्य है, तो लूप से बाहर निकलता है, और यदि यह शून्य नहीं है, तो लूप अपने संबद्ध विवरण को निष्पादित करता है और फिर चरण 3 निष्पादित करता है

    • आम तौर पर लूपकंट्रोल चर के मूल्य को संशोधित करने के लिए उपयोग किए जाने वाले असाइनमेंट को निष्पादित करता है, फिर चरण 2 को दोहराता है

लूपिंग स्टेटमेंट के लिए वाक्यविन्यास नियम निम्नलिखित हैं -

Example

<statement> 
::= forever <statement> 
||=forever 
begin 
   <statement>+ 
end  

<Statement> 
::= repeat ( <expression> ) <statement> 
||=repeat ( <expression> ) 
begin
   <statement>+ 
end  

<statement> 
::= while ( <expression> ) <statement> 
||=while ( <expression> ) 
begin 
   <statement>+ 
end  
<statement> 
::= for ( <assignment> ; <expression> ; <assignment> ) 
<statement> 
||=for ( <assignment> ; <expression> ; <assignment> ) 
begin 
   <statement>+ 
end

देरी नियंत्रण

देरी नियंत्रण

एक प्रक्रियात्मक कथन का निष्पादन निम्नलिखित सिंटैक्स का उपयोग करके विलंब-नियंत्रित किया जा सकता है -

<statement> 
::= <delay_control> <statement_or_null> 
<delay_control> 
::= # <NUMBER> 
||= # <identifier> 
||= # ( <mintypmax_expression> )

निम्नलिखित उदाहरण 10 समय इकाइयों द्वारा असाइनमेंट के निष्पादन में देरी करता है -

# 10 rega = regb;

अगले तीन उदाहरण संख्या संकेत (#) के बाद एक अभिव्यक्ति प्रदान करते हैं। अभिव्यक्ति के मूल्य द्वारा निर्दिष्ट सिमुलेशन समय की मात्रा से असाइनमेंट की देरी।

घटना नियंत्रण

निम्नलिखित प्रक्रिया नियंत्रण सिंटैक्स का उपयोग करके एक प्रक्रियात्मक कथन का निष्पादन एक नेट या रजिस्टर पर एक मूल्य परिवर्तन, या एक घोषित घटना की घटना के साथ सिंक्रनाइज़ किया जा सकता है -

Example

<statement> 
::= <event_control> <statement_or_null> 

<event_control> 
::= @ <identifier> 
||= @ ( <event_expression> ) 

<event_expression> 
::= <expression> 
||= posedge <SCALAR_EVENT_EXPRESSION> 
||= negedge <SCALAR_EVENT_EXPRESSION> 
||= <event_expression> <or <event_expression>>

* <SCALAR_EVENT_EXPRESSION> एक ऐसी अभिव्यक्ति है जो एक बिट मान का समाधान करती है।

नेट और रजिस्टरों पर मूल्य परिवर्तन का उपयोग घटनाओं के रूप में एक बयान के निष्पादन को गति प्रदान करने के लिए किया जा सकता है। यह एक अंतर्निहित घटना का पता लगाने के रूप में जाना जाता है। वेरिलॉग सिंटैक्स आपको परिवर्तन की दिशा के आधार पर परिवर्तन का पता लगाने की अनुमति देता है - अर्थात, मान 1 (posedge) या मान 0 (negedge) की ओर। अज्ञात अभिव्यक्ति मूल्यों के लिए posedge और negedge का व्यवहार इस प्रकार है -

  • 1 से अज्ञात और अज्ञात से 0 तक के संक्रमण पर एक निगेज का पता लगाया जाता है
  • 0 से अज्ञात और अज्ञात से 1 तक संक्रमण पर एक posedge का पता लगाया जाता है

प्रक्रियाएं: हमेशा और प्रारंभिक ब्लॉक

वेरिलॉग में सभी प्रक्रियाएँ निम्नलिखित चार ब्लॉकों में से एक के भीतर निर्दिष्ट की जाती हैं। 1) प्रारंभिक ब्लॉक 2) हमेशा 3 ब्लॉक) टास्क 4) फ़ंक्शन

सिमुलेशन की शुरुआत में शुरुआती और हमेशा बयान सक्षम होते हैं। प्रारंभिक ब्लॉक केवल एक बार निष्पादित होता है और जब वक्तव्य समाप्त हो जाता है तो इसकी गतिविधि मर जाती है। इसके विपरीत, हमेशा ब्लॉक बार-बार निष्पादित होता है। इसकी गतिविधि केवल तब ही मर जाती है जब अनुकरण समाप्त हो जाता है। प्रारंभिक और हमेशा ब्लॉक की संख्या की कोई सीमा नहीं है जिसे एक मॉड्यूल में परिभाषित किया जा सकता है। कार्य और कार्य ऐसी प्रक्रियाएं हैं जो अन्य प्रक्रियाओं में एक या अधिक स्थानों से सक्षम होती हैं।

प्रारंभिक ब्लॉक

प्रारंभिक कथन का वाक्य विन्यास इस प्रकार है -

<initial_statement> 
::= initial <statement>

निम्नलिखित उदाहरण सिमुलेशन की शुरुआत में चर के आरंभ के लिए प्रारंभिक बयान के उपयोग को दर्शाता है।

Initial 
Begin 
   Areg = 0; // initialize a register 
   For (index = 0; index < size; index = index + 1) 
   Memory [index] = 0; //initialize a memory 
   Word 
End

प्रारंभिक ब्लॉक का एक और विशिष्ट उपयोग तरंग विवरणों की विशिष्टता है जो सर्किट के मुख्य भाग को उत्तेजना प्रदान करने के लिए एक बार निष्पादित करते हैं।

Initial 
Begin 
   Inputs = ’b000000; 
   // initialize at time zero 
   #10 inputs = ’b011001; // first pattern 
   #10 inputs = ’b011011; // second pattern 
   #10 inputs = ’b011000; // third pattern 
   #10 inputs = ’b001000; // last pattern 
End

हमेशा ब्लॉक

'हमेशा' कथन पूरे सिमुलेशन रन में लगातार दोहराता है। हमेशा बयान के लिए वाक्यविन्यास नीचे दिया गया है

<always_statement> 
::= always <statement>

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

Always areg = ~areg;

उपरोक्त कोड के लिए एक समय पर नियंत्रण प्रदान करना एक संभावित उपयोगी विवरण बनाता है - निम्न उदाहरण में -

Always #half_period areg = ~areg;