RMUL2025/lib/cmsis_5/CMSIS/DSP/Testing/Source/Benchmarks/DistanceF32.cpp

114 lines
2.7 KiB
C++
Executable File

#include "DistanceF32.h"
#include <stdio.h>
#include "Error.h"
#include "Test.h"
void DistanceF32::test_braycurtis_distance_f32()
{
(void)arm_braycurtis_distance_f32(inpA, inpB, this->vecDim);
}
void DistanceF32::test_canberra_distance_f32()
{
(void)arm_canberra_distance_f32(inpA, inpB, this->vecDim);
}
void DistanceF32::test_chebyshev_distance_f32()
{
(void)arm_chebyshev_distance_f32(inpA, inpB, this->vecDim);
}
void DistanceF32::test_cityblock_distance_f32()
{
(void)arm_cityblock_distance_f32(inpA, inpB, this->vecDim);
}
void DistanceF32::test_correlation_distance_f32()
{
memcpy(tmpAp, inpA, sizeof(float32_t) * this->vecDim);
memcpy(tmpBp, inpB, sizeof(float32_t) * this->vecDim);
(void)arm_correlation_distance_f32(tmpAp, tmpBp, this->vecDim);
}
void DistanceF32::test_cosine_distance_f32()
{
(void)arm_cosine_distance_f32(inpA, inpB, this->vecDim);
}
void DistanceF32::test_euclidean_distance_f32()
{
(void)arm_euclidean_distance_f32(inpA, inpB, this->vecDim);
}
void DistanceF32::test_jensenshannon_distance_f32()
{
(void)arm_jensenshannon_distance_f32(inpA, inpB, this->vecDim);
}
void DistanceF32::test_minkowski_distance_f32()
{
(void)arm_minkowski_distance_f32(inpA, inpB, 2,this->vecDim);
}
void DistanceF32::setUp(Testing::testID_t id,std::vector<Testing::param_t>& paramsArgs,Client::PatternMgr *mgr)
{
std::vector<Testing::param_t>::iterator it = paramsArgs.begin();
this->vecDim = *it++;
if ((id != DistanceF32::TEST_MINKOWSKI_DISTANCE_F32_9) && (id != DistanceF32::TEST_JENSENSHANNON_DISTANCE_F32_8))
{
inputA.reload(DistanceF32::INPUTA_PROBA_F32_ID,mgr);
inputB.reload(DistanceF32::INPUTB_PROBA_F32_ID,mgr);
}
else
{
inputA.reload(DistanceF32::INPUTA_F32_ID,mgr);
inputB.reload(DistanceF32::INPUTB_F32_ID,mgr);
}
if (id == DistanceF32::TEST_CORRELATION_DISTANCE_F32_5)
{
tmpA.create(this->vecDim,DistanceF32::TMPA_F32_ID,mgr);
tmpB.create(this->vecDim,DistanceF32::TMPB_F32_ID,mgr);
tmpAp = tmpA.ptr();
tmpBp = tmpB.ptr();
}
inpA=inputA.ptr();
inpB=inputB.ptr();
}
void DistanceF32::tearDown(Testing::testID_t id,Client::PatternMgr *mgr)
{
(void)id;
}