المحاضرة الثانية عشر

You might also like

Download as pdf or txt
Download as pdf or txt
You are on page 1of 7

‫‪Digital Image Processing‬‬ ‫معالجة الصور الرقمية ……………………………………………………‬

‫مقدمة يف معاجلة الصور يف املاتالب‬

‫أنواع الصورة الرقمية‬ ‫‪‬‬


‫فتح وقراءة صورة‪.‬‬ ‫‪‬‬
‫منحني الهيستوغرام و تحسين التباين‪.‬‬ ‫‪‬‬
‫عمليات مختلفة على الصور‪.‬‬ ‫‪‬‬

‫أنواع الصورة الرقمية في الماتالب ‪:‬‬


‫‪Binary Image‬‬
‫هي الصورة التي تمثل بمصفوفة بعداها ‪ MxN‬وهي تحوي اللونين األسود واألبيض فقط ‪ .‬بحيث ياخذ كل بكسل‬
‫قيمة تمثل لون فاألسود يأخذ قيمة ‪ 0‬بينما األبيض يأخذ قيمة ‪.1‬‬
‫(ال يوجد لون رمادي في هذا النوع من الصور)‪.‬‬

‫‪Grayscale Image‬‬
‫هي صورة تمثل بمصفوفة ثنائيةة البعةد ‪ MxN‬وعناصةرها مةن النةوع ‪ double‬تقة بةين المجةا ‪ ]0,1‬حيةث ‪0‬‬
‫يمثل األسود و ‪ 1‬األبيض و ما بينهما درجات اللون الرمادي‪ .‬كل عنصر في المصفوفة يمثل درجةة لةون لبكسةل‬
‫واحد ابيض او اسود او ما بينهما‪.‬‬

‫‪TrueColor RGB Image‬‬


‫هي صورة تمثل بمصفوفة ثالثيةة ثالثيةة البعةد ‪ MxNx3‬عناصةرها مةن نةوع ‪ double‬او ‪( unit8‬سةو نرةر‬
‫النوعين الحقاً) ‪ ,‬فكل بكسل في الصورة ينتج عن دمج ثالثةة مركبةات طعءةاء اللةون المناسةم فالمركبةة الحمةراء‬
‫مكونة من مصفوفة ثنائية (تستخرج من المصفوفة ثالثية البعد) ‪ MxN‬يكون فيهةا قيمةة اللةون بةين المجةا ‪]0,1‬‬
‫األسود ‪ 0‬و األحمر ‪ 1‬و ما بينهما هو درجات اللون األحمر ‪ ,‬و كةذل بالنسةبة لةق ر و األخ ةر‪ .‬وبةدمج ثالثةة‬
‫األلوان ‪ RGB‬من ثالثة مصفوفات ثنائية البعد نحصل على األلوان الحقيقية‪.‬‬

‫يوجد نوعان لمجا اللون ‪:‬‬


‫‪ : Double‬يكون مجاله ‪ ]0,1‬بحيث يكون األسود ‪ 0‬و اللةون ‪ 1‬و درجةات اللةون بينهمةا بحيةث تكةون قةين اللةون‬
‫اصغر من الواحد (فاصلة) مثال ‪. 0.2.0‬‬
‫‪ : Unit8‬تكون قيمتةه صةحيحة ‪ Integer‬و يتةراو مجالةه ‪ ]0,200‬بحيةث ‪ 0‬يمثةل األسةود و ‪ 200‬اللةون و مةا‬
‫بينهما درجات اللون‪.‬‬
‫ً‬
‫يستخدم نوع ‪ unit8‬بدال من ا ‪ double‬للتقليل من مساحة الذاكرة و لتسري من عملية معالجة الصور‪.‬‬

‫فتح وقراءة صورة ‪:‬‬


‫يتن فتح وقراءة صورة من أي نوع بإستخدام تعليمة ‪ :Imread‬ويتن عرضها بإستخدام التعليمة ‪ imshow‬ونميز‬
‫حالتين‬

‫‪ -1‬فتح صورة من الحاسم ‪ :‬لفتح صورة وعرضها من الجها الحاسم نستخدم الصيغة التالية ‪:‬‬
‫;(‪X=imread (path\filename,format‬‬
‫;)‪Imshow(x‬‬
‫حيث تتن قراءة الصورة عبر المسار ‪ filename‬ذات اطمتداد ‪ format‬ومن ثن تخزينها في المصفوفة ‪. x‬‬

‫‪ -2‬فتح صورة من برنامج الماتالب نفسه وعرضها نستخدم الصيغة التالية ‪:‬‬
‫;) ‪X=imread (filename,format‬‬
‫‪-1-‬‬
‫‪Digital Image Processing‬‬ ‫معالجة الصور الرقمية ……………………………………………………‬

‫)‪Imshow(x‬‬

‫مثا ‪ :‬صورة من نوع ‪RGB‬‬


‫;)'‪X = imread('onion.rgb‬‬
‫; )‪imshow(X‬‬

‫‪ :Imwrite‬بفرض أننا قمنا بمعالجة صورة معينة وأجرينا عليها التغييرات المناسبة ثن أردنا حفظ أو طباعة هذه‬
‫الصورة على جها الحاسم بإسن جديد وإمتداد جديد نستخدم هذه التعليمة بالصيغة التالية‪:‬‬
‫;)‪Imwrite(image , filename‬‬
‫مثا ‪:‬‬
‫)'‪x=imread('C:\Users\DigitalNet\Desktop\ferrari','jpeg‬‬
‫)‪imshow(x‬‬
‫;)’‪imwrite(x,’newferrari.bmp‬‬

‫هنا قمنا بءباعة نفس الصورة الموجودة على سءح المكتم إلى مسةار المةاتالب اينةي (‪ current folder‬يظهةر‬
‫في شريط األدوات في واجهة برنامج الماتالب ) باسن جديد ‪ newferrari‬وإمتداد جديد ‪.bmp‬‬

‫‪ :Iminfo‬تمكننا هذه التعليمة بالحصو على معلومات كاملة عن الصورة وبكتاية الصيغة التالية ‪:‬‬
‫)‪info=imfinfo(filename,format‬‬
‫نحصل على معلومات أهمها ‪:‬‬
‫مسار ملف الصورة – حجن الملف – العرض – اطرتفاع – اطمتداد – نظام األلوان‪.‬‬

‫تحويل بين الصور ‪:‬‬


‫‪ :Im2bw‬يمكن تحويل الصورة أيا كان نوعها إلى صورة ثنائية ( أبيض وأسود) بإستخدام هذه التعليمة ‪:‬‬
‫;)‪binary image=im2bw(image,level‬‬
‫حيث ‪ image‬تمثل الصورة األصلية أما ‪ level‬فهي شدة العتبة تتراو بين الصفر والواحد حيث تتحو جمي‬
‫البكسالت التي قيمتها فو العتبة إلى األبيض أو تحمل القيمة ‪ 1‬أما البكسالت التي تحمل قةين تحة العتبةة فتتحةو‬
‫إلى اللون األسود أو تحمل القيمة صفر ‪.‬‬

‫مثا ‪:‬‬
‫;)'‪x=imread('C:\Users\DigitalNet\Desktop\mosque','jpeg‬‬
‫;)‪imshow(x‬‬
‫;)‪y=im2bw(x,0.25‬‬
‫;)‪imshow(y‬‬
‫منحني الهيستوغرام‪:‬‬
‫يظهر هذا المنحني تو ع االضاءة في الصورة على البكسالت ‪,‬حيث يعبر محور السينات على شدة االضاءة و‬
‫محور الصادات بكسالت الصورة باستخدام تعليمة‬
‫)‪Imhist(I‬‬
‫تظهر هذه التعليمة الهيستوغرام (تقسين اطضاءة داخل الصورة ) للصورة (‪)I‬‬
‫‪Imhist(I,n) :‬‬

‫تعرض الهيستوغرام حيث ‪ n‬تحدد عدد ا ‪ bins‬المستخدم في الهيستوغرام ‪ ,‬و تحدد اي ا طو حاجز اللون ‪( ,‬‬
‫إذا كان الصورة ثنائية ‪ n‬تأخذ قيمتين فقط )‪.‬‬

‫‪-2-‬‬
‫‪Digital Image Processing‬‬ ‫معالجة الصور الرقمية ……………………………………………………‬

‫تحسين تباين الصورة ‪:‬‬


‫يمكن تحسين تباين الصورة باستخدام تعليمة ‪ histeq‬كما يلي ‪:‬‬
‫حيث تقوم هذه التعليمة بفرد مستويات االضاءة على كافة بكسالت الصورة ‪ ,‬و ال تبقى مو عة على بكسالت‬
‫معينة ‪.‬‬
‫;)'‪I = imread('pout.tif‬‬
‫)‪imshow(I‬‬
‫)‪figure, imhist(I‬‬
‫;)‪I2 = histeq(I‬‬
‫)‪figure, imshow(I2‬‬
‫)‪figure, imhist(I2‬‬

‫و يمكننا تحسين تباين الصورة من خال ‪:‬‬


‫‪ : imadjust‬يمكننا تعديل تباين الصورة بإستخدام هذه التعليمة ولها عدة أشكا أحدها ‪:‬‬
‫)‪j=imadjust(i‬‬

‫‪-.-‬‬
‫‪Digital Image Processing‬‬ ‫معالجة الصور الرقمية ……………………………………………………‬

‫يادة درجة اطشباع ‪%1‬‬ ‫يادة تباين الصورة من خال‬ ‫وبذل تكون الصورة ‪ j‬هي نفس الصورة ‪ I‬م‬
‫للبيانات‬
‫مثا ‪:‬‬
‫;)'‪I=imread('pout.tif‬‬
‫;)‪imshow(I‬‬
‫;)‪J =imadjust(I‬‬
‫;‪figure‬‬
‫;)‪imshow(J‬‬

‫عمليات أخرى على الصورة ‪:‬‬


‫تكبير و تصغير حجن الصورة ‪:‬‬ ‫·‬
‫‪ :Imresize‬يمكننا تغيير حجن الصورة ثناثية البعد بإستخدام هذه التعليمة ‪ ،‬الصيغة األولى ‪:‬‬
‫)‪J=imresize(I,Scale‬‬

‫حيث ‪ I‬هي الصورة قبل إعادة التقييس و ‪ scale‬نسبة التقييس فإذا كان أكبر من الواحد فسيزداد حجن‬
‫الصورة أما إذا كان أصغر من الواحد فسينقص حجن الصورة‪.‬‬

‫تدوير الصورة ‪:‬‬


‫‪ :Imrotate‬بهذه التعليمة نستءي تدوير الصورة بزاوية معينة بالدرجات‪.‬‬
‫;)‪J=imrotate(I,Angle‬‬
‫حيث ‪ I‬هي الصورة األصلية المراد تدويرها و ‪ angle‬اوية الدوران مقدرة بالدرجات ‪ ،‬مثا ‪:‬‬
‫;)'‪I = imread('circuit.tif‬‬
‫;)'‪J = imrotate(I,45,'bilinear‬‬
‫)‪imshow(I‬‬
‫‪figure,‬‬
‫)‪imshow(J‬‬
‫· اقتءاع جزء من الصورة‪:‬‬
‫‪ :Imcrop‬يمكننا من خال هذه التعليمة من إقتءاع جزء من الصورة وإنراء صورة جديدة من المصورة‬
‫المقتءعة‬
‫;)‪J=imcrop(I‬‬
‫حيث ‪ j‬هي الصورة المقتءعة يدويا حيث يتوجم علي تحديد الجزء من الصورة الذي نريد إقتءاعه يدويا‬

‫قلم الصورة ‪:‬‬


‫‪ :Fliplr‬تمكننا هذه االتعليمة من إجراء قلم للصورة من اليمين لليسار (ال ننسى أن الصورة عبارة عن مصفوفة‬
‫) أي وكأن الصورة وضع أمام مرآة ‪.‬‬
‫‪-0-‬‬
Digital Image Processing …………………………………………………… ‫معالجة الصور الرقمية‬

J=fliplr(I);
‫ الصورة األصلية‬I ‫حيث‬
‫ تمكننا هذه االتعليمة من إجراء قلم للصورة من األعلى إلى األسفل (ال ننسى أن الصورة عبارة عن‬:Flipud
. ) ‫مصفوفة‬
J=flipud(I);
‫ الصورة األصلية‬I ‫حيث‬
: ‫· تصمين مرشحات‬
‫ تصمين مرشح ثنائي البعد من أحد األنواع الرهيرة مثل مرشح غاوص أو البالسيان أو اللوغاريتمي‬:Fspecial
: ‫ويمكن كتابته بالصيغة التالية‬.... ‫او المتوسط‬
h = fspecial(type, parameters );
.‫ مواصفات هذا المرشح‬parameter ‫ تمثل نوع المرشح و‬type ‫حيث‬

: ‫مثا‬
I = imread('cameraman.tif');
subplot(2,2,1);
imshow(I); title('Original Image');

H = fspecial('motion',20,45);
MotionBlur = imfilter(I,H,'replicate');
subplot(2,2,2);
imshow(MotionBlur);title('Motion Blurred Image');
H = fspecial('disk',10);
blurred = imfilter(I,H,'replicate');
subplot(2,2,3);
imshow(blurred); title('Blurred Image');

H = fspecial('unsharp');
sharpened = imfilter(I,H,'replicate');
subplot(2,2,4);
imshow(sharpened); title('Sharpened Image');

-0-
Digital Image Processing …………………………………………………… ‫معالجة الصور الرقمية‬

: ‫إضافة ضجيج‬ ·
‫ إضافة ضجيج للصورة بكتابة الصيغة التالية‬:Imnoise
J = imnoise(I,type)
salt and ‫ أو‬Gaussian ‫ يمثل نوع ال جيج فقد يكون‬type ‫هي الصورة األصلية‬I ‫حيث‬
....poisson ‫ أو‬papper

: ‫مثا‬
I = imread('eight.tif');
J = imnoise(I,'salt & pepper',0.02);
figure,
imshow(I)
figure,
imshow(J)
‫ يمكننا هذه التعليمة من ترغيل الفيديو وإستعراضه من كاميرا الحاسم أو أي كاميرا أو أي‬:Videoinput ·
‫ وهذه الصيغة‬USB ‫كاميرا موصولة معه عن طريق ا‬
obj = videoinput(adaptorname,deviceID,format)
‫ تمثل‬format ‫ الكاميرا و‬ID ‫ هورقن يد على‬deviceID ‫ إسن المتغير للكاميرا و‬adaptername ‫حيث‬
‫ طبعا ال ننسى أن‬MJPG-640*480 ‫ أو‬YUY2-640*480 ‫صيغة العرض قد تكون‬
. ‫ يمثل حجن الصورة ويمكن تغييره‬640*480 ‫الرقن‬

: ‫مثا‬
cam=videoinput('winvideo',1,'YUY2_640x480');
set(cam,'returnedcolorspace','rgb');
vidRes = get(cam, 'VideoResolution');
nBands = get(cam, 'NumberOfBands');
hImage = image( zeros(vidRes(2), vidRes(1), nBands) );
preview(cam,hImage);

-6-
Digital Image Processing …………………………………………………… ‫معالجة الصور الرقمية‬

: ‫مالحظة‬
‫ طستعراض الفيديوومراهدته في نافذة ضمن واجهة الماتالب‬:preview
‫ مهمته إلتقاط صورة من الكاميرا وتكتم بالصيغة التالية‬:Getsnapshot
Image=getsnapshot(obj);
‫ إسن متحو الذي خزن فيه الفيديو‬obj ‫ حيث‬videoinput ‫يأتي هذا التاب مرافقا لتاب‬

: ‫مثا‬
cam=videoinput('winvideo',1,'YUY2_640x480');
set(cam,'returnedcolorspace','rgb');
vidRes = get(cam, 'VideoResolution');
nBands = get(cam, 'NumberOfBands');
hImage = image( zeros(vidRes(2), vidRes(1), nBands) );
preview(cam,hImage);
pause(10);
image1=getsnapshot(cam);
figure;
imshow(image1);

-7-

You might also like