#include "BasicTestsF32.h" #include "Error.h" #define SNR_THRESHOLD 120 /* Reference patterns are generated with a double precision computation. */ #define REL_ERROR (1.0e-6) #define GET_F32_PTR() \ const float32_t *inp1=input1.ptr(); \ const float32_t *inp2=input2.ptr(); \ float32_t *refp=ref.ptr(); \ float32_t *outp=output.ptr(); void BasicTestsF32::test_add_f32() { GET_F32_PTR(); arm_add_f32(inp1,inp2,outp,input1.nbSamples()); ASSERT_EMPTY_TAIL(output); ASSERT_SNR(output,ref,(float32_t)SNR_THRESHOLD); ASSERT_REL_ERROR(output,ref,REL_ERROR); } void BasicTestsF32::test_sub_f32() { GET_F32_PTR(); arm_sub_f32(inp1,inp2,outp,input1.nbSamples()); ASSERT_EMPTY_TAIL(output); ASSERT_SNR(output,ref,(float32_t)SNR_THRESHOLD); ASSERT_REL_ERROR(output,ref,REL_ERROR); } void BasicTestsF32::test_mult_f32() { GET_F32_PTR(); arm_mult_f32(inp1,inp2,outp,input1.nbSamples()); ASSERT_EMPTY_TAIL(output); ASSERT_SNR(output,ref,(float32_t)SNR_THRESHOLD); ASSERT_REL_ERROR(output,ref,REL_ERROR); } void BasicTestsF32::test_negate_f32() { GET_F32_PTR(); arm_negate_f32(inp1,outp,input1.nbSamples()); ASSERT_EMPTY_TAIL(output); ASSERT_SNR(output,ref,(float32_t)SNR_THRESHOLD); ASSERT_REL_ERROR(output,ref,REL_ERROR); } void BasicTestsF32::test_offset_f32() { GET_F32_PTR(); arm_offset_f32(inp1,0.5,outp,input1.nbSamples()); ASSERT_EMPTY_TAIL(output); ASSERT_SNR(output,ref,(float32_t)SNR_THRESHOLD); ASSERT_REL_ERROR(output,ref,REL_ERROR); } void BasicTestsF32::test_scale_f32() { GET_F32_PTR(); arm_scale_f32(inp1,0.5,outp,input1.nbSamples()); ASSERT_EMPTY_TAIL(output); ASSERT_SNR(output,ref,(float32_t)SNR_THRESHOLD); ASSERT_REL_ERROR(output,ref,REL_ERROR); } void BasicTestsF32::test_dot_prod_f32() { float32_t r; GET_F32_PTR(); arm_dot_prod_f32(inp1,inp2,input1.nbSamples(),&r); outp[0] = r; ASSERT_SNR(output,ref,(float32_t)SNR_THRESHOLD); ASSERT_REL_ERROR(output,ref,REL_ERROR); ASSERT_EMPTY_TAIL(output); } void BasicTestsF32::test_abs_f32() { GET_F32_PTR(); arm_abs_f32(inp1,outp,input1.nbSamples()); ASSERT_EMPTY_TAIL(output); ASSERT_SNR(output,ref,(float32_t)SNR_THRESHOLD); ASSERT_REL_ERROR(output,ref,REL_ERROR); } void BasicTestsF32::setUp(Testing::testID_t id,std::vector& params,Client::PatternMgr *mgr) { Testing::nbSamples_t nb=MAX_NB_SAMPLES; switch(id) { case BasicTestsF32::TEST_ADD_F32_1: nb = 3; ref.reload(BasicTestsF32::REF_ADD_F32_ID,mgr,nb); break; case BasicTestsF32::TEST_ADD_F32_2: nb = 8; ref.reload(BasicTestsF32::REF_ADD_F32_ID,mgr,nb); break; case BasicTestsF32::TEST_ADD_F32_3: nb = 9; ref.reload(BasicTestsF32::REF_ADD_F32_ID,mgr,nb); break; case BasicTestsF32::TEST_SUB_F32_4: nb = 3; ref.reload(BasicTestsF32::REF_SUB_F32_ID,mgr,nb); break; case BasicTestsF32::TEST_SUB_F32_5: nb = 8; ref.reload(BasicTestsF32::REF_SUB_F32_ID,mgr,nb); break; case BasicTestsF32::TEST_SUB_F32_6: nb = 9; ref.reload(BasicTestsF32::REF_SUB_F32_ID,mgr,nb); break; case BasicTestsF32::TEST_MULT_F32_7: nb = 3; ref.reload(BasicTestsF32::REF_MULT_F32_ID,mgr,nb); break; case BasicTestsF32::TEST_MULT_F32_8: nb = 8; ref.reload(BasicTestsF32::REF_MULT_F32_ID,mgr,nb); break; case BasicTestsF32::TEST_MULT_F32_9: nb = 9; ref.reload(BasicTestsF32::REF_MULT_F32_ID,mgr,nb); break; case BasicTestsF32::TEST_NEGATE_F32_10: nb = 3; ref.reload(BasicTestsF32::REF_NEGATE_F32_ID,mgr,nb); break; case BasicTestsF32::TEST_NEGATE_F32_11: nb = 8; ref.reload(BasicTestsF32::REF_NEGATE_F32_ID,mgr,nb); break; case BasicTestsF32::TEST_NEGATE_F32_12: nb = 9; ref.reload(BasicTestsF32::REF_NEGATE_F32_ID,mgr,nb); break; case BasicTestsF32::TEST_OFFSET_F32_13: nb = 3; ref.reload(BasicTestsF32::REF_OFFSET_F32_ID,mgr,nb); break; case BasicTestsF32::TEST_OFFSET_F32_14: nb = 8; ref.reload(BasicTestsF32::REF_OFFSET_F32_ID,mgr,nb); break; case BasicTestsF32::TEST_OFFSET_F32_15: nb = 9; ref.reload(BasicTestsF32::REF_OFFSET_F32_ID,mgr,nb); break; case BasicTestsF32::TEST_SCALE_F32_16: nb = 3; ref.reload(BasicTestsF32::REF_SCALE_F32_ID,mgr,nb); break; case BasicTestsF32::TEST_SCALE_F32_17: nb = 8; ref.reload(BasicTestsF32::REF_SCALE_F32_ID,mgr,nb); break; case BasicTestsF32::TEST_SCALE_F32_18: nb = 9; ref.reload(BasicTestsF32::REF_SCALE_F32_ID,mgr,nb); break; case BasicTestsF32::TEST_DOT_PROD_F32_19: nb = 3; ref.reload(BasicTestsF32::REF_DOT_3_F32_ID,mgr); break; case BasicTestsF32::TEST_DOT_PROD_F32_20: nb = 8; ref.reload(BasicTestsF32::REF_DOT_4N_F32_ID,mgr); break; case BasicTestsF32::TEST_DOT_PROD_F32_21: nb = 9; ref.reload(BasicTestsF32::REF_DOT_4N1_F32_ID,mgr); break; case BasicTestsF32::TEST_ABS_F32_22: nb = 3; ref.reload(BasicTestsF32::REF_ABS_F32_ID,mgr,nb); break; case BasicTestsF32::TEST_ABS_F32_23: nb = 8; ref.reload(BasicTestsF32::REF_ABS_F32_ID,mgr,nb); break; case BasicTestsF32::TEST_ABS_F32_24: nb = 9; ref.reload(BasicTestsF32::REF_ABS_F32_ID,mgr,nb); break; } input1.reload(BasicTestsF32::INPUT1_F32_ID,mgr,nb); input2.reload(BasicTestsF32::INPUT2_F32_ID,mgr,nb); output.create(ref.nbSamples(),BasicTestsF32::OUT_SAMPLES_F32_ID,mgr); } void BasicTestsF32::tearDown(Testing::testID_t id,Client::PatternMgr *mgr) { output.dump(mgr); }