laplace.cpp
00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024 #include <filters/laplace.h>
00025
00026 #include <core/exception.h>
00027
00028 #include <ippi.h>
00029 #include <cmath>
00030 #include <cstdlib>
00031
00032
00033
00034
00035
00036
00037
00038
00039 FilterLaplace::FilterLaplace()
00040 : Filter("FilterLaplace")
00041 {
00042 kernel = NULL;
00043 }
00044
00045
00046
00047
00048
00049
00050
00051 FilterLaplace::FilterLaplace(float sigma, unsigned int size, float scale)
00052 : Filter("FilterLaplace")
00053 {
00054 kernel_size = size;
00055 kernel = (int *)malloc( size * size * sizeof(int) );
00056 calculate_kernel( kernel, sigma, size, scale );
00057 }
00058
00059
00060
00061 FilterLaplace::~FilterLaplace()
00062 {
00063 if ( kernel != NULL ) {
00064 free( kernel );
00065 }
00066 }
00067
00068
00069 void
00070 FilterLaplace::apply()
00071 {
00072 IppiSize size;
00073 size.width = src_roi[0]->width - kernel_size;
00074 size.height = src_roi[0]->height - kernel_size;
00075
00076 IppStatus status;
00077
00078 if ( kernel == NULL ) {
00079
00080 status = ippiFilterLaplace_8u_C1R( src[0] + (src_roi[0]->start.y * src_roi[0]->line_step) + (src_roi[0]->start.x * src_roi[0]->pixel_step), src_roi[0]->line_step,
00081 dst + (dst_roi->start.y * dst_roi->line_step) + (dst_roi->start.x * dst_roi->pixel_step), dst_roi->line_step,
00082 size, ippMskSize5x5 );
00083 } else {
00084 IppiSize ksize = { kernel_size, kernel_size };
00085 IppiPoint kanchor = { (kernel_size + 1) / 2, (kernel_size + 1) / 2 };
00086
00087
00088
00089
00090
00091
00092
00093 status = ippiFilter_8u_C1R( src[0] + ((src_roi[0]->start.y + kernel_size / 2) * src_roi[0]->line_step) + ((src_roi[0]->start.x + kernel_size / 2) * src_roi[0]->pixel_step), src_roi[0]->line_step,
00094 dst + ((dst_roi->start.y + kernel_size / 2) * dst_roi->line_step) + ((dst_roi->start.x + kernel_size / 2) * dst_roi->pixel_step), dst_roi->line_step,
00095 size, kernel, ksize, kanchor, 1 );
00096
00097 }
00098
00099 if ( status != ippStsNoErr ) {
00100 throw fawkes::Exception("Laplace filter failed with %i\n", status);
00101 }
00102
00103
00104
00105
00106
00107
00108
00109
00110
00111
00112
00113
00114
00115
00116
00117
00118
00119
00120
00121
00122
00123
00124
00125
00126 }
00127
00128
00129
00130
00131
00132
00133
00134
00135
00136
00137
00138
00139
00140
00141
00142 void
00143 FilterLaplace::calculate_kernel(int *kernel, float sigma, unsigned int size, float scale)
00144 {
00145
00146
00147
00148
00149
00150
00151
00152
00153
00154
00155 for (int h = (-(int)(size / 2)); h <= (int)((size - 1) / 2); ++h) {
00156 for (int w = (-(int)(size / 2)); w <= (int)((size - 1) / 2); ++w) {
00157
00158
00159 int v = (int)roundf( - 1/( M_PI * sigma * sigma * sigma * sigma ) *
00160 ( 1 - ( (w*w + h*h) / (2 * sigma * sigma) ) )
00161 * exp( -( (w*w + h*h) / (2 * sigma * sigma) )) * scale );
00162
00163 kernel[ (h + (size / 2)) * size + (w + (size / 2)) ] = v;
00164 }
00165
00166 }
00167
00168
00169
00170
00171
00172
00173
00174
00175
00176
00177 }