Ideal Lowpass Filter
data:image/s3,"s3://crabby-images/4e5ea/4e5eae8d0cc078a9030211a1558a5b3dfa3c48c0" alt="Image"
Code
for (int i = 0; i < height; i++)
{
int y = i - hh;
for (int j = 0; j < width; j++)
{
int x = j - hw;
int d = (int)System.Math.Sqrt(x * x + y * y);
// filter values outside the range
if ((d > d0))
{
data[i, j].Re = 0;
data[i, j].Im = 0;
}
}
}
Butterworth Lowpass Filter
data:image/s3,"s3://crabby-images/5c932/5c93229df8a8805c0d7ff6c5761fee0d45867709" alt="Image"
Code
for (int i = 0; i < height; i++)
{
int y = i - hh;
for (int j = 0; j < width; j++)
{
int x = j - hw;
double d = System.Math.Sqrt(x * x + y * y);
double h = 1.0 / (1.0 + System.Math.Pow(d / d0, 2.0 * n));
data[i, j].Re *= h;
data[i, j].Im *= h;
}
}
Gaussian Lowpass Filter
data:image/s3,"s3://crabby-images/4d8d5/4d8d57511703e9b6e60ac122d5ec8e8f8fc14c44" alt="Image"
Code
for (int i = 0; i < height; i++)
{
int y = i - hh;
for (int j = 0; j < width; j++)
{
int x = j - hw;
double d = System.Math.Sqrt(x * x + y * y);
double h = System.Math.Exp(-d * d / 2.0 / d0 / d0);
data[i, j].Re *= h;
data[i, j].Im *= h;
}
}
Ideal Highpass Filter
data:image/s3,"s3://crabby-images/905c5/905c53bfcdfc1b84f6cc6e9de2ad19286d78ec65" alt="Image"
Code
for (int i = 0; i < height; i++)
{
int y = i - hh;
for (int j = 0; j < width; j++)
{
int x = j - hw;
int d = (int)System.Math.Sqrt(x * x + y * y);
// filter values outside the range
if ((d < d0))
{
data[i, j].Re = 0;
data[i, j].Im = 0;
}
}
}
Butterworth Highpass Filter
data:image/s3,"s3://crabby-images/5de0d/5de0d8b8ebebf9b36c6e97654f2f9e5c314ea828" alt="Image"
Code
for (int i = 0; i < height; i++)
{
int y = i - hh;
for (int j = 0; j < width; j++)
{
int x = j - hw;
double d = System.Math.Sqrt(x * x + y * y);
double h = 1.0 / (1.0 + System.Math.Pow(d0 / d, 2.0 * n));
data[i, j].Re *= h;
data[i, j].Im *= h;
}
}
Gaussian Highpass Filter
data:image/s3,"s3://crabby-images/13ee8/13ee88ae7581e83e7f964156a8341a9c01110dc4" alt="Image"
Code
for (int i = 0; i < height; i++)
{
int y = i - hh;
for (int j = 0; j < width; j++)
{
int x = j - hw;
double d = System.Math.Sqrt(x * x + y * y);
double h = 1.0 - System.Math.Exp(-d * d / 2.0 / d0 / d0);
data[i, j].Re *= h;
data[i, j].Im *= h;
}
}
Homomorphic Filter
data:image/s3,"s3://crabby-images/675ea/675ea5a4918090ea4b434a3d0274a47e4e9b562b" alt="Image"
Code
for (int i = 0; i < height; i++)
{
int y = i - hh;
for (int j = 0; j < width; j++)
{
int x = j - hw;
double d = System.Math.Sqrt(x * x + y * y);
double h = (γH - γL) * (1.0 - System.Math.Exp(-c * d * d / D0 / D0)) + γL;
data[i, j].Re *= h;
data[i, j].Im *= h;
}
}