OpenEdv-开源电子网

 找回密码
 立即注册
正点原子全套STM32/Linux/FPGA开发资料,上千讲STM32视频教程免费下载...
查看: 8842|回复: 2

STC12C5A60S2单片机程序怎么移植到STM32

[复制链接]

1

主题

2

帖子

0

精华

新手入门

积分
26
金钱
26
注册时间
2015-4-12
在线时间
0 小时
发表于 2015-5-13 09:47:51 | 显示全部楼层 |阅读模式
5金钱
这段程序是关于傅里叶变换 基二FFT算法 。这个程序是在STC12C5A60S2单片机里写的,怎么移植到STM32F4中
[mw_shl_code=c,true]#include<STC12C5A60S2.H> typedef unsigned char uint8; typedef unsigned int uint16; #define channel 0x01 //设置AD通道为 P1.0 #define ADC_POWER (1<<7) #define ADC_SPEEDHH (0x03<<5) #define ADC_START (1<<3) #define PADCH (1<<5) #define ADC_FLAG (1<<4) #define P_3 P3 //32列扫描控制 sbit sw=P1^2;//74HC154组切换控制位 //放大128倍后的sin整数表(128) code char SIN_TAB[128]={0,6,12,18,24,30,36,42,48,54,59,65,70,75,80,85,89,94,98,102, 105,108,112,114,117,119,121,123,124,125,126,126,126,126,126, 125,124,123,121,119,117,114,112,108,105,102,98,94,89,85,80,75, 70,65,59,54,48,42,36,30,24,18,12,6,0,-6,-12,-18,-24,-30,-36,-42, -48,-54,-59,-65,-70,-75,-80,-85,-89,-94,-98,-102,-105,-108,-112, -114,-117,-119,-121,-123,-124,-125,-126,-126,-126,-126,-126,-125, -124,-123,-121,-119,-117,-114,-112,-108,-105,-102,-98,-94,-89,-85, -80,-75,-70,-65,-59,-54,-48,-42,-36,-30,-24,-18,-12,-6}; //放大128倍后的cos整数表(128) code char COS_TAB[128]={127,126,126,125,124,123,121,119,117,114,112,108,105,102,98,94, 89,85,80,75,70,65,59,54,48,42,36,30,24,18,12,6,0,-6,-12,-18,-24, -30,-36,-42,-48,-54,-59,-65,-70,-75,-80,-85,-89,-94,-98,-102, -105,-108,-112,-114,-117,-119,-121,-123,-124,-125,-126,-126,-126, -126,-126,-125,-124,-123,-121,-119,-117,-114,-112,-108,-105,-102, -98,-94,-89,-85,-80,-75,-70,-65,-59,-54,-48,-42,-36,-30,-24,-18, -12,-6,0,6,12,18,24,30,36,42,48,54,59,65,70,75,80,85,89,94,98,102, 105,108,112,114,117,119,121,123,124,125,126,126}; //采样存储序列表 code char LIST_TAB[128] = {0,64,32,96,16,80,48,112,8,72,40,104,24,88,56,120,4,68,36,100,20,84,52,116, 12,76,44,108,28,92,60,124,2,66,34,98,18,82,50,114,10,74,42,106,26,90,58, 122,6,70,38,102,22,86,54,118,14,78,46,110,30,94,62,126,1,65,33,97,17,81,49, 113,9,73,41,105,25,89,57,121,5,69,37,101,21,85,53,117,13,77,45,109,29,93,61, 125,3,67,35,99,19,83,51,115,11,75,43,107,27,91,59,123,7,71,39,103,23,87,55, 119,15,79,47,111,31,95,63,127}; uint8 LED[32]={0x80,0x00,0xC0,0x00,0xE0,0x00,0xF0,0x00, 0xF8,0x00,0xFC,0x00,0xFE,0x00,0xFF,0x00, 0xff,0x80,0xff,0xC0,0xff,0xE0,0xff,0xF0, 0xff,0xF8,0xff,0xFC,0xff,0xFE,0xff,0xFF,}; uint8 COUNT=15,COUNT1=0,ADC_Count=0,LINE=15,G=0,T; uint8 i,j,k,b,p,anum,led=0; int Temp_Real,Temp_Imag,temp; // 中间临时变量 uint16 TEMP1,max=0; int xdata Fft_Real[128]; int xdata Fft_Image[128]; // fft的虚部 uint8 xdata LED_TAB2[16]; //记录 漂浮物 是否需要 停顿一下 uint8 xdata LED_TAB[16]; //记录红色柱状 uint8 xdata LED_TAB1[16]; //记录 漂浮点 /////////////shop60610364.taobao.com///////// void FFT()//基2fft { for( i=1; i<=7; i++) /* for(1) */ { b=1; b <<=(i-1); //碟式运算,用于计算隔多少行计算例如 第一极 1和2行计算 for( j=0; j<=b-1; j++) /* for (2) */ { p=1; p <<= (7-i); p = p*j; for( k=j; k<128; k=k+2*b) /* for (3) */ { Temp_Real=Fft_Real[k]; Temp_Imag=Fft_Image[k]; temp=Fft_Real[k+b]; Fft_Real[k]=Fft_Real[k]+((Fft_Real[k+b]*COS_TAB[p])>>7)+((Fft_Image[k+b]*SIN_TAB[p])>>7); Fft_Image[k]=Fft_Image[k]-((Fft_Real[k+b]*SIN_TAB[p])>>7)+((Fft_Image[k+b]*COS_TAB[p])>>7); Fft_Real[k+b]=Temp_Real-((Fft_Real[k+b]*COS_TAB[p])>>7)-((Fft_Image[k+b]*SIN_TAB[p])>>7); Fft_Image[k+b]=Temp_Imag+((temp*SIN_TAB[p])>>7)-((Fft_Image[k+b]*COS_TAB[p])>>7); // 移位.防止溢出. 结果已经是本值的 1/64 Fft_Real[k] >>= 1; Fft_Image[k] >>= 1; Fft_Real[k+b] >>= 1; Fft_Image[k+b] >>= 1; } } } for(j=0;j<16;j++)//16分频 { TEMP1=((((Fft_Real[j+1]* Fft_Real[j+1]))+((Fft_Image[j+1]*Fft_Image[j+1])))>>1);//求各频段幅值 if(TEMP1<1)TEMP1=0; LED_TAB[j]=TEMP1; if(LED_TAB[j]>max)max=LED_TAB[j]; } if(max>16)//分级量化 { max/=16; for(j=0;j<16;j++)LED_TAB[j]/=max; } } [/mw_shl_code]

???

FFT部分.rar

46.72 KB, 下载次数: 130

正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

88

主题

7377

帖子

5

精华

资深版主

Rank: 8Rank: 8

积分
14980
金钱
14980
注册时间
2013-11-13
在线时间
1823 小时
发表于 2015-5-13 09:58:37 | 显示全部楼层
程序移植主要是程序思维和算法的移植,前提是要把上面的代码看懂。
开往春天的手扶拖拉机
回复

使用道具 举报

1

主题

2

帖子

0

精华

新手入门

积分
26
金钱
26
注册时间
2015-4-12
在线时间
0 小时
 楼主| 发表于 2015-5-13 20:24:22 | 显示全部楼层
回复【2楼】zuozhongkai:
--------------------------
谢谢!但我现在程序还没看懂,算法不熟悉。
回复

使用道具 举报

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

本版积分规则



关闭

原子哥极力推荐上一条 /2 下一条

正点原子公众号

QQ|手机版|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2025-4-20 11:09

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

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