Matlab|基于改進鯨魚優化算法的微網系統能量優化管理matlab-源碼

目錄

一、主要內容

二、部分代碼

三、運行結果

四、下載鏈接


一、主要內容

該程序為《基于改進鯨魚優化算法的微網系統能量優化管理》源碼,主要內容如下:

針對包含多種可再生能源的冷熱電聯供型微網系統的能量優化問題,為了優化其運行過程的經濟效益和環境效益,本文提出一種基于改進鯨魚優化算法的多時間尺度下能量優化方法,首先根據長短期記憶網絡(Long Short Term Memory,LSTM)預測得到的可再生能源出力和負荷需求預先制定調度規劃,然后以此預測數據為基礎,采用改進鯨魚優化算法調整可控設備出力,優化微網系統的運行成本和固定成本。將該方法應用于某樓宇冷熱電聯供型微網,結果表明,在滿足負荷需求的基礎上使得經濟成本平均降低4.03%且經濟效益更優。

1?冷熱電聯供型微網系統

冷熱電聯供型微網系統主要提供冷、熱、電三種形式的能量,可實現能源的綜合利用和高效利用。本文所研究的CCHP系統主要包括光伏發電系統、風力發電系統、聯供單元、儲能系統、燃氣輪機等設備,如圖1所示。

2?長短期記憶網絡(Long Short Term Memory, LSTM)

長短期記憶網絡(Long Short Term Memory, LSTM作為一種特殊的循環神經網絡(Recurrent neural network, RNN),主要用于解決長序列訓練過程中的梯度消失和梯度爆炸問題。典型的LSTM結構如圖2所示。

3?改進鯨魚優化算法

鯨魚優化算法(The Whale Optimization Algorithm,WOA)[13-14]是受到鯨魚在海底運用氣泡捕食法捕食的啟發而發明的一種優化算法,主要包含兩個階段:圍捕階段和氣泡捕食階段。

二、部分代碼

% 對訓練數據和測試數據進行分區,序列的前%90用于訓練,后10%用于測試
% numTimeSteosTrain = floor(0.9*numel(data(:,1)));
% 選取最后的24個數據作為測試數據,前面的數據均為訓練數據
numTimeSteosTrain = 719;dataTrain = data(1:numTimeSteosTrain,:);
dataTest = data(numTimeSteosTrain+1:end,:);% 標準化數據
mu = mean(dataTrain,1);
sig = std(dataTrain,1);dataTrainStandardized = (dataTrain - mu) ./ sig;% 準備預測變量和響應
XTrain = dataTrainStandardized(1:end-1,:);
YTrain = dataTrainStandardized(2:end,:);% 定義LSTM網絡
numFeatures = 6;
numResponses = 6;
numHiddenUnits = 200;layers = [ ...sequenceInputLayer(numFeatures)lstmLayer(numHiddenUnits)fullyConnectedLayer(numResponses)regressionLayer];options = trainingOptions('adam', ...'MaxEpochs',500, ...'GradientThreshold',1, ...'InitialLearnRate',0.005, ...'LearnRateSchedule','piecewise', ...'LearnRateDropPeriod',125, ...'LearnRateDropFactor',0.2, ...'Verbose',0, ...'Plots','training-progress');% 訓練LSTM網絡
net = trainNetwork(XTrain',YTrain',layers,options);% 預測將來時間步
dataTestStandardized = (dataTest - mu) ./ sig;

三、運行結果

四、下載鏈接

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/diannao/41206.shtml
繁體地址,請注明出處:http://hk.pswp.cn/diannao/41206.shtml
英文地址,請注明出處:http://en.pswp.cn/diannao/41206.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

中級職稱如何查詢真假呢?

關于中級職稱如何查詢真假,大家都會有疑問,辦到職稱的人員肯定是想查一查手里的證書,那么沒有證書的人員也想了解一下,今天甘建二告訴大家幾個通俗的職稱查詢方式: 1.電話查詢(以前辦理職稱是這種查詢方式…

20W+喜愛的Pathview網頁版 | 整合表達譜數據KEGG通路可視化

Pathview網站簡介 網址:https://pathview.uncc.edu/ 前段時間介紹了一個R包 — Pathview。它可以整合表達譜數據并可視化KEGG通路,操作是先自動下載KEGG官網上的通路圖,然后整合輸入數據對通路圖進行再次渲染。從而對KEGG通路圖進行一定程度…

uniapp+nodejs實現小程序支付

1.準備商戶號、企業級小程序(或者個體工商戶級別的) 2.在小程序端調用uni.login獲取code,傳遞給后端 uni.login({success: loginRes > {uni.request({url: "http://127.0.0.1:3003/wxpay/pay",data: {code: loginRes.code},method: "get",…

RedHat9 | kickstart無人值守批量安裝

一、知識補充 kickstart Kickstart是一種用于Linux系統安裝的自動化工具,它通過一個名為ks.cfg的配置文件來定義Linux安裝過程中的各種參數和設置。 kickstart的工作原理 Kickstart的工作原理是通過記錄典型的安裝過程中所需人工干預填寫的各種參數,…

漏洞分析 | PHP CGI Windows平臺遠程代碼執行漏洞(CVE-2024-4577)

漏洞概述 PHP CGI(Common Gateway Interface)是在Windows平臺上運行PHP的一種方式。CGI是一種標準接口,允許Web服務器與外部應用程序(如PHP腳本)進行交互,從而生成動態網頁內容。 近期,PHP發布…

Request safe_get 小工具

接口安全獲取請求參數小工具( python) flask import logging import traceback from flask import (Blueprint, request, Response, jsonify, g, send_file)def safe_get(req: request, attr: str, defaultNone):try:if attr in req.form:return req.f…

拍攝泡咖啡的劇本!

泡咖啡的過程可以是一種放松和享受的儀式,同時也是一個記錄生活美好瞬間的好機會。以下是一些步驟和提示,幫助您記錄泡咖啡的過程: 1. **準備材料**: 確保您有新鮮的咖啡豆、磨豆機、咖啡壺、濾紙、熱水和杯子。 2. **選擇音樂**&…

Logstash安裝插件失敗的問題

Logstash安裝插件失敗的問題 安裝 logstash-output-jdbc 失敗 報錯為: Unable to download data from https://rubygems.org - Net::OpenTimeout: Failed to open TCP connection to rubygems.org:443 (execution expired) (https://rubygems.org/latest_specs.4.…

【算法 - 哈希表】兩數之和

這里寫自定義目錄標題 兩數之和題目解析思路解法一 :暴力枚舉 依次遍歷解法二 :使用哈希表來做優化 核心邏輯為什么之前的暴力枚舉策略不太好用了?所以,這就是 這道題選擇 固定一個數,再與其前面的數逐一對比完后&…

Linux系統(CentOS)安裝iptables防火墻

1,先檢查是否安裝了iptables 檢查安裝文件-執行命令:rpm -qa|grep iptables 檢查安裝文件-執行命令:service iptables status 2,如果安裝了就卸裝(iptables-1.4.21-35.el7.x86_64 是上面命令查出來的版本) 執行命令&#xff1a…

藍牙信標和藍牙標簽我們如何區分,區分方法有哪些?

藍牙信標和藍牙標簽其實是兩種不同的技術,很多人可能會把藍牙信標和藍牙標簽搞混,因為區分不開來,但實際上,區分這兩種技術也很簡單,因為它們各自都有不一樣的特性,通過這些特性,我們也能正常區…

相機光學(二十四)——CRA角度

CRA角度 0.參考資料1.什么是CRA角度2.為什么 CRA 會導致luma shading3.為什么 CRA 會導致color shading4.CRA相差過大的具體表現5.CRA Matching6.怎樣選擇sensor的CRA 0.參考資料 1.芯片CRA角度與鏡頭的匹配關系(一) ??2.芯片CRA角度與鏡頭選型的匹配關…

爬蟲進階:Selenium與Ajax的無縫集成

爬蟲與Ajax的挑戰 Ajax(Asynchronous JavaScript and XML)允許網頁在不重新加載整個頁面的情況下與服務器交換數據并更新部分內容。這為用戶帶來了更好的體驗,但同時也使得爬蟲在抓取數據時面臨以下挑戰: 動態內容加載&#xff…

go語言 函數和包

go語言 函數和包 一、函數 在Go語言中,函數是執行特定任務的自包含代碼塊。 1.函數的定義 函數通過func關鍵字定義,格式如下: func 函數名(形參 形參類型, 形參 形參類型) 返回值類型 {函數體return 返回值 }2.基礎函數類型 無參數無返回…

vue中數組出現__ob__: Observer屬性,導致不能正確使用問題解決

直接上圖,如下圖,數組中出現__ob__: Observer屬性,導致無法取值。 解決方案為:JSON.parse(JSON.stringify(數組變量名))深拷貝數組,重新生成一個可枚舉數組。 // 處理代碼如let tempIds JSON.parse(JSON.stringify(i…

一文帶你初探FreeRTOS信號量

本文記錄我初步學習FreeRTOS的信號量的知識,在此記錄分享,希望我的分享對你有所幫助! 什么是信號量 在FreeRTOS中,信號量(Semaphore)是一種用于任務間同步和資源共享的機制。信號量主要用于管理對共享資源的…

Cgi上傳文件 注意事項

//核心代碼 ofstream outfile("/opt/software/" file.getFilename(), ios::out | ios::binary); outfile << file.getData(); //錯誤方式&#xff1a;outfile << file.getData() <<endl; outfile.close(); 參考博客&#xff1a; https://blog.cs…

GNU/Linux - 各種包管理器介紹

Linux 包管理器根據不同的發行版和包管理系統有所不同。以下是一些常見的 Linux 包管理器&#xff1a; 1. RPM (Red Hat Package Manager) * 用于&#xff1a; Red Hat Enterprise Linux (RHEL), Fedora, CentOS, openSUSE * 包管理器&#xff1a; rpm, yum, dnf 2. DEB (Deb…

HTML如何在圖片上添加文字

HTML如何在圖片上添加文字 當我們開發一個頁面&#xff0c;插入圖片時&#xff0c;需要有一組文字對圖片進行描述。那么HTML中如何在圖片上添加文字呢&#xff1f;這篇文章告訴你。 先讓我們來看下效果圖&#xff1a; 句子“這是一張夜空圖片”被放置在了圖片的左下角。 那么…

Leetcode.342 4的冪

給定一個整數&#xff0c;寫一個函數來判斷它是否是 4 的冪次方。如果是&#xff0c;返回 true &#xff1b;否則&#xff0c;返回 false 。 整數 n 是 4 的冪次方需滿足&#xff1a;存在整數 x 使得 n 4x 示例 1&#xff1a; 輸入&#xff1a;n 16 輸出&#xff1a;true示…