विषयसूची:
![वीएचडीएल में मास्टरमाइंड गेम: 3 चरण वीएचडीएल में मास्टरमाइंड गेम: 3 चरण](https://i.howwhatproduce.com/images/001/image-75-78-j.webp)
वीडियो: वीएचडीएल में मास्टरमाइंड गेम: 3 चरण
![वीडियो: वीएचडीएल में मास्टरमाइंड गेम: 3 चरण वीडियो: वीएचडीएल में मास्टरमाइंड गेम: 3 चरण](https://i.ytimg.com/vi/i-95AJHroRA/hqdefault.jpg)
2024 लेखक: John Day | [email protected]. अंतिम बार संशोधित: 2024-01-30 09:22
![VHDL. में मास्टरमाइंड गेम VHDL. में मास्टरमाइंड गेम](https://i.howwhatproduce.com/images/001/image-75-79-j.webp)
![VHDL. में मास्टरमाइंड गेम VHDL. में मास्टरमाइंड गेम](https://i.howwhatproduce.com/images/001/image-75-80-j.webp)
हमारे प्रोजेक्ट के लिए, हमने बेसिस3 बोर्ड पर खेले जाने वाले वीएचडीएल में "मास्टरमाइंड" गेम बनाया। मास्टरमाइंड पारंपरिक रूप से खूंटे और एक गेम बोर्ड के साथ खेला जाने वाला एक कोड-ब्रेकिंग गेम है। खिलाड़ी एक खिलाड़ी दो से छिपे हुए 4 की एक पंक्ति में मिश्रित रंगों के खूंटे रखता है। खिलाड़ी दो के पास बोर्ड पर खूंटे रखने के अनुमानों की संख्या 'x' होती है, जो खिलाड़ी एक को दिखाई देती है। प्रत्येक अनुमान के बाद, खिलाड़ी दो को 2 संख्याओं के बारे में सूचित किया जाता है: कितने खूंटे सही रंग हैं, और कितने खूंटे पंक्ति में सही स्थिति में हैं। उन सुरागों का उपयोग करते हुए, खिलाड़ी दो को पिन के सही क्रम का अनुमान लगाना चाहिए, जिसे खिलाड़ी ने आवंटित संख्या अनुमान में रखा है।
हमारे कार्यान्वयन में, खेल एकल खिलाड़ी है। प्रोग्राम द्वारा खूंटे का एक यादृच्छिक संयोजन उत्पन्न किया जाता है, और खिलाड़ी को सही क्रम का अनुमान लगाने के लिए बेसिस 3 बोर्ड का उपयोग करना चाहिए। बाइनरी मानों द्वारा दर्शाए गए चार "रंग" हैं। 7-सेगमेंट डिस्प्ले तीन मान दिखाता है: शेष घुमाव, सही स्थिति में पिन की संख्या, और पिन की संख्या जो गलत स्थिति में सही रंग हैं (ये मान 9, 0 और 0 से शुरू होते हैं)। खिलाड़ी अपने अनुमान के लिए बाइनरी मानों का चयन करने के लिए बोर्ड पर स्विच का उपयोग करता है, और अनुमान जमा करने के लिए एक और स्विच फ़्लिप करता है। यदि वे सही हैं, तो गेम समाप्त हो जाता है और 7-सेगमेंट डिस्प्ले "GG" दिखाता है। यदि नहीं, तो टर्न काउंटर 1 से कम हो जाता है और खिलाड़ी इस आधार पर फीडबैक प्राप्त करता है कि उनके अनुमान में कितने पिन संयोजन में पिन के रंग या स्थिति से मेल खाते हैं। यदि खिलाड़ी सही ढंग से अनुमान लगाए बिना मोड़ से बाहर निकलता है, तो डिस्प्ले "GO" (गेम ओवर का प्रतिनिधित्व) दिखाता है। खिलाड़ी किसी भी समय शुरू करने के लिए रीसेट स्विच को फ्लिप भी कर सकता है।
चरण 1: सामग्री
![सामग्री सामग्री](https://i.howwhatproduce.com/images/001/image-75-81-j.webp)
![सामग्री सामग्री](https://i.howwhatproduce.com/images/001/image-75-82-j.webp)
![सामग्री सामग्री](https://i.howwhatproduce.com/images/001/image-75-83-j.webp)
चूंकि पूरा गेम बोर्ड पर ही खेला जा सकता है, केवल आवश्यक सामग्री बेसिस 3 बोर्ड, बोर्ड से कनेक्ट करने के लिए एक माइक्रो यूएसबी केबल, और एक कंप्यूटर/लैपटॉप है जिसे आप कोड करने के लिए उपयोग कर सकते हैं!
चरण 2: कोड
![कोड कोड](https://i.howwhatproduce.com/images/001/image-75-84-j.webp)
![कोड कोड](https://i.howwhatproduce.com/images/001/image-75-85-j.webp)
इस गेम को FPGA पर काम करने के लिए, इसे लिखने का सबसे आसान तरीका एक स्टेट मशीन बनाना होगा। एक राज्य मशीन होने से खेल को वास्तव में काम करने के लिए आवश्यक अनुक्रमिक और इंटरैक्टिव अनुभव की अनुमति मिलती है। सब कुछ सुचारू रूप से चलाने के लिए, स्टेट मशीन FPGA के आंतरिक क्लॉक सिग्नल पर आधारित होगी, यह सुनिश्चित करते हुए कि सब कुछ सिंक में है। मुख्य मॉड्यूल चार राज्यों के साथ एक राज्य मशीन है; प्रारंभिक स्थिति (आरंभिक), सबमिट उत्तर राज्य (सबअन्स), डिस्प्ले स्टेट (डिस), और चेकएंडगेम स्टेट (चेकएंड)। स्टेट मशीन के साथ, मुख्य मॉड्यूल में दो सबमॉड्यूल होते हैं, एक 4-अंकों वाला सेवन सेगमेंट डिस्प्ले (जिसका अपना ClkDivider सबमॉड्यूल होता है), और रैंडम नंबर जेनरेटर (वास्तव में एक छद्म-यादृच्छिक संख्या जनरेटर)। लोगों के लिए यह देखने के लिए कि वे क्या आसान इनपुट कर रहे हैं, स्विच ऑन करने पर प्रत्येक स्विच के ऊपर एलईडी को चालू करने के लिए एक बुनियादी प्रक्रिया ब्लॉक भी है। कोड का एक मूल अवलोकन चित्र में दिए गए माइंड मैप में देखा जा सकता है।
देखने वाला पहला घटक रैंडम नंबर जेनरेटर (रैंडमजेन) है। चूंकि हार्डवेयर से उत्पन्न वास्तविक यादृच्छिक संख्या प्राप्त करना तकनीकी रूप से संभव नहीं है, इसलिए सबसे सरल उपाय यह था कि रैंडमजेन वास्तव में एक लीनियर-फीडबैक शिफ्ट रजिस्टर (एलएफएसआर) हो। LFSR में clk का इनपुट और आउटपुट "a" (एक 12-बिट संख्या) होता है। प्रत्येक घड़ी चक्र, "000000000001" से शुरू होकर एक नया 12-बिट नंबर उत्पन्न होता है, अंततः खुद को दोहराने से पहले 1 और 0 के 12-बिट्स के सभी संयोजनों के माध्यम से जा रहा है। आउटपुट "ए" हर घड़ी चक्र दिया जाता है, इसलिए यह लगातार चल रहा है। Clk को मुख्य मॉड्यूल से Clk में मैप किया जाता है, और "a" को मुख्य मॉड्यूल में RandNum सिग्नल में मैप किया जाता है।
दूसरा सबमॉड्यूल 4-अंकों वाला सेवन सेगमेंट डिस्प्ले है। यह 4-अंकीय सात खंड प्रदर्शन प्रदर्शित करने का एक बहुत ही सरल तरीका है। डिस्प्ले मुख्य मॉड्यूल से Clk पर सेट है, फिर भी इस सबमॉड्यूल में ClkDivider का अपना सबमॉड्यूल है। ClkDivider (1298 Hz पर सेट) का उपयोग सेवन सेगमेंट के लिए घड़ी को गति देने के लिए किया जाता है ताकि सभी अंक एक ही समय पर दिखाई दें (क्योंकि वास्तव में एक समय में केवल एक अंक ही चालू हो सकता है)। वेरिएबल "डिजिट" का उपयोग डिस्प्ले पर स्पॉट के माध्यम से साइकिल चलाने के लिए किया जाता है, और प्रत्येक अंक के साथ मूल 4-बिट इनपुट डिस्प्ले की शर्तें आती हैं, जिसमें 0 से 9 अंक दिखाने के विकल्प होते हैं और कुछ भी नहीं। डिस्प्ले पर सबसे दूर का बायां अंक शून्य पर सेट है क्योंकि इस गेम में इसका उपयोग नहीं किया जाता है।
मुख्य मॉड्यूल में राज्य मशीन शामिल है। इस प्रक्रिया में चार अवस्थाएँ प्रारंभिक, SubAns, Dis, और CheckEnd हैं। जब प्रारंभिक अवस्था में, यदि सबमिटबीटीएन (चेकिंग के लिए आपके उत्तर को सबमिट करने के लिए इस्तेमाल किया जाने वाला स्विच) '1' पर सेट है, तो मशीन SubAns State में चली जाती है। कभी भी Rbtn (मशीन को रीसेट करने के लिए प्रयुक्त स्विच) को '1' पर सेट किया जाता है, फिर मशीन प्रारंभिक स्थिति में वापस आ जाती है। जब SubAns State में, जब SubmitBtn = '0' फिर से, यह Dis State में चला जाता है। जब डिस स्टेट में, यदि काउंटडाउन = 0 (अनुमान लगाने के लिए बाएं मुड़ें 0 पर गिरते हैं) या यदि RSpotCount = 4 (जिसका अर्थ है कि खिलाड़ी सही स्थानों पर सभी सही रंगों के रूप में), तो मशीन चेकएंड स्टेट में जाती है। यदि इनमें से कोई भी नहीं होता है, तो जब सबमिटबीटीएन = '1' फिर से होता है, तो यह एक और अनुमान लगाने की अनुमति देने के लिए सबअन्स स्थिति में वापस चला जाता है। जब चेकएंड स्थिति में, यह खेल का अंत होता है, और रीसेट को हिट करने का एकमात्र तरीका है, इसे प्रारंभिक स्थिति में वापस करना। यह स्टेट मशीन डायग्राम में आसानी से देखा जा सकता है। व्यवहारिक रूप से प्रारंभिक राज्य सब कुछ वापस प्रारंभिक स्थिति में शुरू करता है। उलटी गिनती (सिग्नल जो बचाता है कि खिलाड़ी के पास कितने मोड़ बचे हैं) को 9 पर सेट किया गया है, RSpotCount (सिग्नल जो बचाता है कि आपके द्वारा अनुमान लगाए गए कितने रंग सही जगह पर हैं) 0 पर सेट है, RColorCount (सिग्नल जो बचाता है कि कितने आपके द्वारा अनुमान लगाए गए रंग सही हैं लेकिन गलत जगह पर हैं) 0 पर सेट है, और छोटी उलटी गिनती (संकेत जो अंततः उलटी गिनती में मैप की जाती है जो वास्तव में बाद के राज्यों में प्रत्येक मोड़ को बदल देती है) को 9 पर सेट किया जाता है। इसके अलावा, प्रारंभिक स्थिति में रैंडनम (छद्म-यादृच्छिक उत्पन्न संख्या) चार अलग-अलग चेक (प्रत्येक 3-बिट रंग के लिए एक) में विभाजित है और सिग्नल चेक 1, चेक 2, चेक 3, चेक 4 में सहेजा गया है। ये चेक वही हैं जो आपके अनुमान से वास्तव में तुलना की जाती है, इसलिए भले ही LFSR हमेशा RandNum को हर चक्र को बदलने का कारण बना रहा हो, एक बार जब आप प्रारंभिक स्थिति छोड़ देते हैं तो चेक वही रहते हैं, जिससे सहेजे गए मान को आपके उत्तर की तुलना करने की अनुमति मिलती है। इसका मतलब यह भी है कि जब भी मशीन रीसेट हो जाती है, तो खिलाड़ी के पास अनुमान लगाने के लिए एक नया मूल्य होता है।
सबमिटअंसर स्टेट (SubAns) काउंटडाउन एनेबलर (सिग्नल "चेंज") को '1' में बदल देता है। टर्न ट्रैकिंग के काम करने के लिए बाद में इसकी आवश्यकता होती है। उसके बाद, राज्य स्विच से खिलाड़ी इनपुट की तुलना उपरोक्त राज्य में किए गए चेक से करता है। सिग्नल rs1, rs2, rs3, rs4 और सिग्नल rc1, rc2, rc3, rc4 पूर्णांक प्रकार हैं जो कि if स्टेटमेंट के आधार पर या तो 1 या 0 पर सेट होते हैं। सिग्नल rs सही जगह के लिए होते हैं और rc सही रंग के लिए होते हैं। उदाहरण के लिए यदि रंग 1 खिलाड़ी का अनुमान RandNum के चेक1 के बराबर है, तो rs1 = 1 क्योंकि इसका मतलब है कि सही रंग सही जगह पर है। यदि रंग 1 चेक 1 के बराबर नहीं है, लेकिन अन्य चेकों में से एक के बराबर है, तो आरसी = 1। यह प्रत्येक रंग और प्रत्येक चेक के लिए किया जाता है।
डिस्प्ले स्टेट (डिस) सबसे पहले काउंटडाउन एनेबलर की तलाश करता है। यदि यह '1' है, तो छोटी उलटी गिनती 1 नीचे जाती है (इसलिए पहली बारी पर यह 9 से 8 आदि तक जाती है)। नहीं तो मोड़ नहीं बदलता। इसके बावजूद, ऊपर से सभी rs मान जोड़े जाते हैं और RSpotCounter को सिग्नल करने के लिए असाइन किए जाते हैं। साथ ही सभी rc मान जोड़े जाते हैं और RColorCounter को असाइन किए जाते हैं। अंत में उलटी गिनती को छोटे उलटी गिनती का मूल्य सौंपा गया है। सिग्नल RSpotCounter, RColorCounter, और काउंटडाउन सभी प्रक्रिया के बाहर 4-बिट std_logic_vectors में परिवर्तित हो जाते हैं, और पोर्ट मैप के माध्यम से सेवन सेगमेंट डिस्प्ले सबमॉड्यूल में धकेल दिए जाते हैं। इस तरह, जब तक आप कोई नया उत्तर सबमिट नहीं करते, तब तक प्रदर्शन सही चीज़ें दिखाता है।
चेकएंड स्टेट इस बात के लिए है कि आप जीते हैं या हारे हैं। यदि आप जीत गए हैं (सभी 4 रंग सही जगह पर हैं, अन्यथा RSpotCounter = 4 के रूप में जाना जाता है), तो "GG" (तकनीकी रूप से 66 के रूप में दिखाया गया है) यह दिखाने के लिए सात खंड पर प्रदर्शित होता है कि आप जीत गए हैं। यदि आप हार गए हैं (काउंटडाउन 0 तक पहुंच गया है) तो गेम ओवर के डिस्प्ले पर "GO" (तकनीकी रूप से 60 के रूप में दिखाया गया है) प्रदर्शित होता है। किसी भी परिणाम के साथ, रीसेट स्विच को चालू करने से मशीन फिर से खेलने के लिए प्रारंभिक स्थिति में वापस आ जाएगी।
स्रोत कोड यहां पाया जा सकता है।
चरण 3: निष्कर्ष
![](https://i.ytimg.com/vi/y-qHxI7hoYc/hqdefault.jpg)
इस परियोजना को पूरा करने से हमें अधिक जटिल सर्किट बनाने के बारे में बहुत कुछ सिखाया गया। हमारा प्रारंभिक डिजाइन एक परिमित राज्य मशीन नहीं था। हमें अलग-अलग तरीकों (FSM सहित) का उपयोग करके कई बार डिबग करना और कोड को फिर से लिखना मुश्किल लगा। प्रशिक्षक के सुझाव पर, हम FSM दृष्टिकोण से चिपके रहे और हम खेल को समाप्त करने में सक्षम थे। हमने सीखा कि पारंपरिक प्रोग्रामिंग दृष्टिकोण की तुलना में हार्डवेयर के आधार पर कोड को डिजाइन करना अधिक प्रभावी है। हमें सेवन सेगमेंट डिस्प्ले से जुड़ी कई चुनौतियों का भी सामना करना पड़ा। इसे "भूत" के बिना कई नंबर प्रदर्शित करना मुश्किल था, और हमें इसे पूरा करने के लिए एक घड़ी विभाजक का उपयोग करना पड़ा। यदि हम इस परियोजना को और विकसित करना चाहते हैं, तो हम रंगीन एल ई डी को बेसिस 3 से जोड़ देंगे ताकि उपयोगकर्ता रंगों के संख्यात्मक प्रतिनिधित्व के बजाय रंग (पारंपरिक खेल की तरह) देख सकें। अंततः, हमने जटिल सर्किट डिज़ाइन, वास्तविक जीवन अनुप्रयोगों और हार्डवेयर का उपयोग करने की चुनौतियों के बारे में अधिक समझ प्राप्त की, बजाय सही परिस्थितियों के साथ सिमुलेशन चलाने के।
सिफारिश की:
फ़्लिक में गेम डिज़ाइन ५ चरणों में: ५ चरण
![फ़्लिक में गेम डिज़ाइन ५ चरणों में: ५ चरण फ़्लिक में गेम डिज़ाइन ५ चरणों में: ५ चरण](https://i.howwhatproduce.com/images/001/image-2360-j.webp)
5 चरणों में फ़्लिक में गेम डिज़ाइन: फ़्लिक गेम बनाने का एक बहुत ही सरल तरीका है, विशेष रूप से एक पहेली, दृश्य उपन्यास, या साहसिक खेल जैसा कुछ
Arduino ISP के रूप में -- AVR में बर्न हेक्स फ़ाइल -- एवीआर में फ्यूज -- प्रोग्रामर के रूप में Arduino: 10 कदम
![Arduino ISP के रूप में -- AVR में बर्न हेक्स फ़ाइल -- एवीआर में फ्यूज -- प्रोग्रामर के रूप में Arduino: 10 कदम Arduino ISP के रूप में -- AVR में बर्न हेक्स फ़ाइल -- एवीआर में फ्यूज -- प्रोग्रामर के रूप में Arduino: 10 कदम](https://i.howwhatproduce.com/images/001/image-2389-51-j.webp)
Arduino ISP के रूप में || AVR में बर्न हेक्स फ़ाइल || एवीआर में फ्यूज || अरुडिनो प्रोग्रामर के रूप में:………………अधिक वीडियो के लिए कृपया मेरे YouTube चैनल को सब्सक्राइब करें……यह लेख आईएसपी के रूप में आर्डिनो के बारे में सब कुछ है। यदि आप हेक्स फ़ाइल अपलोड करना चाहते हैं या यदि आप एवीआर में अपना फ्यूज सेट करना चाहते हैं तो आपको प्रोग्रामर खरीदने की आवश्यकता नहीं है, आप कर सकते हैं
वीएचडीएल और वेरिलोग में एक साधारण वीजीए नियंत्रक का डिजाइन: 5 कदम
![वीएचडीएल और वेरिलोग में एक साधारण वीजीए नियंत्रक का डिजाइन: 5 कदम वीएचडीएल और वेरिलोग में एक साधारण वीजीए नियंत्रक का डिजाइन: 5 कदम](https://i.howwhatproduce.com/images/002/image-4965-32-j.webp)
VHDL और Verilog में एक साधारण VGA नियंत्रक का डिज़ाइन: इस निर्देश में, हम RTL में एक साधारण VGA नियंत्रक डिज़ाइन करने जा रहे हैं। वीजीए कंट्रोलर डिजिटल सर्किट है जिसे वीजीए डिस्प्ले को चलाने के लिए डिज़ाइन किया गया है। यह फ्रेम बफर (वीजीए मेमोरी) से पढ़ता है जो प्रदर्शित किए जाने वाले फ्रेम का प्रतिनिधित्व करता है, और आवश्यक
वीएचडीएल में एसपीआई मास्टर का डिजाइन: 6 चरण
![वीएचडीएल में एसपीआई मास्टर का डिजाइन: 6 चरण वीएचडीएल में एसपीआई मास्टर का डिजाइन: 6 चरण](https://i.howwhatproduce.com/images/002/image-5866-8-j.webp)
VHDL में SPI मास्टर का डिज़ाइन: इस निर्देश में, हम VHDL में स्क्रैच से SPI बस मास्टर डिज़ाइन करने जा रहे हैं
वीएचडीएल में यूएआरटी का डिजाइन: 5 कदम
![वीएचडीएल में यूएआरटी का डिजाइन: 5 कदम वीएचडीएल में यूएआरटी का डिजाइन: 5 कदम](https://i.howwhatproduce.com/images/002/image-5928-40-j.webp)
VHDL में UART का डिज़ाइन: UART का मतलब यूनिवर्सल एसिंक्रोनस रिसीवर ट्रांसमीटर है। यह सबसे लोकप्रिय और सरल धारावाहिक संचार प्रोटोकॉल है। इस निर्देश में, आप सीखेंगे कि VHDL में UART मॉड्यूल कैसे डिज़ाइन किया जाए