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

网站 改版网站开发前端要学什么

网站 改版,网站开发前端要学什么,培训美工设计师,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.hkea.cn/news/14540421/

相关文章:

  • 昆明网站推广排名qq浏览器网页版入口
  • 产品网络推广方案设计郑州关键词优化顾问
  • 网站没收录可以做排名国内快速建站
  • 外贸开发产品网站模板利用access做网站
  • 网站seo优化免关于asp sql网站开发的书籍
  • 网站改版重新收录wordpress获取图片路径
  • 济南网站建设正规公司百度查重免费
  • 广西城乡建设厅网站应用网站开发
  • asp.net网站建设教程上海app网络推广公司电话
  • 湖北网站定制开发多少钱设计类培训机构
  • 网站建设分金手指排名一昆明做烤瓷牙哪去柏德L网站
  • 门户网站建设注意事项可以做众筹的网站有哪些
  • 网站开发一般要用到哪些软件点点网 xml转wordpress
  • 微信小程序制作精灵seo都用在哪些网站
  • wordpress自动采集1024seo优化技巧
  • 宝塔面板做网站不能打开PHP显示404做网站的花费
  • 注册网站地址秦皇岛网站设计
  • 洛阳网站建设找洛阳铭信网络新余服装网站建设
  • 注册分公司流程及所需资料seo是什么味
  • 浙江 外贸网站建设买完域名接下来怎么弄
  • 成都网站建设哪家好山东省住房和城乡城乡建设厅网站
  • 郑州网站建设哪家强广州市研发网站建设价格
  • 柬埔寨网站建设开发区网站建设在哪
  • 游戏网站建设的目的电子产品定制开发
  • 电商erp网站开发公共资源交易中心级别
  • 为什么建设网站要年年交钱常见的网络营销形式有
  • 企业网站自助建设现在还有做网站的必要吗
  • 中企动力做的网站山西太原销售网站模板
  • 网站备案后可以修改吗化妆品网站建设需求问卷调查
  • 西安市建设工程信息网诚信平台官网长沙做网站seo优化外包