Senin, 03 Januari 2011

REKAYASA PERANGKAT LUNAK



PENDAHULUAN
1.       Apakah Perangkat Lunak?
2.       Apakah Rekayasa Perangkat Lunak (RPL) ?
3.       Apa perbedaan antara RPL dengan ilmu komputer (computer science) ?
4.       Apa perbedaan RPL dan rekayasa sistem ?
5.       Apa yang dimaksud dengan proses perangkat lunak ?
6.       Apakah model proses perangkat lunak ?
7.       Berapa biaya rekayasa perangkat lunak ?
8.       Apa saja metode-metode RPL ?
9.       Apa yang dimaksud dengan CASE (Computer-Aided Software Engineering) ?
10.   Apakah atribut-atribut perangkat lunak yang baik ?
11.   Apa tantangan kunci yang dihadapi RPL ?
PERANGKAT LUNAK
Perangkat Lunak (Software) tidak sama dengan program komputer. Perangkat lunak tidak hanya mencakup program, tetapi juga semua dokumentasi dan konfigurasi data yang berhubungan, yang diperlukan untuk membuat agar program beroperasi dengan benar.
Sistem Perangkat Lunak terdiri dari :
  1. Sejumlah program yg terpisah
  2. File-file konfigurasi
  3. Dokumentasi sistem
  4. Dokumentasi User
Dua tipe produk perangkat lunak :
  • Produk Generik à Sistem stand-alone standar yg diproduksi oleh organisasi pengembang dan dijual ke pasar terbuka ke siapapun yg membelinya. Biasa disebut sebagai software shrink-wrapped. Contoh : pengolah kata (word processor).
  • Produk pesanan (yang disesuaikan) à Sistem yg dipesan oleh pelanggan tertentu. Dikembangkan khusus bagi pelanggan oleh kontraktor perangkat lunak. Contoh : Sistem untuk mendukung proses bisnis tertentu dan sistem kontrol lalu lintas udara.
Perbedaan PENTING antara tipe2 perangkat lunak :
a.         Pada produk generik, organisasi yang mengembangkan perangkat lunak mengontrol spesifikasi perangkat lunak.
b.         Pada produk pesanan, spesifikasi biasanya dikembangkan dan dikontrol oleh organisasi yang membeli perangkat lunak tersebut.
REKAYASA PERANGKAT LUNAK
RPL atau Software Engineering (SE) à Disiplin ilmu yang membahas semua aspek produksi perangkat lunak, mulai dari tahap awal spesifikasi sistem sampai pemeliharaan sistem setelah digunakan. Ada 2 istilah kunci disini :
a.    “disiplin rekayasa” à Perekayasa membuat suatu alat bekerja.  Menerapkan teori, metode, dan alat bantu yang sesuai, selain itu mereka menggunakannya dengan selektif dan selalu mencoba mencari solusi terhadap permasalahan.
b.    “semua aspek produksi perangkat lunak” à RPL tidak hanya berhubungan dengan proses teknis dari pengembangan perangkat lunak tetapi juga dengan kegiatan seperti Manajemen proyek PL dan pengembangan alat bantu, metode, dan teori untuk mendukung produksi PL.
Perbedaan antara RPL dengan Computer Science ?
Intinya, computer science berhubungan dengan teori dan metode yang mendasari sistem komputer dan perangkat lunak, sedangkan RPL berhubungan dengan praktek dalam memproduksi perangkat lunak.
Perbedaan RPL dengan Rekayasa Sistem ?
Rekayasa sistem berkaitan dengan semua aspek dalam pembangunan sistem berbasis komputer termasuk hardware, rekayasa PL dan proses. RPL adalah bagian dari rekayasa sistem yang meliputi pembangunan PL, infrasktruktur, kontrol, aplikasi dan database pada sistem.
Proses Perangkat Lunak
Serangkaian kegiatan dan hasil-hasil relevannya yang menghasilkan perangkat lunak à sebagian besar dilakukan oleh perekayasa perangkat lunak. Ada 4 kegiatan/aktivitas pada proses PL :
1.       Spesifikikasi Perangkat Lunak à Fungsionalitas perangkat lunak dan batasan kemampuan operasinya harus didefinisikan.
2.       Pengembangan Perangkat Lunak à Perangkat lunak yang memenuhi spesifikasi harus di produksi
3.       Validasi Perangkat Lunak à Perangkat lunak harus divalidasi untuk menjamin bahwa perangkat lunak melakukan apa yang diinginkan oleh pelanggan.
4.       Evolusi Perangkat Lunak à Perangkat lunak harus berkembang untuk memenuhi kebutuhan pelanggan.
Model Proses Perangkat Lunak
Merupakan deskripsi yang disederhanakan dari proses perangkat lunak di presentasikan dengan sudut pandang tertentu.
Bisa mencakup kegiatan yang merupakan bagian dari proses perangkat lunak, produk perangkat lunak, dan peran orang yang terlibat pada rekayasa perangkat lunak (Perekayasa PL).
Contoh Jenis Model Proses PL
  1. Model aliran kerja (workflow) à menunjukkan kegiatan pada proses bersama dengan input, output, dan ketergantungannya. Merepresentasikan pekerjaan manusia.
  2. Model aliran data (data flow) à merepresentasikan proses sebagai suatu set kegiatan yang melakukan transformasi data. Menunjukkan bagaimana input ke proses, misalnya spesifikasi ditransformasi menjadi output, misalnya menjadi desain.
Model peran/aksi à merepresentasikan peran orang yang terlibat pada PL dan kegiatan yg menjadi tanggung jawab mereka.
Model atau paradigma umum pada proses PL
    1. Model air terjun (waterfall) à Mengambil kegiatan dasar seperti spesifikasi, pengembangan, validasi, dan evolusi dan merepresentasikannya sebagai fase-fase proses yang berbeda seperti spesifikasi persyaratan, perancangan perangkat lunak, implementasi, pengujian dan seterusnya.
    2. Pengembangan evolusioner à Pendekatan ini berhimpitan dengan kegiatan spesifikasi, pengembangan, dan validasi. Sistem awal dikembangkan dengan cepat dari spesifikasi abstrak. Sistem ini kemudian di perbaiki dengan masukan dari pelanggan untuk menghasilkan sistem yang memuaskan kebutuhan pelanggan.
    3. Pengembangan Sistem Formal à Pendekatan ini menghasilkan suatu sistem matematis yang formal dan mentransformasikan spesifikasi ini, dengan menggunakan metode matematik menjadi sebuah program.
    Pengembangan berdasarkan pemakaian ulang (Reusable) à Teknik ini menganggap bahwa bagian-bagian sistem sudah ada. Proses pengembangan sistem terfokus pada pengintegrasian bagian-bagian sistem dan bukan pengembangannya dari awal.
    Biaya Rekayasa Perangkat Lunak
      Umumnya sekitar 60% untuk biaya pengembangan (development) dan 40% biaya pengujian (testing).
      Distribusi biaya yang tepat selama proses perangkat lunak bergantung pada proses yang digunakan dan jenis perangkat lunak yang dikembangkan.
      Metode-metode RPL
      Pendekatan-pendekatan terstruktur terhadap pengembangan perangkat lunak mencakup model, notasi, aturan, saran pengembangan sistem (rekomendasi), dan panduan proses.
      • Deskripsi model sistem –> Deskripsi model yang harus dikembangkan dan notasi yang digunakan untuk mendefinisikan model-model ini. Ex : model aliran data.
      • Aturan –> Batasan yang berlaku bagi model sistem. Ex : Setiap entitas pada model sistem harus memiliki nama yang unik.
      • Rekomendasi  –> Saran dalam membentuk perancangan yang baik. Ex : Tidak ada objek yang memiliki lebih dari tujuh sub-objek yang berhubungan dengannya.
      • Panduan Proses  –> Aktifitas yang bisa diikuti untuk mengembangkan model sistem. Ex : Atribut objek harus didokumentasi sebelum mendefinisikan operasi yang berhubungan dengan objek.
      CASE (Computer-Aided Software Engineering)
      Mencakup berbagai macam program yang digunakan untuk mendukung kegiatan PL seperti analisis persyaratan, pemodelan sistem, debugging, dan pengujian.
      Atribut-atribut PL yang baik
      n  Perangkat Lunak seharusnya memberikan user kebutuhan fungsionalitas dan kinerja yang :
      1.       Dapat dipelihara (Maintanability) à PL harus dapat memenuhi perubahan kebutuhan user.
      2.       Dapat diandalkan (Dependability) à PL harus dapat dipercaya dan tidak menyebabkan kerusakan fisik atau ekonomi jika terjadi kegagalan sistem.
      3.       Efisien à PL harus efisien dalam penggunaan sumber daya sistem.
      4.       Kemampupakaian (Usability) à PL harus dapat dipakai sesuai dengan yang direncanakan.Tantangan Kunci yang dihadapi RPL ?
      Tantangan Warisan (Legacy) à Tantangan memelihara dan meng-update PL sedemikian sehingga biaya yg berlebihan dapat dihindari dan layanan bisnis yg penting tetap dilakukan.
      1. Tantangan Heterogenitas à Tantangan teknik pengembangan untuk membangun perangkat lunak yang dapat diandalkan dan cukup flexibel untuk menghadapi heterogenitas yang ada.
      Tantangan Pengiriman à Tantangan mempersingkat waktu kirim sistem besar dan kompleks, tanpa mengurangi kualitas sistem.

       PENGERTIAN
      RPL secara umum disepakati dari terjemahan Software Engineering yang mulai populer tahun 1968 pada Software Engineering Conference oleh NATO. pengertian RPL sendiri yaitu disiplin ilmu yang membahas seluruh aspek produksi perangkat lunak dari tahap analisa kebutuhan user, menentukan spesifikasi kebutuhan user, disain pengkodean, pengujian, hingga kepemeliharaan sistem setelah dipakai. jadi jelas RPL bukan hanya pembuatan tapi juga semua aspek dalam pembuatan suatu software.
      2. TUJUAN REKAYASA PERANGKAT LUNAK

      - Memperoleh biaya produksi software yang rendah
      - menghasilkan software berkinerja tinggi, handal dan tepat waktu
      - menghasilkan software yang dapat bekerja pada berbagai platform
      - menghasilkan software dengan biaya perawatan rendah

      3. RUANG LINGKUP REKAYASA PERANGKAT LUNAK
      (GB 1)

      - Software requirements berhubungan dengan spesifikasi kebutuhan dan persyaratan perangkat lunak.
      - Software design mencakup proses penentuan arsitektur, komponen, antarmuka, dan karakteristik lain dari perangkat lunak.
      - Software construction berhubungan dengan detil pengembangan perangkat lunak, termasuk algoritma, pengkodean, pengujian, dan pencarian kesalahan.
      - Software testing meliputi pengujian pada keseluruhan perilaku perangkat lunak.
      - Software maintenance mencakup upaya-upaya perawatan ketika perangkat lunak telah dioperasikan.
      - Software configuration management berhubungan dengan usaha perubahan konfigurasi perangkat lunak untuk memenuhi kebutuhan tertentu.
      - Software engineering management berkaitan dengan pengelolaan dan pengukuran RPL, termasuk perencanaan proyek perangkat lunak.
      - Software engineering tools and methods mencakup kajian teoritis tentang alat bantu dan metode RPL.
      - Software engineering process berhubungan dengan definisi, implementasi, pengukuran, pengelolaan, perubahan dan perbaikan proses RPL.
      - Software quality menitikberatkan pada kualitas dan daur hidup perangkat lunak.

      4. RPL dan DISIPLIN ILMU KOMPUTER

      Disiplin ilmu komputer lahir awal tahun 1940 yang merupakan integrasi teori algoritma, logika matematika, dan ditemukannya penyimpanan program secara elektronik pada komputer.
      (GB 2: Klasifikasi disiplin Ilmu Komputem menurut ACM, Denning dan Wikipedia)

      5. RPL DISIPLIN ILMU LAIN
      (GB 3: Keterkaitan RPL dan ilmu lain)

      - Bidang ilmu manajemen meliputi akutansi, finansial, pemasaran, manajemen operasi, ekonomi, analisis kuantitatif, manajemen sumber daya manusia, kebijakan dan strategi bisnis.
      - Bidang ilmu matematika meliputi aljabar linier, kalkulus, peluang, statistik, analisis numerik dan matematika diskrit.
      - Bidang ilmu manajemen proyek meliputi semua hal yang berkaitan dengan proyek, seperti ruang lingkup proyek, anggaran, tenaga kerja, kualitas, manajemen resiko, dan penjadwalan proyek.
      - Bidang ilmu manajemen kualitas meliputi pengembangan sistem kualitas, manajemen resiko dan keandalan, perbaikan kualitas, dan metode-metode kuantitatif.
      - Bidang ilmu ergonomika menyangkut hubungan (interaksi) antara manusia dengan komponen-komponen lain dalam sistem komputer.
      - Bidang ilmu rekayasa sistem meliputi teori sistem, analisis biaya-keuntungan, pemodelan, simulasi, proses dan operasi bisnis.

      6. PERKEMBANGAN REKAYASA PERANGKAT LUNAK (RPL)

      - 1940an
      Komputer pertama yang membolehkan pengguna menulis kode program langsung
      - 1950an
      Generasi awal interpreter dan bahasa macro
      Generasi pertama compiler
      Generasi kedua compiler
      - 1960an
      Komputer mainframe mulai dikomersialkan
      Pengembangan perangkat lunak pesanan
      Konsep Software Engineering mulai digunakan
      - 1970an
      Perangkat pengembang perangkat lunak
      Perangkat minicomputer komersial
      - 1980an
      Perangkat Komputer Personal (PC) komersial
      Peningkatan permintaan perangkat lunak
      - 1990an
      Pemrograman berorientasi obyek (OOP)
      Agile Process dan Extreme Programming
      Peningkatan drastis kapasitas memori
      Peningkatan penggunaan internet
      - 2000an
      Platform interpreter modern (Java, .Net, PHP, dll)
      Outsourcing

      7. PROFESI DAN SERTIFIKASI

      Profesi sebagai software engineer mungkin asing ditelinga anda termasuk anda karena kerancuan istilah RPL tadi. sertifikasi kopetensi RPL sampai sekarang masih menjadi perdebatan dalam industri software karena menuntut hal yang spesifik untuk software tertentu. ACM (association for computing machinery) pernah membuat sertifikasi untuk program software engineer tahun 1980an tapi dihentikan karena kurang peminat. IEEE sudah mengeluarkan lebih dari 500 sertifikat profesi RPL. di Canada telah keluar sertifikat legal untuk RPL yang disebut ISP (Information System Professional)

      Saat ini, sertifikasi untuk RPL di Indonesia juga belum tersedia, namun telah disusun Standar Kompetensi Kerja Nasional Indonesia untuk Bidang Programmer Komputer. Meskipun belum memenuhi cakupan bidang RPL secara keseluruhan, namun paling tidak dapat digunakan sebagai pendekatan sertifikasi bidang RPL.

      Tidak ada komentar:

      Posting Komentar