84#ifdef STORM_USE_CLN_EA
85 STORM_PRINT(
"Using CLN numbers for exact arithmetic.\n");
87 STORM_PRINT(
"Using GMP numbers for exact arithmetic.\n");
89#ifdef STORM_USE_CLN_RF
90 STORM_PRINT(
"Using CLN numbers for rational functions.\n");
92 STORM_PRINT(
"Using GMP numbers for rational functions.\n");
96 STORM_PRINT(
"Linked with CArL v" << STORM_CARL_VERSION <<
".\n");
102#ifdef STORM_HAVE_GLPK
103 STORM_PRINT(
"Linked with GLPK v" << GLP_MAJOR_VERSION <<
"." << GLP_MINOR_VERSION <<
".\n");
112#ifdef STORM_HAVE_GUROBI
113 STORM_PRINT(
"Linked with Gurobi Optimizer v" << GRB_VERSION_MAJOR <<
"." << GRB_VERSION_MINOR <<
"." << GRB_VERSION_TECHNICAL <<
".\n");
117#ifdef STORM_HAVE_MATHSAT
118 char* msatVersion = msat_get_version();
119 STORM_PRINT(
"Linked with " << msatVersion <<
".\n");
120 msat_free(msatVersion);
124#ifdef STORM_HAVE_SOPLEX
125 STORM_PRINT(
"Linked with Soplex v" << SOPLEX_VERSION <<
".\n");
129#ifdef STORM_HAVE_SPOT
130 STORM_PRINT(
"Linked with Spot v" << spot::version() <<
".\n");
134#ifdef STORM_HAVE_SYLVAN
139#ifdef STORM_HAVE_XERCES
140 STORM_PRINT(
"Linked with Xerces-C v" << gXercesMajVersion <<
"." << gXercesMinVersion <<
"." << gXercesRevision <<
".\n");
145 unsigned int z3Major, z3Minor, z3BuildNumber, z3RevisionNumber;
146 Z3_get_version(&z3Major, &z3Minor, &z3BuildNumber, &z3RevisionNumber);
147#ifdef STORM_HAVE_Z3_OPTIMIZE
148 STORM_PRINT(
"Linked with Z3 Theorem Prover v" << z3Major <<
"." << z3Minor <<
" Build " << z3BuildNumber <<
" Rev " << z3RevisionNumber
149 <<
" (with optimization features).\n");
151 STORM_PRINT(
"Linked with Z3 Theorem Prover v" << z3Major <<
"." << z3Minor <<
" Build " << z3BuildNumber <<
" Rev " << z3RevisionNumber <<
".\n");
154 STORM_PRINT(
"Not linked with Z3 Theorem Prover\n");
161 getrusage(RUSAGE_SELF, &ru);
163 std::cout <<
"\nPerformance statistics:\n";
166 uint64_t maximumResidentSizeInMegabytes = ru.ru_maxrss / 1024 / 1024;
170 uint64_t maximumResidentSizeInMegabytes = ru.ru_maxrss / 1024;
172 std::cout <<
" * peak memory usage: " << maximumResidentSizeInMegabytes <<
"MB\n";
173 char oldFillChar = std::cout.fill(
'0');
174 std::cout <<
" * CPU time: " << ru.ru_utime.tv_sec <<
"." << std::setw(3) << ru.ru_utime.tv_usec / 1000 <<
"s\n";
175 if (wallclockMilliseconds != 0) {
176 std::cout <<
" * wallclock time: " << (wallclockMilliseconds / 1000) <<
"." << std::setw(3) << (wallclockMilliseconds % 1000) <<
"s\n";
178 std::cout.fill(oldFillChar);