网站大量收购闲置独家精品文档,联系QQ:2885784924

智能电表算法分析1.docx

  1. 1、本文档共14页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
智能电表算法分析Σ-Δ ADC结构模拟调制模块功能说明 模拟输入正弦波,经过220/630的增益调整,输给减法器模块的被减数,减法器的输出积分延时模块。一路经过1/3的增益调整作为加法器的一路输入,另一路经过1/4的增益调整后积分延时,然后经过2/3的增益调整作为加法器的另外一路输入。加法器的输出经过sign模块,如果大于0输出为1,如果小于0输出为-1,如果等于0输出为0。Sign模块的输出疏密波经过44/630增益调整反馈给减法器的减数输入。Sign模块的输出疏密波输出给CIC模块。数字解调模块(CIC模块)功能说明 模拟模块输出的疏密波(1、-1)经过三次积分延时处理,然后经过1/64抽样处理, 经过三次微分延时处理,然后去掉多余的符号位,低位补5位的0,最后输出24位的带符号位的ADC数字信号。matlab仿真分析中发现CIC输出的19位信号中最低位常为0。Σ-Δ的matlab仿真程序2.1 模拟调制模块matlab仿真程序x1 = 0.16 * sin( 2 * pi * f * n * t + 0.5);for i = 1:1:numb if(i==1) x2(i) = x1(i)*220/630 + 0; else x2(i) = x1(i)*220/630 -sign( x2d(i-1)/3 + x3d(i-1)*2/3 )*44/630; end if(i==1) x2d(i) = 0; else x2d(i) = x2d(i-1) + x2(i); end if(i==1) x3d(i) = 0; else x3d(i) = x3d(i-1) + x2d(i-1)/4; end if(i==1) x4(i) = 0; else x4(i) = x2d(i-1)/3 + x3d(i-1)*2/3; end if(i==1) x5(i) = 0; else x5(i) = sign( x2d(i-1)/3 + x3d(i-1)*2/3 );endend2.2 数字解调模块(CIC)matlab仿真程序for i=1:1:numb if ( i==1) add_1(i) = 0; else add_1(i) = add_1(i-1) + in(i); endend for i=1:1:numb if ( i==1) add_2(i) = 0; else add_2(i) = add_2(i-1) + add_1(i-1); endend for i=1:1:numb if ( i==1) add_3(i) = 0; else add_3(i) = add_3(i-1) + add_2(i-1); end end for i=1:1:numb if ( i==1) add_3_reg(i) = 0; else if (wcnt_00(i)==1) add_3_reg(i) = add_3(i-1); else add_3_reg(i) = add_3_reg(i-1); end end end for i=1:1:numb if (i==1) sub_00(i) = 0; else if (wcnt_00(i)==1) sub_00(i) = add_3(i-1) - add_3_reg(i-1); else sub_00(i) = sub_00(i-1); end end if (i==1) sub_00_reg(i) = 0; else if (wcnt_00(i)==1) sub_00_reg(i) = sub_00(i-1); else sub_00_reg(i) = sub_00_reg(i-1); end end if (i==1) sub_01(i) = 0; else if (wcnt_01(i)==1) sub_01(i) = sub_00(i) - sub_00_reg(i); else sub_01(i) = sub_01(i-1); end end if (i==1) sub_01_reg(i) = 0; else if (wcnt_00(i)==1) sub_01_reg(i) = sub_01(i-1); else sub_01_reg(i) = sub_01_reg(i-1); end end if (i==1) sub_02(i) = 0; else if (wcnt_02(i)==1) sub_02(i) = sub_01(i) - sub_01_reg(i); else sub_02(i) = sub_02(i-1); e

文档评论(0)

8883320 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档