我有两个系列,series1和series2。我的目标是自动地/定量地找到 Series2与Series1有多少不同,在逐个bin的基础上(每个bin代表一个特定的功能)。
可以通过clicking here.看到其原始大小的图像
Series1是预期的结果。
Series2是测试/传入系列。
我提供了一个直方图,其中Series2以深棕色表示。您还可以注意到,在221和353之间的x轴上有很大的变化。即Series2小于Series1。我正在使用C++进行编码。
我认为互相关会有所帮助,但会基于相似性而不是不相似性产生一个值。我看到人们谈论Kolmogorov-Smirnov检验。这是我应该执行的测试吗?
更新1:
我正在尝试执行模板匹配。我将模板图像和传入的测试图像分为8x8块。我正在尝试将模板图像中的一个块与测试图像中的相同块(基于空间像素位置)进行比较。我计算每个块内的强度总和,获得Template图像的series1并获得测试图像的Series2。
最佳答案
这是一种算法的C实现,用于从预测数据中计算实际数据的差异。该算法来自Osborne / McGraw-Hill著作权为1980的一本名为《实用BASIC程序》的书。
这是.h文件:
/*
* divergence.h
*
* Created on: Jan 13, 2011
* Author: Erik Oosterwal
*/
#ifndef DIVERGENCE_H_
#define DIVERGENCE_H_
typedef struct
{
int DataSize;
float TotalError;
float AbsError; //< Total Absolute Error
float SqError; //< Total Squared Error
float MeanError;
float MeanAbsError;
float MeanSqError;
float RMSError; //< Root Mean Square Error
}DIVERGENCE_ERROR_TYPE;
void Divergence__Error(int size, float expected[], float actual[], DIVERGENCE_ERROR_TYPE *error);
// Prefer to use abs() from "stdlib.h"
#ifndef ABS
#define ABS(x) ((x)>0) ? (x) : (0-(x)) //< Not safe!!! - Do not increment parameter inside ABS()!
#endif
#endif /* DIVERGENCE_H_ */
.... c文件:
/*
* divergence.c
*
* Created on: Jan 13, 2011
* Author: Erik Oosterwal
*/
#include "math.h"
#include "divergence.h"
/**
* @brief Compute divergence from expected values.
*
* @details Compute the raw errors, absolute errors, root mean square errors,
* etc. for a series of values.
*
* @param size - integer value defines the number of values to compare.
*/
void Divergence__Error(int size, float expected[], float actual[], DIVERGENCE_ERROR_TYPE *error)
{
double total_err = 0.0;
double abs_err = 0.0;
double abs_sqr_err = 0.0;
double temp = 0.0;
int index = 0;
for(index=0; index<size; index++)
{
temp = (double)(actual[index])-(double)(expected[index]);
total_err+=temp;
abs_err+=ABS(temp);
abs_sqr_err+=pow(ABS(temp),2);
}
temp = (double)size;
error->DataSize = (int)size;
error->TotalError = (float)total_err;
error->AbsError = (float)abs_err;
error->SqError = (float)abs_sqr_err;
error->MeanError = (float)(total_err/temp);
error->MeanAbsError = (float)(abs_err/temp);
error->MeanSqError = (float)(abs_sqr_err/temp);
error->RMSError = (float)(sqrt(abs_sqr_err/temp));
}
...以及用于测试功能的样本main():
/*
* main.c
*
* Created on: Jan 13, 2011
* Author: Erik Oosterwal
*/
#include <stdio.h>
#include "divergence.h"
float vote[]={40.3, 22.5, 16.3, 10.5, 7.2, 3.2};
float poll[]={42.7, 21.4, 18.2, 6.0, 7.4, 4.3};
float actual[] ={74, 70, 58, 60, 65, 73, 70};
float predict[]={49, 62, 75, 82, 37, 58, 92};
int main(int argc, char *argv[])
{
DIVERGENCE_ERROR_TYPE stats;
Divergence__Error(6, poll, vote, &stats);
printf("%i\n%f\n%f\n%f\n%f\n%f\n%f\n%f\n\n\n",stats.DataSize,stats.TotalError,stats.AbsError,stats.SqError,stats.MeanError,stats.MeanAbsError,stats.MeanSqError,stats.RMSError);
Divergence__Error(7, predict, actual, &stats);
printf("%i\n%f\n%f\n%f\n%f\n%f\n%f\n%f\n\n\n",stats.DataSize,stats.TotalError,stats.AbsError,stats.SqError,stats.MeanError,stats.MeanAbsError,stats.MeanSqError,stats.RMSError);
return(0);
}
我不能保证这是最快的方法,并且该函数可以使用一些调整使其对不同的数据类型更加友好,但是它可以工作,并且结果已针对本书中提供的示例进行了验证。