mirror of
https://github.com/OPM/opm-simulators.git
synced 2025-02-25 18:55:30 -06:00
Allow to prevent SimulatorReport for printing to std::cout.
This commit adds a verbose flag to the constructor of SimulatorReport to allow for deactivating any output to std:cout. This is handy for parallel runs where we only want to print statistics on one process.
This commit is contained in:
@@ -23,12 +23,13 @@
|
|||||||
|
|
||||||
namespace Opm
|
namespace Opm
|
||||||
{
|
{
|
||||||
SimulatorReport::SimulatorReport()
|
SimulatorReport::SimulatorReport(bool verbose)
|
||||||
: pressure_time(0.0),
|
: pressure_time(0.0),
|
||||||
transport_time(0.0),
|
transport_time(0.0),
|
||||||
total_time(0.0),
|
total_time(0.0),
|
||||||
total_newton_iterations( 0 ),
|
total_newton_iterations( 0 ),
|
||||||
total_linear_iterations( 0 )
|
total_linear_iterations( 0 ),
|
||||||
|
verbose_(verbose)
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -42,6 +43,8 @@ namespace Opm
|
|||||||
}
|
}
|
||||||
|
|
||||||
void SimulatorReport::report(std::ostream& os)
|
void SimulatorReport::report(std::ostream& os)
|
||||||
|
{
|
||||||
|
if ( verbose_ )
|
||||||
{
|
{
|
||||||
os << "Total time taken: " << total_time
|
os << "Total time taken: " << total_time
|
||||||
<< "\n Pressure time: " << pressure_time
|
<< "\n Pressure time: " << pressure_time
|
||||||
@@ -50,8 +53,11 @@ namespace Opm
|
|||||||
<< "\n Overall Linear Iterations: " << total_linear_iterations
|
<< "\n Overall Linear Iterations: " << total_linear_iterations
|
||||||
<< std::endl;
|
<< std::endl;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
void SimulatorReport::reportFullyImplicit(std::ostream& os)
|
void SimulatorReport::reportFullyImplicit(std::ostream& os)
|
||||||
|
{
|
||||||
|
if ( verbose_ )
|
||||||
{
|
{
|
||||||
os << "Total time taken (seconds): " << total_time
|
os << "Total time taken (seconds): " << total_time
|
||||||
<< "\nSolver time (seconds): " << pressure_time
|
<< "\nSolver time (seconds): " << pressure_time
|
||||||
@@ -59,8 +65,11 @@ namespace Opm
|
|||||||
<< "\nOverall Linear Iterations: " << total_linear_iterations
|
<< "\nOverall Linear Iterations: " << total_linear_iterations
|
||||||
<< std::endl;
|
<< std::endl;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
void SimulatorReport::reportParam(std::ostream& os)
|
void SimulatorReport::reportParam(std::ostream& os)
|
||||||
|
{
|
||||||
|
if ( verbose_ )
|
||||||
{
|
{
|
||||||
os << "/timing/total_time=" << total_time
|
os << "/timing/total_time=" << total_time
|
||||||
<< "\n/timing/pressure/total_time=" << pressure_time
|
<< "\n/timing/pressure/total_time=" << pressure_time
|
||||||
@@ -69,6 +78,7 @@ namespace Opm
|
|||||||
<< "\n/timing/linear/iterations=" << total_linear_iterations
|
<< "\n/timing/linear/iterations=" << total_linear_iterations
|
||||||
<< std::endl;
|
<< std::endl;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
} // namespace Opm
|
} // namespace Opm
|
||||||
|
@@ -36,7 +36,7 @@ namespace Opm
|
|||||||
unsigned int total_linear_iterations;
|
unsigned int total_linear_iterations;
|
||||||
|
|
||||||
/// Default constructor initializing all times to 0.0.
|
/// Default constructor initializing all times to 0.0.
|
||||||
SimulatorReport();
|
SimulatorReport(bool verbose=true);
|
||||||
/// Increment this report's times by those in sr.
|
/// Increment this report's times by those in sr.
|
||||||
void operator+=(const SimulatorReport& sr);
|
void operator+=(const SimulatorReport& sr);
|
||||||
/// Print a report to the given stream.
|
/// Print a report to the given stream.
|
||||||
@@ -44,6 +44,9 @@ namespace Opm
|
|||||||
/// Print a report, leaving out the transport time.
|
/// Print a report, leaving out the transport time.
|
||||||
void reportFullyImplicit(std::ostream& os);
|
void reportFullyImplicit(std::ostream& os);
|
||||||
void reportParam(std::ostream& os);
|
void reportParam(std::ostream& os);
|
||||||
|
private:
|
||||||
|
// Whether to print statistics to std::cout
|
||||||
|
bool verbose_;
|
||||||
};
|
};
|
||||||
|
|
||||||
} // namespace Opm
|
} // namespace Opm
|
||||||
|
Reference in New Issue
Block a user