1、线性函数转换,表达式如下:
y=(x-MinValue)/(MaxValue-MinValue)
说明:x、y分别为转换前、后的值,MaxValue、MinValue分别为样本的最大值和最小值。
2、对数函数转换,表达式如下:
y=log10(x)
gauss归一化code:
#include
#include
using namespace std;
#define sqr(a) (a)*(a)
void GaussianNormalize(float *f, int size)
{
if (size <= 0)
return;
float mean = 0, sigma = 0;
for (int i = 0; i < size; i++)
mean += f[i];
mean /= size;
for (i = 0; i < size; i++)
sigma += sqr(f[i] - mean);
sigma = (float)sqrt(sigma / size);
// now gaussian normalization
for (i = 0; i < size; i++)
{
f[i] = ((f[i] - mean) / (3 * sigma) + 1) / 2;
if (f[i] < 0.0)
f[i] = 0.0;
else if (f[i] > 1.0)
f[i] = 1.0;
}
}
int main()
{
float a[3] = {3.7f,7,2};
float b[3] = {13,160,230};
GaussianNormalize(a,3);
GaussianNormalize(b,3);
return 0;
}