<< Chapter < Page | Chapter >> Page > |
copy V:\ece320\idk\c6000\IDK\Examples\NTSC\img_proc
copy V:\ece320\idk\c6000\IDK\Drivers\include
copy V:\ece320\idk\c6000\IDK\Drivers\lib
After the IDK is powered on, open Code Composer 2 by clicking
on the "CCS 2" icon on the desktop. From the "Project" menu,select "Open," and then open
img_proc.pjt
. You
should see a new icon appear at the menu on the left side ofthe Code Composer window with the label
img_proc.pjt
. Double click on this icon to see a
list of folders. There should be a folder labeled "Source."Open this folder to see a list of program files.
The
main.c
program calls the
img_proc.c
function that displays the output of
four image processing routines in four quadrants on themonitor. The other files are associated with the four image
processing routines. If you open the "Include" folder, youwill see a list of header files. To inspect the main program,
double click on the
main.c
icon. A window with
the C code will appear to the right.
Scroll down to the
tskMainFunc()
in the
main.c
code. A few lines into this function, you
will see the line
LOG_printf(&trace,"Hello\n");
. This line
prints a message to the message log, which can be useful fordebugging. Change the message "
Hello\n
" to
"
Your Name\n
" (the "
\n
" is a
carriage return). Save the file by clicking the little floppydisk icon at the top left corner of the Code Composer window.
To compile all of the files when the "
.out
" file
has not yet been generated, you need to use the "Rebuild All"command. The rebuild all command is accomplished by clicking
the button displaying three little red arrows pointing down ona rectangular box. This will compile every file the main.c
program uses. If you've only changed one file, you only needto do a "Incremental Build," which is accomplished by clicking
on the button with two little blue arrows pointing into a box(immediately to the left of the "Rebuild All" button). Click
the "Rebuild All" button to compile all of the code. A windowat the bottom of Code Composer will tell you the status of the
compiling (i.e., whether there were any errors or warnings).You might notice some warnings after compilation - don't worry
about these.
Click on the "DSP/BIOS" menu, and select "Message Log." A new
window should appear at the bottom of Code Composer. Assumingthe code has compiled correctly, select "File" -> "Load
Program" and load
img_proc.out
(the same
procedure as on the other version of Code Composer). Nowselect "Debug" -> "Run" to run the program (if you have
problems, you may need to select "Debug" -> "Go Main" beforerunning). You should see image processing routines running on
the four quadrants of the monitor. The upper left quadrant(quadrant 0) displays a low pass filtered version of the
input. The low pass filter "passes" the detail in the image,and attenuates the smooth features, resulting in a "grainy"
image. The operation of the low pass filter code, and howdata is moved to and from the filtering routine, was described
in detail in the previous section. The lower left quadrant(quadrant 2) displays the output of an edge detection
algorithm. The top right and bottom right quadrants(quadrants 1 and 3, respectively), show the original input
displayed unprocessed. At this point, you should notice yourname displayed in the message log.
You will create the component code
flip_invert.c
to implement an algorithm that horizontally flips and inverts
the input image. The code in
flip_invert.c
will
operate on one line of the image at a time. The
copyim.c
wrapper will call
flip_invert.c
once for each row of the prescaled
input image. The
flip_invert
function call
should appear as follows:
flip_invert(in_data, out_data, cols);
where
in_data
and
out_data
are
pointers to the input and output buffers in internal memory,and
cols
is the length of each column of the
prescaled image.
The
img_proc.c
function should call the
copyim.c
wrapper so that the flipped and inverted
image appears in the top right (first) quadrant. The call to
copyim
is as follows:
copyim(scratch_pad,
out_img, out_ptr, pitch);
This call is commented out in the
im_proc.c
code.
The algorithm that copies the image (unprocessed) to thescreen is currently displayed in quadrant 1, so you will need
to comment out its call and replace it with the call tocopyim.
Your algorithm should flip the input picture horizontally, such that someone on the left side of the screen looking leftin quadrant 3 will appear on the right side of the screen looking right. This is similar to putting a slide in a slideprojector backwards. The algorithm should also invert the picture, so that something white appears black and vice versa.The inversion portion of the algorithm is like looking at the negative for a black and white picture. Thus, the totaleffect of your algorithm will be that of looking at the wrong side of the negative of a picture.
To create a new component file, write your code in a file
called "
flip_invert.c
". You may find the
component code for the low pass filter in"
conv3x3_c.c
" helpful in giving you an idea of
how to get started. To compile this code, you must include itin the "
img_proc
" project, so that it appears as
an icon in Code Composer. To include your new file, rightclick on the "
img_proc.pjt
" icon in the left
window of Code Composer, and select "Add Files."
Notification Switch
Would you like to follow the 'Digital signal processing laboratory (ece 420)' conversation and receive update notifications?