Validator Situng Pilpres 2019 (VSP-2019) adalah validator hasil hitung suara Pemilu Presiden & Wakil Presiden RI 2019 pada website pemilu2019.kpu.go.id berdasarkan form C1 yang terlampir. Pembuatan aplikasi yang berbasis Python 3.6 ini dilatarbelakangi tingginya kesalahan input oleh pihak KPU sehingga menurunkan tingkat kepercayaan masyarakat kepada instansi Pemerintah. Oleh karena itu, diperlukan validator yang bekerja instan dan akurat dalam memvalidasi data yang masuk.
Creator
- 2101690774 - Yukha Dharmeswara
- 2101696645 – Calvin Hartanto Honggare
Requirements Tidak ada versi spesifik, silahkan install versi terbaru, let deprecated be deprecated.
- chromedriver : http://chromedriver.chromium.org/
- requests : https://pypi.org/project/requests/
- selenium : https://pypi.org/project/selenium/
- scikit-image : https://pypi.org/project/scikit-image/
- numpy : https://pypi.org/project/numpy/
- scikit-learn : https://pypi.org/project/scikit-learn/
- opencv : https://pypi.org/project/opencv-python/
- joblib : https://pypi.org/project/joblib/
- pyqt5 : https://pypi.org/project/pyqt5/
- win32gui : https://pypi.org/project/win32gui/
- keyboard : https://pypi.org/project/keyboard/
- psutil : https://pypi.org/project/psutil/
Penggunaan Aplikasi Penggunaan VSP-2019 sangatlah mudah, anda perlu mengklik tombol Browse untuk memilih TPS yang ingin dicek, jika anda sudah berada pada halaman TPS yang diinginkan, tekan tombol “Shift” pada Keyboard anda. Jika data TPS telah dimuat, anda tinggal mengklik tombol Compare untuk melaksanakan proses validasi. Aplikasi akan memunculkan hasil validasi pada Kolom Log (elemen no. 2 pada gambar di bawah).
Cara Kerja Aplikasi
- Men-scrape data dari website KPU.
- Mengekstrak region of interest dari kolom angka pada form C1.
- Memprediksi angka yang muncul pada region of interest menggunakan LinearSVC dengan fitur HoG.
- Membandingkan angka dari website dengan dari hasil ekstrak C1.
Training Dataset Dataset didapat dari sumber website pemilu2019.kpu.go.id, khususnya dari Kabupaten Aceh Barat, Kabupaten Aceh Barat Daya, dan Kabupaten Aceh Besar pada tanggal 11 Mei 2019. Dataset ini terdiri dari 16319 digit (14120 training data + 2199 testing data) berukuran 32x32 piksel. Dataset dibagi menjadi 11 kelas, yaitu 0,1,2,3,4,5,6,7,8,9, dan X. Karena ada beberapa faktor yang menyebabkan dataset tidak dapat digunakan (Salah input, salah form, pemberian tanda X tidak formal, dicoret-coret, digit ekstraktor gagal mengekstrak data), diperlukan pembersihan secara manual, yang semestinya 23190 digit menjadi 16319 digit.
Feature Fitur yang dipakai untuk mengklasifikasi digit adalah Histogram of Oriented Gradients. Histogram of Oriented Gradients adalah feature descriptor berdasarkan histogram/distribusi dari orientasi gradien local pada gambar. HoG berguna karena dapat mengenali edge dan corner pada gambar yang merupakan bagian vital pada object recognition. HoG diperoleh dengan cara membagi gambar ke dalam beberapa cell, tiap cell akan dihitung orientasi gradiennya, lalu akan di sederhanakan menjadi n-bin(default skimage.feature.hog 9-bin). Cell akan dikelompokkan menjadi beberapa block untuk dinormalisasi. Secara default, skimage.feature.hog menggunakan L2-Hys, yaitu menormalisasi block menggunakan L2, lalu membatasi maksimum value menjadi 0.2, lalu dinormalisasi kembali menggunakan L2. L2 normalization bekerja dengan cara membagi value dengan hasil akar kuadrat dari jumlah kuadrat tiap value.
hog_feature = hog(image, orientations=9, pixels_per_cell=(4, 4), cells_per_block=(8, 8), visualize=False) Nilai parameter pixels_per_cell (ppc) dan cells_per_block (cpb) digunakan karena memiliki akurasi tertinggi saat percobaan menggunakan 2199 testing data.
Classifier Classifier yang digunakan adalah Linear Support Vector Classification, karena keterbatasan hardware yang mengurungkan saya mencoba classifier lain seperti Stochastic Gradient Descent Classifier atau Neural Networks.
Testing & Akurasi Menggunakan 2199 testing data (200 data tiap digit), akurasi tertinggi diperoleh dari ppc=(4, 4), cpb=(8, 8), dengan akurasi 0.9618008185538881.
Testing Dunia Nyata Walaupun classifier mendapat skor tinggi saat testing menggunakan 2199 testing data, nyatanya hanya berkisar 75-90%. Hal ini diakibatkan proses ekstrak angka dari form C1 yang kaku.
Saran
- Diperlukan digit extractor yang lebih baik, mayoritas terjadi misprediksi dikarenakan salah potong oleh digit extractor kami.
- Mode Otomatis sehingga user tidak perlu menunjukkan aplikasi halaman TPS secara manual. (Rencana awal VSP-2019, namun karena masalah stabilitas, bentuk aplikasi VSP-2019 diubah menjadi versi saat ini).
- Menambah kelas tambahan, yaitu “-“. Karena banyak petugas KPPS menulis X dengan “-“.
- Menambah Exception “0” = “X”. Karena banyak petugas KPPS menulis X X X pada nilai 0, semestinya X X O.
- Berhubungan dengan poin 3 dan 4, mengedukasi para petugas KPPS pentingnya menulis hasil perhitungan suara dengan teratur, bukan hanya aplikasi sulit memprediksi, manusia juga.
Source Code https://github.com/ouwyukha/ValidatorPilpres2019-dengan-HOG-LinearSVC
RAW Dataset https://drive.google.com/file/d/1HY1pI8rn60tfArCIkP9A9eM_yab3SKRe/view?usp=sharing
Referensi
- https://pemilu2019.kpu.go.id/#/ppwp/hitung-suara/
- https://selenium-python.readthedocs.io/api.html
- https://blog.chromium.org/2011/05/remote-debugging-with-chrome-developer.html
- https://www.programcreek.com/python/example/89830/win32gui.DestroyWindow
- https://www.learnopencv.com/image-alignment-feature-based-using-opencv-c-python/
- https://stackoverflow.com/questions/50759678/cropping-greyscale-images-within-larger-images-using-opencv-and-python/50760599
- https://github.com/bikz05/digit-recognition
- https://www.learnopencv.com/histogram-of-oriented-gradients/
- https://tel.archives-ouvertes.fr/tel-00390303/file/NavneetDalalThesis.pdf
- https://scikit-image.org/docs/dev/auto_examples/features_detection/plot_hog.html
- https://scikit-learn.org/stable/modules/generated/sklearn.svm.LinearSVC.html#sklearn.svm.LinearSVC