BM-103 Programlamaya Giriş Güz 2016 (8. Sunu)

Slides:



Advertisements
Benzer bir sunumlar
Bilgisayar Programlama Güz 2011
Advertisements

Bilgisayar Programlama Güz 2011
BM-103 Programlamaya Giriş Güz 2014 (7. Sunu)
BM-103 Programlamaya Giriş Güz 2014 (8. Sunu)
BM-103 Programlamaya Giriş Güz 2014 (4. Sunu)
BM-103 Programlamaya Giriş Güz 2014 (9. Sunu)
MATLAB’ de Programlama
MATLAB’ de Programlama
Bilgisayar Programlama Güz 2011
BM-103 Programlamaya Giriş Güz 2012 (3. Sunu)
Algoritma.  Algoritma, belirli bir görevi yerine getiren sonlu sayıdaki işlemler dizisidir.  Başka bir deyişle; bir sorunu çözebilmek için gerekli olan.
Atalet, maddenin, hareketteki değişikliğe karşı direnç gösterme özelliğidir.
Hatırlatma Ortogonal bazlar, ortogonal matrisler ve Gram-Schmidt yöntemi ile ortogonaleştirme vektörleri aşağıdaki özeliği sağlıyorsa ortonormaldir: ortogonallik.
Determinant Bir kare matrisin tersinir olup olmadığına dair bilgi veriyor n- boyutlu uzayda matrisin satırlarından oluşmuş bir paralel kenarın hacmine.
BM-308 Paralel Programlamaya Giriş Bahar 2016 (2. Sunu) (Yrd. Doç. Dr. Deniz Dal)
LUCA Bilgisayarlı muhasebe programı
Metrik koşullarını sağlıyor mu?
ÖTÖ 451 Okul Yönetiminde Bilgisayar Uygulamaları R. Orçun Madran.
BİLGİSAYAR PROGRAMLAMA MATLAB Yrd.Doç.Dr. Cengiz Tepe.
Örnek 1 Kullanıcının girdiği bir sayının karesini hesaplayan bir program yazınız.
1. Ders Bir, İki ve Üç Yazarlı Eserlerin Kataloglanması Prof. Dr. Bülent Yılmaz Arş. Gör. Tolga Çakmak.
9. HAFTA 25 Nisan2016. Fonksiyon M-Dosyaları Fonksiyon dosyaları ilk satırda “function” kelimesi bulunan “.m” uzantısı bulunan dosyalardır. MATLAB içinde.
ÇARPMA İŞLEMİ X x x x xx x.
ÇOK BOYUTLU SİNYAL İŞLEME
Bölüm 3 : Yapay Sinir Ağları (MatLab) Artificial Neural Network
BİLGİSAYAR PROGRAMLAMA DERSİ 6. DERS NOTU Konu: Matlab’ de Diziler ve Matrisler.
BİLGİSAYAR PROGRAMLAMA DERSİ
OLAYLAR (EVENT).
BM-103 Programlamaya Giriş Güz 2016 (3. Sunu)
TAM SAYILAR.
BM-103 Programlamaya Giriş Güz 2016 (5. Sunu)
Hatırlatma: Durum Denklemleri
Geçen hafta ne yapmıştık
BM-103 Programlamaya Giriş Güz 2016 (7. Sunu)
Problem Çözme ve Algoritmalar
Yapay Sinir Ağı Modeli (öğretmenli öğrenme) Çok Katmanlı Algılayıcı
Yrd. Doç. Dr. Mustafa Akkol
C Programlama Yrd.Doç.Dr. Ziynet PAMUK BMM211-H05
BİLGİSAYAR PROGRAMLAMA Ders 5: Döngüler
- Sağlama - Kısa yoldan Çarpmalar
BİLGİSAYAR ÇEŞİTLERİ.
NBP103 Programlama Temelleri Öğr. Gör. Mahmut Kılıçaslan
HÜRRİYET ANADOLU LİSESİ
BM-103 Programlamaya Giriş Güz 2012 (6. Sunu)
PROBLEM ÇÖZME VE ALGORİTMALAR
BMS-301 Kabuk Programlama Güz 2017 (7. Sunu) (Yrd. Doç. Dr. Deniz Dal)
Pascal’da Kullanılan Standart Prosedür ve Fonksiyonlardan Bazıları
3.hafta METODLAR.
Prof.Dr.Şaban EREN Yasar Üniversitesi Fen-Edebiyat Fakültesi
PARAMETRİK HİPOTEZ TESTLERİ
Teknoloji Fakültesi Mekatronik MTM326 Veri Toplama ve İşleme
BM-103 Programlamaya Giriş Güz 2016 (6. Sunu)
İleri Algoritma Analizi
DİJİTAL GÖRÜNTÜ İŞLEME Y. Doç. Dr. Esra Tunç Görmüş
Bilgisayar Bilimi Koşullu Durumlar.
NİŞANTAŞI ÜNİVERSİTESİ
Sunucu Bilgisayara Eğitim Yazılımı Yüklemek İçin;
Fonksiyonlar ve Alt Programlar
6. DÖNGÜ (TEKRARLAMA) DEYİMLERİ
Bilgisayar Bilimi Fonksiyon Yazma.
Değerler ve Değişkenler
NİŞANTAŞI ÜNİVERSİTESİ
NİŞANTAŞI ÜNİVERSİTESİ
BLM-111 PROGRAMLAMA DİLLERİ I Ders-10 Diziler
Pascal’da Kullanılan Standart Prosedür ve Fonksiyonlardan Bazıları
MTM216 GÖRSEL PROGRAMLAMA
MTM216 GÖRSEL PROGRAMLAMA
İleri Algoritma Analizi
Bilimsel Araştırma Yöntemleri
NİŞANTAŞI ÜNİVERSİTESİ
Sunum transkripti:

BM-103 Programlamaya Giriş Güz 2016 (8. Sunu) (Yrd. Doç. Dr. Deniz Dal)

İKİ BOYUTLU DİZİLER (MATRİSLER) İki boyutlu dizi (matris) denildiğinde aklınıza kare bulmaca veya satranç tahtası gelmelidir. TRSE1 sınıfı da 2 boyutlu bir dizi midir?

MATLAB’DE İKİ BOYUTLU DİZİLER (MATRİSLER) VE size Fonksiyonu size aşırı yüklenmiş bir MATLAB fonksiyonudur.

MATRİS ELEMANLARINA İNDİS İLE ULAŞMA Virgül ile ayrılmış iki indis kullanıldığına dikkat ediniz (satır indisi ve sütun indisi). Tek boyutlu dizilerde ise tek bir indis kullandığımızı da hatırlayınız.

İPUCU Kendisine M adındaki bir matrisi parametre olarak alan bir fonksiyon m-dosyası matrisin boyutuyla ilgili bir işlem yapıyorsa size(M) fonksiyonunu muhakkak kullanmak zorundadır. (Bu fonksiyona komut penceresinden nasıl bir matrisin parametre olarak aktarılacağı peşinen bilinemez çünkü.)

İPUCU Bir matris içerisinde iç içe 2 for döngüsü kullanılarak kolaylıkla gezilebilir. Dıştaki döngü (i ile kontrol edilen döngü) satır indislerini ve içteki döngü (j ile kontrol edilen döngü) sütun indislerini temsil amacıyla kullanılabilir. [satirSayisi sutunSayisi]=size(M); toplam=0; for i=1:satirSayisi for j=1:sutunSayisi toplam=toplam+M(i,j); end disp(toplam); Bu program ne iş yapar?

MATRİSLERDE İŞLEMLER Aşağıdaki matris işlemlerini MATLAB zaten kolayca gerçekleştirmektedir. Ama bizim amacımız bu işlemleri şimdiye kadar öğrendiğimiz programlama yapıları ile kendimizin yazabilmesidir. Matrislerin Bir Skalerle Çarpımı Matrislerde Toplama ve Çıkarma Matrislerde Çarpma Matrislerin Transpozu

Matrislerin Bir Skalerle Çarpımı Kendisine parametre olarak aldığı bir M matrisinin her bir elemanını yine kendisine parametre olarak aldığı bir k skaleri ile çarpan ve elde ettiği N matrisini geriye döndüren bir MATLAB fonksiyonunu MatrisiSkalerleCarp.m adındaki fonksiyon m-dosyasının içerisine yazınız. function N=MatrisiSkalerleCarp(M,k) N=[ ];%Başlangıçta Boş Bir Matris [satirSayisi sutunSayisi]=size(M); for i=1:satirSayisi for j=1:sutunSayisi N(i,j)=M(i,j)*k; end KOMUT PENCERESİ >>MatrisiSkalerleCarp([1 2;3 4],6) ans= 6 12 18 24

Matrislerde Toplama ve Çıkarma İşlemi Kendisine parametre olarak aldığı bir M matrisi ile yine kendisine parametre olarak aldığı bir N matrisini toplayarak elde ettiği T matrisini geriye döndüren bir MATLAB fonksiyonunu IkiMatrisiTopla.m adındaki fonksiyon m-dosyasının içerisine yazınız. İki matrisin toplanabilmesi veya çıkarılabilmesi ancak ve ancak boyutlarının (yani satır ve sütun sayılarının) eşit olması ile mümkündür. function T=IkiMatrisiTopla(M,N) T=[ ];%Başlangıçta Boş Bir Matris [satirSayisiM sutunSayisiM]=size(M); [satirSayisiN sutunSayisiN]=size(N); if (satirSayisiM==satirSayisiN)&&(sutunSayisiM==sutunSayisiN) for i=1:satirSayisiM%Veya satirSayisiN for j=1:sutunSayisiM%Veya sutunSayisiN T(i,j)=M(i,j)+N(i,j); end KOMUT PENCERESİ >>IkiMatrisiTopla([1 2;3 4],[5 6;7 8]) ans= 6 8 10 12

Matrislerde Çarpma İşlemi A ve B gibi iki matrisin çarpılabilmesi için A matrisinin sütun sayısının B matrisinin satır sayısına eşit olması gerekmektedir. A matrisi mxn, B matrisi nxk ise bu çarpma işlemi sonucunda elde edilecek C matrisinin boyutu mxk olacaktır. A=[1 2 1;0 3 -1]; B=[1 2; 1 5;2 3]; if size(A,2) ~= size(B,1) disp('Çarpım İllegal'); return; end C=zeros(size(A,1),size(B,2)); for i=1:2 for j=1:2 for k=1:3 C(i,j)=C(i,j)+A(i,k)*B(k,j); disp(A); disp(B); disp(C); Örnek

Matrislerde Transpoz İşlemi Transpoz, matrislerde satır ile sütunun yer değiştirmesi işlemidir. Yani A=2x3’lük bir matrisin transpozu alındığı zaman B=AT=3x2’lik bir matris elde edilir. A=[1 3 0; 4 2 -3]; B=[ ]; [m n]=size(A); for i=1:n %A’nın Sütunu for j=1:m %A’nın Satırı B(i,j)=A(j,i); end disp(A); disp(B); B =AT 1 4 3 2 0 -3 A = 1 3 0 4 2 -3 Komut satırında A' yı test ediniz. Hangi metod daha kolay ? 

BİR KARE MATRİSİN ANA KÖŞEGENİ (Kuzey Batı – Güney Doğu Köşegeni) Köşegen Üzerindeki Elemanlar (i==j) Üst Üçgen Bölgedeki Elemanlar (j>i) İç Döngü Değişkeni (j) 𝑴= 𝟒 𝟒 −𝟏𝟓 𝟑 𝟐𝟕 𝟏 𝟕𝟖 𝟗 𝟏𝟔 −𝟕 𝟏𝟐𝟑 −𝟗 𝟐𝟓 𝟑𝟒 𝟐 𝟒 𝟓𝟖 𝟑𝟒 𝟒𝟐 𝟓𝟔 −𝟔𝟓 𝟏𝟏𝟐 𝟐 𝟖 𝟑 Dış Döngü Değişkeni (i) Alt Üçgen Bölgedeki Elemanlar (i>j)

BİR KARE MATRİSİN İKİNCİL KÖŞEGENİ (Kuzey Doğu – Güney Batı Köşegeni) Üst Üçgen Bölgedeki Elemanlar (i+j)<(n+1) Köşegen Üzerindeki Elemanlar (i+j)==(n+1) İç Döngü Değişkeni (j) 𝑴= 𝟒 𝟒 −𝟏𝟓 𝟑 𝟐𝟕 𝟏 𝟕𝟖 𝟗 𝟏𝟔 −𝟕 𝟏𝟐𝟑 −𝟗 𝟐𝟓 𝟑𝟒 𝟐 𝟒 𝟓𝟖 𝟑𝟒 𝟒𝟐 𝟓𝟔 −𝟔𝟓 𝟏𝟏𝟐 𝟐 𝟖 𝟑 Dış Döngü Değişkeni (i) Alt Üçgen Bölgedeki Elemanlar (i+j)>(n+1)

UYGULAMA Kendisine parametre olarak aldığı bir M kare matrisinin ana köşegeni üzerindeki elemanlarının aritmetik ortalamasını bularak geriye döndüren bir MATLAB fonksiyonu yazınız. (İç içe 2 for döngüsüne ihtiyaç duyulur mu? Tek bir for döngüsü ile çözüme ulaşabilir miyiz?) UYGULAMA Kendisine parametre olarak aldığı bir M kare matrisinin ikincil köşegeni üzerindeki elemanlarının geometrik ortalamasını bularak geriye döndüren bir MATLAB fonksiyonu yazınız. (İç içe 2 for döngüsüne ihtiyaç duyulur mu? Tek bir for döngüsü ile çözüme ulaşabilir miyiz?)

UYGULAMA Aşağıdaki gibi bir ekran çıktısı verecek EkranaRakamBas.m adında bir fonksiyon m-dosyası yazınız. (Fonksiyonunuz kendisine hiçbir argüman almayacak ve geriye yine hiçbir değer çevirmeyecektir.) EKRAN ÇIKTISI >>EkranaRakamBas() 1 2 3 4 5 6 7 8 9 1 2 3 4 5 6 7 8 1 2 3 4 5 6 7 1 2 3 4 5 6 1 2 3 4 5 1 2 3 4 1 2 3 1 2 1 function EkranaRakamBas() clc; for i=1:9 %Satır Sayısı for j=1:(10-i) %Sütun Sayısı fprintf('%d ', j); end fprintf('\n'); %Bir Alt Satırın Başına Git 15

UYGULAMA Aşağıdaki gibi bir ekran çıktısı verecek EkranaRakamBas.m adında bir fonksiyon m-dosyası yazınız. (Fonksiyonunuz kendisine hiçbir argüman almayacak ve geriye yine hiçbir değer çevirmeyecektir.) EKRAN ÇIKTISI >>EkranaRakamBas() 1 1 1 1 1 1 1 1 1 2 2 2 2 2 2 2 2 3 3 3 3 3 3 3 4 4 4 4 4 4 5 5 5 5 5 6 6 6 6 7 7 7 8 8 9 16

UYGULAMA Aşağıdaki gibi bir ekran çıktısı verecek EkranaRakamBas.m adında bir fonksiyon m-dosyası yazınız. (Fonksiyonunuz kendisine hiçbir argüman almayacak ve geriye yine hiçbir değer çevirmeyecektir.) 9x9’luk bir kare matrisin ana köşegene göre alt üçgen bölgesinde (ana köşegen dahil) (if i>=j) j’leri, üst üçgen bölgesinde ise boşluk karakterlerini ekrana basan bir çözüm işe yarar mı? EKRAN ÇIKTISI >>EkranaRakamBas() 1 1 2 1 2 3 1 2 3 4 1 2 3 4 5 1 2 3 4 5 6 1 2 3 4 5 6 7 1 2 3 4 5 6 7 8 1 2 3 4 5 6 7 8 9 17

UYGULAMA K=[-4 3 0;2 0 4 ] matrisindeki sıfırların sayısını ve yerini (satır ve sütun numaralarını) ekrana basan bir MATLAB düzyazı m-programı yazınız. K=[-4 3 0;2 0 4 ];%Rastgele Matris İçinde Sıfır Arayın [m n]=size(K); sifirSayisi=0;%Sayaç for i=1:m for j=1:n if K(i,j)==0 sifirSayisi=sifirSayisi+1; fprintf('K(%d,%d)=0\n',i,j); end disp(K); fprintf('K Matrisindeki SIFIR Sayisi=%d\n',sifirSayisi);

KİTAPTAKİ 31.1-31.58 ARASI UYGULAMALARI BİRLİKTE YAZALIM VE ÇALIŞTIRALIM.