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