Skip to content

Latest commit

 

History

History
179 lines (101 loc) · 10.4 KB

File metadata and controls

179 lines (101 loc) · 10.4 KB

Pengesanan Objek

Model klasifikasi imej yang telah kita pelajari sebelum ini mengambil imej dan menghasilkan keputusan kategori, seperti kelas 'nombor' dalam masalah MNIST. Walau bagaimanapun, dalam banyak kes, kita bukan sahaja ingin mengetahui bahawa gambar menggambarkan objek - kita juga ingin menentukan lokasi tepatnya. Inilah tujuan utama pengesanan objek.

Pengesanan Objek

Imej dari laman web YOLO v2

Pendekatan Naif untuk Pengesanan Objek

Jika kita ingin mencari seekor kucing dalam gambar, pendekatan naif untuk pengesanan objek adalah seperti berikut:

  1. Pecahkan gambar kepada beberapa jubin.
  2. Jalankan klasifikasi imej pada setiap jubin.
  3. Jubin yang menghasilkan pengaktifan yang cukup tinggi boleh dianggap mengandungi objek yang dicari.

Pengesanan Objek Naif

Imej dari Buku Latihan

Walau bagaimanapun, pendekatan ini jauh dari ideal kerana ia hanya membolehkan algoritma menentukan kotak sempadan objek dengan sangat tidak tepat. Untuk lokasi yang lebih tepat, kita perlu menjalankan sejenis regresi untuk meramalkan koordinat kotak sempadan - dan untuk itu, kita memerlukan dataset khusus.

Regresi untuk Pengesanan Objek

Blog post ini memberikan pengenalan yang baik tentang pengesanan bentuk.

Dataset untuk Pengesanan Objek

Anda mungkin akan menemui dataset berikut untuk tugas ini:

  • PASCAL VOC - 20 kelas
  • COCO - Common Objects in Context. 80 kelas, kotak sempadan dan topeng segmentasi

COCO

Metrik Pengesanan Objek

Intersection over Union

Untuk klasifikasi imej, mudah untuk mengukur sejauh mana algoritma berfungsi, tetapi untuk pengesanan objek kita perlu mengukur kedua-dua ketepatan kelas dan ketepatan lokasi kotak sempadan yang diramalkan. Untuk yang terakhir, kita menggunakan Intersection over Union (IoU), yang mengukur sejauh mana dua kotak (atau dua kawasan arbitrari) bertindih.

IoU

Rajah 2 dari blog post yang sangat baik tentang IoU

Ideanya mudah - kita membahagikan kawasan persilangan antara dua figura dengan kawasan gabungannya. Untuk dua kawasan yang sama, IoU akan menjadi 1, manakala untuk kawasan yang tidak bertindih sepenuhnya ia akan menjadi 0. Jika tidak, ia akan berbeza dari 0 hingga 1. Kita biasanya hanya mempertimbangkan kotak sempadan yang mempunyai IoU melebihi nilai tertentu.

Average Precision

Misalkan kita ingin mengukur sejauh mana kelas objek tertentu $C$ dikenali. Untuk mengukurnya, kita menggunakan metrik Average Precision, yang dikira seperti berikut:

  1. Pertimbangkan lengkung Precision-Recall yang menunjukkan ketepatan bergantung pada nilai ambang pengesanan (dari 0 hingga 1).
  2. Bergantung pada ambang, kita akan mendapat lebih atau kurang objek yang dikesan dalam imej, dan nilai ketepatan dan recall yang berbeza.
  3. Lengkungnya akan kelihatan seperti ini:

Imej dari NeuroWorkshop

Purata Precision untuk kelas tertentu $C$ adalah kawasan di bawah lengkung ini. Lebih tepat lagi, paksi Recall biasanya dibahagikan kepada 10 bahagian, dan Precision diambil purata untuk semua titik tersebut:

$$ AP = {1\over11}\sum_{i=0}^{10}\mbox{Precision}(\mbox{Recall}={i\over10}) $$

AP dan IoU

Kita hanya akan mempertimbangkan pengesanan yang mempunyai IoU melebihi nilai tertentu. Sebagai contoh, dalam dataset PASCAL VOC biasanya $\mbox{IoU Threshold} = 0.5$ diandaikan, manakala dalam COCO AP diukur untuk nilai $\mbox{IoU Threshold}$ yang berbeza.

Imej dari NeuroWorkshop

Mean Average Precision - mAP

Metrik utama untuk Pengesanan Objek dipanggil Mean Average Precision, atau mAP. Ia adalah nilai Average Precision, purata merentasi semua kelas objek, dan kadang-kadang juga merentasi $\mbox{IoU Threshold}$. Proses pengiraan mAP dijelaskan dengan lebih terperinci dalam blog post ini), dan juga di sini dengan contoh kod.

Pendekatan Berbeza untuk Pengesanan Objek

Terdapat dua kelas utama algoritma pengesanan objek:

  • Region Proposal Networks (R-CNN, Fast R-CNN, Faster R-CNN). Idea utama adalah untuk menghasilkan Regions of Interests (ROI) dan menjalankan CNN ke atasnya, mencari pengaktifan maksimum. Ia agak serupa dengan pendekatan naif, kecuali ROI dihasilkan dengan cara yang lebih bijak. Salah satu kelemahan utama kaedah ini adalah ia perlahan kerana kita memerlukan banyak laluan pengklasifikasi CNN ke atas imej.
  • One-pass (YOLO, SSD, RetinaNet) kaedah. Dalam seni bina ini, kita mereka bentuk rangkaian untuk meramalkan kedua-dua kelas dan ROI dalam satu laluan.

R-CNN: Region-Based CNN

R-CNN menggunakan Selective Search untuk menghasilkan struktur hierarki kawasan ROI, yang kemudian dilalui oleh pengekstrak ciri CNN dan pengklasifikasi SVM untuk menentukan kelas objek, dan regresi linear untuk menentukan koordinat kotak sempadan. Kertas Rasmi

RCNN

Imej dari van de Sande et al. ICCV’11

RCNN-1

*Imej dari blog ini

F-RCNN - Fast R-CNN

Pendekatan ini serupa dengan R-CNN, tetapi kawasan ditentukan selepas lapisan konvolusi diterapkan.

FRCNN

Imej dari Kertas Rasmi, arXiv, 2015

Faster R-CNN

Idea utama pendekatan ini adalah menggunakan rangkaian neural untuk meramalkan ROI - yang dipanggil Region Proposal Network. Kertas, 2016

FasterRCNN

Imej dari kertas rasmi

R-FCN: Region-Based Fully Convolutional Network

Algoritma ini lebih pantas daripada Faster R-CNN. Idea utama adalah seperti berikut:

  1. Kita mengekstrak ciri menggunakan ResNet-101.
  2. Ciri-ciri diproses oleh Position-Sensitive Score Map. Setiap objek dari $C$ kelas dibahagikan kepada $k\times k$ kawasan, dan kita melatih untuk meramalkan bahagian objek.
  3. Untuk setiap bahagian dari $k\times k$ kawasan, semua rangkaian mengundi untuk kelas objek, dan kelas objek dengan undian maksimum dipilih.

r-fcn image

Imej dari kertas rasmi

YOLO - You Only Look Once

YOLO adalah algoritma satu-laluan masa nyata. Idea utama adalah seperti berikut:

  • Imej dibahagikan kepada $S\times S$ kawasan.
  • Untuk setiap kawasan, CNN meramalkan $n$ objek yang mungkin, koordinat kotak sempadan dan confidence=probability * IoU.

YOLO

Imej dari kertas rasmi

Algoritma Lain

✍️ Latihan: Pengesanan Objek

Teruskan pembelajaran anda dalam buku latihan berikut:

ObjectDetection.ipynb

Kesimpulan

Dalam pelajaran ini, anda telah mengambil lawatan pantas tentang pelbagai cara pengesanan objek dapat dicapai!

🚀 Cabaran

Baca artikel dan buku latihan tentang YOLO ini dan cuba sendiri

Ulasan & Kajian Kendiri