MPPT工作流程及算法和硬件的选择
目前,MPPT算法有开路电压比率(离线)、短路电流比率(离线)、观察调节(在线)、极限追踪控制法(在线)。
在光伏控制系统中,因为日照、温度等条件的变化,光伏电池的输出功率也是在不断变化的,为保证使得光伏电池的输出功率保持在最大点,需要调整光伏电池输出电压(日照强度发生变化时,短路电流变化大,开路电压受影响小;环境温度发生变化时,短路电流受影响小,开路电压变化大)。另外,光伏电池的输出电压和电流也和负载有很大关系,负载大,输出电压大,输出电流小;负载小,输出电压小,输出电流大。光伏电池的MPP中的电压是指光伏电池的输出电压。
开路电压比率法——这可以说是非常经典也相当古老的方法了,又名“固定电压法”。简单来说,算法基于最大功率电压和开路电压的线性关系式 ,系数 取值由设计师决定,一般介于0.71到0.78之间,大多数设定为0.76。
MPPT在追踪时,首先开路DC端来测量开路电压,然后通过算法来计算最大功率电压并且定位最大功率点。MPPT会保持在该功率点一段时间,然后重复开路测算并且重新定位。
固定电压法的最大优点就是制作便宜并且应用简单。相反,缺点也十分明显:精确值和追踪效率较低。尽管固定电压法被称之为“追踪”算法,事实上它依然是在整个工作循环中的一个计算设定值而非即时追踪值。
其次,此方法完全且单纯依赖于组串的开路电压值而放弃了对于工作电流的追踪。当局部阴影出现在阵列时,实际最大功率点和MPPT设定功率点就会出现相当大的偏差,偏差范围取决于阴影遮盖程度。最后,每次机器进行开路电压测量时,太阳能系统是无法输出功率的,随着时间和次数累计此算法会造成一定量的能量流失。总体来说,差评。
短路电流比率法——和固定电压法的算法相似,可以表述为 , 是一个变量系数,通常变化范围在0.78至0.92。
和固定电压法不同的是,短路电流比率法要求在转换器内置一个高频开关来测量短路电流。比较推荐的是在组串和DC link的电容之间安装一个FET(field-effect transistor)。由于电流受到光照强度的影响非常大,通常机器还需要一个DSP(digital signal processor)来保证IV曲线的全扫描和数据的准确度。这也让短路电流比率法设计更加复杂且难以应用。差评。
观察调节法——站在巨人肩头发展出来的算法你敢不服?目前,P&O依然应用在世界各大主流的逆变器中也是最广泛的被应用的算法,没有之一。
相比于ESC,P&O可以在更短的时间内追踪时触碰更大的区域,扫描更多地数据。这进一步提高了P&O的追踪效率和准确率。由于它在短时间内可以处理大量的数据,这也一定程度抵制了突变光照强度对于追踪精确度的影响。
缺点的话,由于它扫描的范围较大,会一定程度的导致输出功率缺乏稳定性,但是抖动程度基本都在±4%以内。所以我还要给它32个赞!P&O还有一个姐妹版本,还是“爬山”逻辑,但是并入了“试错”法(trial and error)。处理器会根据下一刻追踪点的移动趋势,比较功率的正增量或负增量。如果功率持续增加,处理器将会继续同方向移动追踪点,不停比较直到功率达到峰值。
极限追踪控制法——该算法第一次提出在19世纪20年代,也是目前全球最流行的“观测调节法”(Perturb and Observe)的前身。算法的创新点是引入了向量在P-V曲线中。处理器根据电压的增量或减量来比较对应的功率增减量,进而确定追踪功率点的移动方向。具体判定方法请参照图二,一目了然。
ESC算法的巨大成功是相比于之前的固定电压法,通过渐进向量引入了“爬山法”的概念,进而开启了动态追踪的算法。
ESC极大地拓宽了MPPT对于DC端输入能量的捕捉,显著地提高了追踪效率。由于ESC对于后代MPPT算法的影响深远,导致它的短板也一并被继承下来并至今“祸害”众多一线品牌的逆变器。ESC对于陡然变化的光照反应强烈,举个通俗例子,MPPT正专注的比较着功率和电压的变量,“嗯,正向移动的电压同步伴随着功率的增加,明显最大功率点还在正向(右边),那我继续向右移动”。
此时云层挡住了阳光,稍稍影响了输入的直流功率,使之略微下降,“慢着!正向移动的电压竟然导致功率减小了!我肯定错过了最大功率点,快掉头!”
于是,追踪点就离它的归宿越来越远的地方飘去。。。我在实验室模拟测试时,亲眼看到最多达到70%左右的偏差。基于ESC这种一级(first stage)追踪的设计理念,这种现象,无解。但是欣赏它对后世的正面影响以及理念创新,还是好评!
综合考虑,MPPT的算法采用极限追踪控制法来进行软件实现,即采集PN侧电压、流向PN侧的电流数据,计算 和 判断 与 的关系, 大于 ,此时应按 减小PN侧的目标电压;若 小于 ,此时应按 增加PN侧的目标电压。
MPPT硬件选择
MPPT的实现是通过调节光伏电池输出电压来实现的,若光伏电池输出电压直接连接到DC/AC的PN侧,那么光伏电池输出电压波动就会直接影响PN侧电压,最好是在光伏电池和DC/AC之间加一个中间环节,通过这个中间环节来调整输入电压,保持输出电压稳定,增加或减小输出电流。这个功能一般有BUCK、BOOST、BUCK-BOOST、CUK电路和开关电路可以选择,但BUCK电路是连续向负载供电、间接从电源取电;BOOST电路时间接向负载供电、连续从电源取电,为保证光伏电池板的发电效率得到较好使用,一般选择BOOST电路来实现MPPT。
选择BOOST电路来实现MPPT算法,其结构拓扑如下图。
考虑成本问题,再加上光伏电池输出的所有最大功率点对应的输出电压差别不是很大,MPPT不使用DC/DC电路来实现,在现有的DC/AC平台上进行实现。
MPPT程序实现
变流器的工作流程为:
启动——预充电——PN侧抬压——接入光伏电池——输出(MPPT)。
可以确定,MPPT的作用是在电压环上作用,并且是在变流器进入工作状态后开始工作。
采用现有的DC/AC平台来实现MPPT,存在两个问题:控制步长(时间间隔)问题、扰动步长 问题、判断精度问题。
控制步长问题——PN侧电压在MPPT过程中会产生一定的波动,但因为对于光伏电池来说(结合下面两图),其最大功率点对应的电压大致都在一个不大的范围内,并且都接近开路电压,所以,对于在DC/AC上实现MPPT,要考虑多长时间对PN侧目标电压进行一次更新。目前State Manage函数是0.1ms进入一次,可以考虑MPPT的控制步长为0.2~0.5ms,步长暂定为0.3ms。
相同光照、不同温度
相同温度,不同光照
扰动步长问题——考虑在变流器进入工作状态后,其PN侧电压为较稳定的值,即使光照强度、环境温度发生变化,光伏电池的最大功率点电压的变动范围不会很大。根据其采集回来的PN侧电压和光伏电池输出电流,并计算和前一时刻的功率差值 ,根据电导增量法进行判断,然后在目标跟踪电压上增加或减小一定的步长 。因为在光伏电池开始工作后,PN侧电压不是从0开始的,而是在光伏电池最大功率点对应电压附近,所以 的值会比较小,K值的设置通过调试程序获得,K暂定为5。
判断精度问题——由导纳法的工作流程图(下图)可以知道,在流程中存在 、 与0的关系的判断,程序中总是会存在误差,并且检测中也会存在,如果以0为判断准值,考虑实际应用中的误差因素,用一个小的阀值来替代0。阀值暂定为0.1V和0.1A。
MPPT算法C程序实现
#include "16F877.h"
#device ADC = 8 // 一个8位寄存器ADC模式
#fuses HS, NOWDT, PUT, NOPROTECT, BROWNOUT, NODEBUG, NOLVP // High-Speed 20MHz, No Watchdog, No Protection, Brownout Protection,
#use delay(clock=20000000) // 20MHz Crystal
//int is defined as 8-bit unsigned integer using CCS compiler
void main (void)
{
signed int direction;
int delta;
int pwm;
int upperbound;
int lowerbound;
float power;
float powerold;
float voltage;
float voltagedrop;
float voltagedifference;
float currentma;
float measuredvoltage;
float measuredvoltagedrop;
direction = 1; // Set initial direction to positive
delta = 1; // Amount by which to adjust the PWM - 7-bit resolution so duty step of 2%
pwm = 26; // Initial position of the PWM - 50% Duty Cycle with 7-bit resolution.
upperbound = 49; // Upper bound of the PWM %
lowerbound = 1; // Lower bound of the PWM %
power = 0; // Initial Value of Power
setup_adc(ADC_CLOCK_DIV_32); // ADC clock
setup_adc_ports(ALL_ANALOG); // Set all inputs to analog
output_low(PIN_C1); // Set CCP1 output low
setup_ccp1(ccp_pwm); // setup pin CCP1 (RC2) to do PWM
setup_timer_2(T2_DIV_BY_1,12,1); // 384.615kHz
while (1)
{
//delay_ms(1000) // Wait 1 Second
set_adc_channel(0); // Select RA0
//delay_ms(20); // Wait to Read ADC
measuredvoltage = read_adc(); // Read the voltage input from ADC channel 0
set_adc_channel(1); // Select RA1
//delay_ms(20); // Wait to Read ADC
measuredvoltagedrop = read_adc(); // Read the Voltage dropped across the R from ADC channel 1
voltage = measuredvoltage/51; // Measured Voltage is 51 steps per Volt at a Reference Voltage of 5V
voltagedrop = measuredvoltagedrop/51;
voltagedifference = voltage - voltagedrop;
currentma = voltagedifference; // Calculating Current using 1K Resistance
powerold = power; // Calculate the Power from the inputs
power = voltage * currentma;
pwm = pwm + direction*delta; // Adjust Pulse Width Modulation Value by Delta value
if (power < powerold) // If at top of curve, change direction
{
direction = -direction;
continue;
}
if (pwm > upperbound) // If at maximum PWM, Stop here
{
pwm = upperbound;
continue;
}
if (pwm < lowerbound) // If at mi
nimum PWM, Stop here
{
pwm = lowerbound;
continue;
}
set_pwm1_duty(pwm); // Set PWM Mark-Space Radio to approx 50%
}
}
嵌入式物联网需要学的东西真的非常多,千万不要学错了路线和内容,导致工资要不上去!
无偿分享大家一个资料包,差不多150多G。里面学习内容、面经、项目都比较新也比较全!某鱼上买估计至少要好几十。(点击找小助理领取)
相关文章:

MPPT工作流程及算法和硬件的选择
MPPT算法选择 目前,MPPT算法有开路电压比率(离线)、短路电流比率(离线)、观察调节(在线)、极限追踪控制法(在线)。 在光伏控制系统中,因为日照、温度等条件的变化,光伏电池的输出功率也是在不断变化的,为保证使得光伏电池的输出功…...

C#,《小白学程序》第十九课:随机数(Random)第六,随机生成任意长度的大数(BigInteger)
1 文本格式 using System; using System.Linq; using System.Text; using System.Collections.Generic; /// <summary> /// 大数的(加减乘除)四则运算、阶乘运算 /// 乘法计算包括小学生算法、Karatsuba和Toom-Cook3算法 /// 除法运算为 Truffer…...

每日一练【移动零】
一、题目描述 283. 移动零 - 力扣(LeetCode) 给定一个数组 nums,编写一个函数将所有 0 移动到数组的末尾,同时保持非零元素的相对顺序。 请注意 ,必须在不复制数组的情况下原地对数组进行操作。 二、题目解析 可以…...

QT修改windowTitle的名字以及图片
1.修改名字:点击ui的QMainWindow,然后找到windowTitle的选项修改即可 2.修改windowTitle的图片,依旧是找到windowIcon,选择资源,这个资源可以是你放到qrc里面的图片也可以是外置的图片 3.然后运行就可以看到效果了...

C语言-指针讲解(3)
文章目录 1.字符指针变量1.1 字符指针变量类型是什么1.2字符指针变量的两种使用方法:1.3字符指针笔试题讲解1.3.1 代码解剖 2.数组指针变量2.1 什么是数组指针2.2 数组指针变量是什么?2.2.3 数组指针变量的举例 2.3数组指针和指针数组的区别是什么&#…...

慢 SQL 分析及优化
目录 分析慢 SQL SQL 优化 单表优化 多表优化 慢 SQL:指 MySQL 中执行比较慢的 SQL排查慢 SQL 最常用的方法:通过慢查询日志来查找慢 SQL MySQL 的慢查询日志是 MySQL 提供的一种日志记录,它用来记录在 MySQL 中响应时间超过阈值的语句&…...
PTA:计算m到n之间所有素数的和
题目 计算m到n之间所有素数的和,其中 2 < m <n <100 输入格式: 请在这里写输入格式。例如:输入两个正整数 输出格式: 请在这里描述输出格式。例如:输出两个正整数之间的素数和。 样例 输入样例: 在这里给出一组输入。例如&…...
Golang实现YOLO:高性能目标检测算法
引言 目标检测是计算机视觉领域的重要任务,它不仅可以识别图像中的物体,还可以标记出物体的位置和边界框。YOLO(You Only Look Once)是一种先进的目标检测算法,以其高精度和实时性而闻名。本文将介绍如何使用Golang实…...
文档 + 模型
文档 模型 0: 基于MATLAB的soc锂电池系统设计 1: 电力系统继电保护仿真设计-毕业论文 2: 继电保护仿真-三段式电流保护的方案设计及分析-相间短路 3: 直流电机双闭环控制系统 转速电流双闭环调速 4: matlab电力系统继电保护仿真 三段电流保护仿真-双侧电源系统 5: OFDM-MIMO课…...

计算机毕业设计php+bootstrap小区物业管理系统
意义:随着我国经济的发展和人们生活水平的提高,住宅小区已经成为人们居住的主流,人们生活质量提高的同时,对小区物业管理的要求也越来越高,诸如对小区的维修维护,甚至对各项投诉都要求小区管理者做得好&…...

Osg线程模型(选择不当,会引发崩溃)
来自《最长的一帧》...

2161根据数字划分数组
给你一个下标从 0 开始的整数数组 nums 和一个整数 pivot 。请你将 nums 重新排列,使得以下条件均成立: 所有小于 pivot 的元素都出现在所有大于 pivot 的元素 之前 。所有等于 pivot 的元素都出现在小于和大于 pivot 的元素 中间 。小于 pivot 的元素之…...

Oracle Linux 9.3 发布
导读Oracle Linux 9 系列发布了第 3 个版本更新,支持 64 位 Intel 和 AMD (x86_64) 以及 64 位 Arm (aarch64) 平台。与所有的 Oracle Linux 版本一样,此版本与相应 RHEL 版本 100% 应用二进制兼容。 对于 x86_64 和 aarch64 架构,Oracle Li…...
XML Schema中的simpleContent 元素
XML Schema中的simpleContent 元素出现在complexType 内部,是对complexType 的一种扩展、或者限制。 simpleContent 元素在complexType元素内部最多只能出现1次。 simpleContent元素下面必须包含1个restriction或者extension元素。 例如,下面的Schema片…...

线性分类器--分类模型
记录学习 北京邮电大学计算机学院 鲁鹏 为什么从线性分类器开始? 形式简单、易于理解 通过层级结构(神经网络)或者高维映射(支撑向量机)可以 形成功能强大的非线性模型 什么是线性分类器? 线性分…...

【开源】基于Vue和SpringBoot的企业项目合同信息系统
项目编号: S 046 ,文末获取源码。 \color{red}{项目编号:S046,文末获取源码。} 项目编号:S046,文末获取源码。 目录 一、摘要1.1 项目介绍1.2 项目录屏 二、功能模块2.1 数据中心模块2.2 合同审批模块2.3 合…...
指针数组用指针变量模拟二维数组
指针数组 指针数组是指针还是数组?? 整型数组:数组中的每个元素都是整型 字符数组:数组中的每个元素都是字符 指针数组:数组中的每个元素都是指针 #include<stdio.h> int main() { int a 10; int* …...

接口文档自动生成工具:详细教程和实用技巧
本篇文章详细教你如何使用 Apifox 的 IDEA 插件实现自动生成接口代码。好处简单总结有以下几点: 自动生成接口文档: 不用手写,一键点击就可以自动 生成文档,当有更新时,点击一下就可以自动同步接口文档;代…...

C语言--不创建第三个变量,实现对两个数字的交换
我们先来看一下,创建临时变量交换两个数字。 #include<stdio.h> {int a2;int b3;int tmp0;printf("before:a%d b%d\n",a,b);tmpa;ab;btmp;printf("after:a%d b%d\n",a,b);return 0; } 图解: 运行结果: 再看一下不…...
Java中的mysql——面试题+答案(数据库连接池,批处理操作)——第22期
当涉及Java中的MySQL时,面试题的范围可以涵盖更多方面,包括高级主题和实践经验。 什么是Hibernate?它与JDBC有什么区别? 答案: Hibernate是一个开源的对象关系映射(ORM)框架,它允许J…...

观成科技:隐蔽隧道工具Ligolo-ng加密流量分析
1.工具介绍 Ligolo-ng是一款由go编写的高效隧道工具,该工具基于TUN接口实现其功能,利用反向TCP/TLS连接建立一条隐蔽的通信信道,支持使用Let’s Encrypt自动生成证书。Ligolo-ng的通信隐蔽性体现在其支持多种连接方式,适应复杂网…...

Vue3 + Element Plus + TypeScript中el-transfer穿梭框组件使用详解及示例
使用详解 Element Plus 的 el-transfer 组件是一个强大的穿梭框组件,常用于在两个集合之间进行数据转移,如权限分配、数据选择等场景。下面我将详细介绍其用法并提供一个完整示例。 核心特性与用法 基本属性 v-model:绑定右侧列表的值&…...
测试markdown--肇兴
day1: 1、去程:7:04 --11:32高铁 高铁右转上售票大厅2楼,穿过候车厅下一楼,上大巴车 ¥10/人 **2、到达:**12点多到达寨子,买门票,美团/抖音:¥78人 3、中饭&a…...
Rust 异步编程
Rust 异步编程 引言 Rust 是一种系统编程语言,以其高性能、安全性以及零成本抽象而著称。在多核处理器成为主流的今天,异步编程成为了一种提高应用性能、优化资源利用的有效手段。本文将深入探讨 Rust 异步编程的核心概念、常用库以及最佳实践。 异步编程基础 什么是异步…...

让AI看见世界:MCP协议与服务器的工作原理
让AI看见世界:MCP协议与服务器的工作原理 MCP(Model Context Protocol)是一种创新的通信协议,旨在让大型语言模型能够安全、高效地与外部资源进行交互。在AI技术快速发展的今天,MCP正成为连接AI与现实世界的重要桥梁。…...

面向无人机海岸带生态系统监测的语义分割基准数据集
描述:海岸带生态系统的监测是维护生态平衡和可持续发展的重要任务。语义分割技术在遥感影像中的应用为海岸带生态系统的精准监测提供了有效手段。然而,目前该领域仍面临一个挑战,即缺乏公开的专门面向海岸带生态系统的语义分割基准数据集。受…...

人机融合智能 | “人智交互”跨学科新领域
本文系统地提出基于“以人为中心AI(HCAI)”理念的人-人工智能交互(人智交互)这一跨学科新领域及框架,定义人智交互领域的理念、基本理论和关键问题、方法、开发流程和参与团队等,阐述提出人智交互新领域的意义。然后,提出人智交互研究的三种新范式取向以及它们的意义。最后,总结…...

Linux 中如何提取压缩文件 ?
Linux 是一种流行的开源操作系统,它提供了许多工具来管理、压缩和解压缩文件。压缩文件有助于节省存储空间,使数据传输更快。本指南将向您展示如何在 Linux 中提取不同类型的压缩文件。 1. Unpacking ZIP Files ZIP 文件是非常常见的,要在 …...

云原生安全实战:API网关Kong的鉴权与限流详解
🔥「炎码工坊」技术弹药已装填! 点击关注 → 解锁工业级干货【工具实测|项目避坑|源码燃烧指南】 一、基础概念 1. API网关(API Gateway) API网关是微服务架构中的核心组件,负责统一管理所有API的流量入口。它像一座…...

CMS内容管理系统的设计与实现:多站点模式的实现
在一套内容管理系统中,其实有很多站点,比如企业门户网站,产品手册,知识帮助手册等,因此会需要多个站点,甚至PC、mobile、ipad各有一个站点。 每个站点关联的有站点所在目录及所属的域名。 一、站点表设计…...