是不是CCS的buge?
定义一个联合体:
typedef union FACTORY_TEST
{
uint16_tAll;
struct
{
uint16_t IQ_FullScale_Hz;
uint16_t IQ_FullScale_V;
uint16_t ADC_FullScale_V1; //1V为单位
uint16_t ADC_FullScale_V2; //1V为单位
}code;
}FACTORYT;
FACTORYT FactoryTest
FactoryTest.code.IQ_FullScale_V = 160;
FactoryTest.code.ADC_FullScale_V1 = 160;
_iqValue_Mb = (_iq)(FactoryTest.code.IQ_FullScale_V);
_iqValue_Ma = (_iq)(FactoryTest.code.ADC_FullScale_V1);
float_tV_a = (float_t)(Value_Ma);
float_tV_b = (float_t)(Value_Mb);
float_tValue = V_a/V_b;
运行后显示:Value = 160.0;
显然结果不是期望的·Value = 1.0
不用联合,直接用结构:
typedef struct FACTORY_TEST
{
uint16_t IQ_FullScale_Hz;
uint16_t IQ_FullScale_V;
uint16_t ADC_FullScale_V1; //1V为单位
uint16_t ADC_FullScale_V2; //1V为单位
}FACTORYT;
FACTORYT FactoryTest
FactoryTest.IQ_FullScale_V = 160;
FactoryTest.ADC_FullScale_V1 = 160;
_iqValue_Mb = (_iq)(FactoryTest.IQ_FullScale_V);
_iqValue_Ma = (_iq)(FactoryTest.ADC_FullScale_V1);
float_tV_a = (float_t)(Value_Ma);
float_tV_b = (float_t)(Value_Mb);
float_tValue = V_a/V_b;
运行后显示:Value = 1..0;
是期望的结果。
CCS 为6.2,编译器为c2000_15.12.3.LTS
dsp为 F28069M
出现这一问题的原因是什么?是否是CCS自身编译器的问题? 只能说DSP的相关数据类型比较复杂 需要好好研究
可能与VS的运行结果差距很大 嗯, 这里特别要注意一点.DSP 为了处理小数, 扩展了 _iq 这个数据类型.
这是用整数模拟的定点数. 看 _iq 的定义, 你会发现定义成了 long.
所以 _iq 的数据只有在 IQ 的运算里才是定点数, 否则是 long
因此你就不能用 (float) 做强制类型转换. 转换的结果会是错误的
页:
[1]