银杏科技有限公司旗下技术文档发布平台 | |||
技术支持电话 | 0379-69926675-801 | ||
技术支持邮件 | Gingko@vip.163.com | ||
版本 | 日期 | 作者 | 修改内容 |
---|---|---|---|
V1.0 | 2020-03-05 | gingko | 初次建立 |
1.在主界面选择File–>New Project 或者直接点击ACCEE TO MCU SELECTOR 2.出现芯片型号选择,搜索自己芯片的型号,双击型号,或者点击Start Project进入配置 在搜索栏的下面,提供的各 种查找方式,可以选择芯片内核,型号,等等,可以帮助你查找芯片。本实验选取的芯片型号为:STM32H750IBKx。 3.配置RCC,使用外部时钟源 4.时基源选择SysTick 5.将PA10,PB7,PB8设置为GPIO_Output 6.引脚模式配置 7.设置串口 8.在NVIC Settings一栏使能接收中断 9.时钟源设置,选择外部高速时钟源,配置为最大主频 10.工程文件的设置, 这里就是工程的各种配置 我们只用到有限几个,其他的默认即可 IDE我们使用的是 MDK V5.27 11.点击Code Generator,进行进一步配置
12.然后点击GENERATE CODE 创建工程 创建成功,打开工程。
int main(void) { int i,j; int res; int time[2]; static int error_flag = 0; HAL_Init(); SystemClock_Config(); i2c.initialize(); axp152.initialize(); axp152.set_dcdc1(3500);//[ARM & FPGA BK1/2/6 &OTHER] axp152.set_dcdc2(1200);//[FPGA INT & PLL D] axp152.set_aldo1(2500);//[FPGA PLL A] axp152.set_dcdc4(3300);//[POWER_OUTPUT] axp152.set_dcdc3(3300);//[FPGA BK4][Adjustable] axp152.set_aldo2(3300);//[FPGA BK3][Adjustable] axp152.set_dldo1(3300);//[FPGA BK7][Adjustable] axp152.set_dldo2(3300);//[FPGA BK5][Adjustable] MX_GPIO_Init(); MX_USART2_UART_Init(); usart2.initialize(115200); usart2.printf("\x0c"); //清屏 usart2.printf("\033[1;32;40m"); //设置终端字体为绿色 usart2.printf("Hello, I am iCore4T!\r\n\r\n"); usart2.printf("DSP BasicMath TEST......\r\n"); while (1) { uwTick = 0; for(j = 0;j < 10000;j++){ for(i = 0;i < MAX_BLOCKSIZE;i ++){ res = SinCos_Test(testInput_f32[i],0); if(res != 0)error_flag ++; } } time[0] = HAL_GetTick(); uwTick = 0; for(j = 0;j < 10000;j++){ for(i = 0;i < MAX_BLOCKSIZE;i ++){ res = SinCos_Test(testInput_f32[i],1); if(res != 0)error_flag ++; } } time[1] = HAL_GetTick(); if(error_flag == 0){ usart2.printf("*NO DSP MATHLIB runtime:%dms *USE DSP MATHLIB runtime:%dms\r",time[0], time[1]); LED_ON; } else{ usart2.printf("Error\r"); LED_OFF; } } }
int SinCos_Test(float testInput,unsigned char mode) { float Sinx,Cosx; float Result; switch (mode){ case 0: //不适用DSP MATH库 Sinx = sinf(testInput); //不适用DSP优化的sin,cos函数 Cosx = cosf(testInput); Result = Sinx*Sinx + Cosx*Cosx; //计算结果应该等于1 Result = fabsf(Result-1.0f); //对比与1的差值 if(Result > DELTA)return -1; //判断 break; case 1://使用DSP MATH库 Sinx = arm_sin_f32(testInput); //适用DSP优化的sin,cos函数 Cosx = arm_cos_f32(testInput); Result = Sinx*Sinx + Cosx*Cosx; //计算结果应该等于1 Result = fabsf(Result-1.0f); //对比与1的差值 if(Result > DELTA)return -1; //判断 break; default: break; } return 0; }