CFD Online Logo CFD Online URL
www.cfd-online.com
[Sponsors]
Home > Forums > Software User Forums > OpenFOAM > OpenFOAM Programming & Development

ODE solver in OpenFOAM

Register Blogs Community New Posts Updated Threads Search

Reply
 
LinkBack Thread Tools Search this Thread Display Modes
Old   November 14, 2023, 10:46
Post ODE solver in OpenFOAM
  #1
Senior Member
 
Join Date: Jan 2019
Posts: 125
Blog Entries: 1
Rep Power: 0
Michael@UW is on a distinguished road
Hi deal Foamers,

I have a couple of questions about the ODE solver in OpenFOAM.

Question 1:

In the file test-ODE.C


I don't see the purpose of the following two lines:
Code:
    
// Print the evolution of the solution and the time-step
    scalarField dyStart(ode.nEqns());
    ode.derivatives(xStart, yStart, dyStart);
I understand the derivatives are calculated through the function ode.derivatives and stored in dyStart, but dyStart
is never used again later.
The ODE is solved by calling the function
Code:
odeSolver->solve(x, xEnd, y, dxEst);
If we look at the solve function for an instantiated solve, e.g. RKCK45, odes_.derivatives is called there. So it makes no sense to me to call ode.derivatives above.

Question 2:
In the ODESolver.C, the following two solve functions call each other recursively, so there seems to be a dead loop. Can anyone explain how they work?

Code:
void Foam::ODESolver::solve
(
    scalar& x,
    scalarField& y,
    scalar& dxTry
) const
{
    stepState step(dxTry);
    solve(x, y, step);
    dxTry = step.dxTry;
}
 
 
void Foam::ODESolver::solve
(
    scalar& x,
    scalarField& y,
    stepState& step
) const
{
    scalar x0 = x;
    solve(x, y, step.dxTry);
    step.dxDid = x - x0;
}


Feel free to answer or discuss any of these questions. Thank you!

Michael
Michael@UW is offline   Reply With Quote

Old   November 15, 2023, 07:09
Default
  #2
Senior Member
 
Domenico Lahaye
Join Date: Dec 2013
Posts: 798
Blog Entries: 1
Rep Power: 17
dlahaye is on a distinguished road
Many thanks for raising these issues!

Q1: not sure. Possibly it helps to write down the problem more formally, as \dot{y} = f(y(x), x) supplied with initial guess y(0) = y0 and try to reason on an algorithm from here. You raise the issue of derivatives. I assume that derivatives are used by implicit algorithms only. RK45 is an explicit algorithm. Not sure whether this helps.

Q2: not sure either. It is possible that the size of the step is adapted inbetween calls of the solve function?

I am happy to discuss further.
dlahaye is offline   Reply With Quote

Old   November 15, 2023, 09:30
Default
  #3
Senior Member
 
Join Date: Jan 2019
Posts: 125
Blog Entries: 1
Rep Power: 0
Michael@UW is on a distinguished road
[QUOTE=dlahaye;860062]Many thanks for raising these issues!

Thank you for the discussion.

Quote:
Originally Posted by dlahaye View Post
Q1: not sure. Possibly it helps to write down the problem more formally, as \dot{y} = f(y(x), x) supplied with initial guess y(0) = y0 and try to reason on an algorithm from here. You raise the issue of derivatives. I assume that derivatives are used by implicit algorithms only. RK45 is an explicit algorithm. Not sure whether this helps.
It seems to make sense, for example, if we want to call
Code:
Foam::scalar Foam::Euler::solve
(
    const scalar x0,
    const scalarField& y0,
    const scalarField& dydx0,
    const scalar dx,
    scalarField& y
) const
{
    // Calculate error estimate from the change in state:
    forAll(err_, i)
    {
        err_[i] = dx*dydx0[i];
    }
 
    // Update the state
    forAll(y, i)
    {
        y[i] = y0[i] + err_[i];
    }
 
    return normalizeError(y0, y, err_);
}
directly which requires the derivatives dydx0, of course we also need to specify the solver type (Euler) explicitly.

By contrast, if we call
Code:
void Foam::Euler::solve
(
    scalar& x,
    scalarField& y,
    scalar& dxTry
) const
{
    adaptiveSolver::solve(odes_, x, y, dxTry);
}
which will eventually call the first solve function, but the difference is that the derivatives are calculated during this call process somewhere, so there is no need to call ode.derivatives outside these functions. But for the ODE-test.C, it is confusing, since the derivatives are not used explicitly.

Quote:
Originally Posted by dlahaye View Post
Q2: not sure either. It is possible that the size of the step is adapted inbetween calls of the solve function?
Further looking at the code of ODESolver class, it is an abstract class, so the inter-call between
Code:
void Foam::ODESolver::solve
(
    scalar& x,
    scalarField& y,
    scalar& dxTry
) const
{
    stepState step(dxTry);
    solve(x, y, step);
    dxTry = step.dxTry;
}
and
Code:
void Foam::ODESolver::solve
(
    scalar& x,
    scalarField& y,
    stepState& step
) const
{
    scalar x0 = x;
    solve(x, y, step.dxTry);
    step.dxDid = x - x0;
}
should never happen, since all instantiations have implemented these two virtual functions, so if the first solve function is called, the second function of the instance instead of that of the base (ODESolver) will be called.

Quote:
Originally Posted by dlahaye View Post
I am happy to discuss further.
Your response helped me to think more deeply. Hope more ideas can come in and clarify these issues.
Michael@UW is offline   Reply With Quote

Old   November 16, 2023, 07:46
Default
  #4
Senior Member
 
Domenico Lahaye
Join Date: Dec 2013
Posts: 798
Blog Entries: 1
Rep Power: 17
dlahaye is on a distinguished road
Dear Michael,

I am confused about your most recent reply. I miss the head, body and tail of the points you raise.

Is it valuable for you to re-iterative on the points you raise? Possibly it allows me to provide input.

Thanks, Domenico.
dlahaye is offline   Reply With Quote

Old   November 16, 2023, 09:41
Default
  #5
Senior Member
 
Join Date: Jan 2019
Posts: 125
Blog Entries: 1
Rep Power: 0
Michael@UW is on a distinguished road
Sorry for the confusion. I came out of these thoughts when I was trying to comment on your comments, but I did not address your comments actually. Let me rephrase my thoughts.

(Q1) First of all, I don't think the derivatives are needed in the code of ODE-Test.C, because odeSolver->solve(x, xEnd, y, dxEst) takes care of the derivatives inside the function.

However, if you call another version of solve function, such as odeSolver->solve(x0, y0, dydx0, dx, y), then we need to call ode.derivatives(x0, y0, dxdy0) explicitly. This responds to your comment: "Possibly it helps to write down the problem more formally, as \dot{y} = f(y(x), x) supplied with initial guess y(0) = y0 and try to reason on an algorithm from here."

By the way, both the implicit and explicit ODE solver use the derivatives for the integration.

Again, as a test code, the appearance of the unnecessary ode.derivatives is confusing.

(Q2) "It is possible that the size of the step is adapted in-between calls of the solve function" Yes, the size of the step can be adapted by these in-between calls, but it does not explain how to exit the dead-loop call.

My explanation is that these two functions are virtual functions in the base class (ODESolver), so if one of the two solve functions is (must be) overridden in the derived class, this call-loop will be broken. The design seems subtle and I cannot fully understand.

Hope this makes more sense to you. Please feel free to share your inputs and post more discussion.
Michael@UW is offline   Reply With Quote

Reply

Tags
ode sovler, openfoam v2112


Posting Rules
You may not post new threads
You may not post replies
You may not post attachments
You may not edit your posts

BB code is On
Smilies are On
[IMG] code is On
HTML code is Off
Trackbacks are Off
Pingbacks are On
Refbacks are On


Similar Threads
Thread Thread Starter Forum Replies Last Post
Frequently Asked Questions about Installing OpenFOAM wyldckat OpenFOAM Installation 3 November 14, 2023 12:58
How to check the results of OpenFOAM Solver? priyankap OpenFOAM Running, Solving & CFD 3 April 8, 2019 04:18
How to contribute to the community of OpenFOAM users and to the OpenFOAM technology wyldckat OpenFOAM 17 November 10, 2017 16:54
Suggestion for a new sub-forum at OpenFOAM's Forum wyldckat Site Help, Feedback & Discussions 20 October 28, 2014 10:04
New OpenFOAM Forum Structure jola OpenFOAM 2 October 19, 2011 07:55


All times are GMT -4. The time now is 06:46.