Optimize cost function to obtain optimal value of the optimization variable.
21 ビュー (過去 30 日間)
古いコメントを表示
The problem is to find a and b such that the cost function
is minimized. The cost function
is defined as,
data:image/s3,"s3://crabby-images/2d14c/2d14c2170215ee9df2e877655d0b9258154be1f0" alt=""
data:image/s3,"s3://crabby-images/2d14c/2d14c2170215ee9df2e877655d0b9258154be1f0" alt=""
data:image/s3,"s3://crabby-images/e16a2/e16a223fda4a2dad9d76b2d66b7a2530042094c2" alt=""
The dynamical equations are:
data:image/s3,"s3://crabby-images/85a05/85a05d4356823d5c83f458e76b81775e67ccbdab" alt=""
data:image/s3,"s3://crabby-images/37dba/37dba75ee2b6ba93cc0bf02aab416bf38ee2492c" alt=""
data:image/s3,"s3://crabby-images/8442d/8442d9af08a83ff9258e399b76fb3b2cc9adc6ac" alt=""
I tried to use the ode45 to solve the the dynamical equations but was unable to solve using the ode45 as it has a and b also as variables, which are needed to optimize the cost function. Can someone help to solve the equations by ode45 and minimize the cost function at the same time? I am trying to use fminsearch but how to use it?
0 件のコメント
採用された回答
Walter Roberson
2022 年 10 月 3 日
Create a function that accepts a and b and uses ode45() to run the system to tspan 10. Return the values of y1(end) and y2(end) for those particular a and b
Now write a caller to that function that accepts a vector of two values, a and b, runs the function mentioned above, calculates C and returns the value.
Now use fminunc() or fmincon() on that second function. The vector of coordinates that minimizes the function will be the a and b values you are looking for.
3 件のコメント
Walter Roberson
2022 年 10 月 3 日
init_ab = [0 1];
best_ab = fminunc(@cost_ab, init_ab);
a = best_ab(1); b = best_ab(2);
function cost = cost_ab(ab)
[t,y]=ode45(@(t,y) ques1(t,y,ab(1),ab(2)), [0 10], [1,2]');
cost = (y(end,1) - 1500).^2 + (y(end,2) - pi/2).^2;
end
Torsten
2022 年 10 月 3 日
init_ab = [0 1];
[best_ab,cost] = fminunc(@cost_ab, init_ab)
a = best_ab(1); b = best_ab(2);
function cost = cost_ab(ab)
ques1 = @(t,y)[cos(ab(1)+ab(2)*t)-sin(y(2));(sin(ab(1)+ab(2)*t)-cos(y(2)))/y(1)];
[t,y]=ode45(ques1, [0 10], [1,2]');
cost = (y(end,1) - 1500).^2 + (y(end,2) - pi/2).^2;
end
その他の回答 (0 件)
参考
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!