Nama : Anis Safira
Kelas : XII RPL 1
P. Bergerak KD1
Soal
!!
1. Pengertian Sdlc
2. Metode pengembangan perangkat lunak
3. Perbedaan OOA,OOD,OOSE,OMT,UML
4. Jenis jenis diagram UML
Jawaban!!
1. Pengertian SDLC
Systems Development Life Cycle merupakan siklus hidup pengembangan system. Dalam rekayasa system
dan rekayasa perangkat lunak, SDLC berupa suatu proses pembuatan dan
pengubahan sistem serta model dan metodologi yang digunakan
untuk mengembangkan sistem-sistem tersebut.
Dalam rekayasa perangkat
lunak, konsep SDLC mendasari berbagai jenis metodologi pengembangan
perangkat lunak. Metodologi-metodologi ini membentuk suatu kerangka kerja untuk
perencanaan dan pengendalian pembuatan sistem informasi, yaitu proses
pengembangan perangkat lunak.
Pengembangan SDLC adalah
proses yang digunakan oleh analis system untuk mengembangkan sistem informasi,
termasuk persyaratan, validasi, pelatihan, dan pengguna (stakeholder)
kepemilikan. Setiap SDLC harus menghasilkan sistem berkualitas tinggi yang
memenuhi atau melampaui harapan pelanggan, mencapai penyelesaian dalam waktu
dan perkiraan biaya, bekerja secara efektif dan efisien di saat ini dan direncanakanteknologi
Informasi infrastruktur, dan murah untuk mempertahankan dan biaya efektif.
Fungsi SDLC
Untuk menggambarkan tahapan-tahapan utama dan
langkah-langkah dari setiap tahapan yang secara garis besar terbagi dalam fase
fase utama dalam SDLC, yaitu :
Perencanaan : Mengapa Mengembangkan Sistem?
Analisis : Siapa, apa, kapan dan dimana sistem diterapkan?
Perancangan : Bagaimana kerja sistem?
Implementasi : Bagaimana Sistem Dipasang/diinstall?
Ø Perencanaan :
· Mengidentifikasikan Nilai Bisnis
· Analisis Kelayakan
· Membuat Rencana Kerja
· Mengatur Staff
· Mengontrol dan Mengarahkan Projek
Ø Analisis :
· Analisis masalah
· Mencari informasi yang terkait dengan sistem
· Menentukan model proses
· Menentukan model data
Ø Perancangan :
· Perancangan Proses secara Fisik
· Perancangan Arsitektur Sistem
· Perancangan Interface
· Perancangan Basis Data dan Berkas
· Perancangan Program
Ø Implementasi:
· Construction
· Instalation
Setiap kegiatan dalam SDLC dapat dijelaskan melalui tujuan (purpose) dan
hasil kegiatannya (deliverable). Apabila kegiatan utama tersebut dijabarkan ke
dalam langkah-langkah yang lebih rinci dapat digambarkan seperti berikut :
+---------------------------------------------------------------------+
:
ANALYSIS
:
DESIGN :
IMPLEMENTATION :
+---------------------------------------------------------------------
:
:
+---------------+
:
:
+-->:
Problem :
:
:
|
: Detection :
:
:
|
+---------------+
+-----------+
+-----------+
+--------->
| |
:
| |
: |
|
+---------------+ | : +---------------+ | : +---------------+
|
: Initial : | : :
Output : | : : Programming / :
| : Investigation
: | :
:
: | : : test :
|
+---------------+ | : +---------------+ | : +---------------+
+--------->
| |
:
| |
: |
|
+---------------+ | : +---------------+ | : +---------------+
| :
Requirements : | : :
Input : | : : Training / :
|
: Analysis : | :
:
: | : : Other :
|
+---------------+ | : +---------------+ | : +---------------+
+--------->
| |
: |
| : |
+---------------+ | :
+---------------+ | : +---------------+
: Generation of : | :
: Files :--+ :
: System :
: Alternatives : | :
:
: : : Change Over :
+---------------+ | :
+---------------+ : +---------------+
| |
:
:
+---------------+ |
:
:
: Selection of :--+
:
:
: Proper System :
:
:
+---------------+
:
:
|
System Development Methodology adalah suatu rangkaian langkah untuk
mengimplementasikan SLDC itu sendiri. Dalam dunia rekayasa perangkat lunak
terdapat empat buah metodologi dalam menerapkan SLDC, yakni :
1.
Waterfall
Development Methodology
2.
Parallel
Development Methodology
3.
Rapid
Application Development
4.
Agile
Development: Extreme Programming
Kelima
metodologi tersebut tidak ada yang paling bagus. Semua mempunyai kelebihan dan
kekurangan. Tergantung suatu kelompok pengembang perangkat lunak menggunakan
metode apa yang paling cocok dengan kondisi lingkungan pengembangan perangkat
lunak tersebut.
2. Metode Pengembangan Perangkat Lunak
Ada beberapa metode dalam pengembangan perangkat lunak
yang dikemukakan oleh Ian Sommerville dan Roger S. Pressman.
Menurut Ian Sommerville:
1. Model Pengembangan Prototyping (Evolusioner)
Pengembangan evolusioner berdasarkan pada ide untuk mengembangkan implementasi awal, memperlihatkannya kepada user untuk dikomentari, dan memperbaikinya secara bertahap sampai sistem yang memenuhi persyaratan diperoleh.
Pengembangan prototyping terbagi dua:
Pengembangan evolusioner berdasarkan pada ide untuk mengembangkan implementasi awal, memperlihatkannya kepada user untuk dikomentari, dan memperbaikinya secara bertahap sampai sistem yang memenuhi persyaratan diperoleh.
Pengembangan prototyping terbagi dua:
·
Exploratory
Programming
Tujuan proses ini adalah bekerja dengan pelanggan untuk menyelidiki kebutuhan mereka dan mengirimkan sistem akhir. Pengembangan dimulai dengan bagian-bagian sistem yang dipahami. Sistem berubah dengan adanya tambahan fitur-fitur baru sesuai usulan pelanggan.
Tujuan proses ini adalah bekerja dengan pelanggan untuk menyelidiki kebutuhan mereka dan mengirimkan sistem akhir. Pengembangan dimulai dengan bagian-bagian sistem yang dipahami. Sistem berubah dengan adanya tambahan fitur-fitur baru sesuai usulan pelanggan.
·
Throw-away
prototyping
Tujuan pengembangan evolusioner adalah untuk memahami kebutuhan pelanggan dan mendefinisikan kebutuhan yang lebih baik untuk sistem. Prototype berkonsentrasi pada eksperimen, dengan kebutuhan pelanggan yang tidak dipahami dengan baik.
Tujuan pengembangan evolusioner adalah untuk memahami kebutuhan pelanggan dan mendefinisikan kebutuhan yang lebih baik untuk sistem. Prototype berkonsentrasi pada eksperimen, dengan kebutuhan pelanggan yang tidak dipahami dengan baik.
Masalah dalam metode ini:
1. Proses tidak bisa dilihat. Manajer
membutuhkan hasil reguler untuk mengukur kemajuan. Jika sistem dikembangkan
dengan cepat, tidaklah efektif dari segi biaya jika dihasilkan dokumen yang
merefleksikan setiap versi sistem.
Sistem seringkali memiliki struktur yang buruk. Perubahan yang terus-menerus cenderung merusak struktur perangkat lunak. Penyesuaian perubahan perangkat lunak menjadi semakin sulit dan mahal.
Diperlukan alat bantu dan teknik khusus. Keperluan ini memungkinkan pengembangan yang cepat tetapi mungkin tidak kompatibel dengan alat bantu atau teknik lain dan relatif hanya sedikit orang yang memiliki keahlian untuk memakainya.
Sistem seringkali memiliki struktur yang buruk. Perubahan yang terus-menerus cenderung merusak struktur perangkat lunak. Penyesuaian perubahan perangkat lunak menjadi semakin sulit dan mahal.
Diperlukan alat bantu dan teknik khusus. Keperluan ini memungkinkan pengembangan yang cepat tetapi mungkin tidak kompatibel dengan alat bantu atau teknik lain dan relatif hanya sedikit orang yang memiliki keahlian untuk memakainya.
2. Model Pengembangan Sistem
Formal
Pengembangan sistem formal merupakan pendekatan terhadap pengembangan perangkat lunak yang memiliki kesamaan dengan model waterfall, tetapi proses pengembangannya didasarkan pada transformasi matematis dan dari spesifikasi sistem menjadi program yang dapat dijalankan.
Perbedaan antara pendekatan formal dengan waterfall:
1) Spesifikasi persyaratan perangkat lunak diperbaiki menjadi spesifikasi formal yang rinci yang dinyatakan dalam notasi matematis.
2) Proses pengembangan perancangan, implementasi, dan pengujian unit digantikan oleh proses pengembangan transformasional di mana spesifikasi formal diperbaiki, melalui serangkaian transformasi menjadi program.
Pada proses transformasi, representasi matematis formal dari sistem secara sistematis diubah menjadi representasi sistem yang lebih rinci, tetapi tetap benar secara matematis. Setiap langkah menambahkan perincian sampai spesifikasi formal diubah menjadi program yang ekivalen.
Keuntungan pendekatan transformasional adalah suatu program telah memenuhi spesifikasinya, bahwa jarak Antara setiap transformasi lebih kecil daripada jarak Antara spesifikasi dan program.
Contoh yang paling dikenal tentang proses pengembangan formal ini adalah proses Cleanroom, yang aslinya dikembangkan oleh IBM. Proses Cleanroom bergantung pada pengembangan perangkat lunak incremental dan setiap tahap dikembangkan dan kebenarannya di demonstrasikan dengan menggunakan pendekatan formal. Tidak ada pengujian kesalahan pada proses dan pengujian sistem difokuskan pada penilaian keandalan sistem.
Pengembangan sistem formal merupakan pendekatan terhadap pengembangan perangkat lunak yang memiliki kesamaan dengan model waterfall, tetapi proses pengembangannya didasarkan pada transformasi matematis dan dari spesifikasi sistem menjadi program yang dapat dijalankan.
Perbedaan antara pendekatan formal dengan waterfall:
1) Spesifikasi persyaratan perangkat lunak diperbaiki menjadi spesifikasi formal yang rinci yang dinyatakan dalam notasi matematis.
2) Proses pengembangan perancangan, implementasi, dan pengujian unit digantikan oleh proses pengembangan transformasional di mana spesifikasi formal diperbaiki, melalui serangkaian transformasi menjadi program.
Pada proses transformasi, representasi matematis formal dari sistem secara sistematis diubah menjadi representasi sistem yang lebih rinci, tetapi tetap benar secara matematis. Setiap langkah menambahkan perincian sampai spesifikasi formal diubah menjadi program yang ekivalen.
Keuntungan pendekatan transformasional adalah suatu program telah memenuhi spesifikasinya, bahwa jarak Antara setiap transformasi lebih kecil daripada jarak Antara spesifikasi dan program.
Contoh yang paling dikenal tentang proses pengembangan formal ini adalah proses Cleanroom, yang aslinya dikembangkan oleh IBM. Proses Cleanroom bergantung pada pengembangan perangkat lunak incremental dan setiap tahap dikembangkan dan kebenarannya di demonstrasikan dengan menggunakan pendekatan formal. Tidak ada pengujian kesalahan pada proses dan pengujian sistem difokuskan pada penilaian keandalan sistem.
3. Model
Pengembangan Berorientasi Pemakaian Ulang (Reuse-oriented software engineering)
Metode pengembangan yang berorientasi pemakaian ulang ini bergantung pada sejumlah besar komponen perangkat lunak yang dapat didaur ulang, yang bisa didapat, dan beberapa kerangka kerja integrasi untuk komponen-komponen ini.
Metode pengembangan yang berorientasi pemakaian ulang ini bergantung pada sejumlah besar komponen perangkat lunak yang dapat didaur ulang, yang bisa didapat, dan beberapa kerangka kerja integrasi untuk komponen-komponen ini.
Tahap-tahap pengembangan :
1. Analisis komponen. Jika
diketahui spesifikasi persyaratan, komponen-komponen untuk implementasi
spesifikasi tersebut akan dicari. Biasanya, tidak ada kesesuaian yang tepat dan
komponen yang dapat dipakai hanya memberikan sebagian dari fungsional yang
dibutuhkan.
2. Modifikasi kebutuhan. Pada tahap
ini, kebutuhan dianalisis dengan menggunakan informasi mengenai komponen yang
telah didapat. Kebutuhan kemudian dimodifikasi untuk merefleksikan komponen
yang tersedia. Jika modifikasi tidak mungkin dilakukan, maka kegiatan analisis
komponen bisa dulang untuk mencari solusi alternatif.
3. Perancangan sistem dengan pemakaian
ulang. Pada tahap ini, kerangka kerja sistem dirancang, atau kerangka kerja
yang telah ada dipakai ulang. Perancang memperhitungkan komponen yang dipakai
ulang dan mengatur kerangka kerja untuk menyesuaikan. Beberapa perangkat lunak
yang baru mungkin perlu dirancang jika komponen yang dapat dipakai ulang tidak
tersedia.
4. Pengembangan dan integrasi.
Perangkat lunak yang tidak dapat dibeli akan dikembangkan dan komponen dari
sistem COTS (Commercial Off-The-Shelf
system) diintegrasikan untuk membentuk sistem. Integrasi sistem pada
model ini bisa merupakan kegiatan yang terpisah.
Keuntungan: mengurangi besarnya perangkat lunak yang
akan dikembangkan, serta memperkecil biaya dan resiko.
Ada tiga jenis komponen perangkat lunak yang dapat
digunakan dalam proses reuse-oriented:
1. Layanan web yang dikembangkan sesuai
dengan standar layanan dan yang tersedia untuk permintaan jauh.
2. Koleksi objek yang dikembangkan
sebagai paket yang diintegrasikan dengan kerangka komponen seperti NET
atau J2EE.
3. Sistem perangkat lunak Stand-alone
yang dikonfigurasi untuk digunakan dalam lingkungan tertentu.
4. Model Pengembangan Waterfall
Model pertama yang diterbitkan untuk proses pengembangan perangkat lunak yang diambil dari proses rekayasa lain (Royce, 1970).
Tahap-tahap utama dari pengembangan ini:
Model pertama yang diterbitkan untuk proses pengembangan perangkat lunak yang diambil dari proses rekayasa lain (Royce, 1970).
Tahap-tahap utama dari pengembangan ini:
1. Analisis dan definisi kebutuhan.
Layanan, batasan, dan tujuan sistem ditentukan melalui konsultasi dengan user.
2. Perancangan sistem dan perangkat
lunak. Proses perancangan sistem membagi persyaratan dalam sistem perangkat
keras atau perangkat lunak. Kegiatan ini menentukan arsitektur sistem secara
keseluruhan. Perancangan melibatkan identifikasi dan deskripsi abstraksi sistem
perangkat lunak yang mendasar.
3. Implementasi dan pengujian unit .
Pada tahap ini, perancangan perangkat lunak direalisasikan dengan program atau
unit program. Pengujian ini melibatkan verifikasi bahwa setiap unit telah
memenuhi spesifikasinya.
4. Integrasi dan pengujian sistem. Unit
program atau program individual diintegrasikan dan diuji sebagai sistem yang
lengkap untuk menjamin bahwa kebutuhan sistem telah dipenuhi.
5. Operasi dan pemeliharaan, yaitu
mengoperasikan program di lingkungannya dan melakukan pemeliharaan. Biasanya
ini merupakan fase siklus hidup yang paling lama. Pemeliharaan mencakup koreksi
dari berbagai error yang tidak ditemukan pada tahap-tahap sebelumnya, melakukan
perbaikan atas implementasi unit sistem dan pengembangan layanan sistem, dan
persyaratan-persyaratan baru ditambahkan.
Prinsip dari metode ini hasil dari setiap fase
merupakan satu atau lebih dokumen yang disetujui. Fase berikutnya tidak
boleh dimulai sebelum sebelumnya selesai. Pada prakteknya, tahap-tahap ini
bertumpang tindih dan memberikan informasi satu sama lain.
Kekurangan model pengembangan Waterfall:
Kekurangan model pengembangan Waterfall:
·
Pada waktu
perancangan, masalah dengan persyaratan diidentifikasi, pada saat pengodean,
ditemukan masalah perancangan dan seterusnya.
·
Proses
perangkat lunak bukanlah model linear sederhana, tetapi melibatkan serangkaian
iterasi kegiatan pengembangan.
·
Sebagai
akibat dari biaya pembuatan dan persetujuan dokumen iterasi menjadi mahal dan
melibatkan pengerjaan ulang yang rumit.
·
Pada tahap
akhir (operasi dan pemeliharaan) perangkat lunak digunakan, error dan
penghapusan atas persyaratan perangkat lunak yang asli akan ditemukan.
·
Melakukan
perubahan (pemeliharaan sistem) dapat mengakibatkan perulangan beberapa atau
seluruh tahap proses sebelumnya.
·
Terjadinya
pembagian proyek menjadi tahap-tahap yang tidak fleksibel.
Untuk mengatasi masalah yang muncul pada model ini,
komitmen harus dilakukan pada tahap awal proses. Model harus digunakan hanya
ketika persyaratan dipahami dengan baik. Secara konsekuen, proses perangkat
lunak yang berdasarkan pada pendekatan ini masih digunakan untuk pengembangan
perangkat lunak, terutama jika merupakan bagian dari sistem proyek rekayasa
yang lebih besar.
Menurut Roger S. Pressman:
1. Linear Sequential Model
Model ini pertama kali dikemukakan oleh Royce. Model ini disebut juga model klasik atau waterfall. Model ini menyarankan pendekatan pengembangan secara sekuen dan sistematik untuk pengembangan perangkat lunak dimulai di level sistem, berlanjt ke analisis, lalu perancangan, pemrograman, pengujian, dan pemeliharaan.
Kelemahan model ini:
Ø Proyek-proyek nyata jarang mengikuti alur sekuen yang diusulkan model. Meskipun linear model dapat mengakomodasikan iterasi, tetapi model melakukan secara tidak langsung. Sebagai hasilnya, perubahan-perubahan dapat menyebabkan kebingungan saat tim pengembangan melakukannya.
Ø Customer suling menyatakan semua kebutuhannya secara eksplisit. Model ini memerlukan pernyataan eksplisit iut dan sulit mengakomodasikan ketidakpastian yang terdapat di awal dari kebanyakan proyek.
Ø Customer harus memiliki kesabaran. Versi yang dapat bekerja dari program tidak akan tersedia sampai akhir proyek. Kesalahan besar utama, jika tidak terdeteksi sampai program kerja dikaji ulang, maka kesalahan itu akan dapat mengakibatkan program sama sekali tidak dapat digunakan. Menyediakan banyak sumber daya.
Alasan kelemahan model ini:
• Kebutuhan harus ditetapkan di awal siklus hidup
• Kebutuhan di validasi terlalu lambat.
2. Incremental Process Model
Model ini mengombinasikan antara linear sequential model dengan filosofi iterative pada prototyping. Pada masing-masing sekuen linear menghasilkan perangkat lunak yang semakin meningkat komplektisitasnya. Setiap urutan linier menghasilkan penyampaian “bertahap” dari perangkat lunak [mcd93] dengan cara yang mirip dengan kenaikan yang dihasilkan oleh aliran proses evolusi.
Sebagai contoh, perangkat lunak pengolah kata yang dikembangkan menggunakan paradigma tambahan mungkin memberikan manajemen berkas dasar, mengedit, dan fungsi produksi dokumen kenaikan pertama, editing dan dokumen kemampuan produksi yang lebih canggih dalam selisih kedua, ejaan dan memeriksa kenaikan ketiga tata bahasa; dan kemampuan tata letak halaman dalam kenaikan keempat. Perlu dicatat bahwa aliran proses untuk peningkatan apapun dapat menggabungkan paradigma prototyping.
Ketika model inkremental digunakan, kenaikan pertama sering merupakan produk inti . Artinya, persyaratan dasar dibahas tetapi banyak fitur tambahan (beberapa diketahui, dan tidak diketahui orang lain) tetap tidak terkirim. Produk inti digunakan oleh pelanggan. Sebagai akibat dari penggunaan dan / atau evaluasi , rencana dikembangkan untuk kenaikan berikutnya . Rencana pembahasan modifikasi produk inti untuk lebih memenuhi kebutuhan pelanggan dan pengiriman fitur tambahan dan fungsionalitas. Proses ini diulang setelah pengiriman setiap kenaikan, sampai produk lengkap diproduksi.
Model proses incremental berfokus pada penyampaian produk operasional dengan kenaikan masing-masing . Kenaikan awal adalah versi dari produk akhir dilucuti-down, tetapi mereka memberikan kemampuan yang melayani pengguna dan juga menyediakan platform untuk evaluasi oleh pengguna.
Pengembangan Incremental sangat berguna ketika staf tidak tersedia untuk implementasi lengkap dengan batas waktu bisnis yang telah ditetapkan untuk proyek tersebut. Kenaikan awal dapat diimplementasikan dengan sedikit orang. Jika produk inti diterima dengan baik, maka staf tambahan ( jika diperlukan ) dapat ditambahkan untuk mengimplementasikan kenaikan berikutnya. Selain itu, kenaikan dapat direncanakan untuk mengelola risiko teknis. Sebagai contoh, sistem utama mungkin memerlukan ketersediaan perangkat keras baru yang sedang dalam tahap pengembangan dan tanggal pengiriman yang tidak pasti. Ini mungkin untuk merencanakan kenaikan awal dengan cara yang menghindari penggunaan perangkat keras ini, sehingga memungkinkan fungsi parsial untuk disampaikan kepada pengguna akhir tanpa penundaan yang banyak.
1. Linear Sequential Model
Model ini pertama kali dikemukakan oleh Royce. Model ini disebut juga model klasik atau waterfall. Model ini menyarankan pendekatan pengembangan secara sekuen dan sistematik untuk pengembangan perangkat lunak dimulai di level sistem, berlanjt ke analisis, lalu perancangan, pemrograman, pengujian, dan pemeliharaan.
Kelemahan model ini:
Ø Proyek-proyek nyata jarang mengikuti alur sekuen yang diusulkan model. Meskipun linear model dapat mengakomodasikan iterasi, tetapi model melakukan secara tidak langsung. Sebagai hasilnya, perubahan-perubahan dapat menyebabkan kebingungan saat tim pengembangan melakukannya.
Ø Customer suling menyatakan semua kebutuhannya secara eksplisit. Model ini memerlukan pernyataan eksplisit iut dan sulit mengakomodasikan ketidakpastian yang terdapat di awal dari kebanyakan proyek.
Ø Customer harus memiliki kesabaran. Versi yang dapat bekerja dari program tidak akan tersedia sampai akhir proyek. Kesalahan besar utama, jika tidak terdeteksi sampai program kerja dikaji ulang, maka kesalahan itu akan dapat mengakibatkan program sama sekali tidak dapat digunakan. Menyediakan banyak sumber daya.
Alasan kelemahan model ini:
• Kebutuhan harus ditetapkan di awal siklus hidup
• Kebutuhan di validasi terlalu lambat.
2. Incremental Process Model
Model ini mengombinasikan antara linear sequential model dengan filosofi iterative pada prototyping. Pada masing-masing sekuen linear menghasilkan perangkat lunak yang semakin meningkat komplektisitasnya. Setiap urutan linier menghasilkan penyampaian “bertahap” dari perangkat lunak [mcd93] dengan cara yang mirip dengan kenaikan yang dihasilkan oleh aliran proses evolusi.
Sebagai contoh, perangkat lunak pengolah kata yang dikembangkan menggunakan paradigma tambahan mungkin memberikan manajemen berkas dasar, mengedit, dan fungsi produksi dokumen kenaikan pertama, editing dan dokumen kemampuan produksi yang lebih canggih dalam selisih kedua, ejaan dan memeriksa kenaikan ketiga tata bahasa; dan kemampuan tata letak halaman dalam kenaikan keempat. Perlu dicatat bahwa aliran proses untuk peningkatan apapun dapat menggabungkan paradigma prototyping.
Ketika model inkremental digunakan, kenaikan pertama sering merupakan produk inti . Artinya, persyaratan dasar dibahas tetapi banyak fitur tambahan (beberapa diketahui, dan tidak diketahui orang lain) tetap tidak terkirim. Produk inti digunakan oleh pelanggan. Sebagai akibat dari penggunaan dan / atau evaluasi , rencana dikembangkan untuk kenaikan berikutnya . Rencana pembahasan modifikasi produk inti untuk lebih memenuhi kebutuhan pelanggan dan pengiriman fitur tambahan dan fungsionalitas. Proses ini diulang setelah pengiriman setiap kenaikan, sampai produk lengkap diproduksi.
Model proses incremental berfokus pada penyampaian produk operasional dengan kenaikan masing-masing . Kenaikan awal adalah versi dari produk akhir dilucuti-down, tetapi mereka memberikan kemampuan yang melayani pengguna dan juga menyediakan platform untuk evaluasi oleh pengguna.
Pengembangan Incremental sangat berguna ketika staf tidak tersedia untuk implementasi lengkap dengan batas waktu bisnis yang telah ditetapkan untuk proyek tersebut. Kenaikan awal dapat diimplementasikan dengan sedikit orang. Jika produk inti diterima dengan baik, maka staf tambahan ( jika diperlukan ) dapat ditambahkan untuk mengimplementasikan kenaikan berikutnya. Selain itu, kenaikan dapat direncanakan untuk mengelola risiko teknis. Sebagai contoh, sistem utama mungkin memerlukan ketersediaan perangkat keras baru yang sedang dalam tahap pengembangan dan tanggal pengiriman yang tidak pasti. Ini mungkin untuk merencanakan kenaikan awal dengan cara yang menghindari penggunaan perangkat keras ini, sehingga memungkinkan fungsi parsial untuk disampaikan kepada pengguna akhir tanpa penundaan yang banyak.
Tahap incremental model:
• 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.
3. Evolutionary Process Model
Model evolusi adalah model pelanggan. Model ini dicirikan dengan pengembangan, mengembangkan versi-versi sistem yang semakin lebih lengkap. Model telah mempertimbangkan untuk mengakomodasikan evolusi produk secara lengkap.
Model ini terdiri dari:
A Prototyping model
Model ini dimulai dengan pengumpulan informasi mengenai kebutuhan, dimana:
§ Pengembang dan pemesan bertemu dan mendefinisikan sasaran-sasaran umum.
§ Mengidentifikasi kebutuhan yang telah diketahui, dan
§ Mencari bidang-bidang yang masih memerlukan pendefinisian.
Tahapan Pengembangan Prototype:
• 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.
3. Evolutionary Process Model
Model evolusi adalah model pelanggan. Model ini dicirikan dengan pengembangan, mengembangkan versi-versi sistem yang semakin lebih lengkap. Model telah mempertimbangkan untuk mengakomodasikan evolusi produk secara lengkap.
Model ini terdiri dari:
A Prototyping model
Model ini dimulai dengan pengumpulan informasi mengenai kebutuhan, dimana:
§ Pengembang dan pemesan bertemu dan mendefinisikan sasaran-sasaran umum.
§ Mengidentifikasi kebutuhan yang telah diketahui, dan
§ Mencari bidang-bidang yang masih memerlukan pendefinisian.
Tahapan Pengembangan Prototype:
Gambar Model Prototype menurut Roger S. Pressman
1. Mendengarkan Pelanggan
Pada tahap ini dilakukan pengumpulan kebutuhan dari sistem dengan cara mendengar kebutuhan dari pelanggan. Untuk membuat suatu sistem yang sesuai kebutuhan, maka harus diketahui terlebih dahulu bagaimana sistem yang sedang berjalan untuk kemudian mengetahui masalah yang terjadi.
2. Merancang dan Membuat Prototype
Pada tahap ini, dilakukan perancangan dan pembuatan prototype system. Prototype yang dibuat disesuaikan dengan kebutuhan sistem yang telah didefinisikan sebelumnya dari kebutuhan pelanggan atau pengguna.
3. Uji Coba
Pada tahap ini, prototype dari sistem di uji coba oleh pelanggan atau pengguna. Kemudian dilakukan evaluasi kekurangan-kekurangan dari kebutuhan pelanggan. Pengembangan kemudian kembali mendengarkan keluhan dari pelanggan untuk memperbaiki prototype yang ada.
Prototipe berfungsi sebagai sebuah mekanisme untuk mengidentifikasi kebutuhan perangkat lunak. Jika prototipe kerja akan dibangun, dapat menggunakan fragmen program yang ada atau menerapkan alat-alat ( misalnya , generator laporan dan window manager) yang memungkinkan program kerja yang akan dihasilkan dengan cepat . Tetapi apa yang dilakukan dengan prototipe ketika telah melayani tujuan yang dijelaskan sebelumnya? Brooks [ Bro95 ] menyediakan satu jawaban : Dalam kebanyakan proyek, sistem pertama kali dibangun hampir tidak dapat digunakan . Ini mungkin terlalu lambat , terlalu besar , canggung dalam penggunaan atau ketiga . Tidak ada pilihan lain kecuali untuk memulai lagi , perih tapi cerdas , dan membangun sebuah versi didesain ulang di mana masalah ini diselesaikan .
Prototipe bisa berfungsi sebagai “sistem pertama”. Brooks merekomendasikan salah satu yang terbuang. Tetapi ini mungkin merupakan pandangan yang ideal . Meskipun beberapa prototipe dibangun sebagai ” buangan, ” lain evolusi dalam arti bahwa prototipe perlahan-lahan berkembang menjadi stakeholder system. Both aktual dan insinyur perangkat lunak seperti paradigma prototyping . Pengguna bisa merasakan sistem yang sebenarnya , dan pengembang bisa membangun sesuatu dengan segera.
Pototyping dapat menjadi masalah karena alasan berikut:
Stakeholder melihat apa yang tampaknya menjadi versi kerja perangkat lunak, tidak menyadari bahwa prototipe dimiliki bersama-sama secara sembarangan, tidak menyadari bahwa terburu-buru dalam membuatnya, pekerjaan belum dianggap kualitas perangkat lunak secara keseluruhan atau pemeliharaan jangka panjang. Ketika diberi tahu bahwa produk harus dibangun kembali sehingga tingkat kualitas yang tinggi dapat dipertahankan, stakeholder mengeluh dan meminta bahwa ” beberapa perbaikan ” diterapkan untuk membuat prototipe pekerjaan produk. Terlalu sering , manajemen pengembangan perangkat lunak mengalah .
ü Sebagai seorang insinyur perangkat lunak, sering membuat kompromi implementasi untuk mendapatkan prototipe bekerja dengan cepat. Sebuah sistem operasi yang tidak pantas atau bahasa pemrograman dapat digunakan hanya karena tersedia dan dikenal, sebuah algoritma yang tidak efisien dapat diimplementasikan hanya untuk menunjukkan kemampuan. Setelah beberapa waktu , sudah merasa nyaman dengan pilihan ini dan melupakan semua alasan mengapa mereka tidak pantas . Kurang dari ideal pilihan sekarang telah menjadi bagian integral dari sistem.
1. Mendengarkan Pelanggan
Pada tahap ini dilakukan pengumpulan kebutuhan dari sistem dengan cara mendengar kebutuhan dari pelanggan. Untuk membuat suatu sistem yang sesuai kebutuhan, maka harus diketahui terlebih dahulu bagaimana sistem yang sedang berjalan untuk kemudian mengetahui masalah yang terjadi.
2. Merancang dan Membuat Prototype
Pada tahap ini, dilakukan perancangan dan pembuatan prototype system. Prototype yang dibuat disesuaikan dengan kebutuhan sistem yang telah didefinisikan sebelumnya dari kebutuhan pelanggan atau pengguna.
3. Uji Coba
Pada tahap ini, prototype dari sistem di uji coba oleh pelanggan atau pengguna. Kemudian dilakukan evaluasi kekurangan-kekurangan dari kebutuhan pelanggan. Pengembangan kemudian kembali mendengarkan keluhan dari pelanggan untuk memperbaiki prototype yang ada.
Prototipe berfungsi sebagai sebuah mekanisme untuk mengidentifikasi kebutuhan perangkat lunak. Jika prototipe kerja akan dibangun, dapat menggunakan fragmen program yang ada atau menerapkan alat-alat ( misalnya , generator laporan dan window manager) yang memungkinkan program kerja yang akan dihasilkan dengan cepat . Tetapi apa yang dilakukan dengan prototipe ketika telah melayani tujuan yang dijelaskan sebelumnya? Brooks [ Bro95 ] menyediakan satu jawaban : Dalam kebanyakan proyek, sistem pertama kali dibangun hampir tidak dapat digunakan . Ini mungkin terlalu lambat , terlalu besar , canggung dalam penggunaan atau ketiga . Tidak ada pilihan lain kecuali untuk memulai lagi , perih tapi cerdas , dan membangun sebuah versi didesain ulang di mana masalah ini diselesaikan .
Prototipe bisa berfungsi sebagai “sistem pertama”. Brooks merekomendasikan salah satu yang terbuang. Tetapi ini mungkin merupakan pandangan yang ideal . Meskipun beberapa prototipe dibangun sebagai ” buangan, ” lain evolusi dalam arti bahwa prototipe perlahan-lahan berkembang menjadi stakeholder system. Both aktual dan insinyur perangkat lunak seperti paradigma prototyping . Pengguna bisa merasakan sistem yang sebenarnya , dan pengembang bisa membangun sesuatu dengan segera.
Pototyping dapat menjadi masalah karena alasan berikut:
Stakeholder melihat apa yang tampaknya menjadi versi kerja perangkat lunak, tidak menyadari bahwa prototipe dimiliki bersama-sama secara sembarangan, tidak menyadari bahwa terburu-buru dalam membuatnya, pekerjaan belum dianggap kualitas perangkat lunak secara keseluruhan atau pemeliharaan jangka panjang. Ketika diberi tahu bahwa produk harus dibangun kembali sehingga tingkat kualitas yang tinggi dapat dipertahankan, stakeholder mengeluh dan meminta bahwa ” beberapa perbaikan ” diterapkan untuk membuat prototipe pekerjaan produk. Terlalu sering , manajemen pengembangan perangkat lunak mengalah .
ü Sebagai seorang insinyur perangkat lunak, sering membuat kompromi implementasi untuk mendapatkan prototipe bekerja dengan cepat. Sebuah sistem operasi yang tidak pantas atau bahasa pemrograman dapat digunakan hanya karena tersedia dan dikenal, sebuah algoritma yang tidak efisien dapat diimplementasikan hanya untuk menunjukkan kemampuan. Setelah beberapa waktu , sudah merasa nyaman dengan pilihan ini dan melupakan semua alasan mengapa mereka tidak pantas . Kurang dari ideal pilihan sekarang telah menjadi bagian integral dari sistem.
B The Spiral model
Model ini diusulkan oleh Boehm. Model ini menggabungkan Antara sifat alami iterasi dari prototyping dengan aspek sistematik dan terkendali dan linear sequential model. Model ini memberi peluang untuk pengembangan cepat.
Model spiral adalah model proses perangkat lunak evolusioner yang merupakan pasangan sifat iteratif dari prototipe dengan aspek terkontrol dan sistematis dari model waterfall. Ini memberikan potensi untuk pengembangan yang semakin cepat menjadi versi lebih lengkap dari perangkat lunak.
Boehm [ Boe01a ] menggambarkan model dengan cara sebagai berikut : Model pengembangan spiral adalah model proses pembangkit risiko – driven yang digunakan untuk memandu multi-stakeholder concurrent engineering sistem intensif perangkat lunak . Ini memiliki dua fitur utama yang membedakan . Salah satunya adalah pendekatan siklik yang secara bertahap menggelar sistem definisi dan implementasi sekaligus mengurangi derajat risiko. Yang lainnya adalah satu set titik anchor tumpuan untuk memastikan komitmen stakeholder untuk solusi sistem yang layak dan saling memuaskan .
Penggunaan model spiral, software dikembangkan dalam serangkaian rilis evolusi. Selama iterasi awal , rilis memungkinkan model atau prototype . Selama iterasi kemudian, versi semakin lebih lengkap dari sistem rekayasa yang diproduksi.
Rangkaian pertama sekitar spiral, timbul melewati dalam pengembangan spesifikasi produk, berikutnya sekitar spiral dapat digunakan untuk mengembangkan prototipe dan kemudian versi progresif lebih canggih dari perangkat lunak. Setiap hasil melewati perencanaan wilayah dalam penyesuaian dengan rencana proyek. Biaya dan jadwal disesuaikan berdasarkan umpan balik yang berasal dari pelanggan setelah melahirkan.
Selain itu, manajer proyek menyesuaikan jumlah yang direncanakan iterasi yang dibutuhkan untuk menyelesaikan perangkat lunak. Tidak seperti model proses lain yang berakhir ketika perangkat lunak disampaikan, model spiral dapat disesuaikan untuk menerapkan sepanjang hidup perangkat lunak komputer. Oleh karena itu, sirkuit pertama di sekitar spiral mungkin merupakan “proyek pengembangan konsep ” yang dimulai pada inti spiral dan berlanjut selama beberapa iterasi sampai pengembangan konsep selesai. Jika konsep ini dikembangkan menjadi produk yang sebenarnya, proses hasil luar pada spiral dan sebuah “proyek pengembangan produk baru” dimulai. Produk baru akan berkembang melalui sejumlah iterasi sekitar spiral. Kemudian, sirkuit sekitar spiral dapat digunakan untuk mewakili ” proyek peningkatan produk . ” Pada dasarnya, spiral, ketika ditandai dengan cara ini, tetap operatif sampai perangkat lunak tersebut pensiun . Ada kalanya proses ini tidak aktif, tetapi setiap kali perubahan dimulai, proses dimulai pada titik masuk yang sesuai (misalnya, peningkatan produk ) .
Model ini diusulkan oleh Boehm. Model ini menggabungkan Antara sifat alami iterasi dari prototyping dengan aspek sistematik dan terkendali dan linear sequential model. Model ini memberi peluang untuk pengembangan cepat.
Model spiral adalah model proses perangkat lunak evolusioner yang merupakan pasangan sifat iteratif dari prototipe dengan aspek terkontrol dan sistematis dari model waterfall. Ini memberikan potensi untuk pengembangan yang semakin cepat menjadi versi lebih lengkap dari perangkat lunak.
Boehm [ Boe01a ] menggambarkan model dengan cara sebagai berikut : Model pengembangan spiral adalah model proses pembangkit risiko – driven yang digunakan untuk memandu multi-stakeholder concurrent engineering sistem intensif perangkat lunak . Ini memiliki dua fitur utama yang membedakan . Salah satunya adalah pendekatan siklik yang secara bertahap menggelar sistem definisi dan implementasi sekaligus mengurangi derajat risiko. Yang lainnya adalah satu set titik anchor tumpuan untuk memastikan komitmen stakeholder untuk solusi sistem yang layak dan saling memuaskan .
Penggunaan model spiral, software dikembangkan dalam serangkaian rilis evolusi. Selama iterasi awal , rilis memungkinkan model atau prototype . Selama iterasi kemudian, versi semakin lebih lengkap dari sistem rekayasa yang diproduksi.
Rangkaian pertama sekitar spiral, timbul melewati dalam pengembangan spesifikasi produk, berikutnya sekitar spiral dapat digunakan untuk mengembangkan prototipe dan kemudian versi progresif lebih canggih dari perangkat lunak. Setiap hasil melewati perencanaan wilayah dalam penyesuaian dengan rencana proyek. Biaya dan jadwal disesuaikan berdasarkan umpan balik yang berasal dari pelanggan setelah melahirkan.
Selain itu, manajer proyek menyesuaikan jumlah yang direncanakan iterasi yang dibutuhkan untuk menyelesaikan perangkat lunak. Tidak seperti model proses lain yang berakhir ketika perangkat lunak disampaikan, model spiral dapat disesuaikan untuk menerapkan sepanjang hidup perangkat lunak komputer. Oleh karena itu, sirkuit pertama di sekitar spiral mungkin merupakan “proyek pengembangan konsep ” yang dimulai pada inti spiral dan berlanjut selama beberapa iterasi sampai pengembangan konsep selesai. Jika konsep ini dikembangkan menjadi produk yang sebenarnya, proses hasil luar pada spiral dan sebuah “proyek pengembangan produk baru” dimulai. Produk baru akan berkembang melalui sejumlah iterasi sekitar spiral. Kemudian, sirkuit sekitar spiral dapat digunakan untuk mewakili ” proyek peningkatan produk . ” Pada dasarnya, spiral, ketika ditandai dengan cara ini, tetap operatif sampai perangkat lunak tersebut pensiun . Ada kalanya proses ini tidak aktif, tetapi setiap kali perubahan dimulai, proses dimulai pada titik masuk yang sesuai (misalnya, peningkatan produk ) .
Setiap Loop dibagi menjadi beberapa sektor :
a. 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.
B. Risk assessment and reduction (Penanganan dan pengurangan resiko): setiap resiko dianalisis secara detil pada sektor ini. Langkah-langkah penanganan dilakukan, misalnya membuat prototype untuk mengetahui ketidakcocokan kebutuhan.
C. 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
d. 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.
a. 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.
B. Risk assessment and reduction (Penanganan dan pengurangan resiko): setiap resiko dianalisis secara detil pada sektor ini. Langkah-langkah penanganan dilakukan, misalnya membuat prototype untuk mengetahui ketidakcocokan kebutuhan.
C. 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
d. 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.
4. RAD (Rapid
Application Development) Model
RAD adalah proses pengembangan perangkat lunak yang
semakin meningkatkan (incremental) yang menekankan pada siklus pengembangan
yang cepat. Model RAD merupakan adaptasi “berkecepatan tinggi” dari linear
sequential model dimana pengembangan yang cepat dapat diperoleh dengan
menggunakan pembangunan berbasis pada komponen.
RAD harus didukung oleh perangkat dan lingkungan pengembangan yang memadai, biasanya dikembangkan berdasarkan orientasi komponen. Lingkungan pengembangan telah memiliki library yang luar biasa besar dan lengkap seperti Java Development Kit beserta seluluru library dari Sun dan vendor-vendor lain pendukung.
Kelemahan dalam model ini:
1. Tidak cocok untuk proyek skala besar
2. Proyek bisa gagal karena waktu yang disepakati tidak dipenuhi
3. Sistem yang tidak bisa dimodularisasi tidak cocok untuk model ini
4. Resiko teknis yang tinggi juga kurang cocok untuk model ini
RAD harus didukung oleh perangkat dan lingkungan pengembangan yang memadai, biasanya dikembangkan berdasarkan orientasi komponen. Lingkungan pengembangan telah memiliki library yang luar biasa besar dan lengkap seperti Java Development Kit beserta seluluru library dari Sun dan vendor-vendor lain pendukung.
Kelemahan dalam model ini:
1. Tidak cocok untuk proyek skala besar
2. Proyek bisa gagal karena waktu yang disepakati tidak dipenuhi
3. Sistem yang tidak bisa dimodularisasi tidak cocok untuk model ini
4. Resiko teknis yang tinggi juga kurang cocok untuk model ini
Sistem dibagi-bagi menjadi beberapa modul dan dikerjakan dalam waktu yang hampir bersamaan dalam batasan waktu yang sudah ditentukan.
A) Business modelling : menjawab pertanyaan-pertanyaan: informasi apa yang mengendalikan proses bisnis? Informasi apa yang dihasilkan? Siapa yang menghasilkan informasi? Kemana informasi itu diberikan? Siapa yang mengolah informasi? Untuk kebutuhan dari sistem
b) Data modelling: aliran informasi yang sudah didefinisikan, disusun menjadi sekumpulan objek data. Ditentukan karakteristik/atribut dan hubungan antar objek-objek tersebut untuk analisis kebutuhan dan data
c) Process Modelling : objek data yang sudah didefinisikan diubah menjadi aliran informasi yang diperlukan untuk menjalankan fungsi-fungsi bisnis.
D) Application Generation: RAD menggunakan component program yang sudah ada atau membuat component yang bisa digunakan lagi, selama diperlukan.
E) Testing and Turnover: karena menggunakan component yang sudah ada, maka kebanyakan component sudah melalui uji atau testing. Namun, component baru dan interface harus tetap diuji.
5. Concurrent Models
Model ini bisa digunakan untuk pengembangan sistem client/server. Model pengembangan concurrent, disebut juga concurrent engineering, yang memungkinkan tim software untuk mewakili unsur-unsur berulang dan bersamaan pada salah satu model proses. Sebagai contoh, kegiatan pemodelan yang ditetapkan untuk model spiral dicapai dengan menerapkan satu atau lebih dari perangkat lunak tindakan rekayasa berikut: prototipe, analisis, dan desain. Kegiatan modeling dalam salah satu negara yang mencatat pada waktu tertentu. Demikian pula, kegiatan lainnya, tindakan, atau tugas (misalnya, komunikasi atau konstruksi) dapat direpresentasikan secara analog. Semua kegiatan rekayasa perangkat lunak yang ada secara bersamaan namun berada di negara-negara yang berbeda.
Pemodelan Concurrent mendefinisikan serangkaian acara
yang akan memicu transisi dari negara ke negara untuk masing-masing kegiatan
rekayasa perangkat lunak, tindakan, atau tugas. Sebagai contoh, selama tahap
awal desain (tindakan rekayasa perangkat lunak utama yang terjadi selama
kegiatan modeling), inkonsistensi dalam model persyaratan yang ditemukan. Ini
menghasilkan analisis event koreksi model, yang akan memicu aksi analisis
kebutuhan dari negara yang dilakukan ke negara perubahan menunggu.
Pemodelan Concurrent ini berlaku untuk semua jenis pengembangan perangkat lunak dan memberikan gambaran yang akurat tentang keadaan proyek. Setiap kegiatan, tindakan, atau tugas pada jaringan berjalan bersamaan dengan kegiatan, tindakan, atau tugas lain . Event yang dihasilkan pada satu titik dalam memicu transisi jaringan proses antara states.
Pemodelan Concurrent ini berlaku untuk semua jenis pengembangan perangkat lunak dan memberikan gambaran yang akurat tentang keadaan proyek. Setiap kegiatan, tindakan, atau tugas pada jaringan berjalan bersamaan dengan kegiatan, tindakan, atau tugas lain . Event yang dihasilkan pada satu titik dalam memicu transisi jaringan proses antara states.
3.
Perbedaan OOA,OOD,OOSE,OMT,UML
1.
OOA (Object Oriented
Analysis)
Object Oriented Analysis adalah merupakan suatu analisis yang menekankan pada penemuan dan penjabaran object-object atau konsep-konsep yang mana menguji kebutuhan-kebutuhan dari perspektif kelas dan penemuan object- object didalam kamus problem domain. Pada analisis, para pengembang menggunakan object untuk menentukan kebutuhan-kebutuhan sistem.
2. OOD (Object Oriented Design)
OOD adalah metode untuk mentransformasi model analisis yang dibuat
dengan menggunakanooa ke
dalam suatu model desain yang berfungsi sebagai cetak biru bangunan perangkat
lunak.
3.
OOSE Object-Oriented Software Engineering
Adalah teknik desain perangkat lunak yang
digunakan dalamdesain perangkat lunak dalam pemrogramanberorientasi objek.
4. OMT telah mengusulkan tiga jenis utama dari model :
Object Model
: Model objek merupakan fenomena statis dan lebih stabil dalam domain pemodelan
konsep utama adalah kelas dan asosiasi dengan atribut dan operasi . . Agregasi
dan generalisasi ( dengan beberapa warisan ) adalah hubungan yang telah
ditetapkan .
Model
dinamis: Model dinamis merupakan keadaan transisi tampilan / model . Konsep utama
adalah negara , transisi antara negara dan peristiwa untuk memicu transisi .
Tindakan dapat dimodelkan sebagai terjadi dalam negara . Generalisasi dan
agregasi ( concurrency ) adalah hubungan yang telah ditetapkan
Model fungsional
: model fungsional menangani perspektif model proses , kira-kira sesuai dengan
diagram aliran data . Konsep utama adalah pengolahan , penyimpanan data ,
aliran data , dan aktor .
5 UML
adalah UML merupakan singkatan dari “Unified
Modelling Language” yaitu
suatu metode permodelan secara visual untuk sarana perancangan sistem
berorientasi objek, atau definisi UML yaitu sebagai suatu bahasa yang
sudah menjadi standar pada visualisasi, perancangan dan juga pendokumentasian
sistem softwere. Saat ini UML sudah menjadi bahasa standar dalam penulisan
blue print softwere.
4.jenis jenis UML
A. Use case diagram
Use case diagram yaitu salah satu
jenis diagram pada UML yang menggambarkan interaksi antara sistem dan aktor,
use case diagram juga dapat men-deskripsikan tipe interaksi antara si pemakai
sistem dengan sistemnya.
Inilah contoh dari use case diagram.
B. Activity Diagram
Activity diagram atau diagram
aktivitas yaitu salah satu jenis diagram pada UML yang dapat memodelkan
proses-proses apa saja yang terjadi pada sistem.
Inilah contoh dari activity diagram.
C. Sequence diagram
Sequence diagram yaitu salah satu
jenis diagram pada UML yang menjelaskan interaksi objek yang berdasarkan urutan
waktu, sequence diagram juga dapat menggambarkan urutan atau tahapan yang harus
dilakukan untuk dapat menghasilkan sesuatu seperti pada use case diagram.
Inilah contoh dari sequence diagram.
D. Class diagram
Class diagram yaitu salah satu jenis
diagram pada UML yang digunakan untuk menampilkan kelas-kelas
maupun pakaet-paket yang ada pada suatu sistem yang nantinya akan
digunakan. Jadi diagram ini dapat memberikan sebuah gambaran mengenai
sistem maupun relasi-relasi yang terdapat pada sistem tersebut.
✕Powered By Albireo
Inilah contoh dari class diagram.
E. Statemachine diagram
Statemachine diagram yaitu salah
satu jenis diagram pada UML yang menggambarkan transisi maupun perubahan
keadaan suatu objek pada sistem.
Inilah contoh dari statemachine diagram.
✕Powered By Albireo
F. Communication diagram
Communication diagram yaitu salah
satu jenis diagram pada UML yang dapat menggamabarkan tahapan terjadinya
suatu aktivitas dan diagram ini juga menggambarkan interaksi antara objek yang
ada pada sistem. Hampir sama seperti sequence diagram akan tetapi communication
diagram lebih menekankan kepada peranan masing-masing objek pada sistem.
Inilah contoh dari communication diagram.
G. Deployment diagram
Deployment diagram yaitu salah satu
diagram pada UML yang menunjukan tata letak suatu sistem secara fisik, dapat
juga dikatakan untuk menampilkan bagian-bagian softwere yang terdapat pada
hardwere dan digunakan untuk menerapkan suatu sistem dan hubungan antara
komponen hardwere. Jadi Deployment diagram intinya untuk menunjukan letak
softwere pada hardwere yang digunakan sistem.
✕Powered By Albireo
Inilah contoh dari deployment diagram.
H. Component diagram
Component diagram yaitu salah satu
jenis diagram pada UML yang menggambarkan softwere pada suatu sistem.
Component diagram merupakan penerapan softwere dari satu ataupun lebih
class, dan biasanya berupa file data atau .exe, source kode, table, dokumen
dsb.
Inilah contoh dari component diagram.
I. Object diagram
Object diagram yaitu salah satu
jenis diagram pada UML yang menggambarkan objek-objek pada suatu sistem dan
hubungan antarnya.
J. Composite structure diagram
✕Powered By albireocomposite structure
diagram yaitu salah satu jenis diagram pada UML yang menggambarkan struktur
internal dari penklasifikasian (class, component atau use case) dan termasuk
titik-titik interaksi penklasifikasian kebagian lainnya dari suatu sistem. Ini
hampir mirip seperti class diagram akan tetapi composite structure diagram
menggambarkan bagian-bagian dari individu kelas saja bukan semua kelas.
K. Interaction Overview Diagram
Interaction Overview diagram yaitu
salah satu jenis diagram pada UML yang berguna untuk men-visualisasikan
kerjasama dan hubungan antara activity diagram dengan sequence diagram.
L. Package diagram
Package diagram yaitu salah satu
jenis diagram pada UML digunakan untuk mengelompokan kelas dan juga menunjukan
bagaimana elemen model akan disusun serta mengambarkan ketergantungan antara
paket-paket.
M. Diagram Timing
Diagram timing yaitu salah satu
jenis diagram pada UML yang disebut sebagai bentuk lain dari interaksi diagram,
dimana fokus yang paling utamanya kepada waktu. Diagram timing berguna
untuk menunjukan faktor-faktor yang membatasi waktu antara perubahan state
terhadap objek yang berbeda.