10 #ifndef ROL_ERRORMEASUREINFO_HPP
11 #define ROL_ERRORMEASUREINFO_HPP
13 #include "ROL_ParameterList.hpp"
20 int &nStatistic, std::vector<Real> &lower,
21 std::vector<Real> &upper,
bool &isBoundActivated,
22 const bool printToStream =
false,
23 std::ostream &outStream = std::cout) {
24 name = parlist.sublist(
"SOL").sublist(
"Error Measure").get<std::string>(
"Name");
25 lower.clear(); upper.clear();
26 nStatistic = 0; isBoundActivated =
false;
27 if ( name ==
"Koenker-Bassett" ||
28 name ==
"Moreau-Yosida-Koenker-Bassett" ||
29 name ==
"Generalized Moreau-Yosida-Koenker-Bassett" ||
30 name ==
"Exponential" ||
31 name ==
"Least Squares" ||
33 name ==
"Log Quantile" ||
34 name ==
"Smoothed Worst Cast" ) {
38 ROL_TEST_FOR_EXCEPTION(
true,std::invalid_argument,
39 ">>> (ROL::ErrorMeasureInfo): Invalid probability " << name <<
"!");
43 if ( printToStream ) {
45 oldFormatState.copyfmt(outStream);
47 outStream << std::endl;
48 outStream << std::scientific << std::setprecision(6);
49 outStream << std::setfill(
'-') << std::setw(80) <<
"-" << std::endl;
50 outStream <<
" ERRORMEASURE INFORMATION" << std::endl;
51 outStream << std::setfill(
'-') << std::setw(80) <<
"-" << std::endl;
52 outStream <<
" NAME" << std::endl;
53 outStream <<
" " << name << std::endl;
54 outStream <<
" NUMBER OF STATISTICS" << std::endl;
55 outStream <<
" " << nStatistic << std::endl;
56 outStream <<
" ARE BOUNDS ACTIVATED" << std::endl;
57 outStream <<
" " << (isBoundActivated ?
"TRUE" :
"FALSE") << std::endl;
58 if ( isBoundActivated ) {
59 outStream <<
" STATISTIC LOWER BOUNDS" << std::endl;
60 for (
int i = 0; i < nStatistic-1; ++i) {
61 outStream <<
" " << lower[i] << std::endl;
63 outStream <<
" " << lower[nStatistic-1] << std::endl;
64 outStream <<
" STATISTIC UPPER BOUNDS" << std::endl;
65 for (
int i = 0; i < nStatistic-1; ++i) {
66 outStream <<
" " << upper[i] << std::endl;
68 outStream <<
" " << upper[nStatistic-1] << std::endl;
70 outStream << std::setfill(
'-') << std::setw(80) <<
"-" << std::endl;
71 outStream << std::endl;
73 outStream.copyfmt(oldFormatState);
Contains definitions of custom data types in ROL.
basic_nullstream< char, char_traits< char >> nullstream
void ErrorMeasureInfo(ROL::ParameterList &parlist, std::string &name, int &nStatistic, std::vector< Real > &lower, std::vector< Real > &upper, bool &isBoundActivated, const bool printToStream=false, std::ostream &outStream=std::cout)