18 KiB
আপনার IoT ডিভাইস থেকে স্টক গণনা করুন - ভার্চুয়াল IoT হার্ডওয়্যার এবং রাস্পবেরি পাই
একটি ছবিতে স্টক গণনার জন্য ভবিষ্যদ্বাণী এবং তাদের বাউন্ডিং বক্সের সংমিশ্রণ ব্যবহার করা যেতে পারে।
বাউন্ডিং বক্স দেখান
ডিবাগিংয়ের একটি সহায়ক ধাপ হিসেবে, আপনি শুধু বাউন্ডিং বক্স প্রিন্ট করাই নয়, বরং ছবিতে বাউন্ডিং বক্স আঁকতেও পারেন যা ছবি ক্যাপচার করার সময় ডিস্কে লেখা হয়েছিল।
কাজ - বাউন্ডিং বক্স প্রিন্ট করুন
-
নিশ্চিত করুন যে
stock-counter
প্রকল্পটি VS Code-এ খোলা আছে এবং আপনি যদি ভার্চুয়াল IoT ডিভাইস ব্যবহার করেন তবে ভার্চুয়াল পরিবেশটি সক্রিয় করা হয়েছে। -
for
লুপের মধ্যেprint
স্টেটমেন্টটি পরিবর্তন করে নিম্নলিখিত কোডটি ব্যবহার করুন, যাতে বাউন্ডিং বক্সগুলো কনসোলে প্রিন্ট হয়:print(f'{prediction.tag_name}:\t{prediction.probability * 100:.2f}%\t{prediction.bounding_box}')
-
অ্যাপটি চালান এবং ক্যামেরা তাক করুন শেলফে থাকা কিছু স্টকের দিকে। বাউন্ডিং বক্সগুলো কনসোলে প্রিন্ট হবে, যেখানে বাম, উপরের, প্রস্থ এবং উচ্চতার মান 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}
কাজ - ছবিতে বাউন্ডিং বক্স আঁকুন
-
Pip প্যাকেজ Pillow ব্যবহার করে ছবিতে আঁকা সম্ভব। এটি ইনস্টল করতে নিম্নলিখিত কমান্ডটি ব্যবহার করুন:
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 এর মান থেকে নিচের ডানদিকের কোঅর্ডিনেট গণনা করে। এগুলো ছবির কোঅর্ডিনেটে রূপান্তরিত হয় ছবির প্রাসঙ্গিক মাত্রার সাথে গুণ করে। উদাহরণস্বরূপ, যদি বাম মানটি 0.5 হয় এবং ছবিটি 600 পিক্সেল চওড়া হয়, এটি 300-এ রূপান্তরিত হবে (0.5 x 600 = 300)।
প্রতিটি বাউন্ডিং বক্স ছবিতে একটি লাল রেখা ব্যবহার করে আঁকা হয়। শেষে সম্পাদিত ছবিটি সংরক্ষণ করা হয়, মূল ছবির উপর লিখে।
-
অ্যাপটি চালান এবং ক্যামেরা তাক করুন শেলফে থাকা কিছু স্টকের দিকে। আপনি VS Code এক্সপ্লোরারে
image.jpg
ফাইলটি দেখতে পাবেন এবং এটি নির্বাচন করে বাউন্ডিং বক্সগুলো দেখতে পারবেন।
স্টক গণনা করুন
উপরের ছবিতে, বাউন্ডিং বক্সগুলো সামান্য ওভারল্যাপ করেছে। যদি এই ওভারল্যাপ অনেক বেশি হয়, তাহলে বাউন্ডিং বক্সগুলো একই বস্তু নির্দেশ করতে পারে। সঠিকভাবে বস্তুগুলো গণনা করতে, আপনাকে উল্লেখযোগ্য ওভারল্যাপযুক্ত বক্সগুলো উপেক্ষা করতে হবে।
কাজ - ওভারল্যাপ উপেক্ষা করে স্টক গণনা করুন
-
Pip প্যাকেজ Shapely ব্যবহার করে ইন্টারসেকশন গণনা করা সম্ভব। আপনি যদি রাস্পবেরি পাই ব্যবহার করেন, তবে প্রথমে একটি লাইব্রেরি ডিপেনডেন্সি ইনস্টল করতে হবে:
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)])
এটি একটি ভবিষ্যদ্বাণীর বাউন্ডিং বক্স ব্যবহার করে একটি পলিগন তৈরি করে।
-
ওভারল্যাপযুক্ত বস্তুগুলো সরানোর লজিকটি সমস্ত বাউন্ডিং বক্স তুলনা করে। যদি কোনো জোড়া ভবিষ্যদ্বাণীর বাউন্ডিং বক্সগুলো ওভারল্যাপ থ্রেশহোল্ডের চেয়ে বেশি হয়, তাহলে একটি ভবিষ্যদ্বাণী মুছে ফেলা হয়। তুলনা করার জন্য, প্রথম ভবিষ্যদ্বাণীটি দ্বিতীয়, তৃতীয়, চতুর্থ ইত্যাদির সাথে তুলনা করা হয়, তারপর দ্বিতীয়টি তৃতীয়, চতুর্থ ইত্যাদির সাথে। নিম্নলিখিত কোড এটি করে:
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 ব্যবহার করে অনুবাদ করা হয়েছে। আমরা যথাসাধ্য সঠিকতার জন্য চেষ্টা করি, তবে অনুগ্রহ করে মনে রাখবেন যে স্বয়ংক্রিয় অনুবাদে ত্রুটি বা অসঙ্গতি থাকতে পারে। মূল ভাষায় থাকা নথিটিকে প্রামাণিক উৎস হিসেবে বিবেচনা করা উচিত। গুরুত্বপূর্ণ তথ্যের জন্য, পেশাদার মানব অনুবাদ সুপারিশ করা হয়। এই অনুবাদ ব্যবহারের ফলে কোনো ভুল বোঝাবুঝি বা ভুল ব্যাখ্যা হলে আমরা দায়বদ্ধ থাকব না।