-
Notifications
You must be signed in to change notification settings - Fork 11
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Run fmi2SetXXX function to initialize FMU start values #778
Conversation
I guess this PR contains some conflicts with #777, will need to update based on the merge :) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The implementation looks good, and it's great to get this fixed. Correctness issues should always have high priority, IMO.
That said, I wonder if this really needs to be an entirely new interface function in simulator
. Couldn't the things you do in the new simulator::initialize_start_values()
function be done at the start of simulator::setup()
instead, before it calls slave_->start_simulation()
?
src/cosim/slave_simulator.cpp
Outdated
void initialize_start_values() | ||
{ | ||
auto deltaT = duration::zero(); | ||
auto filter = [this](const variable_type& vt) { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
variable_type
and value_reference
are just integers in disguise, and should therefore be passed by value rather than by reference.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Also, we have the scalar_value
alias which you can use instead of that variant
.
tests/data/fmi2/StateInitExample.fmu
Outdated
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
When adding an FMU, you should update tests/data/fmi2/README.md
and possibly include a licence file, cf. #764.
src/cosim/slave_simulator.cpp
Outdated
@@ -518,6 +546,34 @@ class slave_simulator::impl | |||
return result; | |||
} | |||
|
|||
void initialize_start_values() |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The functions are generally listed in the order they're supposed to be called, so this should come before setup()
.
@@ -119,6 +119,11 @@ class simulator : public manipulable | |||
*/ | |||
virtual void start_simulation() = 0; | |||
|
|||
/** | |||
* Runs fmiXSetINI (4.2.4) functions to initialize variables' start values. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
We haven't made reference to the FMI spec anywhere else in this interface, nor in any other of our general interfaces, because they are supposed to be agnostic with respect to the underlying binary interface. All FMI-specific stuff is hidden away in the cosim::fmi
module. (I admit that we're still leaking FMI details like a sieve, but we haven't been this explicit about it before.) I suggest writing a more general and extensive description of what the function is supposed to do instead.
Also, as commented elsewhere, the functions are generally in call order, so this should go before setup()
.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
LGTM
Agree. I've moved the functionality into |
Builds are running into test failures, all of which are something like this:
Seems this is originating in FMILibrary. |
I don't think so. It is caused by a C++ exception ( |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Looks good to me, provided the cause of the exception is found and fixed.
This reverts commit 790ba4c.
Hei thanks for the follow up @restenb and @kyllingstad
|
Thanks for the fix. I completely missed that I had introduced this. I was looking at the setup when your commit came in, wondering if our setup order was somehow incorrect. But by the way I read this, and the table on page 110 of the FMI 2.0.4 specification, this appears to be correct now. Variables are initialized between
For calls to fmi2SetXXX: I don't recall that we use this |
Note that since we have users waiting on this fix on our side, I'm aiming to merge this & release libcosim tomorrow. |
Yeah, I also remember reading this one. I think libcosim currently does not parse |
No, it's more that we don't need to worry about the |
…circuits" the error message.
According to FMI 2.0.4 spec (Section 4.2.4), start values are read during
instantiated
state viafmi2SetXXX
. But libcosim does not run these functions ininstantiated
state and this makes some of FMUs exported (e.g. Simulink) not initializing values accordingly.For example see below cosim_demo_app that runs an integrator whose initial condition is set via parameter
Parameter.Integrator_x0
:The initial condition is not properly set via the parameter (i.e. not starting from 10).
On the other hand,
fmpy
properly initialize this value when set in the simulation setting:To fix this, this PR added an additional function
initialize_start_values()
that runs beforesimulator::setup()
infixed_step_algorithm::cosim::impl::initialize()
Check
state_init_test.cpp
to observe different behaviours with the previous libcosim version