久久久久久久999_99精品久久精品一区二区爱城_成人欧美一区二区三区在线播放_国产精品日本一区二区不卡视频_国产午夜视频_欧美精品在线观看免费

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 4108|回復: 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 單片機教程網

快速回復 返回頂部 返回列表
主站蜘蛛池模板: 黄色免费在线视频 | 欧美黄视频 | 免费黄色片网站 | 欧美一级一级 | 亚洲一区免费观看 | 黄色片中文字幕 | 亚洲在线一区二区 | 成人激情视频在线观看 | a在线视频 | 日本不卡视频在线观看 | 精品亚洲一区二区三区 | www.黄色网 | 精品网站999www | 日本一级淫片色费放 | 亚洲精品自拍 | 二区三区在线观看 | 色噜噜狠狠一区二区三区 | www.色日本| 日韩欧美在线播放 | 久久视频一区 | 青青草成人在线 | 二区三区在线观看 | 日韩在线专区 | a级片久久 | 中文字幕精品在线 | 青青操影院 | 婷婷99 | www一区 | 色婷婷视频在线观看 | 超碰在线视屏 | 亚洲午夜在线观看 | 久久久不卡 | 午夜国产福利 | 国产精品99久久久久久久久 | 999热视频| 日韩午夜在线观看 | 黄色网页在线 | 日日夜夜天天操 | 国产午夜视频 | 久久理论片 | 久久国产精品99久久人人澡 |