当前位置: 首页 > news >正文

flash html网站模板网络营销是什么活动

flash html网站模板,网络营销是什么活动,seo类目链接优化,wordpress菜单底部导航代码1 获取Whetstone程序 Whetstone程序#xff0c;我用github被墙了#xff0c;所以用了KK的方式。 获取的程序目录如上所示。 2 新建STM32工程 配置如上#xff0c;生成工程即可。 3 在生成的工程中添加并修改Whetstone程序 3.1 实现串口打印功能 在生成的usart.c文件中…1 获取Whetstone程序 Whetstone程序我用github被墙了所以用了KK的方式。 获取的程序目录如上所示。 2 新建STM32工程 配置如上生成工程即可。 3 在生成的工程中添加并修改Whetstone程序 3.1 实现串口打印功能 在生成的usart.c文件中添加些代码实现串口打印注意串口的IO引脚STM32G4的评估板需要外部连接串口USB口没有连接串口线。 #ifndef __MICROLIB #define __FILE_INCOMPLETE 1 #endif #include stdio.h#ifndef __MICROLIB struct __FILE {int handle;/* Whatever you require here. If the only file you are using is *//* standard output using printf() for debugging, no file handling *//* is required. */ }__stdout; #endif #define PUTCHAR_PROTOTYPE int fputc(int ch, FILE *f)// 该函数放在usart.c文件最后即可 PUTCHAR_PROTOTYPE {/* e.g. write a character to the LPUART1 and Loop until the end of transmission */HAL_UART_Transmit(hlpuart1, (uint8_t *)ch, 1, 0xFFFF);return ch; }此外需要在MX_LPUART1_UART_Init()函数中添加USART外设初始化函数。 HAL_UART_MspInit(hlpuart1);至此串口打印功能即添加完成。 3.2 修改whetstone.c 工程目录下新建Whetstone文件夹并将whetstone.c拷贝进去 给工程添加源文件 /*******************************whetstone.c*************************************/ #include stdlib.h #include stdio.h #include string.h #include math.h// 添加头文件 #include main.h // 我将Whetstone的函数声明放在main.h了 #include stdint.h #include stm32g4xx_hal.h//stm32G4的hal库头文件若更换芯片型哈需要更改// 添加systick计时 #define GETMYTIME(_t) (*_t HAL_GetTick())//使用Systick获取时间 uint64_t TickValue 0;// 中间变量/* map the FORTRAN math functions, etc. to the C versions */ #define DSIN sin #define DCOS cos #define DATAN atan #define DLOG log #define DEXP exp #define DSQRT sqrt #define IF if/* function prototypes */ void POUT(long N, long J, long K, double X1, double X2, double X3, double X4); void PA(double E[]); void P0(void); void P3(double X, double Y, double *Z); #define USAGE usage: whetdc [-c] [loops]\n//#define PRINTOUT 1uint32_t time_in_secs(uint64_t ticks); uint64_t get_timer_value(void);/*COMMON T,T1,T2,E1(4),J,K,L */ double T,T1,T2,E1[5]; int J,K,L; int argc 0; //Mod for nucleo. Change in code below if you want non-default loop count//************************************ //** Whetstone 64b-DP ** //** SUB ** //************************************ int Whetstone(void) // ------------ Metoda ----------- {printf(Beginning Whetstone benchmark at );printf( %d MHz ...\n\n, SystemCoreClock/1000000);/* used in the FORTRAN version */long I;long N1, N2, N3, N4, N6, N7, N8, N9, N10, N11;double X1,X2,X3,X4,X,Y,Z;long LOOP;int II, JJ;/* added for this version */long loopstart 0;uint64_t startsec,finisec 0;double KIPS;int continuous;loopstart 25000; /* 1000 see the note about LOOP below */continuous 0;II 1; /* start at the first arg (temp use of II here) */LCONT: /* ******************************************** * Start benchmark timing at this point. ******************************************** */startsec 0;finisec 0;startsec get_timer_value();/* ******************************************** * The actual benchmark starts here. ******************************************** */T .499975;T1 0.50025;T2 2.0; /* ******************************************** * With loopcount LOOP10, one million Whetstone instructions * will be executed in EACH MAJOR LOOP..A MAJOR LOOP IS EXECUTED * II TIMES TO INCREASE WALL-CLOCK TIMING ACCURACY. * * LOOP 1000; */LOOP loopstart;II 1;JJ 1;IILOOP:N1 0;N2 12 * LOOP;N3 14 * LOOP;N4 345 * LOOP;N6 210 * LOOP;N7 32 * LOOP;N8 899 * LOOP;N9 616 * LOOP;N10 0;N11 93 * LOOP; /* ******************************************** * Module 1: Simple identifiers ******************************************** */X1 1.0;X2 -1.0;X3 -1.0;X4 -1.0;for (I 1; I N1; I){X1 (X1 X2 X3 - X4) * T;X2 (X1 X2 - X3 X4) * T;X3 (X1 - X2 X3 X4) * T;X4 (-X1 X2 X3 X4) * T;} #ifdef PRINTOUTIF (JJII) POUT(N1,N1,N1,X1,X2,X3,X4); #endif/* ******************************************** * Module 2: Array elements ******************************************** */E1[1] 1.0;E1[2] -1.0;E1[3] -1.0;E1[4] -1.0;for (I 1; I N2; I){E1[1] ( E1[1] E1[2] E1[3] - E1[4]) * T;E1[2] ( E1[1] E1[2] - E1[3] E1[4]) * T;E1[3] ( E1[1] - E1[2] E1[3] E1[4]) * T;E1[4] (-E1[1] E1[2] E1[3] E1[4]) * T;}#ifdef PRINTOUTIF (JJII) POUT(N2,N3,N2,E1[1],E1[2],E1[3],E1[4]); #endif/* ******************************************** * Module 3: Array as parameter ******************************************** */for (I 1; I N3; I){PA(E1);} #ifdef PRINTOUTIF (JJII) POUT(N3,N2,N2,E1[1],E1[2],E1[3],E1[4]); #endif/* ******************************************** * Module 4: Conditional jumps ******************************************** */J 1;for (I 1; I N4; I){if (J 1)J 2;elseJ 3;if (J 2)J 0;elseJ 1;if (J 1)J 1;elseJ 0;}#ifdef PRINTOUTIF (JJII) POUT(N4,J,J,X1,X2,X3,X4); #endif/* ******************************************** * Module 5: Omitted * Module 6: Integer arithmetic ******************************************** */J 1;K 2;L 3;for (I 1; I N6; I){J J * (K-J) * (L-K);K L * K - (L-J) * K;L (L-K) * (KJ);E1[L-1] J K L;E1[K-1] J * K * L;}#ifdef PRINTOUTIF (JJII) POUT(N6,J,K,E1[1],E1[2],E1[3],E1[4]); #endif/* ******************************************** * Module 7: Trigonometric functions ******************************************** */X 0.5;Y 0.5;for (I 1; I N7; I){X T * DATAN(T2*DSIN(X)*DCOS(X)/(DCOS(XY)DCOS(X-Y)-1.0));Y T * DATAN(T2*DSIN(Y)*DCOS(Y)/(DCOS(XY)DCOS(X-Y)-1.0));}#ifdef PRINTOUTIF (JJII)POUT(N7,J,K,X,X,Y,Y); #endif/* ******************************************** * Module 8: Procedure calls ******************************************** */X 1.0;Y 1.0;Z 1.0;for (I 1; I N8; I){P3(X,Y,Z);} #ifdef PRINTOUTIF (JJII)POUT(N8,J,K,X,Y,Z,Z); #endif/* ******************************************** * Module 9: Array references ******************************************** */J 1;K 2;L 3;E1[1] 1.0;E1[2] 2.0;E1[3] 3.0;for (I 1; I N9; I){P0();} #ifdef PRINTOUTIF (JJII) POUT(N9,J,K,E1[1],E1[2],E1[3],E1[4]); #endif/* ******************************************** * Module 10: Integer arithmetic ******************************************** */J 2;K 3;for (I 1; I N10; I){J J K;K J K;J K - J;K K - J - J;}#ifdef PRINTOUTIF (JJII) POUT(N10,J,K,X1,X2,X3,X4); #endif/* ******************************************** * Module 11: Standard functions ******************************************** */X 0.75;for (I 1; I N11; I){X DSQRT(DEXP(DLOG(X)/T1));} #ifdef PRINTOUTIF (JJII) POUT(N11,J,K,X,X,X,X); #endif/* ******************************************** * THIS IS THE END OF THE MAJOR LOOP. ******************************************** */if (JJ II)goto IILOOP;/* ******************************************** * Stop benchmark timing at this point. ******************************************** */// finisec time(0);finisec get_timer_value();//timer.reset();/* *-------------------------------------------------------------------- * Performance in Whetstone KIPs per second is given by * * (100*LOOP*II)/TIME * * where TIME is in seconds. *-------------------------------------------------------------------- */double vreme;vreme time_in_secs(finisec - startsec);if (vreme 0){printf(Insufficient duration- Increase the LOOP count \n);finisec 0; startsec 0;return 1;}printf(Loops: %ld , \t Iterations: %d, \t Duration: %.3f sec. \n,LOOP, II, vreme);KIPS (100.0 * LOOP * II) / vreme ;if (KIPS 1000.0)printf(C Converted Double Precision Whetstones: %.3f MIPS \n\n, KIPS / 1000);elseprintf(C Converted Double Precision Whetstones: %.3f KIPS \n\n, KIPS);// printf(C Converted Double Precision Whetstones: %.3f MIPS \n\n, KIPS / 1000);if (continuous)goto LCONT;finisec 0; startsec 0;return 1; }void PA(double E[]) {J 0;L10:E[1] ( E[1] E[2] E[3] - E[4]) * T;E[2] ( E[1] E[2] - E[3] E[4]) * T;E[3] ( E[1] - E[2] E[3] E[4]) * T;E[4] (-E[1] E[2] E[3] E[4]) / T2;J 1;if (J 6)goto L10; }void P0(void) {E1[J] E1[K];E1[K] E1[L];E1[L] E1[J]; }void P3(double X, double Y, double *Z) {double X1, Y1;X1 X;Y1 Y;X1 T * (X1 Y1);Y1 T * (X1 Y1);*Z (X1 Y1) / T2; }// 原本该函数应该是用定时器实现的 double time_in_secs(uint64_t ticks) {// scale timer down to avoid uint64_t - double conversion in RV32 // int scale 256; // uint32_t delta ticks / scale; // uint32_t freq get_timer_freq() / scale; // return delta / (double)freq;int scale 10000; // double delta ticks / scale; //修改前double delta (double)(ticks*1.0) / scale;//修改后return delta; }// 根据原有的函数接口使用systick作为计时单元实现计时 uint64_t get_timer_value(void) {GETMYTIME(TickValue);return TickValue; }#ifdef PRINTOUT void POUT(long N, long J, long K, double X1, double X2, double X3, double X4) {printf(%7ld %7ld %7ld %12.4e %12.4e %12.4e %12.4e\n,N, J, K, X1, X2, X3, X4); } #endif 在main.c添加 #include stdio.hprintf(\nMy Benchmark example for Whetstones \n); Whetstone(); //Call of Whetstone banchmark methode在main.h添加 int Whetstone(void);4 烧录测试 修改前 修改后 暂时没有具体分析细节问题只是跑通了 修改记录 2025.2.7——可能有朋友注意到了时间上是正好5s一般不可能这么规整检查了一下代码是time_in_secs()函数在转换时没有考虑到浮点导致。已修改
http://www.lakalapos1.cn/news/28516/

相关文章:

  • 某些网站域名解析错误北京手机网站建设外包
  • 网站蜘蛛爬行统计系统关键词优化最好的方法
  • 淄博市临淄区建设局网站模板下载后怎么使用
  • 南京高端网站制作如何做好一个品牌推广
  • 在线代理服务器网站平面设计工资一般薪资多少
  • dz网站开发微淘客网站建设
  • 如何提高 网站的点击量陕西住房城乡住房建设厅网站
  • 做网站开发实习生怎么样福州网站建设模板
  • ui网站推荐网页qq空间登录入口
  • scratch少儿编程网站wordpress站内全文检索
  • 河源市住宅和城乡规划建设局网站仿帝国网站源码
  • 大庆北京网站建设企业黄页名单
  • 开封公司网站如何制作电子商务网站建设第一章课后
  • 快速搭建网站优帮云郑州工商注册
  • 北京网站建设公司费用网页qq注册新账号免费
  • 做门户网站 公司营业范围是啥红番茄 网站点评
  • 网站标题怎么写最佳的搜索引擎
  • 网站建设在电访销售话术软件详细设计文档模板
  • 站长统计官网东莞外贸企业网站建设
  • 好大夫 网站开发全国 网站备案 数量
  • 网站设计专业实验室建设app定制开发大概多少钱
  • 网站配色技巧google关键词分析工具
  • 网站做点线表格网站建设与管理实践报告
  • 雷州网站开发公司重庆网站推广联系方式
  • 烟台定制网站建设价格网站制作厂家
  • 永兴县网站建设长沙网站定制建设
  • 重庆企业网站备案要多久时间个人网站备案需要多久
  • cdn网站dede视频网站源码
  • 微信上可以做网站吗手机网址制作
  • 便宜网站建设成都做电商需要学什么