Kompleksitas Desain Perangkat Lunak
Kompleksitas Istilah adalah singkatan dari keadaan peristiwa atau hal-hal, yang memiliki banyak hubungan yang saling berhubungan dan struktur yang sangat rumit. Dalam pemrograman perangkat lunak, ketika desain perangkat lunak direalisasikan, jumlah elemen dan interkoneksinya secara bertahap menjadi sangat besar, yang menjadi terlalu sulit untuk dipahami sekaligus.
Kompleksitas desain perangkat lunak sulit untuk dinilai tanpa menggunakan metrik dan ukuran kompleksitas. Mari kita lihat tiga ukuran kompleksitas perangkat lunak yang penting.
Ukuran Kompleksitas Halstead
Pada tahun 1977, Tuan Maurice Howard Halstead memperkenalkan metrik untuk mengukur kompleksitas perangkat lunak. Metrik Halstead bergantung pada implementasi aktual program dan ukurannya, yang dihitung langsung dari operator dan operan dari kode sumber, secara statis. Ini memungkinkan untuk mengevaluasi waktu pengujian, kosakata, ukuran, kesulitan, kesalahan, dan upaya untuk kode sumber C / C ++ / Java.
Menurut Halstead, “Program komputer adalah implementasi dari algoritma yang dianggap sebagai kumpulan token yang dapat diklasifikasikan sebagai operator atau operan”. Metrik Halstead menganggap program sebagai urutan operator dan operan terkait.
Ia mendefinisikan berbagai indikator untuk memeriksa kompleksitas modul.
Parameter | Berarti |
---|---|
n1 | Jumlah operator unik |
n2 | Jumlah operan unik |
N1 | Jumlah total kemunculan operator |
N2 | Jumlah total kejadian operan |
Saat kami memilih file sumber untuk melihat detail kerumitannya di Metric Viewer, hasil berikut terlihat di Laporan Metrik:
Metrik | Berarti | Representasi Matematika |
---|---|---|
n | Kosa kata | n1 + n2 |
N | Ukuran | N1 + N2 |
V. | Volume | Panjang * Kosakata Log2 |
D | Kesulitan | (n1 / 2) * (N1 / n2) |
E | Upaya | Kesulitan * Volume |
B | Kesalahan | Volume / 3000 |
T | Waktu pengujian | Waktu = Upaya / S, di mana S = 18 detik. |
Pengukuran Kompleksitas Siklomatik
Setiap program mencakup pernyataan untuk dieksekusi untuk melakukan beberapa tugas dan pernyataan pengambilan keputusan lainnya yang memutuskan, pernyataan apa yang perlu dieksekusi. Konstruksi pengambilan keputusan ini mengubah aliran program.
Jika kita membandingkan dua program dengan ukuran yang sama, program dengan lebih banyak pernyataan pengambilan keputusan akan lebih kompleks karena kontrol program sering melompat.
McCabe, pada tahun 1976, mengusulkan Cyclomatic Complexity Measure untuk mengukur kompleksitas perangkat lunak tertentu. Ini adalah model berbasis grafik yang didasarkan pada konstruksi pengambilan keputusan program seperti pernyataan if-else, do-while, repeat-sampai, switch-case dan goto.
Proses untuk membuat grafik kendali aliran:
- Hancurkan program dalam blok yang lebih kecil, dibatasi oleh konstruksi pengambilan keputusan.
- Buat node yang mewakili masing-masing node ini.
- Hubungkan node sebagai berikut:
Jika kontrol dapat bercabang dari blok i ke blok j
Gambarlah sebuah busur
Dari simpul keluar ke simpul masuk
Gambarlah sebuah busur.
Untuk menghitung kompleksitas Cyclomatic dari modul program, kami menggunakan rumus -
V(G) = e – n + 2
Where
e is total number of edges
n is total number of nodes
Kompleksitas Cyclomatic dari modul di atas adalah
e = 10
n = 8
Cyclomatic Complexity = 10 - 8 + 2
= 4
Menurut P. Jorgensen, Cyclomatic Complexity dari sebuah modul tidak boleh melebihi 10.
Titik Fungsi
Ini banyak digunakan untuk mengukur ukuran perangkat lunak. Titik Fungsi berkonsentrasi pada fungsionalitas yang disediakan oleh sistem. Fitur dan fungsionalitas sistem digunakan untuk mengukur kompleksitas perangkat lunak.
Titik fungsi dihitung pada lima parameter, dinamakan Input Eksternal, Output Eksternal, File Internal Logis, File Antarmuka Eksternal, dan Pertanyaan Eksternal. Untuk mempertimbangkan kompleksitas perangkat lunak, setiap parameter dikategorikan lebih lanjut sebagai sederhana, rata-rata atau kompleks.
Mari kita lihat parameter titik fungsi:
Input Eksternal
Setiap masukan unik ke sistem, dari luar, dianggap sebagai masukan eksternal. Keunikan masukan diukur, karena tidak ada dua masukan yang memiliki format yang sama. Input ini dapat berupa data atau parameter kontrol.
Simple - jika jumlah input rendah dan mempengaruhi lebih sedikit file internal
Complex - jika jumlah input tinggi dan mempengaruhi lebih banyak file internal
Average - Diantara sederhana dan kompleks.
Output Eksternal
Semua jenis keluaran yang disediakan oleh sistem dihitung dalam kategori ini. Keluaran dianggap unik jika format keluaran dan / atau pemrosesannya unik.
Simple - jika jumlah keluaran rendah
Complex - jika jumlah keluaran tinggi
Average - di antara sederhana dan kompleks.
File Internal Logis
Setiap sistem perangkat lunak memelihara file internal untuk memelihara informasi fungsionalnya dan berfungsi dengan baik. File-file ini menyimpan data logis dari sistem. Data logis ini mungkin berisi data fungsional dan data kontrol.
Simple - jika jumlah tipe record rendah
Complex - jika jumlah tipe record tinggi
Average - di antara sederhana dan kompleks.
File Antarmuka Eksternal
Sistem perangkat lunak mungkin perlu berbagi file dengan beberapa perangkat lunak eksternal atau mungkin perlu meneruskan file untuk diproses atau sebagai parameter ke beberapa fungsi. Semua file ini dihitung sebagai file antarmuka eksternal.
Simple - jika jumlah tipe record dalam file bersama rendah
Complex - jika jumlah tipe record dalam file bersama tinggi
Average - di antara sederhana dan kompleks.
Pertanyaan Eksternal
Permintaan adalah kombinasi dari input dan output, di mana pengguna mengirimkan beberapa data untuk ditanyakan sebagai input dan sistem merespons pengguna dengan output dari permintaan yang diproses. Kompleksitas kueri lebih dari Input Eksternal dan Output Eksternal. Query dikatakan unik jika input dan outputnya unik dalam hal format dan datanya.
Simple - jika kueri membutuhkan pemrosesan rendah dan menghasilkan sejumlah kecil data keluaran
Complex - jika kueri membutuhkan proses tinggi dan menghasilkan data keluaran dalam jumlah besar
Average - di antara sederhana dan kompleks.
Masing-masing parameter ini dalam sistem diberi bobot sesuai dengan kelas dan kompleksitasnya. Tabel di bawah ini menyebutkan bobot yang diberikan untuk setiap parameter:
Parameter | Sederhana | Rata-rata | Kompleks |
---|---|---|---|
Masukan | 3 | 4 | 6 |
Keluaran | 4 | 5 | 7 |
Penyelidikan | 3 | 4 | 6 |
File | 7 | 10 | 15 |
Antarmuka | 5 | 7 | 10 |
Tabel di atas menghasilkan Titik Fungsi mentah. Titik-titik fungsi ini disesuaikan dengan kompleksitas lingkungan. Sistem dijelaskan menggunakan empat belas karakteristik berbeda:
- Komunikasi data
- Pemrosesan terdistribusi
- Tujuan kinerja
- Beban konfigurasi operasi
- Tingkat transaksi
- Entri data online,
- Efisiensi pengguna akhir
- Pembaruan online
- Logika pemrosesan yang kompleks
- Re-usability
- Kemudahan instalasi
- Kemudahan operasional
- Beberapa situs
- Keinginan untuk memfasilitasi perubahan
Faktor karakteristik ini kemudian dinilai dari 0 sampai 5, seperti yang disebutkan di bawah ini:
- Tidak ada pengaruh
- Incidental
- Moderate
- Average
- Significant
- Essential
Semua rating kemudian dijumlahkan sebagai N. Nilai N berkisar dari 0 sampai 70 (14 tipe karakteristik x 5 tipe rating). Ini digunakan untuk menghitung Faktor Penyesuaian Kompleksitas (CAF), menggunakan rumus berikut:
CAF = 0.65 + 0.01N
Kemudian,
Delivered Function Points (FP)= CAF x Raw FP
FP ini kemudian dapat digunakan dalam berbagai metrik, seperti:
Cost = $ / FP
Quality = Kesalahan / FP
Productivity = FP / orang-bulan