余弦相似度:通过计算两个向量的夹角余弦值来评估他们的相似度

余弦相似度:通过计算两个向量的夹角余弦值来评估他们的相似度_第1张图片
余弦值的范围在[-1,1]之间,值越趋近于1,代表两个向量的方向越接近;
越趋近于-1,他们的方向越相反;
接近于0,表示两个向量近乎于正交。

float comparator(const float* comp1, const float* comp2) // 传入两个数组
{
     
	float similarity;
	
	float sum = 0;
	float sum1 = 0, sum2 = 0;

	for (int i = 0; i < 4; i++) // 已知每个数组各含4个元素
	{
     
		sum = sum + comp1[i] * comp2[i]; 
		sum1 = sum1 + comp1[i] * comp1[i]; 
		sum2 = sum2 + comp2[i] * comp2[i]; 
	}

	float a1 = sqrtf(sum1);
	float a2 = sqrtf(sum2);

	similarity = sum / (a1 * a2);

	return similarity;
}

你可能感兴趣的:(C/C++)