विषयसूची:
- चरण 1: उपयोगकर्ता की आयु का विश्लेषण करने के लिए एक उपयोगकर्ता इनपुट बनाएं
- चरण 2: उपयोगकर्ता के लिए ऑडियो का परीक्षण करें
- चरण 3: दाहिने कान के लिए ऑडियोमेट्री टेस्ट करें
- चरण 4: बाएं कान के लिए समान कोड बनाएं
- चरण 5: डेटा की तुलना करने के लिए एक साथ-साथ चित्र बनाएं
- चरण 6: यदि आप चाहें तो थोड़ा धन्यवाद संदेश जोड़ें
वीडियो: MATLAB का उपयोग करके वयस्क श्रवण परीक्षण कैसे करें: 6 चरण
2024 लेखक: John Day | [email protected]. अंतिम बार संशोधित: 2024-01-30 09:21
अस्वीकरण: हमारा परीक्षण एक चिकित्सा निदान नहीं है और इसका उपयोग इस तरह नहीं किया जाना चाहिए। सुनने की क्षमता को सटीक रूप से मापने के लिए, कृपया किसी चिकित्सकीय पेशेवर से मिलें।
हमारे पास पहले से मौजूद सामग्रियों का उपयोग करते हुए, हमारे समूह ने श्रवण परीक्षण किया। हमारा परीक्षण केवल वयस्कों और किशोरों के उपयोग के लिए है क्योंकि छोटे बच्चों की सुनवाई विभिन्न श्रेणियों में आती है और इसे केवल एक पेशेवर द्वारा मापा जाना चाहिए।
यह परियोजना हमारी बीएमई मैटलैब कक्षा में काम करते हुए और साइन तरंगों द्वारा बनाई गई ध्वनियों के साथ खेलते समय प्रेरित हुई थी। हम विभिन्न पिचों पर ध्वनि चलाने के लिए साइन वेव को बदलने के तरीकों में रुचि रखते थे।
इस परियोजना के लिए हमें केवल MATLAB R2018b चलाने वाला एक कंप्यूटर और ईयरबड की एक जोड़ी की आवश्यकता थी। हमने कार्यक्रम को और अधिक हास्यप्रद बनाने के लिए एक मूल चरित्र, फ्रांसिस को शुभंकर के रूप में शामिल किया।
चरण 1: उपयोगकर्ता की आयु का विश्लेषण करने के लिए एक उपयोगकर्ता इनपुट बनाएं
इस कोड का पहला भाग एक उपयोगकर्ता इनपुट बनाना है जो यह तय करता है कि क्या वे श्रवण परीक्षण करने के लिए आगे बढ़ने के लिए पर्याप्त पुराने हैं। हमारे शुभंकर, फ्रांसिस की मूर्खतापूर्ण तस्वीरों को भी जोड़कर ऐसा क्यों नहीं करते? ऐसा करने के लिए, शामिल ज़िप फ़ाइल को डाउनलोड करें और फिर इसे उस फ़ाइल में निकालें जिसे कोड में खींचा जा सकता है। इसका उपयोग करके चित्रों से भरी फ़ाइल को बैच अपलोड करने के लिए आगे बढ़ें:
Dir = 'C:\Users\phoeb\OneDrive\Documents\MATLAB\Frances Drawings';GetDir = 'C:\Users\phoeb\OneDrive\Documents\MATLAB\Frances Drawings\*.jpg';
संदेश बॉक्स और चित्रों की बड़ी छवियों को प्रस्तुत करने के लिए, हमने आपको फ्रांसिस दिखाने की इस मजेदार विधि का उपयोग किया। बस अपनी पसंद की छवि को प्रारूप के साथ इम्रेड करें: वेरिएबल = इमरीड ('nameofPicture.jpg');
फिर imshow(variable) का उपयोग करके इसे दिखाने के लिए आगे बढ़ें; जब आप इसे चलाते हैं तो यह आपके MatLab में एक आकृति के रूप में दिखाई देगा!
अगला संदेश बॉक्स हैं जो पूरे कोड में उपयोग किए जाते हैं। uiwait() एक फ़ंक्शन है जिसमें कोड को तब तक रोक दिया जाता है जब तक कि uiwait के लिए चुना गया फ़क्शन समाप्त नहीं हो जाता। यह चुना हुआ कार्य है msgbox('message', 'title', 'icon')!
जब तक आप ऊपर दिए गए msgbox() प्रारूप का पालन करते हैं, तब तक आप फ्रांसिस द्वारा कहे गए संदेशों को बदलने के लिए स्वतंत्र महसूस कर सकते हैं। यदि आप फ्रांसिस चित्रों का उपयोग करना चाहते हैं, तो 'आइकन' को 'कस्टम' के रूप में लेबल करें और इसे अल्पविराम और आपके द्वारा चुने गए चित्र के इमरीड के चर के साथ आगे बढ़ें! आप प्रीसेट 'आइकन' प्रकारों का भी उपयोग कर सकते हैं। इसे ऐसा दिखना चाहिए:
हाय = इमरीड ('Regular.jpg'); % फ़ाइल अपलोडिमशो (हाय) से छवि को पढ़ता है; uiwait(msgbox('नमस्कार और हमारे श्रवण परीक्षण को चुनने के लिए धन्यवाद! यह फ्रांसेस है और वह आज आपके परीक्षण में आपकी मदद करेगा!', 'स्वागत!', 'कस्टम', हाय));
इसके बाद एक इनपुट बनाएं जो उपयोगकर्ता की उम्र को इस तरह पूछता है!
UserAge = इनपुट ('इस परीक्षण को शुरू करने से पहले, आप कितने साल (वर्ष) हैं? (जैसे 32, 56, …)\n', 's');
नोट: यदि आंकड़े अजीब हो रहे हैं और बहुत अधिक हैं, तो अपने कोड के चलने पर पहले के आंकड़ों को हटाने के लिए सभी को बंद करें का उपयोग करें
फिर एक स्विच केस स्ट्रक्चर बनाएं! याद रखें कि उपयोगकर्ता इनपुट स्ट्रिंग में है और आपको इसे एक संख्यात्मक मान में बदलने की आवश्यकता है। तो str2double (UserAge) का उपयोग करें। प्रत्येक मामले में 4 से 6 या 18 से 40 की आयु की सीमा होनी चाहिए। किसी एक मामले के लिए वेरिएबल को सत्य के रूप में सत्यापित करने के लिए num2cell (सरणी) का उपयोग करें जैसे:
स्विच str2double(UserAge)% परिवर्तन चर एक स्ट्रिंग से एक संख्यात्मक मान मामले में num2cell(0:3)
फ़्रांसिस = इमरीड ('एग.जेपीजी');
इम्शो (फ्रांस);
uiwait(msgbox('आप एक भ्रूण हैं! फ्रांसिस सोचता है कि आपको इसके बजाय एक डॉक्टर के साथ अपना श्रवण परीक्षण करना चाहिए!', 'टेस्ट अस्वीकृत!', 'कस्टम', फ़्रांसिस));
वापसी
उपयोगकर्ता को कोड के साथ आगे बढ़ने से रोकने के लिए पहले के समूहों को वापस कर दिया जाना चाहिए।
केस संरचना को समाप्त करना और सभी आंकड़े बंद करना याद रखें।
चरण 2: उपयोगकर्ता के लिए ऑडियो का परीक्षण करें
यह खंड यह सुनिश्चित करने के लिए मौजूद है कि उनके डिवाइस पर प्रतिभागी की आवाज न तो बहुत शांत है और न ही बहुत तेज है।
उपयोगकर्ता को कुछ चेतावनी देने के लिए एक संदेश बॉक्स पॉप अप होता है और ध्वनि के साथ आगे बढ़ने से पहले उपयोगकर्ता से पुष्टि की प्रतीक्षा करता है: uiwait(msgbox('परीक्षण शुरू होने से पहले, हम आपकी मात्रा सुनिश्चित करने के लिए एक ऑडियो परीक्षण करना चाहते हैं) सही है! तैयार हैं?', 'रुको!', 'सहायता'));
एक साइन लहर 1 के आयाम और 1000 हर्ट्ज की नमूना दर के साथ खेली जाती है: टी = [0: 1/नमूना दर: 2]; वाई = 1 * पाप (2 * पीआई * 200 * टी); ध्वनि (वाई, नमूना दर);
उपयोगकर्ता से तब उपयोगकर्ता द्वारा इनपुट की गई प्रतिक्रिया के साथ एक प्रश्न पूछा जाता है: Q = इनपुट ('क्या आप ध्वनि सुन सकते हैं? [y/n] n', 's');
फिर कुछ समय लगता है जब Q == 'n', यदि सत्य है तो ध्वनि दोहराई जाती है और उपयोगकर्ता से फिर से पूछा जाता है जब तक कि उत्तर 'n' से 'y' में बदल नहीं जाता है: जबकि Q == 'n' अगर strcmp(Q, 'n') disp('अपने कंप्यूटर का वॉल्यूम तेज करें।'); प्रतीक्षा_ध्वनि; विराम(2); क्यू = इनपुट ('क्या आप अब ध्वनि सुन सकते हैं? [y/n] n', 's'); अंत अंत
फिर कोड के वास्तविक परीक्षा भाग को आगे बढ़ाने से पहले प्रतीक्षा करने का एक क्षण है।
चरण 3: दाहिने कान के लिए ऑडियोमेट्री टेस्ट करें
इस कोड में, प्रत्येक व्यक्तिगत कान के लिए अलग-अलग आवृत्तियों और वॉल्यूम के साथ 6 पुनरावृत्तियों के लिए एक लूप चलेगा। आप जिस कान का परीक्षण करना चाहते हैं उसके आधार पर, आउट वैरिएबल में एक पंक्ति में ध्वनि और दूसरी में शून्य होगी।
पहले आप दो खाली लाइन वेक्टर बनाते हैं जो उपयोगकर्ता द्वारा सुनी जाने वाली ध्वनि की आवृत्तियों और आयाम को रिकॉर्ड करते हैं।
यदि आप बजाई गई आवृत्तियों और आयाम को यादृच्छिक बनाना चाहते हैं तो यह भाग लूप के लिए अनुक्रमित में है, हालांकि आप कितनी ध्वनियां बजाना चाहते हैं।
एफ आवृत्ति है: आर = (रैंड * 10000); एफएस = 250 + आर; (रैंड फ़ंक्शन एक बेतरतीब ढंग से उत्पन्न आवृत्ति बनाने के लिए है) t समय की एक निश्चित मात्रा है जो इसके द्वारा निर्धारित होती है: t = linspace(0, Fs*2, Fs*2); s साइन वेव है: s = sin(2*pi*t*1000); (ध्वनि फ़ंक्शन के लिए यादृच्छिक आयाम/डीबी मान बनाने के लिए इसे यादृच्छिक चर w से गुणा किया जा सकता है: w = रैंड;)
दाहिने कान के लिए आउटपुट है: आउट = [शून्य (आकार (टी)); एस]';
आउटपुट कोड के माध्यम से खेला जाता है: ध्वनि (आउट, एफएस)
अगला कदम कोड रिकॉर्ड के साथ यूजर इंटरफेस बनाना है कि यूजर ने आवाज सुनी या नहीं।
पहले आप एक आकृति बनाएं और उस स्थिति का निर्धारण करें जिसमें आकृति दिखाई देगी: gcbf = आकृति ('स्थिति', [३० ८०० ३५० १५०]);
***यदि बटन आपके लिए प्रकट नहीं होता है, तो आकृति की स्थिति, जैसा कि ऊपर सरणी द्वारा दिखाया गया है, आपके कंप्यूटर के लिए गलत स्थिति में हो सकती है। इसे हल करने के लिए, 30 और 800 मानों को अपनी इच्छानुसार किसी भी स्थिति में बदलें। उदाहरण के लिए, [0 0 350 150] होने से मॉनिटर के नीचे बाईं ओर गुई बटन दिखाई देगा।***
जब उपयोगकर्ता ध्वनि सुनता है तो रिकॉर्ड करने के लिए एक टॉगलबटन बनाया जाता है, और स्थिति और प्रदर्शन को अनुकूलित किया जा सकता है: tb = uicontrol('Style', 'togglebutton', 'String', 'जब आप ध्वनि सुनते हैं तो बटन दबाएं', ' tag', 'togglebutton1', 'Position', [30 60 300 40], 'Callback', 'uiresume(gcbf); freq_right = [freq_right, F]; amp_right = [amp_right, w]; close(gcbf);'); इस विशेष कोड में कोड फिर से शुरू होता है और खाली वेक्टर बटन दबाए जाने पर एक मान जोड़ते हैं।
फिर बटन की प्रतिक्रिया लेने के लिए एक प्रतीक्षा फ़ंक्शन बनाएं और दबाए जाने पर बटन में कोड सक्रिय करें: एच = रैंडी ([4, 7]); यूआईवाइट (जीसीबीएफ, एच); (हमने यादृच्छिक चर h किया ताकि प्रतिभागी धोखा न दे सकें और प्रतिक्रिया देने के लिए आवश्यक सेकंड की संख्या निर्धारित कर सकें।)
लूप समाप्त होने के बाद, फ़्रीक्वेंसी आउटपुट वैरिएबल (freq_right) को Hz में रखें इसलिए इसे अकेला छोड़ दें। फिर समीकरण का उपयोग करके dB_right चर को amps से डेसिबल में बदलें: dB_right = mag2db(amp_right)*(-1);
फिर फ़ंक्शन जोड़ें: सभी को बंद करें। यह किसी भी अनावश्यक आंकड़े से बाहर निकल जाएगा जो पॉप अप हो सकता है।
उपयोगकर्ता को समायोजित करने और बाएं कान के लिए तैयार करने के लिए समय देने के लिए, लगभग 10 सेकंड के लिए एक विराम समारोह जोड़ें।
चरण 4: बाएं कान के लिए समान कोड बनाएं
बाएं कान का परीक्षण करने वाला अगला खंड बनाने के लिए दाएं कान के लिए उपयोग किए गए कोड को दोहराएं। फर्क सिर्फ इतना है कि यह बदल रहा है कि ध्वनि किस आउटपुट चैनल से आएगी। ऐसा करने के लिए, वेरिएबल आउट के लिए सरणी मानों के क्रम को फ़्लिप करें। इसे ऐसा दिखना चाहिए:
आउट = [एस; शून्य (आकार (टी))]';
ऐसा करने से दाएँ चैनल से कोई आवाज़ नहीं बल्कि बाएँ चैनल से आवाज़ निकलेगी!
चरण 5: डेटा की तुलना करने के लिए एक साथ-साथ चित्र बनाएं
अब डेटा दिखाने के लिए एक ग्राफ बनाएं! आप एक ही आकृति में दो रेखांकन डाल रहे हैं इसलिए ऐसा करें!
आकृति (1); सबप्लॉट (1, 2, 1); ***सबप्लॉट(1, 2, 2) दूसरे के लिए
प्रत्येक सबप्लॉट के लिए, इन पैच में विशिष्ट रंगों और निर्देशांक के साथ जोड़ें। श्रवण हानि की डिग्री कितनी बड़ी है, इस पर निर्भर करते हुए ये खंड ग्राफ़ से बाहर हैं। इस तरह:
पैच ([२५० ८००० ८००० २५०], [२५ २५ -10 -10], [१.००, ०.८९, ०.२९]); % येलोहोल्ड% पर सबप्लॉट अब निम्नलिखित पैच और स्कैटरप्लॉट धारण करेगा
पाठ (3173, 8, 'सामान्य');
पैच ([२५० ८००० ८००० २५०], [४० ४० 25 २५], [० ०.७५ ०.२५]); % हरा
पाठ (3577, 33, 'हल्का');
पैच ([२५० ८००० ८००० २५०], [५५ ५५ ४० ४०], [०.१६, ०.८७, ०.८७]); % सियान
पाठ (2870, 48, 'मध्यम');
पैच ([२५० ८००० ८००० २५०], [७० ७० ५५ ५५], [०.२२, ०.३६, ०.९४]); % नीला
पाठ (१७३९, ६२, 'मामूली गंभीर');
पैच ([२५० ८००० ८००० २५०], [९० ९० ७० ७०], [०.७८, ०.२४, ०.७८]); % नील लोहित रंग का
पाठ (3142, 80, 'गंभीर');
पैच ([२५० ८००० ८००० २५०], [१२० १२० ९० ९०], [०.९६, ०.२४, ०.२४]); % लाल
पाठ (3200, 103, 'गहरा')
फिर बाएँ और दाएँ स्कैटर प्लॉट जोड़ें! हम आपके लिए एक सामान्य राष्ट्रीय औसत प्रदान कर सकते हैं! यहां:
Nat_FreqL = [२५० ५०० १००० २००० ४००० ८०००]; % x-मान, बायां कानNat_dBL = [१० ३ १० १५ १० १५]; % y-मान
Nat_FreqR = [२५० ५०० १००० २००० ४००० ८०००]; % दाहिना कान
Nat_dBR = [१० ५ १० १५ १० १५];
तितर बितर भूखंडों को बाएँ और दाएँ बिंदुओं को समझना चाहिए। आप क्रॉस और सर्कल कर सकते हैं!
NL = स्कैटर (Nat_FreqL, Nat_dBL, 'bx'); % प्लॉट ब्लू क्रॉस पॉइंटNR = स्कैटर (Nat_FreqR, Nat_dBR, 'ro'); % भूखंड लाल घेरे
विशिष्ट चरों को निर्दिष्ट करके राष्ट्रीय ग्राफ के लिए एक किंवदंती बनाएं: किंवदंती ([एनएल एनआर], {'शीर्षक 1', 'शीर्षक 2'});
अपनी x सीमा 250 से 8000 Hz और अपनी y सीमा -10 से 120 dB तक सेट करें। अपने वर्टिकल टिक को yticks() से बदलना याद रखें
अपने x अक्ष को "फ़्रीक्वेंसी Hz" और अपने y अक्ष को "पिच dB" लेबल करें।
कुल्हाड़ी = gca. के साथ अक्ष को इकट्ठा करके y अक्ष को उलट दें
फिर y दिशा की संपत्ति को इसके साथ बांधें: ax. YDir = 'reverse
अब दूसरे के लिए कोड लगभग समान है, लेकिन लेजेंड के बिना और बाएं और दाएं परीक्षणों के चर के साथ स्कैटरप्लॉट्स को रेखांकन किए बिना।
इन सबके बाद करीब 10 सेकेंड के लिए पॉज फंक्शन जोड़ें ताकि यूजर अपना रिजल्ट देख सके।
चरण 6: यदि आप चाहें तो थोड़ा धन्यवाद संदेश जोड़ें
यह केवल मनोरंजन के लिए है यदि आप चाहें, लेकिन धन्यवाद और विदाई के लिए एक और imread (), imshow () और uiwait (msgbox ()) जोड़ें! इसके अलावा, clf डालना याद रखें; सब बंद करें; सीएलसी; सब कुछ बंद करने के लिए। अच्छा काम आपने किया!
सिफारिश की:
DIY -- कैसे एक स्पाइडर रोबोट बनाने के लिए जिसे Arduino Uno का उपयोग करके स्मार्टफ़ोन का उपयोग करके नियंत्रित किया जा सकता है: 6 चरण
DIY || कैसे एक स्पाइडर रोबोट बनाने के लिए जिसे Arduino Uno का उपयोग करके स्मार्टफ़ोन का उपयोग करके नियंत्रित किया जा सकता है: स्पाइडर रोबोट बनाते समय, रोबोटिक्स के बारे में बहुत सी बातें सीख सकते हैं। जैसे रोबोट बनाना मनोरंजक होने के साथ-साथ चुनौतीपूर्ण भी है। इस वीडियो में हम आपको स्पाइडर रोबोट बनाने का तरीका दिखाने जा रहे हैं, जिसे हम अपने स्मार्टफोन (Androi
Arduino का उपयोग करके DS1307 का उपयोग कैसे करें: 7 चरण
Arduino का उपयोग करके DS1307 का उपयोग कैसे करें: DS1307 एक रीयल टाइम क्लॉक IC (RTC) है। इस IC का उपयोग समय डेटा प्रदान करने के लिए किया जाता है। आवंटित समय सेकंड, मिनट, घंटे, दिन, तिथि, महीना और वर्ष से शुरू होता है। इस आईसी को अतिरिक्त बाहरी घटकों जैसे क्रिस्टल और 3.6V बैटरी की आवश्यकता होती है। क्रिस्टल
रास्पबेरी पाई + यूबीडॉट्स का उपयोग करके अपनी इंटरनेट स्पीड का परीक्षण करें: 9 कदम
रास्पबेरी पाई + यूबीडॉट्स का उपयोग करके आप इंटरनेट की गति का परीक्षण करें: रास्पबेरी पाई न केवल प्रोटोटाइप और शैक्षिक उद्देश्यों के लिए, बल्कि व्यवसायों के भीतर औद्योगिक उत्पादन परियोजनाओं के लिए भी व्यापक रूप से उपयोग किया जाने वाला उपकरण बन गया है। पाई के आकार, कम लागत और पूरी तरह से परिचालित लिनक्स ओएस के अलावा, यह वाई-फाई से भी इंटरैक्ट कर सकता है।
मैक टर्मिनल का उपयोग कैसे करें, और मुख्य कार्यों का उपयोग कैसे करें: 4 कदम
मैक टर्मिनल का उपयोग कैसे करें, और मुख्य कार्यों का उपयोग कैसे करें: हम आपको दिखाएंगे कि मैक टर्मिनल कैसे खोलें। हम आपको टर्मिनल के भीतर कुछ विशेषताएं भी दिखाएंगे, जैसे कि ifconfig, निर्देशिका बदलना, फाइलों तक पहुंचना, और arp. ifconfig आपको अपना आईपी पता, और अपने मैक विज्ञापन की जांच करने की अनुमति देगा
अपने हार्डवेयर का परीक्षण और कार्यान्वयन करने के लिए टिंकरकाड का उपयोग कैसे करें: 5 कदम (चित्रों के साथ)
अपने हार्डवेयर का परीक्षण और कार्यान्वयन करने के लिए टिंकरकाड का उपयोग कैसे करें: सर्किट सिमुलेशन एक ऐसी तकनीक है जहां कंप्यूटर सॉफ्टवेयर इलेक्ट्रॉनिक सर्किट या सिस्टम के व्यवहार का अनुकरण करता है। वास्तव में सर्किट या सिस्टम का निर्माण किए बिना नए डिजाइनों का परीक्षण, मूल्यांकन और निदान किया जा सकता है। सर्किट सिमुलेशन एक हो सकता है