联系方式

  • QQ:99515681
  • 邮箱:99515681@qq.com
  • 工作时间:8:00-21:00
  • 微信:codinghelp

您当前位置:首页 >> Matlab编程Matlab编程

日期:2019-12-13 08:16


The Hong Kong University of Science and Technology

Department of Computer Science and Engineering

COMP4421 (Fall 2019)

Assignment 3

Total = 100 marks

Due: 11:55pm, Dec 9, 2019

Assignments must be submitted via CANVAS

Late Policy: 10% reduction; only one day late is allowed, i.e. 11:55pm, Dec 10

Overview

This assignment consists of two sections: programming section and written section.

Both programming and written parts should be submitted via the CANVAS system. If

you would like to finish the written assignment with hand writing, you may scan and

upload it as a PDF file.

Programming assignment specifics (60%)

Pre-requirement

2.1.1 Input: The input images are in the folder “input_imgs” (/Sample/input_imgs).

You should test all the input images and paste the result images in the PDF file. Note

that we will have some other test images for grading.

2.1.2 Language: Matlab/Octave.

2.1.3 Functions to be used: In this assignment, you can use the built-in function for

filtering and edge detection. However, you cannot use any built-in functions

relating to the image warping and segmentation. 1/6

Programming question 1 - Image Warping (40%)

Based on the 4 corner points computed in Assignment 2, apply the image warping to

transform the target A4 paper into a standard A4 form, that is, 210� ∗ 297� for

vertical direction and 297� ∗ 210� for horizontal direction, where � is the

parameter decided by the user. Inside your own image warping function, you also

need implement your own bilinear interpolation. Please describe your image

warping algorithm briefly in the PDF file.

The function prototype is given in the image_warping.m. If you cannot obtain the 4 corner points in Assignment 2, you can manually find the 4

corner points using some tools in Matlab/Octave.

A sample output is provided as follows,

Programming question 2 - Digit Segmentation (20%)

Followed by the Task 2.1, our input images in this task are the transformed A4 paper

with some hand-written digits on it. Your task here is to use a certain segmentation

algorithm to segment each digit. Note that you can choose any segmentation

methods. However, no matter which algorithm you choose to use, you should

implement it by yourself. Please describe your segmentation algorithm briefly in the

PDF file.

The function prototype is given in the digit_segment.m.

A sample output is provided as follows,

2/6

Here, I provide one of the algorithms I used in my program for the digit

segmentation.

Step 1: Threshold the input images to obtain binary images;

Step 2: Horizontal projection. Count the number of white pixels along horizontal

direction. The number of rows for the digits should be equal to the number of peaks

in the projected histogram. We can then segment the digits by rows.

Step 3: Vertical projection. For each row, we count the number of white pixels along

vertical direction. The number of columns for the digits should be equal to the

number of peaks in the projected histogram. We can then segment the digits by

columns.

[Note: for step 3 you may face the problem that some digits cannot be separated

properly. Here is another idea for Step 3. Scan each column and count the number of

black pixels, denoted as N. If N > H – n, where H is the height of the row_image

obtained in Step 2 and n is a parameter defined by user, the column will be marked.

The segmentation will be performed based on the marked column. This idea, which is

similar to vertical projection, compares the height of the row_image and thus is

easier to control.]

I provide the pipeline combining Assignment 2 and Assignment 3 as follows. Note

that only the parts in the orange dash box are required in this assignment.

3/6

4/6

Written assignment specifics (40%)

Written question 1 - Image Transformation

There is an image I shown as follows. The transformation is defined as �(�⃗) ≡ �⃡�⃗,

where �⃡ = 2� � � �7 and �⃗ = 2��7. After the transformation using �, point A, B, C and

D are transformed to point E, F, G and H respectively.

(Hint: For a 2x2 matrix � = 2� � � �7, the matrix inverse is �:; = ;

<=:>? 2 � −� −� � 7.)

1a) Find the transformation matrix ⃡�. Please show all your steps clearly.

Suppose the intensity values of point I, K, L and M are 2, 5, 9 and 15 respectively.

Image I

Image I’ x y

5/6

1b) Find the intensity value of point J using Bilinear Interpolation. Please show

all your steps clearly.

Written question 2 - Quantization

Given a 4x4 gray-level image A as follows:

13 115 24 231

128 200 64 55

55 255 74 35

178 29 1 80

2a) Compute the quantization (uniform quantization) of A from 256 levels (8 bits) to

16 levels (4 bits).

2b) Compute the column-wise improved gray-scale (IGS) quantization of A from 256

levels (8 bits) to 16 levels (4 bits).

2c) Find the root-mean-square error and mean square signal-to-noise ratio of the result

from your answers in 2a) and 2b).

Image I’

Image I x y

6/6

Written question 3 – Huffman coding

Given Huffman code in the below table.

Symbol Code

C 01

E 10

M 00

O 110

P 1111

R 11101

T 111000

U 111001

3a) Decode the encoded string “011100011111110011110001011101” with the given

Huffman code.

3b) Compute the Huffman code for each symbol in the words “image processing” and

fill in the following table. Show your steps clearly.

Symbol Code

acegimnoprs


版权所有:编程辅导网 2021 All Rights Reserved 联系方式:QQ:99515681 微信:codinghelp 电子信箱:99515681@qq.com
免责声明:本站部分内容从网络整理而来,只供参考!如有版权问题可联系本站删除。 站长地图

python代写
微信客服:codinghelp