विषयसूची:
- चरण 1: तस्वीरें लें
- चरण 2: छवियों को MATLAB में लोड करें
- चरण 3: छवि विश्लेषण
- चरण 4: चेकरबोर्ड पर सफेद वर्गों की चौड़ाई की गणना करें।
- चरण 5: परीक्षण छवि के लिए चरण 3 और 4 दोहराएं
- चरण 6: लेंस के आवर्धन की गणना करें।
- चरण 7: इंटरपोलेशन के माध्यम से आर-स्क्वायर और उपयोगकर्ता के नुस्खे ढूँढना
- चरण 8: उपयोगकर्ता के नुस्खे को ग्राफ़ पर दिखाना
- चरण 9: अपने नुस्खे को संक्षिप्त करें।
वीडियो: अपने नेत्रगोलक के नुस्खे पर ध्यान दें: एक BME60B प्रोजेक्ट: 9 चरण
2024 लेखक: John Day | [email protected]. अंतिम बार संशोधित: 2024-01-30 09:19
द्वारा: हन्ना सिलोस, संग ही किम, थॉमस वाज़क्वेज़, पैट्रिक विस्टे
आवर्धन चश्मा पढ़ने के लिए मौजूद प्रमुख विशेषताओं में से एक है, जिसे उनके डायोप्टर के नुस्खे द्वारा वर्गीकृत किया जाता है। मिशिगन टेक्नोलॉजी यूनिवर्सिटी के अनुसार, एक डायोप्टर लेंस की फोकल लंबाई है, जिसे आमतौर पर मीटर (मिशिगन टेक्नोलॉजी यूनिवर्सिटी) की इकाई में मिमी में मापा जाता है। क्योंकि पढ़ने वाले चश्मे में उत्तल लेंस होते हैं, फोकल लंबाई सकारात्मक होगी, जिससे डायोप्टर भी सकारात्मक होंगे (हाइपरफिजिक्स)। फोकल लंबाई बढ़ जाती है क्योंकि वस्तु के बीच की दूरी वास्तविक लेंस से और दूर हो जाती है, और इससे डायोप्टर कम हो जाते हैं क्योंकि वे व्युत्क्रमानुपाती होते हैं। इसलिए, अतिरिक्त डायोप्टर के साथ पढ़ने वाले चश्मे होने से लेंस को दृश्य को ज़ूम करने में मदद मिलेगी ताकि ऐसा लग सके कि डायोप्टर के मूल्य को बढ़ाकर फोकल लंबाई कम हो गई है।
प्रस्तुत कोड का उपयोग अज्ञात नुस्खे वाले लेंस के डायोप्टर की भविष्यवाणी करने के लिए किया जाएगा। नुस्खे की गणना के लिए दो इनपुट का उपयोग किया जाता है: किसी भी लेंस का उपयोग किए बिना नियंत्रित पृष्ठभूमि की एक तस्वीर, और उसी पृष्ठभूमि की एक और तस्वीर लेकिन पसंद के लेंस के माध्यम से। कार्यक्रम इन दो तस्वीरों के बीच की विकृति को मापेगा। वहां से, हम लेंस के डायोप्टर का अनुमान लगाने में सक्षम होंगे और उपयोगकर्ता को देखने के लिए एक परिणाम तैयार करेंगे।
इस निर्देश के लिए, आपको आवश्यकता होगी:
- कागज की शीट में 11x8.5 पर मुद्रित एक श्वेत-श्याम बिसात पैटर्न
- अपना फोकस लॉक करने की क्षमता वाला कैमरा
- एक तिपाई, या कैमरे को सुरक्षित करने के लिए कुछ समान
- चश्मा पढ़ने के विभिन्न नुस्खे
- मतलब
चरण 1: तस्वीरें लें
लेंस के आवर्धन की गणना करने के लिए, आपको इसकी तुलना वस्तु के वास्तविक आकार से करने में सक्षम होना चाहिए। इस परियोजना के लिए, हम एक आवर्धित छवि की तुलना एक नियंत्रण छवि से करेंगे।
इस प्रकार, पहला कदम एक ही छवि की दो तस्वीरें लेना है - पहला सिर्फ कैमरे के माध्यम से, और दूसरा पढ़ने वाले चश्मे के लेंस के माध्यम से जिसे आप परीक्षण करना चाहते हैं।
आप 1in ग्रिड के साथ 8.5x11in काले और सफेद चेकरबोर्ड की तस्वीर ले रहे होंगे। अपना कैमरा चेकरबोर्ड से 11 इंच की दूरी पर सेट करें। फ़ोटो लेने से पहले, फ़ोकस को बिसात पर लॉक करें।
बिना पठन चश्मे के बिसात का फोटो लें। फिर, बिना कुछ हिलाए रीडिंग ग्लास को कैमरे के सामने रखें और दूसरी फोटो लें।
सुनिश्चित करें कि आपके कैमरे की स्थिति शॉट्स के बीच में नहीं चलती है। केवल एक चीज जो दो तस्वीरों के बीच बदलनी चाहिए, वह है कैमरे के सामने चश्मे के लेंस की उपस्थिति।
जब आप फ़ोटो का काम पूरा कर लें, तो उन्हें अपने कंप्यूटर पर अपलोड करें।
चरण 2: छवियों को MATLAB में लोड करें
एक नई स्क्रिप्ट खोलें।
सबसे पहले, उस निर्देशिका को निर्दिष्ट करें जहाँ फ़ोटो संग्रहीत हैं। फिर,-j.webp
Dir = 'C:\Users\kuras\Desktop\classes\SQ2\BME60b\Sandbox\testphotos'; गेटडिर = डीआईआर ('*.jpg');
हमारी परियोजना के लिए, हम प्रोग्राम के उपयोगकर्ता को संकेत देना चाहते थे कि वे किन फाइलों की तुलना करना चाहते हैं। पहला खंड उपयोगकर्ता को नियंत्रण छवि निर्दिष्ट करने के लिए कहता है, और दूसरा उपयोगकर्ता को परीक्षण छवि निर्दिष्ट करने के लिए कहता है।
- % उपयोगकर्ता से पूछें कि कौन सी फ़ाइल नियंत्रण छवि है।
- नियंत्रण = इनपुट ('# नियंत्रण छवि का। / n');
- कंट्रोलफाइल = [गेटडिर (कंट्रोल) नाम]
- % उपयोगकर्ता से पूछें कि वह कौन सी फ़ाइल है जिसका वे विश्लेषण करना चाहते हैं।
- चुनेंफाइल = इनपुट ('\ n # छवि का आप विश्लेषण करना चाहते हैं। / n');
- PrescripFile = [GetDir (चुनें फ़ाइल)। नाम];
चरण 3: छवि विश्लेषण
MATLAB में एक रंगीन छवि का आकार MxNx3 है, जबकि एक ग्रेस्केल छवि MxN है। इसका अर्थ है कि ग्रेस्केल छवि को बढ़ाना/संपादित करना तेज़ है क्योंकि ट्रैक रखने के लिए कम डेटा है। छवि को ग्रेस्केल में बदलने के लिए rgb2gray का उपयोग करें। (इमोटेट फ़ंक्शन का उपयोग किया गया था क्योंकि हमारी तस्वीरें क्षैतिज में आईं - कोड की यह पंक्ति आपके संस्करण में आवश्यक हो भी सकती है और नहीं भी।)
- % ग्रेस्केल में बदलें और घुमाएं
- मैं = इमरेड (कंट्रोलफाइल);
- मैं = आरजीबी2ग्रे (आई);
- मैं = इम्रोटेट (मैं, ९०);
अगला, छवि प्रदर्शित करें। सबप्लॉट फ़ंक्शन का उपयोग किया जाता है ताकि परीक्षण छवि बाद के चरणों में नियंत्रण के बगल में हो सके।
- % प्रदर्शन
- आकृति 1);
- सबप्लॉट(1, 2, 1)
- इम्शो (मैं);
- शीर्षक (कंट्रोलफाइल);
उपयोगकर्ता को पूर्ण छवि से चेकरबोर्ड को क्रॉप करने के लिए प्रेरित करने के लिए इम्क्रॉप का उपयोग करें। निम्न कोड उपयोगकर्ता को निर्देश प्रदान करने के लिए एक संदेश बॉक्स भी दिखाता है।
- विश्लेषण के लिए% बिसात काट लें
- Waitfor(msgbox({'चेकरबोर्ड को क्रॉप आउट करने के लिए क्रॉस हेयर का उपयोग करें।', 'फिर रुचि के क्षेत्र पर डबल क्लिक करें।'}));
- I_crop = फसल (मैं);
छवि को बिनराइज़ करने के लिए imbinarize का उपयोग करें।
I_binary = imbinarize (I_crop);
चरण 4: चेकरबोर्ड पर सफेद वर्गों की चौड़ाई की गणना करें।
इसके बाद, उपयोगकर्ता को imline का उपयोग करके छवि पर एक रेखा खींचने के लिए प्रेरित करें। यह रेखा बिसात पर क्षैतिज रूप से चलनी चाहिए। यह एक काले वर्ग पर शुरू और समाप्त होना चाहिए (इससे कोई फर्क नहीं पड़ता) - ऐसा इसलिए है क्योंकि हम सफेद वर्गों की चौड़ाई को मापेंगे, न कि काले वाले।
- %रेखा खींचें
- आकृति 1)
- सबप्लॉट(1, 2, 1)
- इमशो (I_बाइनरी);
- Waitfor(msgbox({'ब्लैक स्पेस से ब्लैक स्पेस तक 9 बॉक्स में फैली रेखा खींचने के लिए क्लिक करें और खींचें।', 'पुष्टि करने के लिए डबल क्लिक करें।'}));
- रेखा = इमलाइन;
- स्थिति = प्रतीक्षा (पंक्ति);
- एंडपॉइंट्स = लाइन। getPosition;
खींची गई रेखा के अंतिम बिंदुओं के लिए एक्स और वाई कोऑडिनेट्स निकालें।
- एक्स = समापन बिंदु (:, 1)
- वाई = एंडपॉइंट्स (:, 2);
खींची गई रेखा के साथ पाई गई तीव्रताओं के आधार पर ग्राफ बनाने के लिए इप्रोफाइल का उपयोग करें। यह 0 (काला) से लेकर 1 (सफेद) तक की एक वर्गाकार तरंग के सदृश होना चाहिए। चोटियों और उनके स्थानों की भी गणना करें।
- चित्र 2)
- सबप्लॉट(1, 2, 1)
- शीर्षक ('इमप्रोफाइल रेखा के पार छवि तीव्रता (नियंत्रण)')
- इप्रोफाइल (I_बाइनरी, एक्स, वाई); ग्रिड पर;
- [~, ~, c1, ~, ~] = इम्प्रोफाइल (I_binary, X, Y);
- [चोटियों, स्थान] = खोजपीक्स (सी 1 (:,:, 1));
- रूको
- प्लॉट (लोक, चोटियाँ, 'आरओ');
- रोके रखना
लूप के लिए उपयोग करके इम्प्रोफाइल ग्राफ पर प्रत्येक पठार की लंबाई ज्ञात कीजिए। इंप्रोफाइल ग्राफ में उतनी ही चोटियों के लिए लूप के लिए चलाएं। प्रत्येक पठार की लंबाई की गणना करने के लिए, उन सभी स्थानों को खोजने के लिए 'ढूंढें' फ़ंक्शन का उपयोग करें जहां '0' तीव्रता मान के बजाय '1' है। फिर, पठार की कुल लंबाई प्राप्त करने के लिए उस सरणी की लंबाई की गणना करें, जो पिक्सेल में एक सफेद वर्ग की चौड़ाई के बराबर होनी चाहिए। ControlPlateauList = शून्य (1, लंबाई (लोक));
i = 1: लंबाई (स्थानीय) के लिए
अगर मैं == लंबाई (स्थानीय)
पठार = ढूंढें (सी 1 (लोक (i): अंत,:, 1));
अन्यथा
पठार = ढूंढें (c1(loc(i):loc(i+1)-1,:, 1));
समाप्त
ControlPlateauList(i) = लंबाई (पठार);
समाप्त
चरण 5: परीक्षण छवि के लिए चरण 3 और 4 दोहराएं
*नोट: परीक्षण छवि पर इम्प्रोफाइल रेखा खींचते समय, इसे उन वर्गों के आर-पार खींचना सुनिश्चित करें जो आपके द्वारा नियंत्रण छवि पर खींची गई रेखा के अनुरूप हों।
चरण 6: लेंस के आवर्धन की गणना करें।
बढ़े हुए माप की गणना पठार की लंबाई के माध्य को विभाजित करके की जाती है, जिसकी गणना चरण 5 में की गई थी, नियंत्रण पठार की लंबाई के माध्यम से, जिसकी गणना चरण 4 में की गई थी। इसकी गणना १.०८८४ है।
आवर्धन = माध्य (पठारसूची)/माध्य (कंट्रोलप्लेटोलिस्ट);
चरण 7: इंटरपोलेशन के माध्यम से आर-स्क्वायर और उपयोगकर्ता के नुस्खे ढूँढना
कोड का उपयोग करना:
- md1 = फिटलम (दिया गया प्रिस्क्रिप्शन, मैगअरे);
- रुपये वर्ग = md1. Rsquared.साधारण;
हम दिए गए प्रेसीप्शन (हमारे लेंस दिए गए मान) बनाम मैगएरे (आवर्धन माप अनुपात की एक सरणी जो हमने पहले गणना की थी) के आर-वर्ग मान को पा सकते हैं। एक उच्च पर्याप्त आर-वर्ग मूल्य होने से, यह अनुमान लगाया जा सकता है कि इस पद्धति के उपयोग को सही ठहराने के लिए एक मजबूत पर्याप्त सहसंबंध है। इस विशेष मामले के लिए, आर-वर्ग मान 0.9912 था, जो एक मजबूत सहसंबंध का सुझाव देता है और इसलिए विश्लेषण में इस पद्धति का उपयोग करने में उचित है।
फ़ंक्शन का उपयोग करना:
प्रिस्क्रिप्शन = इंटरप 1 (मैगएरे, गिवेन प्रिस्क्रिप्शन, आवर्धन, 'रैखिक');
हम अपने आवर्धन अनुपात (y-अक्ष पर एक मान) के संबंधित नुस्खे मूल्य (x-अक्ष पर) को प्रक्षेपित कर सकते हैं और यह पता लगा सकते हैं कि उपयोगकर्ता का नुस्खा क्या है।
इस पद्धति के काम करने के लिए इंटरपोलिंग डेटा महत्वपूर्ण है क्योंकि यह हमें उस जानकारी के बारे में धारणा बनाने की अनुमति देता है जो हमारे पास नहीं है, हमारे पास मौजूद जानकारी के आधार पर। जबकि सर्वोत्तम फिट की एक पंक्ति तकनीकी रूप से इस धारणा के लिए एक मजबूत उम्मीदवार होगी, आउटपुट की संख्या को कम करने के लिए सीमाएं बनाना उसी प्रभाव की सेवा करता है जैसे पर्चे चश्मा वैसे भी वृद्धिशील समान मूल्यों में आते हैं। इसे बाद के चरणों में समझाया गया है।
चरण 8: उपयोगकर्ता के नुस्खे को ग्राफ़ पर दिखाना
निम्नलिखित कोड का उपयोग करना:
- आकृति;
- प्लॉट (दिया गया प्रिस्क्रिप्शन, मैगअरे, '-जी')
- रूको
- प्लॉट (प्रिस्क्रिप्शन, आवर्धन, 'बीपी')
- रोके रखना
- ग्रिड
- लीजेंड ('डेटा', 'इंटरपोलेटेड पॉइंट्स', 'लोकेशन', 'एनडब्ल्यू')
हम एक ग्राफ प्लॉट कर सकते हैं जो एक हरे रंग की रेखा के साथ आवर्धन अनुपात बनाम दिए गए नुस्खे को दिखाता है और हमारे परिकलित आवर्धन का पाया गया डेटा एक नीले तारे के साथ हमारे प्रक्षेपित नुस्खे को दिखाता है। फिर लेजेंड शीर्षक, x-अक्ष और y-अक्ष को लेबल करता है और लेजेंड को ऊपरी बाएँ कोने में रखता है।
चरण 9: अपने नुस्खे को संक्षिप्त करें।
नुस्खे के लिए गोलाई बनाने के लिए निम्नलिखित कोड का उपयोग किया जाता है:
-
यदि प्रिस्क्रिप्शन <= 1.125
परिकलित प्रिस्क्रिप्शन = '1.0';
-
एल्सिफ़ प्रिस्क्रिप्शन <= 1.375
परिकलित प्रिस्क्रिप्शन = '1.25';
-
एल्सिफ़ प्रिस्क्रिप्शन <= 1.625
परिकलित प्रिस्क्रिप्शन = '1.5';
-
एल्सिफ़ प्रिस्क्रिप्शन <= 1.875
परिकलित प्रिस्क्रिप्शन = '1.75';
-
अन्य नुस्खे <= 2.25
परिकलित प्रिस्क्रिप्शन = '2.0';
-
एल्सिफ़ प्रिस्क्रिप्शन <= 2.625
परिकलित प्रिस्क्रिप्शन = '2.5';
-
एल्सिफ़ प्रिस्क्रिप्शन <= 3
परिकलित प्रिस्क्रिप्शन = '2.75';
-
अन्य नुस्खे <= 3.375
परिकलित प्रिस्क्रिप्शन = '3.25';
-
अन्यथा
परिकलित प्रिस्क्रिप्शन = 'अज्ञात';
- समाप्त
प्रक्षेप के माध्यम से पाया गया नुस्खा जरूरी वास्तविक नुस्खे को प्रतिबिंबित नहीं करता है - ऐसा इसलिए है क्योंकि मानवीय त्रुटि के कारण फोटो का विश्लेषण करने में हमेशा थोड़ा बदलाव होगा। इस प्रकार, हमें वास्तविक नुस्खे को वर्गीकृत करने के लिए इस कदम की आवश्यकता है।
जो नुस्खे दिए जाते हैं वे आमतौर पर 1.0 डायोप्टर से शुरू होते हैं और उनके नुस्खे में.25 तक बढ़ जाते हैं, इसलिए नुस्खे की गणना के बाद हम उस नुस्खे को निर्धारित करना चाहते हैं जो उपयोगकर्ता की आवश्यकता के अनुसार सबसे उपयुक्त हो। नुस्खे की गणना के बाद, हम इसके मूल्य की जांच करने के लिए दिए गए यदि कथनों के माध्यम से चलाते हैं और यह निर्धारित करते हैं कि कौन सा नुस्खा आवश्यक है। 1.125 से कम या उसके बराबर कुछ भी, तो प्रिस्क्रिप्शन 1.0 है। 1.375 से कम या उसके बराबर कुछ भी, नुस्खा 1.25 है। 1.625 से कम या उसके बराबर कुछ भी, प्रिस्क्रिप्शन 1.5 है। 1.845 से कम या उसके बराबर कुछ भी, नुस्खा 1.75 है। और इसी तरह।
हमारे पास मूल्य बढ़ रहे हैं क्योंकि हम जाँच कर रहे हैं कि क्या मान इससे कम हैं। यदि हमने मूल्यों को कम किया है तो पहला यदि कथन हर समय पहले यदि कथन को पढ़ेगा। यदि नुस्खा सबसे छोटा है, तो हम चाहते हैं कि यह तुरंत इसे सबसे छोटा मान ले, इसलिए सबसे छोटा मूल्य वह है जिसके साथ हमने शुरुआत की थी। उच्चतम मूल्य से अधिक कुछ भी इसका मतलब है कि नुस्खा हमारे डेटा के साथ सीमा में नहीं है, इसलिए यह "अज्ञात" स्ट्रिंग रीडिंग देगा।
सिफारिश की:
अपने बिस्तर को अंडरग्लो दें!: 7 कदम (चित्रों के साथ)
अपने बिस्तर को अंडरग्लो दें !: इस निर्देश में, मैं समझा रहा हूँ कि आरजीबी एलईडी के साथ अपने बिस्तर को कैसे शानदार बनाया जाए। मुझे जो मिले हैं वे रिमोट से नियंत्रित हैं, उनके पास अलग-अलग विकल्प हैं जैसे कि लुप्त होना या चमकना, और वे बहुत सस्ते हैं। हाल ही में बैंग पर बिक्री हुई थी
अपने प्रोजेक्ट को महत्व दें: ग्राफिक डिस्प्ले का उपयोग करें!: 14 कदम
अपने प्रोजेक्ट को महत्व दें: ग्राफिक डिस्प्ले का उपयोग करें!: आज के हमारे वीडियो में, मैं आपको 1.8-इंच TFT डिस्प्ले दिखाने जा रहा हूं। यह 128-बाई-160 ग्राफिक डिस्प्ले है। यह ESP32 LoRa से बड़ा है, और मैं पारंपरिक ESP32 में इसका उपयोग भी दिखाऊंगा। फिर हमारे पास असेंबली और सोर्स होगा
एक ड्रिल बैटरी के साथ अपने सोल्डरिंग आयरन को पावर दें!: 4 कदम (चित्रों के साथ)
एक ड्रिल बैटरी के साथ अपने सोल्डरिंग आयरन को पावर दें !: 2017 के जून में वापस मैं अपने माता-पिता के घर से बाहर चला गया और अपना खुद का किराए पर लेना शुरू कर दिया। कई चीजों में से एक जो बदली वह थी मेरा कार्यक्षेत्र। मैं 12'x 13' कमरे से 4' डेस्क पर गया, जिसका मतलब था कि मुझे कुछ बदलाव करने होंगे। बड़े बदलावों में से एक था स्व
अपने स्कूल के नोटिसबोर्ड को वास्तव में ध्यान देने योग्य बनाएं: 4 कदम
अपने स्कूल के नोटिसबोर्ड को वास्तव में ध्यान देने योग्य बनाएं: एक उबाऊ पुराने नोटिसबोर्ड को सस्ती कीमत पर वास्तव में आकर्षक बनाएं। एक दिन, मैं कक्षा में बैठा था, अपना काम कर रहा था (खांसी, खांसी, बात, खांसी) और मेरे विज्ञान शिक्षक ने मुझे बाहर बुलाया। बगर, मैंने सोचा। लेकिन नहीं, वह वास्तव में चाहता था कि मैं उसका निर्माण करूं
हेलो ९९८ नेत्रगोलक ट्रिम के लिए एलईडी बल्ब रेट्रोफिट: ८ कदम
हेलो 998 आईबॉल ट्रिम के लिए एलईडी बल्ब रेट्रोफिट: यह निर्देशयोग्य वर्णन करता है कि हेलो 998 आईबॉल ट्रिम टुकड़ों को कैसे संशोधित किया जाए ताकि लूमीसेलेक्ट PAR / R16 dimmable लाइट बल्ब को Earthled.com से स्वीकार किया जा सके। एलईडी बल्ब ट्रिम के नेत्रगोलक के उद्घाटन के माध्यम से फिट होने के लिए बहुत बड़ा है। टुकड़ा, लेकिन थोड़े से ef के साथ