求MPPT(太阳能最大功率点跟踪)扰动法算法的完整源程序,最好是基于avr编程的。 20

 我来答
匿名用户
2011-05-24
展开全部
*关于频率和占空比的确定,对于6M晶振,假定PWM输出频率为1KHZ,;这样可以设定占空比可从(1-100)%变化,即0.01ms*100=1ms。周期用T1定时,输出高电平用T1定时。 *
#include <REGX51.H>
#define uchar unsigned char
#define V_TH1 0XFE
#define V_TL1 0X0C
#define V_TMOD 0X11
void init_sys(void); /*系统初始化函数*/
unsigned char ZL,ZH;
void main (void)
{
init_sys();
while(1)
{
Unsigned Int temp;
int16 zkb=50;
Temp =2^16-5*zkb;
ZH = temp/256;
ZL = temp%256;
K();
}
}
void init_sys(void) /*系统初始化函数*/
{
TMOD=V_TMOD; /*定时器初化*/
TH0=ZH;
TL0=ZL;
TH1 = V_TH1;
TL1= V_TL1;
TR1 = 1;
ET1 = 1;
ET0=1; /*允许T0中断
EA=1; /*CPU开中断
}
Void k(int16 vk,ik)
{ static int16 prek;
pk=vk*ik;
prek=0;
vk=0;
if(prvpk==pk)
{
return;
}
else
{
if(pk>prepk)
{ prek=pk;
if(vk>prevk)
{
zkb++;
prevk=vk;
prepk=pk;
}
else
{
zkb--;
prevk=vk;
prepk=pk;
}
}
else
{
if(vk>prevk)
{
zkb++;
prevk=vk;
prepk=pk;
}
else
{
zkb--;
prevk=vk;
prepk=pk;
}
}

/*中断函数*/
void timer0(void) interrupt 1
{
P2_2=! P2_2;
TR0 = 0;
}
Void timer1(void) interrupt 2
{
TH1 = V_TH1; /*恢复定时器T0初始值*/
TL1 = V_TL1;
P2_2=! P2_2;
TH0=ZH; /*恢复定时器T0初始值*/
TL0=ZL;
TR0 = 1;
}
百度网友a78899f8c
2011-05-23 · TA获得超过2763个赞
知道大有可为答主
回答量:782
采纳率:50%
帮助的人:764万
展开全部
采集电压和电流,分别计为Current和Voltage

MPPT_Old=Current*Vlotage;
MPPT_New=Current*Vlotage;
if(MPPT_Old<MPPT_New)
{
MPPT=MPPT_New;
}
else
{
MPPT=MPPT_Old;
}
....
.....
return(MPPT_parameter)

我* 我20号回答的怎么22号又多了一个?
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式