NAME
power_spect_eq - performs wiener filtering
SYNOPSIS
#include "CVIPimage.h"
#include "CVIPtransform.h"
#include "CVIPxformfilter.h"
#include "CVIPdef.h"
#include "CVIParithlogic.h"
Image *power_spect_eq(Image *degr, Image *degr_fn, Image
*p_noise, Image *p_orig, int choice, int cutoff)
<degr> - pointer to the degraded image
<degr_fn> - pointer to the degradation function
<p_noise> - pointer to the noise power spectral density
<p_orig> - pointer to the original image power spectral
density
<choice> - 1 to let R(u,v) = 1, or 2 to let R(u,v) = 0
(R(u,v) = restoration filter, this is used
when the denominator = 0)
<cutoff> - cutoff frequency for filtering
PATH
$CVIPHOME/XFORMFILTER/InverseFilter.c
DESCRIPTION
This function performs a power spectrum equalization filter.
The function does its own memory management, freeing every-
thing passed to it, so if you need your images intact, make
a copy of them before calling this function.
The function tries to determine whether an FFT has been per-
formed on the passed images. If not, the function will per-
form the FFT. This is especially important to note for the
power images. If the power images are in the spatial
domain, they will have an FFT performed on them, before the
squared magnitude is calculated. If an FFT is detected in
the history of any of the power images, that image is
assumed to be representing a power image, and no squared
magnitude is calculated.
The function will also extend the sizes of the passed images
as best it can when they are of unequal size.
Also note that the passed images must have the same number
of (color) bands.
TYPES AND CONSTANTS
None
RETURN VALUES
A pointer to the restored (filtered) image
HISTORY
History information recorded:
parameter #1 = filter cutoff.
parameter #2 = method 1: F(u,v)=G(u,v) when H(u,v)=0
method 2: F(u,v)=0 when H(u,v)=0
EXAMPLE
#include <CVIPtoolkit.h>
#include <CVIPimage.h>
#include <CVIPdef.h>
#include <CVIPconvert.h>
#include <CVIPview.h>
#include "CVIPxformfilter.h"
#define VIEWER "picture"
#define VIDEO_APP "SunVideo &"
void main()
{
Image *cvipImage,*cvipImage1;
Image *cvipImage2,*cvipImage3;
IMAGE_FORMAT format;
char *inputfile,*outputfile;
char *inputfile1,*inputfile2;
(void) setDisplay_Image(VIEWER,"default");
print_CVIP("\n\t\tEnter the File Name of the degraded
image: ");
inputfile =(char *) getString_CVIP();
format = getFormat_CVIP(inputfile);
cvipImage = read_Image(inputfile,1);
view_Image(cvipImage, inputfile);
free(inputfile);
/* the following call creates a gaussian mask of size
3 * 3 */
cvipImage1 = (Image *)h_image(3,3,3);
print_CVIP("\n\t\tEnter the File Name of the original power
spectrum image: ");
inputfile1 =(char *) getString_CVIP();
format = getFormat_CVIP(inputfile1);
cvipImage2 = read_Image(inputfile1,1);
view_Image(cvipImage2, inputfile1);
free(inputfile1);
print_CVIP("\n\t\tEnter the File Name of the noise power
spectrum image: ");
inputfile2 =(char *) getString_CVIP();
format = getFormat_CVIP(inputfile2);
cvipImage3 = read_Image(inputfile2,1);
view_Image(cvipImage3, inputfile2);
free(inputfile2);
/* the following call performs the power spectrum
equalisation on the input image with the gaussian mask
and the cut off frequency equal to 32 */
cvipImage3=(Image *)power_spect_eq(cvipImage,cvipImage1,
cvipImage2, cvipImage3,1,32);
cvipImage=(Image *)ifft_transform(cvipImage3,256);
print_CVIP("\n\t\tEnter the Output File Name: ");
outputfile = getString_CVIP();
view_Image(cvipImage,outputfile);
write_Image(cvipImage,outputfile,CVIP_NO,CVIP_NO,format,1);
free(outputfile);
}
SEE ALSO
libxformfilter
AUTHOR
Copyright (C) 1996 SIUE - by Scott E. Umbaugh and Arve
Kjoelen.