找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 4047|回复: 1
打印 上一主题 下一主题
收起左侧

基于STM32F4的简易示波器源码

[复制链接]
跳转到指定楼层
楼主
ID:303088 发表于 2018-4-29 19:52 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
基于STM3F4的简易示波器  TFT屏幕显示
源码如下
  1. #include "sys.h"
  2. #include "math.h"
  3. #include "arm_math.h"



  4. float fft_inputbuf[FFT_LENGTH*2];        //FFT输入数组
  5. float fft_outputbuf[FFT_LENGTH];        //FFT输出数组


  6. float point_x;
  7. float point_y;
  8. //u32 pinlv[3];  // FPGA 频率 2
  9. float x_o=xx0;
  10. float y_o=yy0;
  11. u16 updata;

  12. int main()
  13. {
  14.         u16 trigger=1000;
  15.         u32 temp=0;
  16.         u32 temp1=0;
  17.         u16 i;
  18.         arm_cfft_radix4_instance_f32 scfft;
  19.         u8 gate;
  20.         u16 adc1;
  21.         NVIC_PriorityGroupConfig(NVIC_PriorityGroup_2);//设置系统中断优先级分组2
  22.         delay_init(168);      //初始化延时函数
  23.         uart_init(115200);
  24.         
  25.         printf("asad");
  26.         LCD_Init();
  27. //        Dac1_Init();                                 //DAC通道1初始化        
  28. //        Dac2_Init();        
  29. //        Key_Init();
  30. //        I2C_INIT();
  31. //        Adc_Init();
  32. //        Dac1_Set_Vol(1500);
  33.         POINT_COLOR=BLUE;//设置字体为蓝色
  34.         //LCD_ShowString(0,line3,110,16,16,"mea frequency:");
  35. //        LCD_ShowString(0,line4,80,16,16,"mea Amp:");
  36.         My_Spi_Init();
  37.         arm_cfft_radix4_init_f32(&scfft,FFT_LENGTH,0,1);//初始化scfft结构体,设定FFT相关参数
  38.         
  39. //        LCD_DrawLine(xx0,zhongjian,xx1,zhongjian);                                                //横轴
  40. //        LCD_DrawLine(xx0,yy0,xx0,yy1);                                                //纵轴
  41. //        LCD_ShowString(row,zhongjian+(float)(yy0-zhongjian)/(1.0-0)*0,24,16,16,"0.0");//纵轴
  42. //        LCD_ShowString(row,zhongjian+(float)(yy0-zhongjian)/(1.0-0)*0.5,27,16,12,"-1.5");//纵轴
  43. //        LCD_ShowString(row,zhongjian+(float)(yy0-zhongjian)/(1.0-0)*1.0,27,16,12,"-3.0");//纵轴
  44. //        LCD_ShowString(row,zhongjian-(float)(yy0-zhongjian)/(1.0-0)*0.5,24,16,12,"1.5");//纵轴
  45. //        LCD_ShowString(row,zhongjian-(float)(yy0-zhongjian)/(1.0-0)*1.0,24,16,12,"3.0");//纵轴
  46. //        LCD_ShowString(row,yy1-16,24,16,16,"V");//纵轴
  47. //        LCD_DrawLine(xx0+(float)(xx1-xx0)/10*2,zhongjian,xx0+(float)(xx1-xx0)/10*2,zhongjian-4);                                                //横轴-2
  48. //        LCD_DrawLine(xx0+(float)(xx1-xx0)/10*4,zhongjian,xx0+(float)(xx1-xx0)/10*4,zhongjian-4);                                                //横轴-4
  49. //        LCD_DrawLine(xx0+(float)(xx1-xx0)/10*6,zhongjian,xx0+(float)(xx1-xx0)/10*6,zhongjian-4);                                                //横轴-6
  50. //        LCD_DrawLine(xx0+(float)(xx1-xx0)/10*8,zhongjian,xx0+(float)(xx1-xx0)/10*8,zhongjian-4);                                                //横轴-8
  51. //        LCD_DrawLine(xx0+(float)(xx1-xx0)/10*10,zhongjian,xx0+(float)(xx1-xx0)/10*10,zhongjian-4);                                                //横轴-10
  52. //        LCD_DrawLine(xx0,zhongjian+(float)(yy0-zhongjian)/(1.0-0)*1.0,xx0+4,zhongjian+(float)(yy0-zhongjian)/(1.0-0)*1.0);                                                //纵轴-1.0
  53. //        LCD_DrawLine(xx0,zhongjian+(float)(yy0-zhongjian)/(1.0-0)*0.5,xx0+4,zhongjian+(float)(yy0-zhongjian)/(1.0-0)*0.5);                                                //纵轴-0.8
  54. //        LCD_DrawLine(xx0,zhongjian-(float)(yy0-zhongjian)/(1.0-0)*0.5,xx0+4,zhongjian-(float)(yy0-zhongjian)/(1.0-0)*0.5);                                                //纵轴-0.6
  55. //        LCD_DrawLine(xx0,zhongjian-(float)(yy0-zhongjian)/(1.0-0)*1.0,xx0+4,zhongjian-(float)(yy0-zhongjian)/(1.0-0)*1.0);                                                //纵轴-0
  56.         while(1)
  57.         {


  58.                         for(i=0;i<FFT_LENGTH;i++)//生成信号序列
  59.                         {
  60.                          save[i]=SPI_ReadByte(0);
  61.                                 
  62.                         }
  63.     LCD_floatNUM(row0,line1,save[i],4,4,16);
  64.                                 for(i=0;i<FFT_LENGTH;i++)//生成信号序列
  65.                         {
  66.                                 if(save[i]>2048)
  67.                                         save[i]=(save[i]-4096);
  68.                                 fft_inputbuf[2*i]=(float)save[i]*(5.0/2048.0);                        
  69.                                 fft_inputbuf[2*i+1]=0;//虚部全部为0
  70.                         }
  71.                         

  72.                           arm_cfft_radix4_f32(&scfft,fft_inputbuf);        //FFT计算(基4)
  73.                                 arm_cmplx_mag_f32(fft_inputbuf,fft_outputbuf,FFT_LENGTH);        //把运算结果复数求模得幅值
  74.                         if(temp==0)
  75.                         for(i=0;i<FFT_LENGTH;i++)
  76.                         {
  77. //                                printf("fft_inputbuf[%d]:%f\r\n",i,fft_outputbuf[i]);
  78.                                 printf("%f\r\n",fft_outputbuf[i]);
  79.                                 temp++;
  80.                         }
  81. //                        
  82.                         }
  83.                         
  84.         }

复制代码

全部资料51hei下载地址:
示波器.rar (1.11 MB, 下载次数: 108)


分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏1 分享淘帖 顶 踩
回复

使用道具 举报

沙发
ID:114007 发表于 2019-2-21 20:17 | 只看该作者
楼主有原理图嘛??
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

手机版|小黑屋|51黑电子论坛 |51黑电子论坛6群 QQ 管理员QQ:125739409;技术交流QQ群281945664

Powered by 单片机教程网

快速回复 返回顶部 返回列表