<< 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.

Implementation

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.

Pixel values are represented as integers between 0 and 255.

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."

Get Jobilize Job Search Mobile App in your pocket Now!

Get it on Google Play Download on the App Store Now




Source:  OpenStax, Digital signal processing laboratory (ece 420). OpenStax CNX. Sep 27, 2006 Download for free at http://cnx.org/content/col10236/1.14
Google Play and the Google Play logo are trademarks of Google Inc.

Notification Switch

Would you like to follow the 'Digital signal processing laboratory (ece 420)' conversation and receive update notifications?

Ask