Veri Tabanında İleri Konular

Slides:



Advertisements
Benzer bir sunumlar
Veritabanı Nedir?
Advertisements

© 2011 IFRS Foundation 1 IFRS for SMEs Konu 2.5(b) Test ve Tartışma Varlıklar Bölümler 14 &15.
T sql-diğer komutlar Metin Akbulut.
Nesneye Dayalı (Nesne Tabanlı ) Programlama
Veri ve Veri Yapıları Genel olarak bilgisayarlar.
VERİ TABANI YÖNETİMİ Ders 11: PL/SQL’e Giriş
ALGORİTMA ÖRNEKLERİ Programlamaya Giriş
P p 8. Ünitede yinelemeli programlamanın teknikleri anlatılmaktadır. p p Gördüğünüz gibi, yinelemeli programlama bir problemin içinde problemin küçük parçalarını.
Tam İkili Ağaçlar 9. Ünite ağaçlardan bahseder.
İlişkisel Veri Modeli.
Veritabanı Yönetim Sistemleri Hızlı ve Kısa Giriş
Veritabanı Temel Kavramlar ve
I ASİMO I ASİMO PREPARED: CENGİZ MURAT TEKİNBÜĞRÜ English Course Presentation TURKEY Mechatronics Engineering at SAKARYA UNIVERSITY PREPARED: CENGİZ.
Atama ve eşleme (eşleştirme) problemleri (Matching and Assignment problems)
GÖRÜNÜŞLER (VİEWS). Görünüş Temel tablolar üzerinde yeni bir tablo almak için yapılan işlemlerin sonucu Sanal tablo- gerçekten veri tabanında yoktur ve.
Logical Design Farid Rajabli.
MySQL Operatörleri ve Fonksiyonları
Bilişim Enstitüsü ++ Bilişim Enstitüsü ++ Bilişim Enstitüsü ++ Bilişim Enstitüsü ++ Bilişim Enstitüsü ++ Bilişim Enstitüsü ++ Bilişim Enstitüsü C ++ Nesne.
SQL (Structured Query Language). MySQL de Temel Komutlar : CREATE DATABASE isim; verilen isimde bir veri tabanı oluşturur. SHOW DATABASES; Tüm yaratılan.
1 T.C. Yükseköğretim Kurulu DİPLOMA EKİ PROGRAM ÖĞRENME ÇIKTILARI (KAZANIMLARI) DİPLOMA EKİ EĞİTİM SEMİNERİ Dönemi Bologna Sürecinin Türkiye’de.
SQL Komutları (2) Uzm. Murat YAZICI.
FONKSİYONLAR İbrahim Onur Sığırcı.
RAISE RECORD/CURSOR TRIGGER
Bir Problemin Programa Dönüştürülme Süreci
VERİTABANI MİMARİSİ Talip Hakan ÖZTÜRK Bank ASYA – ORACLE DBA
Hareket halindeki insanlara ulaşın.Mobil Arama Ağı Reklamları Reach customers with Mobile Search Network.
PROGRAMLAMA DİLLERİNİN EVRİMİ
Bulanık Mantık.
İlişkisel Cebir İlişkisel Hesaplama
Veri Tabanı Yönetim Sistemleri 2 Ders 5 PL/SQL'e Giriş
Bilgisayarlar kodu nasıl işler?
COMPANY Veritabanı Örneği (Gereksinimler)
Kampanyanızı optimize edin. Görüntülü Reklam Kampanyası Optimize Edici'yi Kullanma Display Ads Campaign Optimizer. Let Google technology manage your diplay.
SQL’ e Giriş Uzm. Murat YAZICI.
Bilgisayar Mühendisliği Bölümü
Introduction to Business Process
Onur Görür Ürün Grubu Pazarlama Müdürü Microsoft Türkiye.
Key Terms from the Chapters. Chapter -1 Statistics, Data, and Statistical Thinking Fundemantal Elements of Statistics Statistics: EN: Statistics is the.
Chapter 5: Threads (İş Parçacıkları)
Bulanık Mantık Bulanık Mantığın Temel Kavramları
BM-305 Mikrodenetleyiciler Güz 2015 (6. Sunu) (Yrd. Doç. Dr. Deniz Dal)
Database for APED Büşra Bilgili | Emirhan Aydoğan | Meryem Şentürk | M. Arda Aydın COMPE 341.
Veri Tabanı Yönetimi Dersi 8. Laboratuvarı Arş. Gör. Pınar CİHAN.
CHILD PORNOGRAPHY IŞIK ÜNİVERSİTESİ
Uluslararası Standartlarda Akredite Danışmanlık
INTRODUCTION TO JAVASCRIPT
İSTATİSTİK II Hipotez Testleri 1.
INTRODUCTION TO JAVASCRIPT
Celtic-Plus Proposers Day 22 September 2016, Istanbul
Bilgisayarlar kodu nasıl işler?
Bir Problemin Programa Dönüştürülme Süreci
RA-Relational Algebra
Chapter 1 (Bölüm 1) The accounting equation(muhasebe denklemi) and the balance sheet(bilanço)
INTRODUCTION TO JAVASCRIPT
FINLAND EDUCATION SYSTEM I am talking about the Finnish education system today.
INTRODUCTION TO JAVASCRIPT
ETwinning Nedir?. Türkiye’de 81 ilin katılımıyla yürütülen 1.Projemiz.
NİŞANTAŞI ÜNİVERSİTESİ
İSTATİSTİK II Hipotez Testleri 1.
MAKİNA TEORİSİ II GİRİŞ Prof.Dr. Fatih M. Botsalı.
FONKSİYONLAR İbrahim Onur Sığırcı.
NİŞANTAŞI ÜNİVERSİTESİ
BİLL GATES Şule Eslem ÖZTÜRK NUN OKULLARI Prep-A.
NİŞANTAŞI ÜNİVERSİTESİ
Feminism, unlike the idea of ​​ mankind, is a trend that is prioritized to bring gender inequality to the agenda. The notion of feminism, which is not.
Bilgisayarlar kodu nasıl işler?
According to string theory, every substance in the universe consists of one thing. These strings, which vibrate in different channels, create everything.
VERİTABANI YÖNETİM SİSTEMLERİ 6-SQL Server-3-DDL
Sunum transkripti:

Veri Tabanında İleri Konular Sarı renkli arka planlı sayfalar bilgi amaçlıdır; sınavda sorulmayacak

Ana Başlıklar Sorgu işleme Nesneye yönelik ve nesne-ilişkisel veri tabanları Bulanık Veri Tabanları

Sorgu İşleme

Sorgu İşleme Sorgu İşleme- Veri Tabanından gereken verilerin çıkarılması girişimleri Sorgu Optimalleştirme- sorguları işlemek için etkili yürütme stratejisinin seçilmesi Kaynak kullanımının en aza indirilmesi

Çözümlerin Değerlendirilmesi Veri Tabanı istatistikleri (ilişkiler, özellikler ve endeksler hakkında bilgiler) İstatistiklerin oluşturulması sorunları -her güncellemeden sonra -belli aralıklarla

Farklı İşleme Stratejilerinin Karşılaştırılması (örnek) Sorgu: “London” kentindeki şubelerde çalışan yöneticiler hakkında bilgiler SELECT * FROM staff s, branch b WHERE s.bno=b.bno AND (s.positıon=‘Manager’ AND b.city=‘London’);

Sorgunun İlişkisel Cebirde İfadesi 1.yol  (Staff X Branch) (position =‘Manager’)^(city=‘London’)^(staff.bno=branch.bno) 2.yol  (Staff Branch) (position =‘Manager’)^(city=‘London’) staff.bno=branch.bno 3.yol ( (Staff )) ( (Branch)) position=‘Manager’ staff.bno=branch.bno city=‘London’

Örnek Üzerinde Değerlendirme Staff-1000 satır Branch-50 satır Her şubede bir yönetici (50 yönetici) 5 tane ‘London’ şubesi

Örnek Üzerinde Değerlendirme Staff-1000 satır Branch-50 satır Her şubede bir yönetici (50 yönetici) 5 tane ‘London’ şubesi 1.yol (1000+50)+2*(1000*50)=101050 disk erişimi 2.yol 2*1000+(1000+50)=3050 disk erişimi 3.yol 1000+50+2*(50+5)=1160 disk erişimi

Sorgu İşleme Safhaları Yüksek seviyeli dilde sorgu Sorgunun parç. Sistem katalogu Derleme zamanı İlişkisel cebir ifadesi Sorgunun Opt. Veri Tabanı İstatistikleri Yürütme Planı Kod Üretimi Üretilmiş Kod Çalışma zamanı Veri Tabanı Sorgu çalıştırma Sorgu Çıkışı

Sorgunun Parçalanması Sorgu İşlemenin ilk safhası Yüksek Seviyeli sorgunun ilişkisel cebir sorgusuna dönüştürülmesi Adımları: çözümleme normalleştirme anlamsal çözümleme sadeleştirme yeniden yapılandırma

Çözümleme Programlama Dilleri Derleyicilerini kullanmakla sorgunun sözcüksel ve sözdizimsel çözümlenmesi İlişki ve özelliklerin doğrulanması

Sorgu Ağacının Oluşturulması Çözümleme sonucunun daha uygun ifade biçimi Yaprak düğümler sorgunun her temel ilişkisi için oluşturulur Yaprak olmayan düğümler ilişkisel cebir işlemleri sonucu alınan aralık ilişkiler için oluşturulur Ağacın kökü sorgu neticesini ifade ediyor İşlemler ardışıklığı yapraklardan köke doğrudur

Çözümleme Örneği Sorgunun kabul edilmemesinin 2 nedeni: SELECT staff_no FROM staff WHERE position>10; Sorgunun kabul edilmemesinin 2 nedeni: 1) seçme listesinde tanımlanmamış özellik (Sno olmalı) 2)WHERE yantümcesinde yanlış karşılaştırma

Sorgu Ağacı Kök Aralık İşlemler Staff Branch Yapraklar s.bno=b.bno   s.position =‘Manager’ b.city=‘London’ Kök Aralık İşlemler Staff Branch Yapraklar

Normalleştirme Sorgunun daha kolay işlene bileceği normal biçime dönüştürülmesi 2 normal biçim Birleştirici bağlaçlı normal biçim Ayırıcı Bağlaçlı Normal Biçim

Birleştirici bağlaçlı normal biçim ^ (AND) ile bağlanmış birleştirici bağlaçlar ardışıklığı Her birleştirici birkaç VEYA işlemi içere bilir (position=‘Manager’  salary>20000)^bno=‘B3’

Ayırıcı bağlaçlı normal biçim  (VEYA) ile bağlanmış ayırıcı bağlaçlar ardışıklığı Her ayırıcı birkaç (^)VE işlemi içere bilir (position=‘Manager’ ^bno=‘B3’)  (salary>20000^bno=‘B3’)

Anlamsal Çözümleme Düzgün yazılmamış veya çelişkili olan normalleştirilmiş sorguların ret edilmesi bileşenlerin sonuca katkısının bulunmaması(örn., katılma işlemlerinde) Hiçbir satır için koşulun sağlanmaması

Anlamsal doğruluğun yoklanması İlişki bağlantıları grafı SELECT p.pno,p.street FROM renter r,viewing v,property_for_rent p WHERE r.rno=v.rno AND r.max_rent>=500 AND r.pref_type=‘flat’ AND p.ono=‘CO93’;

İlişki bağlantısı Grafı (örnek) SELECT p.pno,p.street FROM renter r,viewing v,property_for_rent p WHERE r.rno=v.rno AND r.max_rent>=500 AND r.pref_type=‘flat’ AND p.ono=‘CO93’; Sonuç R P V v.pno=p.pno unutulmuş

Sadeleştirme Fazla niceleyicilerin bulunması; ortak altifadelerin elenmesi; Sorgunun, anlamsal olarak aynı güçlü, fakat kolay ve etkili işlene bilecek biçime dönüştürülmesi erişim sınırlamaları görünümlerin tanımlanması bütünlük koşulları

Sadeleştirme Boolean ifadeleri: P^(P) P P  (P) P P^yanlış yanlış P  yanlış P P^doğru P P  doğru doğru P^(-P) yanlış P  (-P) doğru P^(P  Q) P P  (P^Q) P

Sadeleştirme Örneği SELECT sno,fname, lname,salary FROM staff WHERE ( bno=‘B3’ AND salary>20000)AND bno=‘B3’; sorgusu yerine CREATE VIEW staff3 AS SELECT sno,fname, lname,salary WHERE bno=‘B3’; SELECT* FROM staff3 WHERE (bno=‘B3’ AND salary>20000); sorgunun daha basit ifadesi WHERE ( bno=‘B3’ AND salary>20000);

Sorguların Yeniden Yapılanması Daha etkili çalışa bilmesi için sorgular yeniden yapılandırılıyor Sorgu Optimallelleştirmede sezgisel yaklaşım Dönüştürme Kuralları sezgisel işleme stratejileri

Bulanık Mantık

Bulanık mantığın tanımı Bulanık mantık teorisinin kendisi bulanık değildir. Bu mantık bulanıklığı ifade etmek için kullanılıyor. Bulanık mantık, belirsizliği ölçen bulanık kümeler teorisidir. Bulanık mantık tüm nesnelerin,kavramların derecelendirilmesini kabul ediyor. Sıcaklık,yükseklik,hız,güzellik-bunlar hepsi ölçeklene biliyor. Motor cidden sıcaktır. Ali uzun boylu delikanlıdır

Bulanık mantığın tanımı (devamı) Matematiğin temel kavramlarından olan kümeler teorisine göre her bir öğe her hangi bir kümeye kesin olarak ya aittir, ya da ait değil. Bu ise pek çok sözel ifadelerde yeterli olmaya bilir. Yüksek kasanç Yüksek basınç Uzunboylu insan Ilık su  Klasik küme teorisi yapay olarak kavram değerlerini aralıklara ayırıyor: yüksek olmayan (dağ) 1000 m’e kadar Yüksek (dağ) (1000-2000) oldukça yüksek (dağ) … >2000

Bulanık Mantığın tanımı (devamı) Çoğu karar oluşturma ve sorun çözme meselelerinin sayısal anlaşılması ve ifade edilmesi zordur. Ama insan bu tür sorunların çözümünde kesin değil, kesin olmayan bilgileri kullanmakla başarıyı daha çok yakalaya biliyor. Bulanık kümeler teorisi, insanın yaklaşık bilgiler ve belirsizliklerle karar oluşturmasını sağlar Bu teori belirsizlikleri ,anlaşılmazlıkları matematik ifade etmek ve pek çok kesin olmayan gerçekleri öğrenmek için formal araçları desteklemektedir. Bilgileri bulanık kümeleri kullanmakla daha doğal biçimde ifade etmek mümkün olduğundan pek çok mühendislik ve karar alma sorunlarının çözümü de oldukça kolaylaşmış oluyor.

Bulanık mantık uygulamaları Bulanık kümeler teorisi ve bulanık mantığın pek çok uygulama alanı bulunmaktadır: Sınıflandırma; topoloji; dilbilimi; mantık; otomat teorisi; oyun teorisi; örüntü tanıma; tıp; hukuk; karar destek; bilgi çıkarma ve s. Bulanık mantığın uygulandığı araçlar: Otomatik tren , tünel kazıma makineleri, çamaşır yıkama makineleri, pirinç pişirme,hava temizleyici, klima…

Örnek:Bulanık trafik lambaları uygulaması Eğer kırmızı ışıkta bekleyen arabaların sayısı çok ise ve karşı yoldan geçen arabaların sayısı az ise kırmızı ışığın yanma süresini kısaltmalı Amaç: bekleme zamanının en aza indirilmesi

Tarihi bilgi Bulanık,veya çokdeğerli mantık (Fuzzy, or multi-valued logic) 1930’larda Polonyalı filozof Jan Lukasiewicz tarafından önerilmiştir.Klasik mantıktan farklı olarak Lukasiewicz’in önerdiği mantık 0-1 arasındaki tüm gerçek değerleri kapsıyordu. Örneğin, boyu 181cm olan birisinin gerçekten uzun boylu olma mümkünlüğü ( possibility) 0.86 ola biliyor. Bu mantık kesin olmayan sonuçlar çıkarma tekniğine- mümkünlük teorisine götürmüştür. 1965 yılında Lotfi Zadeh (Lütfü Askerzade) ünlü “Fuzzy sets” makalesini yazmıştır. Burada mümkünlük teorisi matematik mantığın formal sistemine doğru ilerletilmiştir. Zadeh doğal dil terimlerine uygulana bilen yeni kavramlar önermiştir. Bulanık kümelerin ifade edilmesi ve işlenilmesi için Zadeh’in ileri sürdüğü yeni mantık bulanık mantıktır

Tarihi bilgi (devamı) Neden bulanık? Zadeh’in söylediği bu terim somut, anlaşılır ve tanımlayıcıdır. Bunun ne olduğunu her kez biliyor. Ama pek çok Batılı bilim adamları bu kavramı, genelde eksi anlamda kullandıkları için uzun süre kabul etmemilerdi. Neden mantık? Bulanıklık bulanık kümlere teorisine dayanıyor ve bulanık mantık teorinin bir küçük kısmıdır

“Bulanık mantık” kavramı İki anlamda işleniliyor: Dar anlamda: Bulanık mantık bulanık kümeler teorisinin bir dalıdır ve bilgilerin tasviri ve çıkarılması ile meşguldür. Diğer mantık sistemlerinden farklı olarak bulanık mantık kesin olmayan ve belirsiz bilgilerle ilgilenmektedir. Geniş anlamda: bulanık mantık bulanık küme teorisi ile eşanlamlı kullanılıyor

Bulanık mantık -çokdeğerlilik Bulanık mantık üyelik derecesine dayanan bilgileri ifade etmek için matematik ilkeler kümesidir. İkili mantık kesin ayırım yapıyor. Bir sınıfın üyesi ve üyesi olmayanlar arasında sınır çizgisi koyuluyor.Örneğin, Ali’un uzun boylu olduğunu söylemeğimiz için onun boyu 180cm’den çok olmalıdır. Eğer sınırı 180cm üzerinden belirlersek, örneğin boyu 179 cm olan Mehmet’in orta boylu olduğunu söylemeli olarız. Mehmet gerçekten mi orta boyludur, yoksa bizim çizgimiz keyfi mi çizilmiştir İkili mantıktan farklı olarak bulanık mantık çok değerlidir. Bu ise üyelik derecesi (degrees of membership) veya doğruluk derecesi (degrees of truth) ile ilgilidir. Bulanık mantık 0 (tamamen yanlış) ve 1 (tamamen doğru) arasında kesintisiz mantıksal değerleri kullanıyor. Örneğin, kesin siyah ve beyaz yerine renkler tayfını kullanıyor

Bulanık kümeler Küme (set) matematiğin temel kavramlarındandır. Doğal dildeki ifadelerde de kümeler üstün derecede kullanılıyor. Örneğin, iyi arabaları fiyatları da yüksektir cümlesinde arabalar kümesi kastediliyor.Ama “iyi araba kavramını kesin ifade etmek zordur. Uzunboylu insanlar kümesine ait edile bilen bazı insanlar tartışmasız uzunboyludur, ama bazılarının uzunboylu mu, orta boylu mu olduğu tartışıla bilir.

Kesin ve Bulanık Kümeler X ekseni konuşma evrenini (universe of discourse) (seçilmiş değişkene uygulana bilecek tüm mümkün değerler) – ifade ediyor. Bizim örnekte değişken boydur. Şekilde insanın boyu evreni tüm uzunboylu insanları kapsıyor. Y ekseni bulanık kümenin üyelik değeridir. Bizim örnekte “uzun adam” bulanık kümesi boy değerlerini uygun üyelik değerlerine yansıtıyor

Kesin ve bulanık kümeler (devamı) X konuşma evreni olsun. Onun elementleri x’lerdir. Kesin kümeler teorisinde X evrenindeki A kesin kümesi A’nın karakteristik fonksiyonu denilen fA(x) fonksiyonu ile tanımlanıyor. fA(x) : X  {0, 1}, nerede ki Bu küme X evrenini 2 elementli kümeye haritalıyor. X evrenindeki her bir x elementi için fA(x) karakteristik fonksiyonu 1 değerini alıyor (eğer x, A kümesine dahil ise ) veya 0 değerini alıyor (x, A kümesine ait değilse)

Kesin ve bulanık kümeler (devamı) Bulanık kümeler teorisinde ise X evreninde A bulanık kümesi , bu kümenin üyelik fonksiyonu denilen µA(x) fonksiyonu ile tanımlanıyor: µA(x) : X  {0, 1}, nerede ki µA(x) = 1, eğer x tümüyle A’da ise; µA(x) = 0, x A’da değilse; 0 < µA(x) < 1 eğer x kısmen A’da ise X evrenindeki her bir x için µA(x) üyelik fonksiyonu , x’in A kümesinin elementi olma derecesini ifade ediyor ve 0 ve 1arasında değerler alıyor. Bu değerler üyelik derecesi veya üyelik değeridir A = {x1, x2, .., xn} A bulanık kümesi böyle ifade edile biler: A = A(xi)/xi + …………. + A(xn)/xn burada A(xi)/xi “üyelik derecesi” bileşenidir

Bulanık kümelerin ifadesi (örnek) Önce üyelik fonksiyonları belirtilmelidir. “uzunboylu adam” örneği için üç bulanık kümemiz var: uzunboylu, kısaboylu ve orta boylu adamlar Boyu 184 cm olan insan orta boylu insan kümesine 0.1 üyelik derecesi ile aittir; aynı zamanda 0.4 üyelik derecesi ile uzun boylu insan kümesine aittir

Dilsel değişkenler Bulanık kümelerin temel kavramlarından birisi dilsel değişkenlerdir ( linguistic variables). Dilsel değişken bulanık değişkendir. Örneğin, “Ali uzunboyludur” cümlesinden anlaşılıyor ki, dilsel değişken Ali , dilsel değer “uzunboylu” almıştır Bulanık uzman sistemlerinde dilsel değişkenler bulanık kurallarda yaygın kullanılmaktadır. Örneğin: IF rüzgar güçlü ise THEN yelkençilik sporu için ortam iyidir IF proje-süresi kısa ise THEN zamanında bitirmeme riski yüksektir IF hız yavaş ise THEN durma mesafesi kısadır

Dilsel Değişkenler (devamı) Dilsel değişkenin mümkün ala bileceği değerler, bu değişkenin konuşma evrenini ifade ediyor. Örneğin, hız dilsel değişkeninin konuşma evreni 0 ve 220km/s arasındaki değerlerdir ve çok yavaş, yavaş, orta, hızlı, çok hızlı bulanık alt kümelerini kapsaya bilir. Dilsel değişkenler kısıtlayıcılarla (hedges) ifade edile bilir. Kısıtlayıcılar bulanık kümenin biçimini değiştiriyor ve zarflardan (çok, biraz, yeterli, daha çok, daha az, azıcık…) oluşuyor.

kümeler üzerinde işlemler-kesin kümeler Tamamlama (complement) Kapsama (containment) Kesişme (intersection) Birleşme (union)

Bulanık kümeler-Tamamlama-Complement Kesin kümeler: bu kümeye ne dahil değil? Bulanık küme: elementler bu kümeye ne kadar ait değil? Kümenin tamamlayıcısı bu kümeye terstir. Örneğin, uzun boylu adamlar kümemiz var ise, onun tamamlayıcısı uzun boylu olmayan adamlar kümesi olacak. Uzun boylu adamları konuşma evreninden çıkarırsak tamamlayıcını alırız. Eğer A bulanık küme ise onun tamamlayıcısı ~A böyle olacak: A(x) = 1  A(x)

Bulanık kümeller-Kapsama-Containment Her küme bir başka kümeleri içere bilir. Küçük kümeye altküme denir. Örneğin, uzun boylu insanlar kümesi tüm uzun boylu insanları içeriyor. Çok uzun boylu insanlar uzun boylu insanlar kümesinin altkümesidir. Uzun boylu insanlar kümesi ise tüm insanlar kümesinin altkümesidir. Kesin kümelerde altkümenin tüm elementleri tamamen daha büyük kümeye aittirler. Bulanık kümelerde ise her bir element büyük kümeden daha az derecede altkümeye ait ola bilir. Bulanık alt kümenin elementleri büyük kümedekine nazaran alt kümeye daha küçük üyeliktedirler Yalnız o zaman B kümesi A’yı kapsar ki, A(x) <= B(x), olsun

Bulanık kümeler-Kesişme Kesin küme: Hangi element her iki kümeye aittir? Bulanık küme: element hangi derecede her iki kümeye aittir Klasik küme teorisinde iki kümenin kesişmesi kümelerin her ikisinde de bulunan elementleri kapsıyor. Örneğin, uzun boylu insanlar ile şişman insanlar kümelerinin kesişmesi onların örtüştüğü (her iki niteliği taşıyan insanlar) alandır. Bulanık kümelerde ise element kısmen ve farklı üyeliklerle her iki kümeye ait ola bilir. Bulanık kesişme her bir elementin her iki kümede en düşük üyeliyidir. X evreninde A ve B bulanık kümelerinin kesişmesi böyledir: AB(x) = min [A(x), B(x)] = A(x)  B(x), xX

Bulanık kümeler-Birleşme Kesin küme: Hangi elementler bu veya diğer kümededir? Bulanık küme: element hangi derecede bu veya diğer kümededir? İki kesin kümenin birleşmesi bu kümelerin en azından birisinde bulunan elementleri kapsar. Örneğin, uzun boyluların kümesi ile şişmanların kümesinin birleşimi uzun boylu ve/veya şişman olan tüm adamları içeriyor. Bulanık kümelerde birleşme kesişmenin tersidir. Birleşme kümesinde elementin üyeliyi bu kümelerde uygun element için en yüksek olan üyelik değeridir. X evreninde A ve B bulanık kümelerinin birleşimi böyledir: AB(x) = max [A(x), B(x)] = A(x)  B(x), nerede ki xX

BULANIK KÜME İŞLEMLERİ

Bulanık kümelerin özellikleri Bulanık kümelerin eşitliği Bir kümenin diğerine dahil edilmesi (Inclusion) Önemlilik (Cardinality) Boş bulanık küme -kesme (alpha-cuts)

Eşitlik- Equality Yalnız o halde ( if and only if-iff) bulanık A kümesinin bulanık B kümesine eşit olduğu kabul edilir ki, A(x) = B(x), xX olsun. Örnek: A = 0.3/1 + 0.5/2 + 1/3 B = 0.3/1 + 0.5/2 + 1/3 yani A = B

Dahilolma- Inclusion Bulanık küme A  X diğer bulanık kümeye B  X dahil ediliyor (altkümesi oluyor): A(x)  B(x), xX Varsayalım ki, X = {1, 2, 3}ve A ve B kümeleri A = 0.3/1 + 0.5/2 + 1/3; B = 0.5/1 + 0.55/2 + 1/3 o zaman A B’nin altkümesidir,veya A  B

Önemlilik- Cardinality Bulanık olmayan Z kümesinin önemliliği Z’in elemanlar sayısıdır. Bulanık A kümesinin önemliliği ise A’nın üyelik fonksiyonlarının değerlerinin toplamıdır ve sigma sayı(Sigma count) adlanır: cardA = A(x1) + A(x2) + … A(xn) = ΣA(xi), i=1..n varsayalım ki, X = {1, 2, 3} ve A ve B kümeleri A = 0.3/1 + 0.5/2 + 1/3; B = 0.5/1 + 0.55/2 + 1/3 cardA = 1.8 cardB = 2.05

Boş bulanık küme-Empty Fuzzy Set A bulanık kümesi yalnız o zaman boş kümedir ki; A(x) = 0, xX Varsayalaım ki, X = {1, 2, 3} ve A kümesi A = 0/1 + 0/2 + 0/3 o zaman A boştur

Alpha –kesim Alpha-cut A  X bulanık kümesinin s -kesim veya -seviyesi A={A(x), xX} bulanık kümesidir. A  X, Örnek: X = {1, 2, 3} ve A = 0.3/1 + 0.5/2 + 1/3 O zaman A0.5 = {2, 3}, A0.1 = {1, 2, 3}, A1 = {3}

Normal Bulanık küme-Fuzzy Set Normality X bulanık altkümesi o zaman normal sayılıyor ki, en azından bir xX elemanı var ki, onun için A(x) = 1. Normal olmayan bulanık altkümelere normalin altında altküme (subnormal) denir. Tüm kesin (crisp) altkümeler, null kümeler dışında normaldir. A bulanık alt kümesinin yüksekliği (height) A’nın elemanlarının aldığı en yüksek üyelik derecesidir: height(A) = maxx(A(x))

Bulanık küme çekirdeği ve desteği- Fuzzy Sets Core and Support A, X’in bulanık altkümesidir. A’nın desteği,X’in, sıfırdan büyük üyelik dereceleri bulunan elementleri içeren kesin altkümesidir: supp(A) = {x A(x)  0 and xX} A’nın çekirdeği, X’in 1 üyelik dereceli tüm elemanları içeren kesin altkümesidir: core(A) = {x A(x) = 1 and xX} Örnek: X={a,b,c,d,e} A=1/a+0.3/b + 0.2/c+ 0.8/d +0/e B= 0.6/a+0.9/b+0.1/c+0.3/d+0.2/e destek: supp(A) = {a, b, c, d } supp(B) = {a, b, c, d, e } çekirdek: core(A) = {a} core(B) = {o}

Bulanık küme matematik işlemleri aA = {aA(x), xX} a =0.5, ve A = {0.5/a, 0.3/b, 0.2/c, 1/d} o zaman Aa = {0.25/a, 0.15/b, 0.1/c, 0.5/d} Aa = {A(x)a, xX} a =2, ve Aa = {0.25/a, 0.09/b, 0.04/c, 1/d}

Bulanık kümeler üzerinde işlemler -Örnek A = {0.2/a, 0.4/b, 1/c, 0.8/d, 0/e} B = {0/a, 0.9/b, 0.3/c, 0.2/d, 0.1/e} Tamamlama Comp(A) = {0.8/a, 0.6/b, 0/c, 0.2/d, 1/e} Comp(B) = {1/a, 0.1/b, 0.7/c, 0.8/d, 0.9/e} Birleşme AB = {0.2/a, 0.9/b, 1/c, 0.8/d, 0.1/e} Kesişme AB = {0/a, 0.4/b, 0.3/c, 0.2/d, 0/e} Alpha-kesme E = A0.5 E = {c, d}

Bulanık kümeler üzerinde işlemler -örnek(devamı) A = {0.2/a, 0.4/b, 1/c, 0.8/d, 0/e} B = {0/a, 0.9/b, 0.3/c, 0.2/d, 0.1/e} destek Supp(A) = {a, b, c, d} Supp(B) = {b, c, d, e} çekirdek Core(A) = {c} Core(B) = {} Önemlilik Card(A) = 0.2 + 0.4 + 1 + 0.8 + 0 = 2.4 Card(B) = 0 + 0.9 + 0.3 + 0.2 + 0.1 = 1.5 Aa : C=A2 C = {0.04/a, 0.16/b, 1/c, 0.64/d, 0/e} aA: D = 0.5B D = {0/a, 0.45/b, 0.15/c, 0.1/d, 0.05/e} a-kesme: A0.2 = {a, b, c, d} A0.3 = {b, c, d} A0.8 = {c, d} A1 = {c}

Bulanık kurallar Lotfi Zadeh’in 1973’de yazdığı makalede bulanık kurallar (fuzzy rules) önerilmiştir. Bulanık kural koşul cümlesi olarak böyle ifade ediliyor: IF x is A THEN y is B Burada x ve y dilsel değişkenlerdir. A ve B uygun olarak X ve Y evreninde tanımlanmış dilsel değerlerdir

Klasik ve Bulanık kurallar Klasik IF-THEN kuralı ikili mantığı kullanıyor: Kural 1: Kural 2: IF hız>100 ise IF hız < 40 ise THEN durma mesafesi uzundur THEN durma mesafesi kısadır Hız değişkeni 0-220 arasında sayı değerler ala biliyor. Ama durma mesafesi kısa veya uzun olmakla iki dilsel değerden birini almalıdır.

Klasik ve Bulanık Kurallar Durma mesafesini bulanık biçimde de ifade etmek mümkündür: kural: 1 kural2: 2 IF hız yüksek ise IF hız yavaş ise THEN durma mesafesi uzundur THEN durma mesafesi kısadır Bulanık kurallarda hız dilsel değişkeni de 0 ve 220 arasında değer alıyor. Ama bu aralık yavaş, orta,süratli gibi bulanık kümeleri içeriyor. Durma mesafesi dilsel değişkeni 0-300m arasında değişiyor ve kısa, orta ,uzun gibi bulanık kümeleri içere biliyor Bulanık sistemlerde eğer kuralın sol tarafı (IF) belirli bir derecede doğru ise kuralın sağ tarafı (THEN) aynı derecede doğrudur

Bulanık kümelerin ateşlenmesi-Firing Fuzzy Rules Aşağıdaki örnek ağırlığın tahmin modelidir. Bu modelde insanın boyu ile kilosu arasındaki bağlantı oluşturulup. IF boy uzun ise THEN kilosu çoktur

Bulanık kuralların tetiklenmesi- Firing Fuzzy Rules Kuralın sağ tarafının çıkış değeri veya gerçek üyelik derecesi sol tarafın gerçek üyelik değerinden doğrudan çıkarıla bilir. Bu bulanık çıklarımdır

Bulanık kuralların tetiklenmesi-Firing Fuzzy Rules Bulanık kümenin sebep kısmı karmaşık (birkaç sebep) ola biliyor: IF proje uzun süreli ise AND proje personel sayısı çok ise AND proje bütçesi yeterli değil THEN risk yüksektir IF hizmet mükemmel ise OR yemekler nefis ise THEN bahşiş büyüktür Sonuç da birkaç kısımdan oluşa biliyor: IF su sıcak ise THEN sıcak suyu azaltmalı; soğuk suyu arttırmalı

Bulanık küme örneği-1 Klima kapalı alanda sıcaklığı ve nemliği kontrol etmek ve belirli düzeyde tutmak için bir alettir. Klimanın pervanesi temiz havanı alıp döndürüyor ve termostatik kontrol altında soğutuyor Varsayalım ki, klimanın 5 kontrol anahtarı bulunmaktadır: Çok soğuk -COLD, soğuk-COOL, ılık-PLEASANT, sıcak_WARM ve Çok sıcak- HOT. Klimanın pervanesini işleten motorun hızı aşağıdaki gibi derecelendirilmiştir: en yavaş-MINIMAL, yavaş-SLOW, orta-MEDIUM, hızlı-FAST ve çok hızlı- BLAST.

Bulanık kümelere örnek-1 (üretim kuralları) Klimanın çalışması için bulanık kurallar: KURAL 1: IF HAVA is ÇOK SOĞUK THEN HIZ is ENYAVAŞ KURAL 2: IF HAVA is SOĞUK THEN HIZ is SLOW KURAL 3: IF HAVA is ILIK THEN HIZ is ORTA KURAL 4: IF HAVA is SICAK THEN HIZ is YÜKSEK KURAL 5: IF HAVA is ÇOK SICAK THEN HIZ is ÇOK YÜKSEK

Bulanık kümelere örnek-2 Sıcaklık için altkümeler: Çok soğuk (COLD): for 0 ≤ t ≤ 10 COLD(t) = – t / 10 + 1 Soğuk (COOL): for 0 ≤ t ≤ 12.5 COLD(t) = t / 12.5 for 12.5 ≤ t ≤ 17.5 COLD(t) = – t / 5 + 3.5

Bulanık kümelere örnek-3: HIZ için bulanık altkümeler: ENDÜŞÜK (MINIMAL): for 0 ≤ v ≤ 30 MIN (t) = – v / 30 + 1 YAVAŞ (SLOW): for 10 ≤ v ≤ 30 SLOW(t) = v / 20 – 0.5 for 30 ≤ v ≤ 50 SLOW(t) = – v / 20 + 2.5

Bulanık Veri Tabanları -Sorguların bulanıklığı Kesin sorgu Kesin sorgu: 1997 yılında yıllık geliri 1000 ve 3000 arasında olan ve çalışanlarının sayısı 200’den fazla olmayan şirketler Bulanık sorgu: Geliri orta düzeyde olan ve çok fazla çalışanı bulunmayan şirketler Bulanık sorgu

Kesin ve Bulanık sorgular 1 feet=12 inch=30.48cm; 1 inch=2.54cm

Kesin ve Bulanık sorgular

Kesin ve Bulanık sorgular

Kesin ve Bulanık sorgular Üyelik fonksiyonlarını birleştirmek için 2 yöntem: En küçük üyeliğin seçilmesi Ortalama değerin bulunması

Kesin ve Bulanık sorgular

Nesne İlişkisel ve Nesneye Yönelik Veri Tabanı Yönetim Sistemleri

VTYS’lerin sınıflandırılması İlişkisel VTYS Nesne-İlişkisel VTYS Dosya sistemleri Nesneye yönelik VTYS

Nesne –İlişkisel VTYS (Öğrenci Veri Tabanı) Öğrenci sınıfı nesneleri,Kişi sınıfının nesnelerine doğru genişletilmelidir Doktora öğrencisi , Yüksek Lisans ve Lisans Öğrencileri altsınıfları Öğrenci sınıfından özellikler miras ala bilmelidir Ders sınıfının nesneleri Çoklu ortam verilerinin işlenilmesi mümkün olmalıdır: Öğrenci resimleri Öğrencilerin ses kayıtları SQL3 accommodates all the same types of SQL 92 and some more complex data types such as photos, images, graphics, and sound Queries could include: selecting students' names and photos in order to produce a yearbook, selecting students' names and photos that are in a certain class for a class roster that the professor can use to more easily identify names with faces, or selecting students' names and voice prints for security measures.

Object-Relational DBMS Introduced in 1992 with the release of the UniSQL/X unified relational and object-oriented database system. Then, Hewlett Packard released OpenODB (later Odapter), which extended its AllBase relational DBMS. In 1993, Montage Systems (later Illustra): shipped the first commercial version of the object-relational Postgres.

Object-Relational DBMS Developing a New Standard: SQL3 SQL3 exists in draft form--anticipated ratification in July 1998. SQL3 accommodates: Object SQL Stored Procedures Triggers User-defined types CLI (Callable Level Interface) Sensitive Cursors Multimedia

Object-Relational DBMS Key Players Informix: Illustra (Informix-Universal Server) UniSQL Oracle: Oracle8 Hewlett-Packard Unisys: OSMOS IBM: DB2 version 3 Sybase: Adaptive Server (introduced Sept. ‘97) Just released--a Java-based ORDBMS: Cloudscape’s JBMS Note that Sybase just released an object-relational database, after years of development. Microsoft apparently has an object-relational database in the works. Just this month, an Oakland-based start-up company, Cloudscape, relased the first “pure” Java-based object-relational database. Cloudscape’s developers are former employees of Illustra, Sybase, and Oracle.

Object-Relational DBMS Real-world applications Oracle8 by Oracle Abbey National, the United Kingdom's fifth-largest bank, is developing a new customer database system to improve manageability of large objects, such as Abbey National's Financial Transactions data. Abbey anticipates using Oracle8 objects to store more complex forms of data, such as other databases and tables. An individual's complete insurance record, including insurance policies, claim forms, credit card receipts, and photos of automobile collision damage, can be stored as an object, providing a view of data that approximates the traditional paper record.

Object-Relational DBMS Real-world applications Nasdaq Stock Market has been testing Oracle8 on Sun Solaris and Sequent Dynix platforms to support its large Decision Support System (DSS) databases. Oracle8 is expected to provide Nasdaq with robust performance, advanced replication, and segment partitioning to help Nasdaq manage its Very Large Data Bases (VLDBs), with Oracle8 scaling up to handle multiple terabytes and 30,000 concurrent users, providing substantial headroom for Nasdaq's hundreds of gigabytes.

Object-Oriented DBMS Suited for Complex Data Nesneye Yönelik VTYS’lerde amaç karmaşık verilerin kontrolünü ve nesneler arasındaki karmaşık ilişkilerin kontrolünü çok iyi yapmaktadır. Examples: Financial portfolio risk-analysis systems Telecommunications service applications WWW document structures Design and manufacturing systems Hospital patient record systems

Object-Oriented DBMS DB functions integrated into programming language The OODBMS integrates database capabilities directly into the object-oriented programming language (C++, Smalltalk, Java). This is different than SQL, which is a separate language that defines, retrieves, and manipulates data. Client is the C++ program Server is the OODBMS

Object-Oriented DBMS Developing Standards The Object Database Management Group (ODMG): standards-setting body, organized in 1991 Rather than defining a completely new standard from the ground up, the ODMG standard builds upon the existing OMG, SQL-92, and ANSI programming language standards to define an application-portability framework among OODBMS

Object-Oriented DBMS Standard: ODMG-93 ODMG-93: the answer to SQL ODMG-93: an extension of the CORBA Persistent Object Service Three major components of ODMG-93: Object Definition Language (ODL) Object Query Language (OQL) C++ and Smalltalk language bindings Persistence Object Service provides a single client interface for storing objects--regardless of whether the object is stored in file systems, relational databases, or object databases. The main idea behind POS is a single object interface to multiple datastores. Object Definition Language: ODMG-93 uses the OMG IDL as its data definition language. ODL is a superset of IDL because it defines elements that are not in IDL, such as collection classes and referential relationships. ODL provides interface and data definition portability across languages and ODBMS vendor platforms. Object Query Language: ODMG-93 defines a SQL-like declarative language for querying and updating database objects. It supports the most commonly used SQL functions, including joins, but purposely left out most of SQL3 semantics because of limitations in its data model. Yet OQL and SQL3 may converge in the future. C++ and Smalltalk language bindings: ODMG-93 defines how to write portable C++ or Smalltalk code that manipulates persistent objects. The developers of ODMG-93 did not believe exclusively in a “universal” Data Manipulation Language, like SQL. Instead, they proposed a “unified object model for sharing data across programming languages, as well as a common query language.” They wanted to respect the syntax of the base language into which it is being inserted. This enables programmers to feel they are writing in a single integrated programming lanuage that supports persistence.

Object-Oriented DBMS Standard: ODMG 2.0 (July 1997) The Object Database Management Group (ODMG) has published the ODMG 2.0 Specification, a key milestone in the development of the only industry standard for object databases. The ODMG 2.0 standard includes: a new ODMG binding for Java that standardizes and simplifies the storage of Java objects in databases a metamodel that provides a language-independent description of a database schema to tools and applications improved C++ and Smalltalk language bindings

Object-Oriented DBMS Key Players GemStone Systems IBEX Computing SA O2 Technology Object Design Objectivity POET Software UniSQL Versant Object Technology (Voting members of ODMG) Voting membership requires that a company must have developed and must commercially ship a object DBMS product. The company must commit 20 percent of the time of a senior object DBMS expert and must commit to implement the ODMG standard. Note that we already named UniSQL as a key player in the ORDBMS. The fact that they are also shaping the standards for the OODBMS might indicate their longterm view that the OO model will eventually dominate the market. Object Design’s ObjectStore won DBMS Magazine’s 1997 Reader’s Choice Award for Best Object-Oriented Database (Nov. 17, 1997, PR Newswire)

Object-Oriented DBMS More Players MITRE Corporation NEC Corporation ONTOS Persistence Software Sybase Unidata VMARK Software Andersen Consulting CERN Electronic Data Systems (EDS) Fujitsu Software Corporation Hitachi Lockheed Martin Microsoft Notice that major companies like Sybase and Microsoft, makers of relational databases, are also playing a role in developing the OO model. Again, an indication of the future. (Reviewer member companies of ODMG) Reviewer membership requires a company to commit 10 percent of the time of a senior object DBMS expert, but does not require that the company ship an object DBMS product.

Object-Oriented DBMS Real-world applications ObjectStore by Object Design The Human Genome Project at the MIT Whitehead Institute (Cambridge, MA) is helping to sequence the entire human genome by the year 2005. They have two applications: MAPBASE (genetic mapping of mice) and LABBASE (physical mapping of humans and mice), both of which use ObjectStore as the data and model repository. They chose an OODBMS for the repository because of its ability to efficiently and quickly manage complex genetic data.

Object-Oriented DBMS Real-world applications Monterey Bay Aquarium Research Institute uses ObjectStore to collect and store multi-media oceanographic research data (videos, image, etc.). They share their ObjectStore-based research data with other research organizations through an extranet application written in Java. They replaced Oracle with ObjectStore because ObjectStore reduced the amount of Java code required (no need to convert their objects to rows & columns) and because ObjectStore could be extended very easily to store any type of multi-media or textual data.

Object-Oriented DBMS Real-world applications Rush-Presbyterian-St.Luke's Medical Center is a 1,000-bed research hospital in Chicago. ObjectStore supports a patient record system for their echocardiography unit. Doctors study echocardiograms (ultrasound recordings of hearts beating) and enter their patient evaluations into ObjectStore. The patient's report is automatically generated in HTML and FAXed to the patient's hospital room in 15 minutes (hours faster than the old, paper-based system).

Object-Oriented DBMS Real-world applications Versant Object Technology NUSTAR International (Atlanta) uses Versant to accept, store, manage, and publish data about real estate in many markets across the country. OODBMS allows great flexibility for updating local editions--each of which includes photos and other information about homes for sale in a given area. Publications are updated very frequently. Company scans between 16,000 and 25,000 photos a week. Each photo is associated with a real estate listing that includes text and graphics (including maps, floor plans, or logos).

Object-Oriented DBMS Limitations? Some DBMS developers define limitations of the OODBMS as follows: OODBMS are limited to small applications (small databases) OODBMS don’t support a lot of concurrent users It takes too much time to deliver an OODBMS application

Object-Oriented DBMS Limitations? A Response 1997 study of 24 applications found that: 15 applications occupied between 1 and 99 GB Four applications supported more than 500 users, with the most common situation involving between 10 and 99 users. Development can be time-consuming, but not in every case and delivery time is improving (facilitated by greater availability of vendor tools). Twelve to twenty-three months is average development period, but many companies delivered in less than a year. Study conducted by Douglas K. Barry, the executive director of the Object Database Management Group (ODMG). Note that no OODBMS studied comes close to supporting 30,000 concurrent users, as the NASDQ ORDBMS does.

Object-Relational DBMS & Object-Oriented DBMS: Predictions Relational DBMS market will grow to $6.8 billion by 1997, and $8.1 billion by 2000 (compared to $2.9 billion in 1995) ORDBMS market will grow to $1 billion by 2000 (compared to $14 million in 1995) OODBMS market will grow to $430 million by 1997 and $600 million by 2000 (compared to $100 million in 1995) Conclusion: Market for OODBMS is growing very fast, but still dwarfed by relational DBMS Combined statistics from the Cowen Research Report, Sept. 15, 1993, and the Data Analysis Group, Feb. 7, 1997.

Object-Relational DBMS or Object-Oriented DBMS? The Future. Future databases (in perhaps 5 to 10 years) will likely be capable of everything. Relational DBs will likely be replaced with object-relational DBs. Object-relational DBs are quickly adapting the capabilities to deal with complex data (objects). Object-oriented DBs are adding querying capabilities similar to those of relational DBs. It is currently useful to distinguish data bases by their ability to deal with complex vs. simple data types and their ability to run a query. There is some merit in each of the DB approaches. The ideal DB of the future will be able to do it all.

SQL3’e örnek(kullanıcı tanımlı tür-User Defined Type(UDT) CREATE TYPE person_type AS ( PRIVATE date_of_birth DATA CHECK (date_of_birth>DATE ‘1900-01-01’), PUBLIC fname VARCHAR(15) NOT NULL , lname VARCHAR(15) NOT NULL, address VARCHAR(50) NOT NULL, tel_no VARCHAR(13) NOT NULL, FUNCTION get_age(P person_type RESULT , DOB:DATE) RETURNS person_type RETURN /*set date_of_birth*/ END)

SQL3’e örnek (kalıtım) CREATE TYPE staff_type UNDER person_type AS ( sno VARCHAR(5) NOT NULL UNIQUE, position VARCHAR(10) NOT NULL, salary DECIMAL(7,2), bno VARCHAR(3) NOT NULL, CREATE FUNCTION is_manager(s STAFF_TYPE) RETURNS BOOLEAN BEGIN IF s>>position=‘Manager’ THEN RETURN TRUE; ELSE RETURN FALSE; ENDIF END)

SQL-3 (özyineleme) Sorgu: Bart’ın seleflerini (soyunu) bulmalı

ROW veri türü CREATE TABLE employee ( EMP_ID INTEGER, NAME ROW( GIVEN VARCHAR (30), FAMILY VARCHAR (30) ) , ADDRESS ROW ( STREET VARCHAR (50), CITY VARCHAR (30), STATE CHAR (2)), SALARY REAL ) SELECT E.NAME.FAMILY FROM employee E