Decision Support System Series

Evaluation based on Distance from Average Solution (EDAS)

Contoh implementasi DSS (Decision Support System) dengan Metode Evaluation based on Distance from Average Solution (EDAS) menggunakan PHP dan MySQL untuk pemilihan lokasi parkir komuter terbaik

Metode Evaluation based on Distance from Average Solution (EDAS) merupakan salah satu metode pengambilan keputusan multikriteria berdasarkan pada skor penilaian Apraisal Score (AS) tertinggi untuk mendapatkan pilihan terbaik dari semua alternatif.

author : cahya dsn, published on : July 17th, 2020 updated on : March 18th, 2021

minerva minerva donasi donation

Mau lihat artikel lainya? Dapatkan artikel-artikel lain seputar pemrograman website di sini, dan dapatkan ide-ide baru

Pre-requisites

  • Pemahaman terhadap dasar-dasar Sistem Pengambilan Keputusan
  • Pemahaman terhadap dasar-dasar teknologi Web,HTML dan CSS
  • Pemahaman terhadap dasar-dasar basis data/database, terutama query SQL pada MySQL/mariaDB
  • Pemahaman terhadap dasar-dasar pemrograman PHP, terutama fungsi-fungsi koneksi database dan pengelolaan tipe data array

1.1. Tahapan Metode EDAS

Metode Evaluation based on Distance from Average Solution EDAS diperkenalkan oleh KeshavarazvvGhorabaee,vet all pada tahun 2015. Dalam melakukan menyelesaikan masalah dan perangkingan, metode EDAS memiliki beberapa langkah yaitu:

1.1.1. Pembentukan Matriks Keputusan (Decision Making Matrix - X)

Pada matriks keputusan (X), baris menunjukkan Alternatif dan kolom menunjukkan kriteria. Matriks keputusan menunjukkan kinerja dari masing-masing alternatif terhadap berbagai kriteria

$X=\left[\begin{array}{cccc} x_{01} & \ldots & x_{0j} & \ldots & x_{0n} \\ \vdots & \ddots & \vdots & \ddots & \vdots \\ x_{i1} & \ldots & x_{ij} & \ldots & x_{in} \\ \vdots & \ddots & \vdots & \ddots & \vdots \\ x_{m1} & \ldots & x_{m2} & \ldots & x_{mn} \\ \end{array}\right] (i=0,1,2,...,m; j=1,2,...,n)$
.. [EDA-01]

xij menunjukkan nilai kinerja alternatif ke-i pada kriteria ke-j, m adalah banyaknya alternatif sedangkan n adalah banyaknya kriteria.

1.1.2. Menentukan Solusi Rata-rata Average Solution (AV)

Solusi rata-rata (AV) sesuai dengan kriteria,ditentukan dengan menggunakan persamaan :

$AV=[AV_{j}]_{1\times m}$
.. [EDA-02]

dimana nilai dari AVj dapat dihitung dengan persamaan :

$AV_{j}=\frac{\sum^n_{i=1}X_{ij}}{n}$
.. [EDA-03]

1.1.3. Menentukan Jarak Positif/Negatif dari Rata-rata (PDA/NDA)

Hitung jarak positif dari matriks rata-rata (PDA) dan jarak negatif dari matriks rata-rata (NDA) sesuai jenis kriteria (benefit dan cost) dengan menggunakan persamaan :

$PDA=[PDA_{ij}]_{n\times m}$
.. [EDA-04]
$NDA=[NDA_{ij}]_{n\times m}$
.. [EDA-05]

Untuk kriteria ke-j yang merupakan kriteria bertipe Benefit maka berlaku :

$PDA_{ij}=\frac{max(0,(X_{ij}-AV_{j}))}{AV_{j}}$
.. [EDA-06]
$NDA_{ij}=\frac{max(0,(AV_{j}-X_{ij}))}{AV_{j}}$
.. [EDA-07]

Sedangkan untuk kriteria ke-j yang merupakan kriteria bertipe Cost maka berlaku :

$PDA_{ij}=\frac{max(0,(AV_{j}-X_{ij}))}{AV_{j}}$
.. [EDA-08]
$NDA_{ij}=\frac{max(0,(X_{ij}-AV_{j}))}{AV_{j}}$
.. [EDA-09]

1.1.4. Menentukan Jumlah Terbobot dari PDA/NDA (SP/SN)

Menentukan jumlah terbobot dari PDA dan NDA untuk semua alternatif dengan persamaan EDA-10 dan EDA-11 berikut ini:

$SP_{i}=\sum^{m}_{j=1}w_j\times PDA_{ij}$
.. [EDA-10]
$SN_{i}=\sum^{m}_{j=1}w_j\times NDA_{ij}$
.. [EDA-11]

Nilai SPi dan SNi, masing-masing adalah nilai jumlah terbobot dari PDA dan NDA untuk setiap alternatif ke-i.

1.1.5. Normalisasi Nilai SP/SN (NSP/NSN)

Tahap berikutnya adalah menghitung nilai normalisasi dari SP daan SN untuk semua alternatif.

$NSP_{i}=\frac{SP_{i}}{max_{i}(SP_{i})}$
.. [EDA-12]
$NSN_{i}=1-\frac{SN_{i}}{max_{i}(SN_{i})}$
.. [EDA-13]

1.1.6. Menghitung Nilai Skor Penilaian (AS)

Setelah nilai normalisasi NSP dan NSN diperoleh, maka dihitung nilai Apraisal Score - Nilai Penilaian - AS sebagai berikut:

$AS_{i}=\frac{1}{2}(NSP_{i}+NSN_{i}) ; \text{ dengan } 0 \leq AS_{i} \leq 1$
.. [EDA-14]

1.1.7. Perankingan

Tahap yang terakhir adalah perangkingan dari nilai skor penilaian AS dari nilai yang tertinggi hingga yang terendah. Alternatif dengan nilai yang tertinggi menunjukkan alternatif yang terbaik.

2.1. Kriteria dan Bobot

Pada kasus penentuan pemilihan lokasi parkir komuter terbaik ini telah ditentukan 9 buah kriteria yang diperhitungkan, yaitu Sistem Informasi Pendukung, Frekuensi Angkutan Umum di lokasi, Total Biaya Parkir dan Angkutan Umum, Luas Lahan, Keunggulan Transportasi Umum dibanding Angkutan Pribadi, Harga Tempat Parkir, Lokasi Parkir Gratis di Pusat Kota, Jarak ke Pusat Kota, dan Trafik Angkutan Umum di Lokasi dengan rincian bobot penilaian seperti pada TABEL 1 berikut :

TABEL 1 : Kriteria dan Bobot Pemilihan Rumah
KodeKriteriaTipe[1]Bobot[2]
C1Sistem Informasi Pendukungbenefit0.086
C2Frekuensi Angkutan Umum di lokasibenefit0.100
C3Total Biaya Parkir dan Angkutan Umumcost0.171
C4Luas Lahanbenefit0.143
C5Keunggulan Transportasi Umum dibanding Angkutan Pribadibenefit0.071
C6Harga Tempat Parkircost0.200
C7Lokasi Parkir Gratis di Pusat Kotacost0.043
C8Jarak ke Pusat Kotacost0.057
C9Trafik Angkutan Umum di Lokasicost0.114
[1] `benefit` menandakan lebih besar lebih baik (Benefit Criteria) sedangkan `cost` menandakan lebih kecil lebih baik (Cost Criteria)
[2] Nilai bobot ditentukan oleh pakar/orang yang berwenang/kompeten untuk memberi pembobotan; atau bisa diperoleh dari hasil kuisioner

2.2. Contoh Data

Data-data awal yang akan diperhitungkan dengan metoda EDAS ini adalah seperti yang tercantum dalam TABEL 2 berikut ini [3]

TABEL 2 : Contoh Data
Alternatif Kriteria
Kode Nama C1C2C3C4C5C6C7C8C9
A1Area 11445865323
A2Petak 51248863444
A3Blok 77246956344
A4Komplek 77255746344
A5Area 29237945433
A6Lot 31354946533
A7Blok 11436645343
A8Blok 57345946443
A9Area 13447763545
A10Area 23355884343
A11Lot 77234966434
A12Area 51247676434
A13Area 31234776534
A14Komplek 23237653434

Keterangan

  • C1 : Sistem Informasi Pendukung
  • C2 : Frekuensi Angkutan Umum di lokasi
  • C3 : Total Biaya Parkir dan Angkutan Umum
  • C4 : Luas Lahan
  • C5 : Keunggulan Transportasi Umum dibanding Angkutan Pribadi
  • C6 : Harga Tempat Parkir
  • C7 : Lokasi Parkir Gratis di Pusat Kota
  • C8 : Jarak ke Pusat Kota
  • C9 : Trafik Angkutan Umum di Lokasi

[3] Data yang diberikan merupakan data yang sudah dikuantisasi, bukan berupa data mentah. Data dalam contoh di generate secara otomatis dari nilai acak/random

2.3. Perhitungan

Berikut ini akan dijabarkan perhitungan dengan metoda EDAS secara manual lengkah demi langkah untuk memudahkan pemahaman terhadap metoda EDAS ini

2.3.1. Matriks Keputusan (X)

Langkah pertama adalah membuat matriks keputusan (X) dari data awal yang ada. Dari data pada TABEL 2 dapat dibuat matriks keputusan sebagai berikut :

$X=\left[ \begin{array}{ccccccccccc}\\ 4 & 4 & 5 & 8 & 6 & 5 & 3 & 2 & 3 \\2 & 4 & 8 & 8 & 6 & 3 & 4 & 4 & 4 \\2 & 4 & 6 & 9 & 5 & 6 & 3 & 4 & 4 \\2 & 5 & 5 & 7 & 4 & 6 & 3 & 4 & 4 \\2 & 3 & 7 & 9 & 4 & 5 & 4 & 3 & 3 \\3 & 5 & 4 & 9 & 4 & 6 & 5 & 3 & 3 \\4 & 3 & 6 & 6 & 4 & 5 & 3 & 4 & 3 \\3 & 4 & 5 & 9 & 4 & 6 & 4 & 4 & 3 \\4 & 4 & 7 & 7 & 6 & 3 & 5 & 4 & 5 \\3 & 5 & 5 & 8 & 8 & 4 & 3 & 4 & 3 \\2 & 3 & 4 & 9 & 6 & 6 & 4 & 3 & 4 \\2 & 4 & 7 & 6 & 7 & 6 & 4 & 3 & 4 \\2 & 3 & 4 & 7 & 7 & 6 & 5 & 3 & 4 \\2 & 3 & 7 & 6 & 5 & 3 & 4 & 3 & 4\end{array} \right]$

Pada matriks keputusan (X) tersebut, data pada baris ke-i adalah menunjukan data dari Alternatif ke-i; sedangkan data pada kolom ke-j menunjukkan kriteria ke-j. Misalnya untuk data x1,9 menunjukkan data untuk alternatif ke 1 yaitu Area 11 untuk kriteria ke 9 (Trafik Angkutan Umum di Lokasi) dengan nilai 3

Secara lengkap, matriks keputusan (X) yang diperoleh dapat ditampilkan dalam bentuk tabel sebagai berikut

TABEL 3 : Matriks Keputusan (X)
Alternatif Kriteria
KodeNama C1C2C3C4C5C6C7C8C9
A1Area 11445865323
A2Petak 51248863444
A3Blok 77246956344
A4Komplek 77255746344
A5Area 29237945433
A6Lot 31354946533
A7Blok 11436645343
A8Blok 57345946443
A9Area 13447763545
A10Area 23355884343
A11Lot 77234966434
A12Area 51247676434
A13Area 31234776534
A14Komplek 23237653434

2.3.2. Nilai Solusi Rata-rata (AV)

Nilai Solusi Rata-rata (AV) dari tiap-tiap kriteria diperhitungkan dari nilai rata-rata nilai semua alternatif pada kriteria tertentu. Sebagai contoh untuk kriteria ke-9 (Trafik Angkutan Umum di Lokasi) dapat dihitung nilai solusi rata-ratanya (AV9) sebagai berikut

$\begin{align} AV_{9}&=\frac{\sum_{i=1}^{14} X_{i,9}}{14} \\ &=\frac{X_{1,9}+X_{2,9}+X_{3,9}+X_{4,9}+X_{5,9}+X_{6,9}+X_{7,9}+X_{8,9}+X_{9,9}+X_{10,9}+X_{11,9}+X_{12,9}+X_{13,9}+X_{14,9}}{14} \\ &=\frac{3+4+4+4+3+3+3+3+5+3+4+4+4+4}{14} \\ &=\frac{51}{14} \\ &=3.643\end{align}$

Dengan perhitungan yang sama, dilakukan perhitungan nilai solusi rata-rata AV untuk kriteria-kriteria yang lain sehingga diperoleh matriks nilai solusi rata-rata AV sebagai berikut:

$AV=[2.643\ \ \ 3.857\ \ \ 5.714\ \ \ 7.714\ \ \ 5.429\ \ \ 5.000\ \ \ 3.857\ \ \ 3.429\ \ \ 3.643]$

2.3.3. Menghitung Jarak Positif/Negatif dari Rata-rata (PDA/NDA)

Setelah didapat nilai solusi rata-ratanya (AV), berikutnya adalah menghitung nilai jarak Positif/Negatif dari rata-rata (PDA/NDA). Untuk kriteria yang bertipe benefit maka berdasarkan persamaan EDA-06 dan EDA-07 dapat dicari nilai PDA/NDA-nya. Sebagai contoh untuk kriteria ke-2 (Frekuensi Angkutan Umum di lokasi) pada alternatif ke-1 (Area 11) bisa dihitung nilai PDA1,2 dan NDA1,2 sebagai berikut:

$\begin{align} PDA_{1,2}&= \text{max}(0,\ \frac{(X_{1,2}-AV_{2})}{AV_{2}}) \\ &=\text{max}(0,\ \frac{(4.000-3.857)}{3.857}) \\ &=\text{max}(0,\ \frac{0.143}{3.857}) \\ &=\text{max}(0,\ 0.037) \\ &=0.037 \\ NDA_{1,2}&= \text{max}(0,\ \frac{(AV_{2}-X_{1,2})}{AV_{2}}) \\ &=\text{max}(0,\ \frac{(3.857-4.000)}{3.857}) \\ &=\text{max}(0,\ \frac{-0.143}{3.857}) \\ &=\text{max}(0,\ -0.037) \\ &=0\end{align}$

Sedangkan untuk kriteria yang bertipe cost maka dapat dicari nilai PDA/NDA-nya berdasarkan persamaan EDA-08 dan EDA-09 . Sebagai contoh untuk kriteria ke-7 (Lokasi Parkir Gratis di Pusat Kota) pada alternatif ke-1 (Area 11) bisa dihitung nilai PDA1,7 dan NDA1,7 sebagai berikut:

$\begin{align} PDA_{1,7}&= \text{max}(0,\ \frac{(AV_{7}-X_{1,7})}{AV_{7}}) \\ &=\text{max}(0,\ \frac{(3.857-3.000)}{3.857}) \\ &=\text{max}(0,\ \frac{0.857}{3.857}) \\ &=\text{max}(0,\ 0.222) \\ &=0.222 \\ NDA_{1,7}&= \text{max}(0,\ \frac{(X_{1,7}-AV_{7})}{AV_{7}}) \\ &=\text{max}(0,\ \frac{(3.000-3.857)}{3.857}) \\ &=\text{max}(0,\ \frac{-0.857}{3.857}) \\ &=\text{max}(0,\ -0.222) \\ &=0 \\ \end{align}$

Dengan perhitungan yang sama untuk semua data dari matriks keputusan (X) diperoleh data jarak positif dari solusi rata-rata (PDA) seperti dalam TABEL 4 berikut ini:

TABEL 4 : Jarak Positif dari Solusi Rata-rata (PDA)
No.AlternatifPDA
KodeNamaC1C2C3C4C5C6C7C8C9
1A1Area 110.5140.0370.1250.0370.1050.0000.2220.4170.176
2A2Petak 510.0000.0370.0000.0370.1050.4000.0000.0000.000
3A3Blok 770.0000.0370.0000.1670.0000.0000.2220.0000.000
4A4Komplek 770.0000.2960.1250.0000.0000.0000.2220.0000.000
5A5Area 290.0000.0000.0000.1670.0000.0000.0000.1250.176
6A6Lot 310.1350.2960.3000.1670.0000.0000.0000.1250.176
7A7Blok 110.5140.0000.0000.0000.0000.0000.2220.0000.176
8A8Blok 570.1350.0370.1250.1670.0000.0000.0000.0000.176
9A9Area 130.5140.0370.0000.0000.1050.4000.0000.0000.000
10A10Area 230.1350.2960.1250.0370.4740.2000.2220.0000.176
11A11Lot 770.0000.0000.3000.1670.1050.0000.0000.1250.000
12A12Area 510.0000.0370.0000.0000.2890.0000.0000.1250.000
13A13Area 310.0000.0000.3000.0000.2890.0000.0000.1250.000
14A14Komplek 230.0000.0000.0000.0000.0000.4000.0000.1250.000

Sedangkan untuk data jarak negatif dari solusi rata-rata (NDA) seperti dalam TABEL 5 berikut ini:

TABEL 5 : Jarak Negatif dari Solusi Rata-rata (NDA)
No.AlternatifNDA
KodeNamaC1C2C3C4C5C6C7C8C9
1A1Area 110.0000.0000.0000.0000.0000.0000.0000.0000.000
2A2Petak 510.2430.0000.4000.0000.0000.0000.0370.1670.098
3A3Blok 770.2430.0000.0500.0000.0790.2000.0000.1670.098
4A4Komplek 770.2430.0000.0000.0930.2630.2000.0000.1670.098
5A5Area 290.2430.2220.2250.0000.2630.0000.0370.0000.000
6A6Lot 310.0000.0000.0000.0000.2630.2000.2960.0000.000
7A7Blok 110.0000.2220.0500.2220.2630.0000.0000.1670.000
8A8Blok 570.0000.0000.0000.0000.2630.2000.0370.1670.000
9A9Area 130.0000.0000.2250.0930.0000.0000.2960.1670.373
10A10Area 230.0000.0000.0000.0000.0000.0000.0000.1670.000
11A11Lot 770.2430.2220.0000.0000.0000.2000.0370.0000.098
12A12Area 510.2430.0000.2250.2220.0000.2000.0370.0000.098
13A13Area 310.2430.2220.0000.0930.0000.2000.2960.0000.098
14A14Komplek 230.2430.2220.2250.2220.0790.0000.0370.0000.098

2.3.4. Menghitung Jumlah Terbobot PDA/NDA (SP/SN)

Nilai SP/SN merupakan jumlah dari nilai PDA/NDA dikalikan dengan bobot (w) sesuai dengan kriterianya untuk setiap alternatif. Sebagai misal, SP1 merupakan penjumlahan dari perkalian nilai PDA1,j dengan bobot kriteria ke-j (wj). Sesuai dengan persamaan EDA-10 didapat nilai SP1 sebagai berikut :

$\begin{align} SP_{1}&= \sum_{j=1}^{9} w_{j} \times PDA_{1,j}\\ &=w_{1} * PDA_{1,1}+w_{2} * PDA_{1,2}+w_{3} * PDA_{1,3}+w_{4} * PDA_{1,4}+w_{5} * PDA_{1,5}+w_{6} * PDA_{1,6}+w_{7} * PDA_{1,7}+w_{8} * PDA_{1,8}+w_{9} * PDA_{1,9}\\ &=0.086 * 0.514+0.100 * 0.037+0.171 * 0.125+0.143 * 0.037+0.071 * 0.105+0.200 * 0.000+0.043 * 0.222+0.057 * 0.417+0.114 * 0.176\\ &=0.044+0.004+0.021+0.005+0.008+0.000+0.010+0.024+0.020\\ &=0.13545892199143\\ \end{align}$

Sedangkan nilai SN1 merupakan penjumlahan dari perkalian nilai NDA1,j dengan bobot kriteria ke-j (wj), sesuai dengan persamaan EDA-11 dapat dihitung sebagai berikut:

$\begin{align} SN_{1}&= \sum_{j=1}^{9} w_{j} \times NDA_{1,j}\\ &=w_{1} * NDA_{1,1}+w_{2} * NDA_{1,2}+w_{3} * NDA_{1,3}+w_{4} * NDA_{1,4}+w_{5} * NDA_{1,5}+w_{6} * NDA_{1,6}+w_{7} * NDA_{1,7}+w_{8} * NDA_{1,8}+w_{9} * NDA_{1,9}\\ &=0.086 * 0.514+0.100 * 0.037+0.171 * 0.125+0.143 * 0.037+0.071 * 0.105+0.200 * 0.000+0.043 * 0.222+0.057 * 0.417+0.114 * 0.176\\ &=0.000+0.000+0.000+0.000+0.000+0.000+0.000+0.000+0.000\\ &=0\\ \end{align}$

Setelah dilakukan perhitungan yang sama untuk alternatif-alternatif yang lain, maka diperoleh nilai SP/SN seperti dalam TABEL 6 berikut ini :

TABEL 6 : Jumlah Terbobot PDA/NDA (SP/SN)
No.AlternatifSPSN
KodeNama
1A1Area 110.135460.00000
2A2Petak 510.096510.11174
3A3Blok 770.037040.09579
4A4Komplek 770.060580.11360
5A5Area 290.051120.10203
6A6Lot 310.143760.07150
7A7Blok 110.073710.09086
8A8Blok 570.080690.06991
9A9Area 130.135240.11660
10A10Area 230.171460.00952
11A11Lot 770.089900.09586
12A12Area 510.031520.14396
13A13Area 310.079250.12020
14A14Komplek 230.087140.13182

2.3.5. Menghitung Nilai Normalisasi SP/SN (NSP/NSN)

Nilai jumlah terbobot SP/SN setiap alternatif selanjutnya dinormalisasi dengan membaginya dengan nilai maksimum nilai SP/SN-nya. Sebagai contoh untuk nilai NSP1 -- nilai NSP dari alternatif ke-1(Area 11) -- dihitung berdasarkan persamaan EDA-12 yaitu nilai SP1 dibagi dengan nilai max(SP), seperti perhitungan berikut:

$\begin{align} NSP_{1}&=\frac{SP_{1}}{\text{max}(SP)}\\ &=\frac{0.13546}{0.17146}\\ &=0.79003828259736\end{align}$

$\begin{align} NSN_{1}&=1-\frac{SN_{1}}{\text{max}(SN)}\\ &=1-\frac{0.00000}{0.14396}\\ &=1\end{align}$

Untuk alternatif-alternatif yang lain bisa dihitung nilai NSP/NSN-nya dengan cara yang sama, dan hasilnya adalah sebagai berikut:

TABEL 7 : Nilai Ternormalisasi NSP/NSN
No.AlternatifNSPNSN
KodeNama
1A1Area 110.790041.00000
2A2Petak 510.562900.22383
3A3Blok 770.216010.33461
4A4Komplek 770.353330.21087
5A5Area 290.298150.29127
6A6Lot 310.838460.50336
7A7Blok 110.429880.36884
8A8Blok 570.470630.51439
9A9Area 130.788750.19006
10A10Area 231.000000.93384
11A11Lot 770.524320.33409
12A12Area 510.183850.00000
13A13Area 310.462200.16502
14A14Komplek 230.508240.08432

2.3.6. Menghitung Nilai Skor Penilaian (AS)

Nilai skor penilaian atau Apraisal Score (AS) didasarkan pada persamaan EDA-14, sebagai contoh untuk skor penilaian dari alternatif ke-1 (Area 11) dapt dihitung sebagai berikut:

$\begin{align} AS_{1}&=\frac{1}{2} (NSP_{1}+NSN_{1})\\ &=\frac{1}{2}(0.79004+1.00000)\\ &=\frac{1}{2} * 1.79004 \\ &=0.89501914129868\end{align}$

Dengan menghitung semua nilai AS dari semua laternatif yang ada, diperoleh hasil seperti terlihat di TABEL 8 berikut ini:

TABEL 8 : Skor Penilaian - Apraisal Score (AS)
NoAlternatifAS
KodeNama
1A1Area 110.89501914129868
2A2Petak 510.39336313360902
3A3Blok 770.27531217067697
4A4Komplek 770.28210109506206
5A5Area 290.29471171649202
6A6Lot 310.67091199515615
7A7Blok 110.3993635522721
8A8Blok 570.49250672766597
9A9Area 130.48940364658046
10A10Area 230.96692172175331
11A11Lot 770.42920686141972
12A12Area 510.091926674008634
13A13Area 310.31361168791112
14A14Komplek 230.29628232941138

2.3.7. Perankingan

Nilai skor penilaian Apraisal Score (AS) yang diperoleh dari hasil perhitungan sebelumnya selanjutnya diurutkan dari yang terbesar hingga yang terendah seperti terlihat dalam TABEL 9 seperti berikut ini :

TABEL 9 : Perangkingan
NoAlternatifASRanking
KodeNama
1A10Area 230.966921721753311
2A1Area 110.895019141298682
3A6Lot 310.670911995156153
4A8Blok 570.492506727665974
5A9Area 130.489403646580465
6A11Lot 770.429206861419726
7A7Blok 110.39936355227217
8A2Petak 510.393363133609028
9A13Area 310.313611687911129
10A14Komplek 230.2962823294113810
11A5Area 290.2947117164920211
12A4Komplek 770.2821010950620612
13A3Blok 770.2753121706769713
14A12Area 510.09192667400863414

Dari hasil perankingan nilai skor penilaian (AS) tersebut, diperoleh bahwa lokasi ke-10 (Area 23) dengan skor penilaian sebesar 0.96692172175331 terpilih sebagai lokasi yang paling baik sebagai lokasi parkir komuter, berdasar kriteria-kriteria dan bobot yang sudah ditentukan.

3.1. Persiapan Database

Sebagai bahan pembelajaran aplikasi EDAS ini; dibuat database (dalam hal ini menggunakan MySQL/MariaDB Database server) sebagai berikut:

CREATE DATABASE IF NOT EXISTS db_dss;
USE db_dss;

Awalnya membuat dulu database dengan nama db_dss jika belum ada database dengan nama tersebut, kemudian gunakan database tersebut dengan memakai sintak USE db_dss;

Dalam hal ini, pembuatan database memakai command console dari database server yang bersangkutan

3.1.1. Membuat Data Tabel Kriteria

Berdasarkan contoh kasus di atas dibuatkan tabel untuk data-data kriteria sebagai berikut:

-- menghapus tabel eda_criterias jika sudah ada
DROP TABLE IF EXISTS eda_criterias;
-- membuat tabel eda_criterias jika tidak ada
CREATE TABLE IF NOT EXISTS eda_criterias(
  id_criteria TINYINT(3) UNSIGNED NOT NULL,
  criteria VARCHAR(100) NOT NULL,
  weight FLOAT NOT NULL,
  attribute SET('benefit','cost'),
  PRIMARY KEY(id_criteria)
)ENGINE=MyISAM;

-- memasukkan data-data kriteria
INSERT INTO eda_criterias(id_criteria,criteria,weight,attribute)
VALUES
(1,'Sistem Informasi Pendukung',0.0860,'benefit'),
(2,'Frekuensi Angkutan Umum di lokasi',0.1000,'benefit'),
(3,'Total Biaya Parkir dan Angkutan Umum',0.1710,'cost'),
(4,'Luas Lahan',0.1430,'benefit'),
(5,'Keunggulan Transportasi Umum dibanding Angkutan Pribadi',0.0710,'benefit'),
(6,'Harga Tempat Parkir',0.2000,'cost'),
(7,'Lokasi Parkir Gratis di Pusat Kota',0.0430,'cost'),
(8,'Jarak ke Pusat Kota',0.0570,'cost'),
(9,'Trafik Angkutan Umum di Lokasi',0.1140,'cost');

3.1.2. Membuat Data Tabel Alternatif

Data-data mengenai kandidat yang akan dievaluasi seperti yang tertera pada contoh kasus di atas dapat di representasikan dalam tabel database sebagai berikut:

-- menghapus tabel eda_alternatives jika sudah ada
DROP TABLE IF EXISTS eda_alternatives;
-- membuat tabel eda_alternatives jika tidak ada
CREATE TABLE IF NOT EXISTS eda_alternatives(
  id_alternative SMALLINT(5) UNSIGNED NOT NULL AUTO_INCREMENT,
  name VARCHAR(30) NOT NULL,
  PRIMARY KEY(id_alternative)
) ENGINE=MyISAM;

-- memasukkan data-data alternatif
INSERT INTO eda_alternatives(id_alternative,name)
VALUES
(1,'Area 11'),
(2,'Petak 51'),
(3,'Blok 77'),
(4,'Komplek 77'),
(5,'Area 29'),
(6,'Lot 31'),
(7,'Blok 11'),
(8,'Blok 57'),
(9,'Area 13'),
(10,'Area 23'),
(11,'Lot 77'),
(12,'Area 51'),
(13,'Area 31'),
(14,'Komplek 23');

Dalam tabel eda_alternatives tersebut hanya disimpan id dan nama alternatif-nya; dalam pengembangannya dapat ditambahkan atribut/properti data lainnya, semisal alamat, nomor telepon, email, dan sebagainya sesuai kebutuhan. Namun dalam contoh ini hanya diperlukan namanya saja.

3.1.3. Membuat Data Tabel Hasil Evaluasi

Berikutnya adalah membuat tabel yang berisi hasil evaluasi dari tiap-tiap kandidat(alternatif) terhadap kriteria-kriteria yang diberikan. Data-data yang ada pada contoh kasus di atas dapat di representasikan dalam tabel relasi antara tabel eda_criterias dengan tabel eda_alternatives sebagai berikut:

-- menghapus tabel eda_evaluations jika sudah ada
DROP TABLE IF EXISTS eda_evaluations;
-- membuat tabel eda_evaluations jika tidak ada
CREATE TABLE IF NOT EXISTS eda_evaluations(
  id_alternative SMALLINT(5) UNSIGNED NOT NULL,
  id_criteria TINYINT(3) UNSIGNED NOT NULL,
  value FLOAT NOT NULL,
  PRIMARY KEY (id_alternative,id_criteria)
)ENGINE=MyISAM;

INSERT INTO eda_evaluations(id_alternative,id_criteria,value)
VALUES
(1,1,4),(1,2,4),(1,3,5),(1,4,8),(1,5,6),(1,6,5),(1,7,3),(1,8,2),(1,9,3),
(2,1,2),(2,2,4),(2,3,8),(2,4,8),(2,5,6),(2,6,3),(2,7,4),(2,8,4),(2,9,4),
(3,1,2),(3,2,4),(3,3,6),(3,4,9),(3,5,5),(3,6,6),(3,7,3),(3,8,4),(3,9,4),
(4,1,2),(4,2,5),(4,3,5),(4,4,7),(4,5,4),(4,6,6),(4,7,3),(4,8,4),(4,9,4),
(5,1,2),(5,2,3),(5,3,7),(5,4,9),(5,5,4),(5,6,5),(5,7,4),(5,8,3),(5,9,3),
(6,1,3),(6,2,5),(6,3,4),(6,4,9),(6,5,4),(6,6,6),(6,7,5),(6,8,3),(6,9,3),
(7,1,4),(7,2,3),(7,3,6),(7,4,6),(7,5,4),(7,6,5),(7,7,3),(7,8,4),(7,9,3),
(8,1,3),(8,2,4),(8,3,5),(8,4,9),(8,5,4),(8,6,6),(8,7,4),(8,8,4),(8,9,3),
(9,1,4),(9,2,4),(9,3,7),(9,4,7),(9,5,6),(9,6,3),(9,7,5),(9,8,4),(9,9,5),
(10,1,3),(10,2,5),(10,3,5),(10,4,8),(10,5,8),(10,6,4),(10,7,3),(10,8,4),(10,9,3),
(11,1,2),(11,2,3),(11,3,4),(11,4,9),(11,5,6),(11,6,6),(11,7,4),(11,8,3),(11,9,4),
(12,1,2),(12,2,4),(12,3,7),(12,4,6),(12,5,7),(12,6,6),(12,7,4),(12,8,3),(12,9,4),
(13,1,2),(13,2,3),(13,3,4),(13,4,7),(13,5,7),(13,6,6),(13,7,5),(13,8,3),(13,9,4),
(14,1,2),(14,2,3),(14,3,7),(14,4,6),(14,5,5),(14,6,3),(14,7,4),(14,8,3),(14,9,4);

3.2. Koneksi Ke Database Server

Dari databse yang sudah dibuat, kita bisa membuat script php untuk membuat koneksi ke database server dengan extension mysqli sebagai berikut:

<?php
//-- konfigurasi database
$dbhost 'localhost';
$dbuser 'root';
$dbpass '';
$dbname 'db_dss';
//-- koneksi ke database server dengan extension mysqli
$db = new mysqli($dbhost,$dbuser,$dbpass,$dbname);
//-- hentikan program dan tampilkan pesan kesalahan jika koneksi gagal
if ($db->connect_error) {
    die(
'Connect Error ('.$db->connect_errno.')'.$db->connect_error);
}
?>

Sesuaikan nilai-nilai $dbhost,$dbuser,$dbpass dan $dbname dengan konfigurasi database yg digunakan.

3.2.1 Mengambil Data Alternatif

Sebelum masuk kebagian inti perhitungan dengan metode EDAS, sebelumnya diambil terlebih dahulu data-data yang akan digunakan dari database. Yang pertama ada data Alternatif. Data ini diambil dari tabel eda_alternatives dan dimasukkan ke dalam variabel $alternatif dengan kode script PHP seperti berikut

<?php
//-- inisialisasi variabel array alternatif
$alternatif=array();
$sql='SELECT * FROM eda_alternatives';
$data=$db->query($sql);
while(
$row $data->fetch_object()){
    
$alternatif[$row->id_alternative]=$row->name;
}
?>

Data nama alternatif dimasukkan ke dalam variabel $alternatif dengan index/key array-nye merupakan id_alternatif-nya

3.2.2 Mengambil Data Kriteria dan Bobot

Data kriteria dan bobot diambil dari tabel eda_criterias dan dimasukkan dalam variabel array $kriteria dan $w sebagai berikut:

<?php
//-- inisialisasi variabel array kriteria dan bobot (W)
$kriteria=$w=array();
$sql='SELECT * FROM eda_criterias';
$data=$db->query($sql);
while(
$row $data->fetch_object()){
    
$kriteria[$row->id_criteria]=array($row->name,$row->attribute);
    
$w[$row->id_kriteria]=$row->weight;
}
?>

Data kriteria berupa nama kriteria dan atribut/tipe-nya dimasukkan ke dalam variabel array dua dimensi $kriteria, key/index yang pertama merupakan id_criteria-nya sedangkan index/key yang kedua, jika '0' maka adalah nama kriteria-nya sendangkan jika '1' maka merupakan atribut/tipe-nya. Sebagai contoh untuk $kriteria[2][0] berisi data nama dari kriteria ke-2 yaitu 'Frekuensi Angkutan Umum di lokasi' dengan atribut/tipe 'benefit'

Sedangkan untuk data nilai bobot-nya dimasukkan ke dalam variabel $w dengan index/key-nya berupa id_kriteria yang bersesuaian

3.3. Langkah-Langkah EDAS

Bagian berikutnya adalah bagian inti dari perhitungan dengan metode EDAS. Di sini dijelaskan langkah per langkah-nya untuk kode PHP-nya, sesuai dengan langkah-langkah perhitungan EDAS secara manual sebelumnya.

3.3.1. Menentukan Matriks Keputusan (X)

Mengacu pada persamaan EDA-01 kita dapat membuat matriks keputusan (X) dengan mengambil data dari tabel eda_evaluations yang kemudian dimasukkan dalam variable array $X dengan kode PHP sebagai berikut:

<?php
//-- inisialisasi variabel array matriks keputusan X
$X=array();
//-- ambil nilai dari tabel
$sql='SELECT * FROM eda_evaluations';
$data=$db->query($sql);
while(
$row $data->fetch_object()){
    
$i=$row->id_alternative;
    
$j=$row->id_criteria;
    
$X[$i][$j]=$aij;
}
?>

Variable array $X merupakan array dua dimensi, dimana dimensi yang pertama merupakan index dari alternatif-nya, sedangkan dimensi yang kedua merupakan index kriteria-nya.$X[$i][$j] berarti merupakan data matrik keputusan untuk alternatif ke $i dan kriteria ke $j

3.3.2. Menentukan Solusi Rata-rata (AV)

Dari matrik keputusan X yang sudah ditentukan dilangkah sebelumnya, kemudian dicari nilai Solusi Rata-rata (AV) dengan script berikut:

<?php
//-- inisialisasi array solusi rata-rata (AV)
$AV=array();
foreach(
$X as $i=>$ai){
    foreach(
$ai as $j=>$aij){
        if(!isset(
$AV[$j])){
            
$AV[$j]=0;
        }
        
$AV[9]+=$aij/$jml_alternative;
    }
}
?>

Nilai solusi rata-rata untuk setiap kriteria ke-$j ($AV[$j]) diperoleh dari nilai rata-rata matriks keputusan ($X) semua alternatif pada kriteria ke-$j.

3.3.3. Menghitung Jarak Positif/Negatif dari Rata-rata (PDA/NDA)

Berdasarkan persamaan EDA-04 sampai dengan EDA-09 dibuat script sebagai berikut :

<?php
//-- inisialisasi array PDA/NDA
$PDA=array();
$NDA=array();
foreach(
$X as $i=>$xi){
    
$PDA[$i]=array();
    
$NDA[$i]=array();
    foreach(
$xi as $j=>$xij){
        if(
$kriteria[$j][1]=='benefit'){
            
$PDA[$i][$j]=max(0,($xij-$AV[$j])/$AV[$j]);
            
$NDA[$i][$j]=max(0,($AV[$j]-$xij)/$AV[$j]);
        }else{
            
$PDA[$i][$j]=max(0,($AV[$j]-$xij)/$AV[$j]);
            
$NDA[$i][$j]=max(0,($xij-$AV[$j])/$AV[$j]);
        }
    }
}
?>

Dalam script di atas, nilai jarak positif/negatif dari rata-rata PDA/NDA didapat dari nilai selisih antara nilai masing-masing nilai matriks keputusan X dengan nilai rata-rata AV dibagi dengan nilai rata-rata AV ditiap kriteria-nya.

3.3.4. Menghitung Jumlah Terbobot PDA/NDA (SP/SN)

Langkah selanjutnya adalah menghitung nilai SP/SN sebagai berikut:

<?php
//-- inisialisasi array SP/SN
$SP=array();
$SN=array();
foreach(
$X as $i=>$xi){
    
$SP[$i]=0;
    
$SN[$i]=0;
    foreach(
$xi as $j=>$xij){
        
$SP[$i]+=$w[$j]*$PDA[$i][$j];
        
$SN[$i]+=$w[$j]*$NDA[$i][$j];
    }
}
?>

Nilai SP/SN adalah nilai penjumlahan (Sum) dari perkalian antara nilai PDA/NDA dengan bobot (w)-nya sesuai kriterianya, untuk setiap alternatif.

3.3.5. Menghitung Nilai Normalisasi SP/SN (NSP/NSN)

Langkah berikutnya adalah melakukan normalisasi nilai SP/SN dengan script berikut ini:

<?php
$NSP
=array();
$NSN=array();
foreach(
$alternatif as $i=>Komplek 23)
{
    
$NSP[$i]=$SP[$i]/max($SP);
    
$NSN[$i]=1-$SN[$i]/max($SN);
}
?>

Untuk mencari nilai normalisasi SP/SN (NSP/NSN) untuk masing-masing alternatif dibagi dengan nilai maksimum SP/SN dari semua alternatif.

3.3.6. Menghitung Nilai Skor Penilaian (AS)

Berdasarkan persamaan EDA-14 kemudian dicari nilai skor penilaian dengan script berikut:

<?php
//-- inisialisasi nilai skor penilaian AS
$AS=array();
foreach(
$alternatif as $i=>$ax)
{
    
$AS[$i]=($NSP[$i]+$NSN[$i])/2;
}
?>

Nilai skor penilaian $AS merupakan nilai rata-rata dari $NSP dengan $NSN. Proses ini dilakukan untuk setiap alternatif ($alternatif) untuk mendapatkan nilai skor penilaian masing-masing alternatif.

3.3.7. Perankingan

Bagian terakhir dari proses metode EDAS adalah perankingan, dimana data skor penilaian $AS diurutkan dari yang terbesar hingga yang terkecil. Berikut adalah contoh script PHP-nya

<?php
//-- mengurutkan secara descending
arsort($AS);
//-- ambil key-index yang pertama
$terpilih=key($AS);
echo 
"Dari hasil perhitungan dipilih alternatif ke-{$terpilih}"
    
." ({$alternatif[$terpilih]}) <br>dengan nilai skor penilaian "
    
." sebesar {$AS[$terpilih]}";
?>

Data nilai skor penilaian $AS diurutkan secara descending dengan fungsi arsort() untuk mengurutkan berdasarkan nilay array namun tetap mempertahankan key-index-nya. Setelah diurutkan, maka item array yang pertama adalah nilai skor penilaian AS yang terpilih, dan key-index-nya menunjukkan alternatif ke-i. Key-index ini diambil dengan fungsi key(), dan selanjutnya ditampilkan hasilnya dengan mengambil nilai dari variabel array $alternatif dengan key-index yang didapat dari baris sebelumnya, yaitu dalam variabel $terpilih. HAsil yang ditampilkan kurang lebih, sebagai berikut :

Dari hasil perhitungan dipilih alternatif ke-10 (Area 23)
dengan nilai skor penilaian sebesar 0.96692172175331

Source code selengkapnya bisa dilihat di tautan ini source source

Konfigurasi aplikasi

Masukkan jumlah Kriteria (n) dan jumlah Alternatif (m) yang akan disimulasikan. Pada simulasi ini dibatasi nilai masukkannya masing-masing hanya bilangan bulat antara 3 s.d 7 saja