【微电网_储能】基于启发式状态机策略和线性程序策略优化方法的微电网中的储能研究【给定系统约束和定价的情况下】(Matlab代码实现)

news/2024/6/17 17:00:39 标签: matlab, 开发语言
👨‍🎓 个人主页: 研学社的博客
💥 💥 💞 💞 欢迎来到本博客 ❤️ ❤️ 💥 💥


🏆 博主优势: 🌞 🌞 🌞博客内容尽量做到思维缜密,逻辑清晰,为了方便读者。


座右铭:行百里者,半于九十。

📋 📋 📋 本文目录如下: 🎁 🎁 🎁
目录
💥1 概述
📚2 运行结果
🎉3 参考文献
🌈4 Matlab代码实现

💥1 概述

能源管理系统(EMS)有助于优化微电网中分布式能源(DER)的使用,特别是在涉及可变定价和发电时。本文使用预测定价和负荷条件来优化存储/销售来自电网规模电池系统的能量。演示了两种方法:启发式状态机策略和基于线性程序的优化方法。

📚2 运行结果

for i = 1:numSim
    if i <= numOffset*numel(pvDataSet)
        heuristicCost(end+1) = out(i).logsout{1}.Values.Data(end);
    else
        optCost(end+1)= out(i).logsout{1}.Values.Data(end);
    end
end
histogram(heuristicCost); hold on;
histogram(optCost);
legend('Heuristic','Optimization');
xlabel('Cost per Day ($)'); hold off;

部分代码:

function [Pgrid,Pbatt,Ebatt] = battSolarOptimize(N,dt,Ppv,Pload,Einit,Cost,FinalWeight,batteryMinMax)

% Minimize the cost of power from the grid while meeting load with power

% from PV, battery and grid

prob = optimproblem;

% Decision variables

PgridV = optimvar('PgridV',N);

PbattV = optimvar('PbattV',N,'LowerBound',batteryMinMax.Pmin,'UpperBound',batteryMinMax.Pmax);

EbattV = optimvar('EbattV',N,'LowerBound',batteryMinMax.Emin,'UpperBound',batteryMinMax.Emax);

% Minimize cost of electricity from the grid

prob.ObjectiveSense = 'minimize';

prob.Objective = dt*Cost'*PgridV - FinalWeight*EbattV(N);

% Power input/output to battery

prob.Constraints.energyBalance = optimconstr(N);

prob.Constraints.energyBalance(1) = EbattV(1) == Einit;

prob.Constraints.energyBalance(2:N) = EbattV(2:N) == EbattV(1:N-1) - PbattV(1:N-1)*dt;

% Satisfy power load with power from PV, grid and battery

prob.Constraints.loadBalance = Ppv + PgridV + PbattV == Pload;

% Solve the linear program

options = optimoptions(prob.optimoptions,'Display','none');

[values,~,exitflag] = solve(prob,'Options',options);

% Parse optmization results

if exitflag <= 0

Pgrid = zeros(N,1);

Pbatt = zeros(N,1);

Ebatt = zeros(N,1);

else

Pgrid = values.PgridV;

Pbatt = values.PbattV;

Ebatt = values.EbattV;

end

🎉3 参考文献

部分理论来源于网络,如有侵权请联系删除。

[1]Jonathan LeSage (2023). Microgrid Energy Management System (EMS) using Optimization.

🌈4 Matlab代码实现


http://www.niftyadmin.cn/n/113123.html

相关文章

研报精选230302

目录 【个股230302华西证券_比亚迪】系列点评五十四&#xff1a;迪“王”需求向上 出口“海”阔天空【个股230302华西证券_华利集团】下游去库存背景下承压&#xff0c;毛利率保持稳健【个股230302开源证券_恒顺醋业】公司信息更新报告&#xff1a;四季度业绩承压&#xff0c;期…

python基础学习3--切片(slice)

在python中&#xff0c;切片&#xff08;slice&#xff09;是对序列型对象&#xff08;如list,string,tuple)的一种高级索引方法。普通索引只取出序列一个下标对应的元素&#xff0c;而切片取出序列中一个范围对应的元素&#xff0c;这里的范围不是狭义上的连续片段。通俗一点就…

CLion+Opencv+QT开发相关

一、QT安装和配置其实我并没有直接在Qt上开发&#xff0c;下载Qt而是因为&#xff1a;CLion可以通过Qt的MinGW作为Toolset&#xff0c;并且可以将Qt creator作为external tool&#xff1b;在进行Opencv的编译安装中可以用Qt自带的MinGW进行编译和安装&#xff0c;不用另外下载M…

Android 10.0 Settings 关掉开发者模式

1.概述 在系统Settings中,系统默认在关于手机里面点击五下版本号进入开发者模式,开启某些功能, 在进行项目定制中,要求去掉进入开发者模式的这个功能,就需要找到关于开启开发者模式的相关代码屏蔽掉就可以了 2.关于屏蔽掉开发者模式的相关核心代码 packages/apps/Settings…

JavaSE21-集合1-set

文章目录一、集合概念二、set集合1、set集合的特点2、HashSet2.1 特点2.2 创建对象2.3 常用方法2.4 遍历2.4.1 foreach遍历2.4.2 使用迭代器遍历2.4.3 转换为数组遍历一、集合概念 集合就是用于存储多个数据的容器。相对于具有相同功能的数组来说&#xff0c;集合的长度可变会…

今天给大家推荐一个使用Vue语法开发的统一框架,uni-app

Bunifu UI WinForms BuniCharts 与 WinForms 的 Bunifu UI 完美结合&#xff0c; webview2代替webbrowser https://juejin.cn/post/7061883110463373343 一次开发多端部署 框架 今天给大家推荐一个使用Vue语法开发的统一框架&#xff0c;uni-app uni-app&#xff0c;作者使用…

BGP 报文格式

BGP 报文格式 BGP 报文由 BGP 报头&#xff08;BGP Header&#xff09; 和 BGP 负载&#xff08;BGP Payload&#xff09; 两部分组成。 ----------------------------------------------------- | BGP Header (19 bytes) | ------------------…

OA智能办公系统功能介绍

OA智能办公系统(Office Automation Intelligent System)是一种集成了多种管理功能的办公自动化系统&#xff0c;旨在提高企业的工作效率和管理水平。以下是OA智能办公系统的功能亮点&#xff1a; 1.考勤管理&#xff1a;实现员工考勤打卡、考勤统计、迟到早退等考勤管理功能&a…