वेरिलॉग में बिहेवियरल मॉडलिंग और टाइमिंग
वेरिलोग में व्यवहार मॉडल में प्रक्रियात्मक बयान होते हैं, जो डेटा प्रकारों के सिमुलेशन और हेरफेर को नियंत्रित करते हैं। ये सभी कथन प्रक्रियाओं के भीतर निहित हैं। प्रत्येक प्रक्रिया में इसके साथ एक गतिविधि प्रवाह जुड़ा हुआ है।
व्यवहार मॉडल के सिमुलेशन के दौरान, 'हमेशा' और 'प्रारंभिक' बयानों द्वारा परिभाषित सभी प्रवाह सिमुलेशन समय 'शून्य' पर एक साथ शुरू होते हैं। प्रारंभिक कथनों को एक बार निष्पादित किया जाता है, और हमेशा कथनों को दोहराव से निष्पादित किया जाता है। इस मॉडल में, रजिस्टर चर 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;