Я хотел бы написать код, чтобы найти минимальную стоимость эксплуатации посудомоечной машины. Это зависит от требуемой мощности, почасовой тарифной ставки и используемого времени. Я использую fmincon
для этого, однако приведенный ниже код показывает следующее сообщение об ошибке:
Пользовательская целевая функция должна возвращать скалярное значение
Моя цель состоит в том, чтобы минимизировать (общая стоимость * время), если общая стоимость равна суммированию (часовая мощность) * (почасовая стоимость) от 1 до 24 часов равна 0,8 кВт-ч, также общая стоимость должна быть больше, чем Ca
, и общее время работы за день составляет один час.
% Array showing the hourly electricity rates (cents per kwh)
R=zeros(24,1);
R(1:7,1)=6;
R(20:24,1)=6;
R(8:11,1)=9;
R(18:19,1)=9;
R(12:17,1)=13;
p_7 = transpose([0.8 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0]); %This is the power pattern of appliance (operates at 0.8 kWh for 1 hour daily)
for k=1:23
P7(:, k+1) = circshift(p_7,k); % This shows all the possible hours of operation
end
Total = P7*R; % This is the total cost per hour at different hourly tariffs
fun = @(x)Total.*(x);
x0 = [1];
A = Total;
%Ca = 0.5;
Ca = ones(1,24);
b = Ca;
Aeq = Total;
Daily_tot_7 = 2*ones(1,24);
beq = Daily_tot_7;
ub = 24;
lb = 1;
x = fmincon(fun,x0,A,b,Aeq,beq,lb,ub)
Я полагаю, что мое понимание о преобразовании ограничений в fmincon
неверно и что я могу упустить жизненно важные ограничения для этой проблемы.