https://github.com/feelpp/feelpp
Tip revision: a9778a06b0d8713f226fe51d3c1915329aba8538 authored by Christophe Prud'homme on 26 April 2020, 15:37:17 UTC
Merge pull request #1472 from feelpp/Pierre-B-patch-1
Merge pull request #1472 from feelpp/Pierre-B-patch-1
Tip revision: a9778a0
test_fmi.cpp
#define BOOST_TEST_MODULE test_fmi
#include <feel/feelcore/testsuite.hpp>
#include <feel/feelfmi/fmu.hpp>
using namespace Feel;
inline AboutData makeAbout()
{
AboutData about( "test_fmi" ,
"test_fmi" ,
"0.1",
"FMI test",
Feel::AboutData::License_GPL,
"Copyright (c) 2017 Feel++ Consortium" );
return about;
}
FEELPP_ENVIRONMENT_WITH_OPTIONS( makeAbout(), feel_options() )
BOOST_AUTO_TEST_SUITE( test_fmi )
BOOST_AUTO_TEST_CASE( test_fmi2cs )
{
Environment::setOptionValue<std::string>("fmu.filename", "${cfgdir}/fmi2cs/fmi2cs.fmu");
FMU my_fmu;
my_fmu.load();
my_fmu.initialize(0,1); // initialize the fmu with t_init=0 and t_final=1
my_fmu.doSteps(0.5); // interate until t_stop=0.5
double h = my_fmu.getValue<double>( "h" );
double v = my_fmu.getValue<double>( "v" );
BOOST_CHECK_SMALL( math::abs(h-0.1602522260970522), 1e-2 );
BOOST_CHECK_SMALL( math::abs(v-3.068004452918325), 1e-2 );
my_fmu.setValue( "h", 0.1602522260970522 );// change the value of h
my_fmu.setValue( "v", 3.068004452918325 ); // change the value of v
my_fmu.doSteps(1); // do steps until t=1
h = my_fmu.getValue<double>( "h" ); // get value of h
v = my_fmu.getValue<double>( "v" ); // get value of v
BOOST_CHECK_SMALL( math::abs(h-0.4680044525539696), 1e-2 );
BOOST_CHECK_SMALL( math::abs(v+1.836995547081675), 1e-2 );
my_fmu.reset(); // reset the model
my_fmu.simulate(); // perform simulation with defaut t_init and t_final. no need to call initalize with this method
h = my_fmu.getValue<double>( "h" );
v = my_fmu.getValue<double>( "v" );
BOOST_CHECK_SMALL( math::abs(h-0.4680044525539696), 1e-2 );
BOOST_CHECK_SMALL( math::abs(v+1.836995547081675), 1e-2 );
}
BOOST_AUTO_TEST_SUITE_END()