Layer-layer pada Software Engineering:
1. Quality Focus Merupakan dasar atau fondasi yang mensupport Software Engineering. Karena tanpa sebuah kualitas yang kita tetapkan maka kita tidak akan tahu software seperti apa yang akan kita buat.
2. Process Proses merupakan dasar dimana terdapat:
Komunikasi dengan klien untuk mengetahui spesifikasi software yang dia inginkan.
Perencanaan, Siapa saja yang terlibat dalam pembuatan software, Scheduling, dan pembagian tugas.
Modelling, dibuat model dari software yang akan kita buat supaya user dan developer mengerti software kita. Konstruksi, mulai coding dan testingnya. Deployment, Software yang sudah jadi di-deliver ke customer.
3. Methods
Pada Methods muncul pertanyaan “bagaimana” kita membuat software, prosedur/fungsi apa saja yang dibutuhkan (pada Procedural Programming) atau behaviour apa saja yang dimiliki oleh sebuah objek tertentu (pada Object Oriented Programming).
4.Tools
Jelas terlihat, tanpa tools proses yang sudah direncanakan dan metode yang sudah ditentukan tidak akan bisa ter-realisasi. Tools itu adalah software apa yang akan kita gunakan untuk membuat software yang akan kita buat.
Linear SequentialModel/Waterfall Model
Model ini adalah model klasik yang bersifat sistematis, berurutan dalam membangun software. Berikut ini ada dua gambaran dari waterfall model.
Sekalipun keduanya menggunakan nama-nama fase yang berbeda, namun sama dalam intinya.
Fase-fase dalam Waterfall Model menurut referensi Pressman:
Fase-fase dalam Waterfall Model menurut referensi Sommerville :
Masalah dengan waterfall :
Bersifat iteratif/ mengandung perulangan. Hasil proses berupa produk yang makin lama makin lengkap sampai versi terlengkap dihasilkan sebagai produk akhir dari proses. Dua model dalam evolutionary software process model adalah:
Incremental Model (Original: Mills)
Proses digambarkan sebagai spiral. Setiap loop mewakili satu fase dari software process. Loop paling dalam berfokus pada kelayakan dari sistem, loop selanjutnya tentang definisi dari kebutuhan, loop berikutnya berkaitan dengan desain sistem dan seterusnya. Setiap Loop dibagi menjadi beberapa sektor :
1. Quality Focus Merupakan dasar atau fondasi yang mensupport Software Engineering. Karena tanpa sebuah kualitas yang kita tetapkan maka kita tidak akan tahu software seperti apa yang akan kita buat.
2. Process Proses merupakan dasar dimana terdapat:
Komunikasi dengan klien untuk mengetahui spesifikasi software yang dia inginkan.
Perencanaan, Siapa saja yang terlibat dalam pembuatan software, Scheduling, dan pembagian tugas.
Modelling, dibuat model dari software yang akan kita buat supaya user dan developer mengerti software kita. Konstruksi, mulai coding dan testingnya. Deployment, Software yang sudah jadi di-deliver ke customer.
3. Methods
Pada Methods muncul pertanyaan “bagaimana” kita membuat software, prosedur/fungsi apa saja yang dibutuhkan (pada Procedural Programming) atau behaviour apa saja yang dimiliki oleh sebuah objek tertentu (pada Object Oriented Programming).
4.Tools
Jelas terlihat, tanpa tools proses yang sudah direncanakan dan metode yang sudah ditentukan tidak akan bisa ter-realisasi. Tools itu adalah software apa yang akan kita gunakan untuk membuat software yang akan kita buat.
Linear SequentialModel/Waterfall Model
Model ini adalah model klasik yang bersifat sistematis, berurutan dalam membangun software. Berikut ini ada dua gambaran dari waterfall model.
Sekalipun keduanya menggunakan nama-nama fase yang berbeda, namun sama dalam intinya.
Fase-fase dalam Waterfall Model menurut referensi Pressman:
Fase-fase dalam Waterfall Model menurut referensi Sommerville :
- Requirements analysis and definition: Mengumpulkan kebutuhan secara lengkap kemudian kemudian dianalisis dan didefinisikan kebutuhan yang harus dipenuhi oleh program yang akan dibangun. Fase ini harus dikerjakan secara lengkap untuk bisa menghasilkan desain yang lengkap.
- System and software design: Desain dikerjakan setelah kebutuhan selesai dikumpulkan secara lengkap.
- Implementation and unit testing: desain program diterjemahkan ke dalam kode-kode dengan menggunakan bahasa pemrograman yang sudah ditentukan. Program yang dibangun langsung diuji baik secara unit.
- Integration and system testing: Penyatuan unit-unit program kemudian diuji secara keseluruhan (system testing).
- Operation and maintenance: mengoperasikan program dilingkungannya dan melakukan pemeliharaan, seperti penyesuaian atau perubahan karena adaptasi dengan situasi sebenarnya. Kekurangan yang utama dari model ini adalah kesulitan dalam mengakomodasi perubahan setelah proses dijalani. Fase sebelumnya harus lengkap dan selesai sebelum mengerjakan fase berikutnya.
Masalah dengan waterfall :
- Perubahan sulit dilakukan karena sifatnya yang kaku.
- Karena sifat kakunya, model ini cocok ketika kebutuhan dikumpulkan secara lengkap sehingga perubahan bisa ditekan sekecil mungkin. Tapi pada kenyataannya jarang sekali konsumen/pengguna yang bisa memberikan kebutuhan secara lengkap, perubahan kebutuhan adalah sesuatu yang wajar terjadi.
- Waterfall pada umumnya digunakan untuk rekayasa sistem yang besar dimana proyek dikerjakan di beberapa tempat berbeda, dan dibagi menjadi beberapa bagian sub-proyek.
Bersifat iteratif/ mengandung perulangan. Hasil proses berupa produk yang makin lama makin lengkap sampai versi terlengkap dihasilkan sebagai produk akhir dari proses. Dua model dalam evolutionary software process model adalah:
Incremental Model (Original: Mills)
- kombinasikan element-element dari waterfall dengan sifat iterasi/perulangan.
- element-element dalam waterfall dikerjakan dengan hasil berupa produk dengan spesifikasi tertentu, kemudian proses dimulai dari fase pertama hingga akhir dan menghasilkan produk dengan spesifikasi yang lebih lengkap dari yang sebelumnya. Demikian seterusnya hingga semua spesifikasi memenuhi kebutuhan yang ditetapkan oleh pengguna.
- Produk hasil increment pertama biasanya produk inti (core product), yaitu produk yang memenuhi kebutuhan dasar. Produk tersebut digunakan oleh pengguna atau menjalani review/pengecekan detil. Hasil review tersebut menjadi bekal untuk pembangunan pada increment berikutnya. Hal ini terus dikerjakan sampai produk yang komplit dihasilkan.
- model ini cocok jika jumlah anggota tim pengembang/pembangun PL tidak cukup.
- Mampu mengakomodasi perubahan secara fleksibel.
- Produk yang dihasilkan pada increment pertama bukanlah prototype, tapi produk yang sudah bisa berfungsi dengan spesifikasi dasar.
- cocok untuk proyek berukuran kecil (tidak lebih dari 200.000 baris coding)
- mungkin terjadi kesulitan untuk memetakan kebutuhan pengguna ke dalam rencana spesifikasi masing-masing hasil increment
Proses digambarkan sebagai spiral. Setiap loop mewakili satu fase dari software process. Loop paling dalam berfokus pada kelayakan dari sistem, loop selanjutnya tentang definisi dari kebutuhan, loop berikutnya berkaitan dengan desain sistem dan seterusnya. Setiap Loop dibagi menjadi beberapa sektor :
- Objective settings (menentukan tujuan): menentukan tujuan dari fase yang ditentukan. Batasan-batasan pada proses dan produk sudah diketahui. Perencanaan sudah disiapkan. Resiko dari proyek sudah diketahui. Alternatif strategi sudah disiapkan berdasarkan resiko-resiko yang diketahui, dan sudah direncanakan.
- Risk assessment and reduction (Penanganan dan pengurangan resiko): setiap resiko dianalisis secara detil pada sektor ini. Langkahlangkah penanganan dilakukan, misalnya membuat prototype untuk mengetahui ketidakcocokan kebutuhan.
- Development and Validation (Pembangunan dan pengujian): Setelah evaluasi resiko, maka model pengembangan sistem dipilih. Misalnya jika resiko user interface dominan, maka membuat prototype User Interface. Jika bagian keamanan yang bermasalah, maka menggunakan model formal dengan perhitungan matematis, dan jika masalahnya adalah integrasi sistem model waterfall lebih cocok.
- Planning: Proyek dievaluasi atau ditinjau-ulang dan diputuskan untuk terus ke fase loop selanjutnya atau tidak. Jika melanjutkan ke fase berikutnya rencana untuk loop selanjutnya.
- Customer communication: membangun komunikasi yang baik dengan pengguna/customer.
- Planning: mendefinisikan sesumber, batas waktu, informasi-informasi lain seputar proyek
- Risk analysis: identifikasi resiko managemen dan teknis
- Engineering: pembangunan contoh-contoh aplikasi, misalnya prototype
- Construction and release : pembangunan, test, install dan support.
- Customer evaluation: mendapatkan feedback dari pengguna beradasarkan evaluasi PL pada fase engineering dan fase instalasi. Pada model spiral, resiko sangat dipertimbangkan. Resiko adalah sesuatu yang mungkin mengakibatkan kesalahan.
Komentar