Ders Adı Kodu Yarıyıl T+U Saat Kredi AKTS
Gereksinim Yönetimi YBS 606 2 3 + 0 3 6
Ön Koşul Dersleri
Önerilen Seçmeli Dersler
Dersin Dili Türkçe
Dersin Seviyesi Doktora
Dersin Türü Seçmeli
Dersin Koordinatörü Doç.Dr. ADEM AKBIYIK
Dersi Verenler
Dersin Yardımcıları
Dersin Kategorisi Diğer
Dersin Amacı

Sistem geliştirme projelerinde, yaşanan problemlerin büyük çoğunluğu, ihtiyaçların ve problemin doğru tanımlanamamasından kaynaklanır. İhtiyaçların ve problemlerin doğru tanımlanması “etkin ve gerçekçi” gereksinim yönetimi ile mümkün olabilir. Müşterinin ne istediği ile aslında neye ihtiyaç duyduğu arasındaki farkın sistem analistlerce doğru biçimde ortaya konulması adına son kullanıcı ve müşteri gereksinimlerinin doğru edinilmesi, ifade edilmesi, önceliklendirilmesi, analiz edilmesi ve yönetilmesi gerekmektedir. Gereksinim Yönetimi dersi, sistem analistlerin yazılım ürün yönetimi kapsamında sahip olmaları gereken bu alandaki nitelikleri kazandırma amacındadır. Ders sonunda öğrenciler;

Yazılım geliştirme sürecini etkin yürütmek adına gereksinimlerin net olarak açıklayabilir ve oluşturabilir.

Farklı gereksinim türlerini ve ürün gereksinimlerindeki değişime doğrudan nasıl adapte olunacağını anlar.

Wireframe ve Storyboard gibi bağlı kalma zorunluluğu düşük olan prototipleri kullanarak müşteri gereksinimlerini görselleştirebilir.

Farklı kullanıcıları ve ihtiyaçlarını tanımlar ve farklı yönlerini ortaya koyabilir.

Müşteri etkileşiminin etkinliğini artırabilir.

Kullanıcı hikayeleri (user stories), kabul testleri, ürün özellik listesi (product backlog) ve hikaye haritaları (story maps) gibi araçlar aracılığıyla gereksinimleri ifade edebilir.

Kalite ve anlaşılırlık için gereksinimlerin nasıl değerlendirilmesi gerektiğini bilir.

Dersin İçeriği

Gereksinime Giriş

Yazılım gereksinimi türleri

Kullanıcı gereksinimleri

Fonksiyonel gereksinimler

Fonksiyonel olmayan gereksinimler

Harici gereksinim türleri

Yazılım gereksinimi değişiklikleri

Kapsamın kontrolü

Kapsam kaymasının önlenmesi

Gereksinimler ve Tasarım

 

Kullanıcı Etkileşimi

Müşteri ve son kullanıcı ihtiyaçlarını belirlemek

Kullanıcı vakaları (use cases) ve ürün tasarımındaki rolü

Wireframes ve Storyboards görsel tasarım teknikleri

 

Gereksinimlerin Yazılması

Çevik (Agile) yaklaşım çerçevesinde gereksinimleri daha fonksiyonel hale çevirilmesi

Gereksinimlerin ifade edilmesi ve onaylanması için kullanıcı hikayeleri ve kabul testleri kullanımı

Gereksinimleri önceliklendirmek için ürün özellik listesi (product backlog) kullanımı

Gereksinimleri organize etmek için hikaye haritaları oluşturmak

 

Kalite Gereksinimleri

Kalite gereksinimleri için kriterler

Gereksinimleri mümkün olduğundan açık hale getirmek

Kalkınma Amaçları
# Ders Öğrenme Çıktıları Öğretim Yöntemleri Ölçme Yöntemleri
1 Yazılım geliştirme sürecini etkin yürütmek adına gereksinimlerin net olarak açıklayabilir ve oluşturabilir. Anlatım, Soru-Cevap, Beyin Fırtınası,
2 Farklı gereksinim türlerini ve ürün gereksinimlerindeki değişime doğrudan nasıl adapte olunacağını anlar. Beyin Fırtınası, Soru-Cevap, Anlatım,
3 Wireframe ve Storyboard gibi bağlı kalma zorunluluğu düşük olan prototipleri kullanarak müşteri gereksinimlerini görselleştirebilir. Tartışma, Beyin Fırtınası, Soru-Cevap, Anlatım,
4 Farklı kullanıcıları ve ihtiyaçlarını tanımlar ve farklı yönlerini ortaya koyabilir. Beyin Fırtınası, Soru-Cevap, Anlatım,
5 Müşteri etkileşiminin etkinliğini artırabilir. Beyin Fırtınası, Soru-Cevap, Anlatım,
6 Kullanıcı hikayeleri (user stories), kabul testleri, ürün özellik listesi (product backlog) ve hikaye haritaları (story maps) gibi araçlar aracılığıyla gereksinimleri ifade edebilir. Problem Çözme, Tartışma, Anlatım,
7 Kalite ve anlaşılırlık için gereksinimlerin nasıl değerlendirilmesi gerektiğini bilir. Beyin Fırtınası, Soru-Cevap, Anlatım,
Hafta Ders Konuları Ön Hazırlık
1 Gereksinime Giriş
2 Yazılım Gereksinimi Türleri I
3 Yazılım Gereksinimi Türleri II
4 Yazılım Gereksinimi Değişiklikleri
5 Gereksinimler ve Tasarım
6 Kullanıcı Etkileşimi I
7 Kullanıcı Etkileşimi II
8 ARA SINAV
9 Gereksinimlerin Yazılması
10 Çevik (Agile) Yaklaşım
11 Scrum Uygulamaları I
12 Scrum Uygulamaları II
13 Kalite Gereksinimleri
14 Genel Değerlendirme
Kaynaklar
Ders Notu

14 haftalık ders notu her dersten önce sisteme yüklenecektir.

Ders Kaynakları

Wiegers, K. ve Beatty J., (2013) “Software Requirements” 3rd Edt. Microsoft Press, Washington.

Leffingwell, D. (2011)“Agile Software Requirements: Lean Requirements Practices for Teams, Programs, and the Enterprise” Pearson, Boston.

Withall, S. (2010) Software Requirement Patterns Microsoft Press, Washington.

Lamsweerde, A. (2009) Requirements Engineering: From System Goals to UML Models to Software Specifications, John Wiley & Sons Ltd, England.

Sıra Program Çıktıları Katkı Düzeyi
1 2 3 4 5
1 En az bir yabancı dili de kullanarak kendi disiplininde derinlemesine bilgi sahibidir. X
2 Kendi disiplinindeki kavram, uygulama, model ve teoriler ile araştırma yöntem bilgisini, bilimsel çalışmalarda ele aldığı işletme ve yönetim sorunlarının çözümünde disipline orijinal katkı sunacak şekilde kullanır. X
3 Sahip olduğu bilgileri etik değerlere uygun, yasalar çerçevesinde, doğru ve güvenli şekilde kullanır. X
4 Disiplini ile ilgili sosyal konular hakkında farkındalığını gösterir. X
5 Bilimsel çalışmalarını nitelikli bilimsel mecralarda yayınlatabilir. X
6 Bilimsel çalışmalarını sözlü olarak bilimsel toplantılarda akademik teamüllere uygun bir şekilde sunabilir. X
7 Toplumsal refah oluşturmak için inovasyona dayalı girişimciliği stratejik eylemler ile ilişkilendirebilir ve tasarlayabilir. X
# Ders Öğrenme Çıktılarının Program Çıktılarına Katkısı PÇ 1 PÇ 2 PÇ 3 PÇ 4 PÇ 5 PÇ 6 PÇ 7
1 Yazılım geliştirme sürecini etkin yürütmek adına gereksinimlerin net olarak açıklayabilir ve oluşturabilir.
2 Farklı gereksinim türlerini ve ürün gereksinimlerindeki değişime doğrudan nasıl adapte olunacağını anlar.
3 Wireframe ve Storyboard gibi bağlı kalma zorunluluğu düşük olan prototipleri kullanarak müşteri gereksinimlerini görselleştirebilir.
4 Farklı kullanıcıları ve ihtiyaçlarını tanımlar ve farklı yönlerini ortaya koyabilir.
5 Müşteri etkileşiminin etkinliğini artırabilir.
6 Kullanıcı hikayeleri (user stories), kabul testleri, ürün özellik listesi (product backlog) ve hikaye haritaları (story maps) gibi araçlar aracılığıyla gereksinimleri ifade edebilir.
7 Kalite ve anlaşılırlık için gereksinimlerin nasıl değerlendirilmesi gerektiğini bilir.
Değerlendirme Sistemi
Yarıyıl Çalışmaları Katkı Oranı
1. Proje / Tasarım 100
Toplam 100
1. Yıl İçinin Başarıya 30
1. Final 70
Toplam 100
AKTS - İş Yükü Etkinlik Sayı Süre (Saat) Toplam İş Yükü (Saat)
Ders Süresi (Sınav haftası dahildir: 16x toplam ders saati) 16 3 48
Sınıf Dışı Ders Çalışma Süresi(Ön çalışma, pekiştirme) 16 2 32
Ödev 1 48 48
Final 1 10 10
Toplam İş Yükü 138
Toplam İş Yükü / 25 (Saat) 5,52
Dersin AKTS Kredisi 6