Any methods to solve optimal control indirect method such as Pontryagin Minimum Principle?

37 visualizaciones (últimos 30 días)
Hi,
I would like to solve an optimal control problem using Pontryagin Minimum Principle. There are few numerical techniques with MATLAB examples using sym toolbox, bvp4c and ODE45 using shooting method. I am trying to implement using ODE45 solver by following steps:
  1. Initialize states, co-state and control
  2. ODE45 solver in forward time to find states.
  3. ODE45 solver in backward time to find co-states
  4. Find hamiltonian and performance index. If difference between previous and present hamiltonian is below given threshold the stop iteration or else go to 5.
  5. Update the control with a selected step size.
I am facing many difficulties in implementation such as;
  1. Difficulty in selecting initial control and co-state.
  2. The state is not bounded within a range as it must be. (must be between 0 and 1, and final state must be a desired value)
I have attached the reference paper which I am trying to implement. If anyone knows any MATLAB toolbox to solve the same, kindly let me know.

Respuesta aceptada

M
M el 13 de Nov. de 2019
Editada: M el 13 de Nov. de 2019

Más respuestas (2)

Philipp Tiwald
Philipp Tiwald el 9 de Ag. de 2020
Hi,
Im trying to implement a simular optimal controll problem. Could you share your solution?

Mohamed Abdullah
Mohamed Abdullah el 17 de Mzo. de 2023
Hello Praveen, do you mind sharing your Matlab code for the Problem you have attached in the PMP-EV file?
  2 comentarios
Mohamed Abdullah
Mohamed Abdullah el 19 de Mzo. de 2023
Thank you very much. I have a question about the second link. I downloaded the zipped file but it appears to me that it contains only measured data not the algorithms itself.

Iniciar sesión para comentar.

Categorías

Más información sobre Partial Differential Equation Toolbox en Help Center y File Exchange.

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by