#include "cvi_ive.h" #include #include #include #include int main(int argc, char **argv) { if (argc != 4) { printf("Incorrect loop value. Usage: %s \n", argv[0]); printf("Example: %s 352 288 data/00_352x288_y.yuv\n", argv[0]); return CVI_FAILURE; } // 00_352x288_y.yuv const char *filename = argv[3]; int ret = CVI_SUCCESS; int input_w, input_h; unsigned long elapsed_cpu; struct timeval t0, t1; input_w = atoi(argv[1]); input_h = atoi(argv[2]); gettimeofday(&t0, NULL); /* 5 by 5*/ CVI_S8 arr5by5[25] = { -1, -2, 0, 2, 1, -4, -8, 0, 8, 4, -6, -12, 0, 12, 6, -4, -8, 0, 8, 4, -1, -2, 0, 2, 1 }; /* 3 by 3*/ CVI_S8 arr3by3[25] = { 0, 0, 0, 0, 0, 0, -1, 0, 1, 0, 0, -2, 0, 2, 0, 0, -1, 0, 1, 0, 0, 0, 0, 0, 0 }; IVE_HANDLE handle = CVI_IVE_CreateHandle(); // Create src image. IVE_IMAGE_S src; CVI_IVE_ReadRawImage(handle, &src, filename, IVE_IMAGE_TYPE_U8C1, input_w, input_h); // Create dst image. IVE_DST_IMAGE_S dst_mag, dst_ang; CVI_IVE_CreateImage(handle, &dst_mag, IVE_IMAGE_TYPE_U16C1, input_w, input_h); CVI_IVE_CreateImage(handle, &dst_ang, IVE_IMAGE_TYPE_U8C1, input_w, input_h); // Config Setting. IVE_MAG_AND_ANG_CTRL_S pstMaaCtrl; pstMaaCtrl.u16Thr = 0; memcpy(pstMaaCtrl.as8Mask, arr3by3, 5 * 5 * sizeof(CVI_S8)); // Run HW IVE. printf("Run HW IVE MagAndAng 3x3 MAG_AND_ANG.\n"); pstMaaCtrl.enOutCtrl = IVE_MAG_AND_ANG_OUT_CTRL_MAG_AND_ANG; CVI_IVE_MagAndAng(handle, &src, &dst_mag, &dst_ang, &pstMaaCtrl, 1); gettimeofday(&t1, NULL); elapsed_cpu = ((t1.tv_sec - t0.tv_sec) * 1000000 + t1.tv_usec - t0.tv_usec); printf("%s CPU time %lu\n", __func__, elapsed_cpu); CVI_IVE_WriteImg(handle, "sample_MagAndAng_MagAndAng3x3_Mag.yuv", &dst_mag); CVI_IVE_WriteImg(handle, "sample_MagAndAng_MagAndAng3x3_Ang.yuv", &dst_ang); printf("Run HW IVE MagAndAng 3x3 MAG_AND_ANG.\n"); pstMaaCtrl.enOutCtrl = IVE_MAG_AND_ANG_OUT_CTRL_MAG; CVI_IVE_MagAndAng(handle, &src, &dst_mag, CVI_NULL, &pstMaaCtrl, 1); CVI_IVE_WriteImg(handle, "sample_MagAndAng_Mag3x3_Mag.yuv", &dst_mag); memcpy(pstMaaCtrl.as8Mask, arr5by5, 5 * 5 * sizeof(CVI_S8)); printf("Run HW IVE MagAndAng 5x5 MAG_AND_ANG.\n"); pstMaaCtrl.enOutCtrl = IVE_MAG_AND_ANG_OUT_CTRL_MAG_AND_ANG; CVI_IVE_MagAndAng(handle, &src, &dst_mag, &dst_ang, &pstMaaCtrl, 1); CVI_IVE_WriteImg(handle, "sample_MagAndAng_MagAndAng5x5_Mag.yuv", &dst_mag); CVI_IVE_WriteImg(handle, "sample_MagAndAng_MagAndAng5x5_Ang.yuv", &dst_ang); printf("Run HW IVE MagAndAng 5x5 MAG_AND_ANG.\n"); pstMaaCtrl.enOutCtrl = IVE_MAG_AND_ANG_OUT_CTRL_MAG; CVI_IVE_MagAndAng(handle, &src, &dst_mag, CVI_NULL, &pstMaaCtrl, 1); CVI_IVE_WriteImg(handle, "sample_MagAndAng_Mag5x5_Mag.yuv", &dst_mag); printf("Run HW IVE MagAndAng 3x3 MAG Thresh.\n"); memcpy(pstMaaCtrl.as8Mask, arr3by3, 5 * 5 * sizeof(CVI_S8)); pstMaaCtrl.u16Thr = 42; CVI_IVE_MagAndAng(handle, &src, &dst_mag, CVI_NULL, &pstMaaCtrl, 1); CVI_IVE_WriteImg(handle, "sample_MagAndAng_Thresh3x3_Mag.yuv", &dst_mag); printf("Run HW IVE MagAndAng 5x5 MAG Thresh.\n"); memcpy(pstMaaCtrl.as8Mask, arr5by5, 5 * 5 * sizeof(CVI_S8)); pstMaaCtrl.u16Thr = 18468; CVI_IVE_MagAndAng(handle, &src, &dst_mag, CVI_NULL, &pstMaaCtrl, 1); CVI_IVE_WriteImg(handle, "sample_MagAndAng_Thresh5x5_Mag.yuv", &dst_mag); CVI_SYS_FreeI(handle, &src); CVI_SYS_FreeI(handle, &dst_mag); CVI_SYS_FreeI(handle, &dst_ang); CVI_IVE_DestroyHandle(handle); return ret; }