particle swarm optimization code to minimize cost function
22 views (last 30 days)
Show older comments
Help me form an objective function and possible constraints to minimize the cost function using Particle Swarm Optimization(PSO).
I have to minimize the electricity cost in a microgrid with fixed load demand for each hour (i.e. 24 hr) using PSO. The microgrid have solar generation , wind generation, Microturbine and an energy storage system. the microgrid is operating in grid connected mode so we need to consider the amount of energy bought from or sold to main grid also for this data of cost of the electricity per hr is given. the following data is available:
solar_power_available_per_hr = [0 0 0 0 0 0 0 0.2 3.75 7.525 10.45 11.95 23.9 21.05 0.315 7.875 0.55 0 0 0 0 0 0 0];
wind_power_available_per_hr = [1.785 1.785 1.785 1.785 1.785 0.915 1.785 1.305 1.785 3.09 8.775 10.41 3.915 2.37 1.785 1.305 1.785 1.785 1.305 1.785 1.305 1.305 0.915 0.615];
power_demand_from_loads_per_hr = [52 50 50 51 56 53 70 75 76 80 78 74 72 72 76 80 85 88 90 87 78 71 65 56];
electricity_price_per_kWh_during_each_hr = [0.23 0.19 0.14 0.12 0.12 0.20 0.23 0.38 1.50 4 4 4 1.5 4 2 1.95 0.6 0.41 0.35 0.43 1.17 0.54 0.30 0.26];
% P_solar: min = 0, max = 25kW;
% P_wind: min = 0, max = 15kW;
% P_microturbine: min = 6kW, max = 30kW;
% battery power: min = -30kW, max = +30kW;
% grid power: min = -30kW, max = +30kW;
battery_efficiency_considerd = 90/100 % (i.e. eta(charge or discharge)=0.9).
Below data is obtained using fuzzy logic based battery scheduling
initial_soc_considered = 86/100 % percent
Pbatt(t) = Pbatt(t-1) + 0.9*Pchar*del(t) - (1/0.9)*Pdis*del(t);
power_of_battery_charged(+)_or_discharge_per_hr = [-18.1072, 0, 0, 0, 0, 0, -18.1072, -18.4010, -18.1072, -10.3106, -10.6032, -9.6518, -9.4837, -8.2505, -9.5903, -8.9892, 19.4399, -18.8184, 12.6071, -19.0777, -16.9413, 16.9189, -17.1563, 16.4767];
Battery_SoC = [86, 65.88, 65.88, 65.88, 65.88, 65.88, 65.88, 45.76, 25.32, 5.19, 5.19, 5.19, 5.19, 5.19, 5.19, 5.19, 5.19, 26.79, 5.88, 19.89, 19.89, 1.07, 19.87, 0.81];
I have scheduled the battery so that minimum amount of power should be bought from the main grid in order to reduce the cost. and excess power can be sold to the grid when demand is low or renewable generation is high.
parameters: Bid price($/kWh) for differnt sources:
battery = 0.38;
solar = 2.584;
wind = 1.073;
microturbine = 0.457;
microturbine_startup_and_shutdown_cost = 0.96;
I am an absolute beginner in PSO. so, if you could provide the basic syntax of PSO for the above problem along with the objective function and constraints it will be really helpful.
Thanks in advance!
9 Comments
Walter Roberson
on 22 Nov 2023
the particleswarm function expects a function handle as the first parameter, and the number of variables as the second parameter. The first output for it is a vector of values that minimizes the function.
https://www.mathworks.com/help/gads/particleswarm.html
Answers (1)
Sam Chak
on 21 Nov 2023
Hi @REENA
Regarding the particleswarm() solver, I believe you can define constraints using the Problem-Based Optimization approach. However, I am accustomed to defining constraints for a collection of vectors in a single function call. If I recall correctly, only the patternsearch() and ga() solvers allow direct calling the nonlinear constraint function in their syntax.
%% Pattern Search method
x0 = [0.25, 0.6, 12.2];
patopt = optimoptions('patternsearch', 'UseCompletePoll', true, 'UseVectorized', true);
[x fval] = patternsearch(@costfun, x0, [], [], [], [], [], [], @nonlcon, patopt)
%% Genetic Algorithm method
gaopt = optimoptions('ga', 'UseVectorized', true);
lb = [0.1 0.5 12.0];
ub = [0.3 0.7 12.2];
[x fval] = ga(@costfun, 3, [], [], [], [], lb, ub, @nonlcon, gaopt)
%% multivariate Cost function to minimized
function y = costfun(x)
y = - x(:,1).^2 - x(:,2).^2 - x(:,3).^2;
end
Nonlinear constraints:
%% subject to Nonlinear constraints
function [c ceq] = nonlcon(x)
c(:,1) = x(:,1).^2/4 + x(:,2).^2/9 + x(:,3).^2/25 - 6; % inequality constraint #1
c(:,2) = cosh(x(:,1) + x(:,2)) - x(:,3); % inequality constraint #2
ceq = x(:,1).*x(:,2).*x(:,3) - 2; % equality constraint #1
end
3 Comments
Sam Chak
on 22 Nov 2023
Hi @REENA
Upon reviewing your code, I noticed the absence of MATLAB's built-in PSO optimizer (particleswarm). Since I didn't devise the PSO algorithm myself, I am unable to discern the correctness of specific lines in your user-defined algorithm.
Furthermore, I find it challenging to comprehend your constraints without annotations. They lack a mathematical representation that would facilitate understanding among scientists, engineers, and mathematicians. This is why I advocate for defining nonlinear constraints for a vector collection in a singular function call (@nonlcon), as demonstrated above.
Regardless, let's decompose this into three learning outcomes:
- Outcome 1: Minimize the cost of the battery optimization problem over the 24-hour period.
- Outcome 2: Attain Outcome #1 through the application of the PSO method.
- Outcome 3: Realize Outcome #2 by implementing a user-defined PSO algorithm.
For Outcome #1, attempt to solve the constrained optimization problem utilizing the patternsearch() and ga() solvers. Subsequently, compare the obtained results with those derived from the PSO solver.
For Outcome #2, address the optimization problem using the built-in particleswarm() solver, by transforming the constrained problem into an unconstrained one. If it yields results reasonably consistent with those obtained from patternsearch() and ga(), it suggests you are on the correct path. Additionally, consider refining the lower and upper bounds to enhance the result further.
Achieving Learning Outcome #3 poses a moderate challenge as you need to ensure the flawlessness or precise functionality of your user-defined PSO algorithm. If you attempt to directly pursue Outcome #3 without first addressing the first two learning outcomes, and even in the event that the user-defined PSO algorithm produces outputs, the ability to validate whether the algorithm genuinely identifies the minimum cost remains uncertain. Therefore, it is advisable to subject the user-defined PSO algorithm to testing, examining its optimization capabilities on both the Sphere function and the Rosenbrock function.
See Also
Categories
Find more on Particle Swarm in Help Center and File Exchange
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!