17 KiB
आपल्या IoT डिव्हाइसवरून स्टॉक मोजा - व्हर्च्युअल IoT हार्डवेअर आणि रास्पबेरी पाई
भविष्यवाण्या आणि त्यांच्या बाउंडिंग बॉक्सेसच्या संयोजनाचा उपयोग प्रतिमेमध्ये स्टॉक मोजण्यासाठी केला जाऊ शकतो.
बाउंडिंग बॉक्सेस दाखवा
डिबगिंगसाठी उपयुक्त पद्धत म्हणून, तुम्ही केवळ बाउंडिंग बॉक्सेस कन्सोलवर प्रिंट करू शकत नाही, तर जेव्हा प्रतिमा कॅप्चर केली जाते तेव्हा डिस्कवर लिहिलेल्या प्रतिमेवर ते काढूही शकता.
कार्य - बाउंडिंग बॉक्सेस प्रिंट करा
-
stock-counter
प्रकल्प VS Code मध्ये उघडा आणि जर तुम्ही व्हर्च्युअल IoT डिव्हाइस वापरत असाल, तर व्हर्च्युअल वातावरण सक्रिय करा. -
for
लूपमधीलprint
स्टेटमेंट खालीलप्रमाणे बदला, जेणेकरून बाउंडिंग बॉक्सेस कन्सोलवर प्रिंट होतील:print(f'{prediction.tag_name}:\t{prediction.probability * 100:.2f}%\t{prediction.bounding_box}')
-
अॅप चालवा आणि कॅमेरा शेल्फवरील स्टॉककडे निर्देशित करा. बाउंडिंग बॉक्सेस कन्सोलवर प्रिंट होतील, ज्यामध्ये left, top, width आणि height चे मूल्य 0-1 दरम्यान असेल.
pi@raspberrypi:~/stock-counter $ python3 app.py tomato paste: 33.42% {'additional_properties': {}, 'left': 0.3455171, 'top': 0.09916268, 'width': 0.14175442, 'height': 0.29405564} tomato paste: 34.41% {'additional_properties': {}, 'left': 0.48283678, 'top': 0.10242918, 'width': 0.11782813, 'height': 0.27467814} tomato paste: 31.25% {'additional_properties': {}, 'left': 0.4923783, 'top': 0.35007596, 'width': 0.13668466, 'height': 0.28304994} tomato paste: 31.05% {'additional_properties': {}, 'left': 0.36416405, 'top': 0.37494493, 'width': 0.14024884, 'height': 0.26880276}
कार्य - प्रतिमेवर बाउंडिंग बॉक्सेस काढा
-
Pillow हे Pip पॅकेज प्रतिमांवर काढण्यासाठी वापरले जाऊ शकते. हे खालील कमांडने इन्स्टॉल करा:
pip3 install pillow
जर तुम्ही व्हर्च्युअल IoT डिव्हाइस वापरत असाल, तर हे सक्रिय व्हर्च्युअल वातावरणातून चालवा.
-
app.py
फाईलच्या शीर्षस्थानी खालील आयात स्टेटमेंट जोडा:from PIL import Image, ImageDraw, ImageColor
हे प्रतिमा संपादित करण्यासाठी आवश्यक कोड आयात करते.
-
app.py
फाईलच्या शेवटी खालील कोड जोडा:with Image.open('image.jpg') as im: draw = ImageDraw.Draw(im) for prediction in predictions: scale_left = prediction.bounding_box.left scale_top = prediction.bounding_box.top scale_right = prediction.bounding_box.left + prediction.bounding_box.width scale_bottom = prediction.bounding_box.top + prediction.bounding_box.height left = scale_left * im.width top = scale_top * im.height right = scale_right * im.width bottom = scale_bottom * im.height draw.rectangle([left, top, right, bottom], outline=ImageColor.getrgb('red'), width=2) im.save('image.jpg')
हा कोड संपादनासाठी आधी सेव्ह केलेली प्रतिमा उघडतो. नंतर तो भविष्यवाण्यांमधून बाउंडिंग बॉक्सेस घेतो आणि 0-1 मधील बाउंडिंग बॉक्स मूल्यांचा उपयोग करून तळाचा उजवा कोपरा काढतो. हे मूल्य प्रतिमेच्या संबंधित परिमाणाने गुणाकार करून प्रतिमा समन्वयांमध्ये रूपांतरित केले जाते. उदाहरणार्थ, जर left चे मूल्य 0.5 असेल आणि प्रतिमा 600 पिक्सेल रुंद असेल, तर ते 300 मध्ये रूपांतरित होईल (0.5 x 600 = 300).
प्रत्येक बाउंडिंग बॉक्स लाल रेषेने प्रतिमेवर काढला जातो. शेवटी संपादित प्रतिमा सेव्ह केली जाते आणि मूळ प्रतिमेवर अधिलिखित केली जाते.
-
अॅप चालवा आणि कॅमेरा शेल्फवरील स्टॉककडे निर्देशित करा. तुम्हाला VS Code एक्सप्लोररमध्ये
image.jpg
फाईल दिसेल, आणि तुम्ही ती निवडून बाउंडिंग बॉक्सेस पाहू शकाल.
स्टॉक मोजा
वरील प्रतिमेत, बाउंडिंग बॉक्सेसमध्ये थोडासा ओव्हरलॅप आहे. जर हा ओव्हरलॅप खूप मोठा असेल, तर बाउंडिंग बॉक्सेस एकाच वस्तूला सूचित करू शकतात. वस्तू योग्यरित्या मोजण्यासाठी, तुम्हाला महत्त्वपूर्ण ओव्हरलॅप असलेल्या बॉक्सेसकडे दुर्लक्ष करणे आवश्यक आहे.
कार्य - ओव्हरलॅपकडे दुर्लक्ष करून स्टॉक मोजा
-
Shapely हे Pip पॅकेज इंटरसेक्शन काढण्यासाठी वापरले जाऊ शकते. जर तुम्ही रास्पबेरी पाई वापरत असाल, तर आधी एक लायब्ररी डिपेंडन्सी इन्स्टॉल करावी लागेल:
sudo apt install libgeos-dev
-
Shapely Pip पॅकेज इन्स्टॉल करा:
pip3 install shapely
जर तुम्ही व्हर्च्युअल IoT डिव्हाइस वापरत असाल, तर हे सक्रिय व्हर्च्युअल वातावरणातून चालवा.
-
app.py
फाईलच्या शीर्षस्थानी खालील आयात स्टेटमेंट जोडा:from shapely.geometry import Polygon
हे ओव्हरलॅप काढण्यासाठी बहुभुज तयार करण्यासाठी आवश्यक कोड आयात करते.
-
बाउंडिंग बॉक्सेस काढण्याच्या कोडच्या वर खालील कोड जोडा:
overlap_threshold = 0.20
हे परिभाषित करते की बाउंडिंग बॉक्सेस एकाच वस्तू मानले जाण्यासाठी किती टक्के ओव्हरलॅप अनुमत आहे. 0.20 म्हणजे 20% ओव्हरलॅप.
-
Shapely वापरून ओव्हरलॅप काढण्यासाठी, बाउंडिंग बॉक्सेस Shapely बहुभुजांमध्ये रूपांतरित करणे आवश्यक आहे. हे करण्यासाठी खालील फंक्शन जोडा:
def create_polygon(prediction): scale_left = prediction.bounding_box.left scale_top = prediction.bounding_box.top scale_right = prediction.bounding_box.left + prediction.bounding_box.width scale_bottom = prediction.bounding_box.top + prediction.bounding_box.height return Polygon([(scale_left, scale_top), (scale_right, scale_top), (scale_right, scale_bottom), (scale_left, scale_bottom)])
हे भविष्यवाणीच्या बाउंडिंग बॉक्सचा उपयोग करून एक बहुभुज तयार करते.
-
ओव्हरलॅपिंग वस्तू काढण्यासाठीची लॉजिक सर्व बाउंडिंग बॉक्सेसची तुलना करते. जर कोणत्याही जोडीच्या भविष्यवाण्यांमध्ये बाउंडिंग बॉक्सेस ओव्हरलॅप थ्रेशोल्डपेक्षा जास्त असेल, तर त्या भविष्यवाण्यांपैकी एक काढून टाकली जाते. सर्व भविष्यवाण्यांची तुलना करण्यासाठी, तुम्ही भविष्यवाणी 1 ची 2, 3, 4 इत्यादींसोबत तुलना करता, नंतर 2 ची 3, 4 इत्यादींसोबत. खालील कोड हे करतो:
to_delete = [] for i in range(0, len(predictions)): polygon_1 = create_polygon(predictions[i]) for j in range(i+1, len(predictions)): polygon_2 = create_polygon(predictions[j]) overlap = polygon_1.intersection(polygon_2).area smallest_area = min(polygon_1.area, polygon_2.area) if overlap > (overlap_threshold * smallest_area): to_delete.append(predictions[i]) break for d in to_delete: predictions.remove(d) print(f'Counted {len(predictions)} stock items')
ओव्हरलॅप Shapely च्या
Polygon.intersection
पद्धतीचा वापर करून काढला जातो, जी ओव्हरलॅप असलेले बहुभुज परत करते. या बहुभुजाचा क्षेत्रफळ काढले जाते. हा ओव्हरलॅप थ्रेशोल्ड एक निश्चित मूल्य नाही, तर बाउंडिंग बॉक्सच्या टक्केवारीचा विचार करतो. त्यामुळे सर्वात लहान बाउंडिंग बॉक्स शोधला जातो आणि ओव्हरलॅप थ्रेशोल्डचा उपयोग करून ओव्हरलॅप क्षेत्रफळ काढले जाते. जर ओव्हरलॅप यापेक्षा जास्त असेल, तर भविष्यवाणी काढून टाकण्यासाठी चिन्हांकित केली जाते.एकदा भविष्यवाणी काढून टाकण्यासाठी चिन्हांकित केली गेली की, ती पुन्हा तपासण्याची गरज नाही, त्यामुळे अंतर्गत लूप पुढील भविष्यवाणी तपासण्यासाठी ब्रेक होतो. यादीतून आयटम काढून टाकताना त्यावर पुनरावृत्ती करता येत नाही, त्यामुळे थ्रेशोल्डपेक्षा जास्त ओव्हरलॅप असलेल्या बाउंडिंग बॉक्सेस
to_delete
यादीत जोडले जातात आणि नंतर शेवटी काढून टाकले जातात.शेवटी, स्टॉक काउंट कन्सोलवर प्रिंट केला जातो. हा काउंट IoT सेवेला पाठवून स्टॉक पातळी कमी असल्यास अलर्ट पाठवता येतो. हा सर्व कोड बाउंडिंग बॉक्सेस काढण्याच्या आधी आहे, त्यामुळे तुम्हाला तयार केलेल्या प्रतिमांवर ओव्हरलॅपशिवाय स्टॉक भविष्यवाणी दिसेल.
💁 हा ओव्हरलॅप काढण्याचा खूप साधा मार्ग आहे, ज्यामध्ये ओव्हरलॅप असलेल्या जोडीतील पहिला काढून टाकला जातो. उत्पादन कोडसाठी, तुम्हाला येथे अधिक लॉजिक जोडावे लागेल, जसे की अनेक वस्तूंच्या ओव्हरलॅपचा विचार करणे, किंवा एक बाउंडिंग बॉक्स दुसऱ्यामध्ये समाविष्ट असल्यास.
-
अॅप चालवा आणि कॅमेरा शेल्फवरील स्टॉककडे निर्देशित करा. आउटपुटमध्ये थ्रेशोल्डपेक्षा जास्त ओव्हरलॅप नसलेल्या बाउंडिंग बॉक्सेसची संख्या दिसेल.
overlap_threshold
मूल्य समायोजित करून भविष्यवाण्या कशा दुर्लक्षित केल्या जातात ते पाहा.
💁 तुम्हाला हा कोड code-count/pi किंवा code-count/virtual-iot-device फोल्डरमध्ये सापडेल.
😀 तुमचा स्टॉक काउंटर प्रोग्राम यशस्वी झाला!
अस्वीकरण:
हा दस्तऐवज AI भाषांतर सेवा Co-op Translator वापरून भाषांतरित करण्यात आला आहे. आम्ही अचूकतेसाठी प्रयत्नशील असलो तरी कृपया लक्षात ठेवा की स्वयंचलित भाषांतरांमध्ये त्रुटी किंवा अचूकतेचा अभाव असू शकतो. मूळ भाषेतील दस्तऐवज हा अधिकृत स्रोत मानला जावा. महत्त्वाच्या माहितीसाठी व्यावसायिक मानवी भाषांतराची शिफारस केली जाते. या भाषांतराचा वापर करून निर्माण होणाऱ्या कोणत्याही गैरसमज किंवा चुकीच्या अर्थासाठी आम्ही जबाबदार राहणार नाही.