Skip to main content

Pengertian Requirements Modeling dalam Software Engineering - Tinjauan Sekilas

Apa itu Requirements Modeling?
Requirements model — sebenarnya seperangkat model — adalah penyajian teknis awal/pertama dari suatu sistem. Rangkaian kalimat atau kata-kata yang dituliskan adalah cara yang baik untuk berkomunikasi, tetapi tidak selalu merupakan cara terbaik untuk menyajikan requirements untuk software komputer. Requirements Modeling menggunakan kombinasi berbentuk teks dan diagram untuk menyajikan requirements dengan cara yang relatif mudah dipahami, dan yang lebih penting, langsung digunakan untuk me-review kebenaran, kelengkapan, dan konsistensi dari requirements.
Siapa yang melakukan ini?
Software engineer (kadang-kadang disebut "analyst") membuat model dari requirements yang diperoleh dari customer/pengguna.
Mengapa ini penting?
Untuk memvalidasi software requirements, kita perlu memeriksanya dari sejumlah sudut pandang berbeda. Misalkan kita akan mempertimbangkan requirements modeling dari tiga perspektif berbeda: scenario-based models (model berbasis skenario), data (information) model (model data/informasi), dan class-based model (model berbasis class). Catatan: beberapa jenis pemodelan yang lain misalnya adalah behavioral and patterns-based model (model berbasis behavior dan pola), flow-oriented model (model berorientasi aliran data). Masing-masing menyajikan requirements dalam "dimensi" yang berbeda, dengan demikian meningkatkan probabilitas untuk menemukan kesalahan, inkonsistensi akan muncul, dan kelalaian.
Apa saja langkah-langkahnya?
Scenario-based modeling (pemodelan berbasis skenario) menyajikan sistem dari sudut pandang pengguna. Data modeling (pemodelan data) menyajikan data/informasi dan menggambarkan objek data yang akan dimanipulasi oleh software dan hubungan di antara objek data tersebut. Class-based modeling (pemodelan berbasis kelas) mendefinisikan objek-objek, atribut-atribut, dan realtionships mereka. Setelah model awal dibuat, model-model tersebut disempurnakan dan dianalisis untuk menilai kejelasan, kelengkapan, dan konsistensi mereka. 
Apa hasil/produk pekerjaan? 
Berbagai macam bentuk berbasis teks dan diagram bisa dipilih untuk requirements model. Masing-masing penyajian ini memberikan satu atau lebih (cara) pandangan dari berbagai elemen model.
Bagaimana kita memastikan bahwa kita telah melakukannya dengan benar?
Hasil/produk kerja requirements modeling harus di-review untuk memastikan kebenaran, kelengkapan, dan konsistensi. Hasil ini harus mencerminkan kebutuhan semua pemangku kepentingan dan membangun fondasi dimana desain bisa mulai dijalankan.
--o0o--

Beberapa jenis/kategori model dalam requirements engineering

a. Model berdasarkan scenario, contoh: use case diagram, user story, activity diagram, use case scenario, dll. Pada pemodelan berdasarkan scenario bertujuan untuk membantu mendefinisikan actor dari sistem dan apa yang harus dilakukan oleh sistem tersebut.

b. Model berdasarkan class, contoh: class diagram, collaboration diagram, dll. Model berdasarkan class menggambarkan beberapa hal berikut:
  • Object dari sistem yang akan dimanipulasi.
  • Operasi (metode atau service) yang akan diterapkan terhadap object untuk mendapatkan efek dari manipulasi yang dilakukan.
  • Hubungan antar object
  • Kolaborasi yang muncul antara kelas yang didefinisikan.
c. Model berdasarkan behavior, contoh state diagram, sequence diagram, dll. Model behavior mengindikasikan bagaimana software akan memberikan respon terhadap event atau stimulus external. Untuk menciptakan model ini, proses analisis harus dilakukan melalui tahapan berikut:
  • Evaluasi semua use case untuk memahami secara keseluruhan urutan interaksi di dalam sistem.
  • Identifikasikan sistem yang menggerakan urutan interaksi dan memahami bagaimana event-event tersebut dikaitkan dengan object specific.
  • Membuat sequence untuk setiap use case
  • Membangun state diagram untuk sistem
  • Melakukan review terhadap model behavioral untuk verifikasi akurasi dan konsistensi
d. Model berdasarkan aliran, contoh: data flow diagram, data models, dll.

Kategori Model dalam Requirements Engineering


Comments

Popular posts from this blog

Pengertian Binding dalam Bahasa Pemrograman dan Kapan Terjadinya

Binding dimaksudkan sebagai pengikatan (association) antara suatu entity dengan atributnya, misalnya binding/pengikatan antara suatu variable dengan tipe datanya atau dengan nilainya, atau dapat juga antara suatu operasi dengan simbol, misalnya simbol + dikenali sebagai operasi penjumlahan atau simbol ^ dikenali sebagai operasi pangkat, dll.  Peristiwa binding dan kapan terjadinya binding (biasanya disebut dengan binding time ) berperan penting dalam membicarakan semantics suatu bahasa pemrograman. Beberapa kemungkinan binding time adalah:

Contoh proses normalisasi relasi dari UNF – 1NF – 2NF – dan 3NF

Dalam posting tulisan tentang: “Tujuan dan Manfaat Normalisasi dalam Perancangan Database” , kita sudah mempelajari tentang: “Apa itu normalisasi” dan “Mengapa kita perlu melakukan normalisasi”. Kedua pertanyaan itu sudah terjawab dalam tulisan tersebut.  Kemudian dalam posting tulisan tentang: “Konsep Ketergantungan Fungsional, Normalisasi, dan Identifikasi Primary Key dalam Perancangan Sistem Database” , kita sudah mempelajari suatu konsep penting yang digunakan untuk melakukan normalisasi, yaitu konsep ketergantungan fungsional yang terdiri dari ketergantungan penuh, ketergantungan parsial atau sebagian, dan ketergantungan transitif. Proses normalisasi pertama-tama dilakukan dengan mengidentifikasi adanya ketergantungan-ketergantungan tersebut dalam relasi-relasi dan kemudian menghilangkannya. Cara melakukan normalisasi, mengidentifikasi berbagai macam ketergantungan, dan menghilangkan ketergantungan pada relasi-relasi bisa dipelajari ulang dalam postingan tulisan d...

Latihan Soal Jawab Matematika Diskrit

Berikut di bawah ini adalah latihan soal jawab untuk matematika diskrit dengan topik-topik: Pernyataan Logika Circuits dan Ekspresi Boolean Argumen (valid/tidak valid) Teori Himpunan Permutasi Fungsi --o0o-- Pernyataan Logika 1. Buatlah tabel kebenaran untuk menentukan yang mana tautology dan yang mana contradiction dalam pernyataan logika (a) dan (b) di bawah ini: a. (p ∧ q) ∨ (∼p ∨ (p ∧ ∼q)) b.  (p ∧ ∼q) ∧ (∼p ∨ q)