mirror of
				https://github.com/OPM/opm-simulators.git
				synced 2025-02-25 18:55:30 -06:00 
			
		
		
		
	Update tests and provide some eclipse output.
This commit is contained in:
		| @@ -1,7 +1,77 @@ | |||||||
|  | NOECHO | ||||||
|  |  | ||||||
|  | RUNSPEC   ====== | ||||||
|  |  | ||||||
| WATER | WATER | ||||||
| OIL | OIL | ||||||
| GAS | GAS | ||||||
|  |  | ||||||
|  | TABDIMS | ||||||
|  |   1    1   40   20    1   20  / | ||||||
|  |  | ||||||
|  | DIMENS | ||||||
|  | 1 1 20 | ||||||
|  | / | ||||||
|  |  | ||||||
|  | WELLDIMS | ||||||
|  |    30   10    2   30 / | ||||||
|  |  | ||||||
|  | START | ||||||
|  |    1 'JAN' 1990  / | ||||||
|  |  | ||||||
|  | NSTACK | ||||||
|  |    25 / | ||||||
|  |  | ||||||
|  | EQLDIMS | ||||||
|  | -- NTEQUL | ||||||
|  |      1 /  | ||||||
|  |       | ||||||
|  |  | ||||||
|  | FMTOUT | ||||||
|  | FMTIN | ||||||
|  |  | ||||||
|  | GRID      ====== | ||||||
|  |  | ||||||
|  | DXV | ||||||
|  | 1.0 | ||||||
|  | / | ||||||
|  |  | ||||||
|  | DYV | ||||||
|  | 1.0 | ||||||
|  | / | ||||||
|  |  | ||||||
|  | DZV | ||||||
|  | 20*5.0 | ||||||
|  | / | ||||||
|  |  | ||||||
|  |  | ||||||
|  | PORO | ||||||
|  | 20*0.2 | ||||||
|  | / | ||||||
|  |  | ||||||
|  |  | ||||||
|  | PERMZ | ||||||
|  |   20*1.0 | ||||||
|  | / | ||||||
|  |  | ||||||
|  | PERMY | ||||||
|  | 20*100.0 | ||||||
|  | / | ||||||
|  |  | ||||||
|  | PERMX | ||||||
|  | 20*100.0 | ||||||
|  | / | ||||||
|  |  | ||||||
|  | BOX | ||||||
|  |  1 1 1 1 1 1 / | ||||||
|  |  | ||||||
|  | TOPS | ||||||
|  | 0.0 | ||||||
|  | / | ||||||
|  |  | ||||||
|  | PROPS     ====== | ||||||
|  |  | ||||||
|  |  | ||||||
| PVDO | PVDO | ||||||
| 100 1.0 1.0 | 100 1.0 1.0 | ||||||
| 200 0.9 1.0 | 200 0.9 1.0 | ||||||
| @@ -22,10 +92,37 @@ SGOF | |||||||
| 0.8 1 0 0.5 | 0.8 1 0 0.5 | ||||||
| / | / | ||||||
|  |  | ||||||
|  | PVTW | ||||||
|  | --RefPres  Bw      Comp   Vw    Cv | ||||||
|  |    1.      1.0   4.0E-5  0.96  0.0 / | ||||||
|  |     | ||||||
|  |  | ||||||
|  | ROCK | ||||||
|  | --RefPres  Comp | ||||||
|  |    1.   5.0E-5 / | ||||||
|  |  | ||||||
| DENSITY | DENSITY | ||||||
| 700 1000 1 | 700 1000 1 | ||||||
| / | / | ||||||
|  |  | ||||||
|  | SOLUTION  ====== | ||||||
|  |  | ||||||
| EQUIL | EQUIL | ||||||
| 50 150 50 0.25 45 0.35 | 45 150 50 0.25 45 0.35 1* 1* 0 | ||||||
| / | / | ||||||
|  |  | ||||||
|  | RPTSOL | ||||||
|  | 'PRES' 'PGAS' 'PWAT' 'SOIL' 'SWAT' 'SGAS' 'RESTART=2' / | ||||||
|  |  | ||||||
|  | SUMMARY   ====== | ||||||
|  | RUNSUM | ||||||
|  |  | ||||||
|  | SEPARATE | ||||||
|  |  | ||||||
|  | SCHEDULE  ====== | ||||||
|  |  | ||||||
|  | RPTSCHED | ||||||
|  | 'PRES' 'PGAS' 'PWAT' 'SOIL' 'SWAT' 'SGAS' 'RESTART=3' 'NEWTON=2' / | ||||||
|  |  | ||||||
|  |  | ||||||
|  | END | ||||||
|   | |||||||
| @@ -1,27 +1,94 @@ | |||||||
|  | NOECHO | ||||||
|  |  | ||||||
|  | RUNSPEC   ====== | ||||||
|  |  | ||||||
| WATER | WATER | ||||||
| OIL | OIL | ||||||
| GAS | GAS | ||||||
| DISGAS | DISGAS | ||||||
|  |  | ||||||
|  | TABDIMS | ||||||
|  |   1    1   40   20    1   20  / | ||||||
|  |  | ||||||
|  | DIMENS | ||||||
|  | 1 1 20 | ||||||
|  | / | ||||||
|  |  | ||||||
|  | WELLDIMS | ||||||
|  |    30   10    2   30 / | ||||||
|  |  | ||||||
|  | START | ||||||
|  |    1 'JAN' 1990  / | ||||||
|  |  | ||||||
|  | NSTACK | ||||||
|  |    25 / | ||||||
|  |  | ||||||
|  | EQLDIMS | ||||||
|  | -- NTEQUL | ||||||
|  |      1 /  | ||||||
|  |       | ||||||
|  |  | ||||||
|  | FMTOUT | ||||||
|  | FMTIN | ||||||
|  |  | ||||||
|  | GRID      ====== | ||||||
|  |  | ||||||
|  | DXV | ||||||
|  | 1.0 | ||||||
|  | / | ||||||
|  |  | ||||||
|  | DYV | ||||||
|  | 1.0 | ||||||
|  | / | ||||||
|  |  | ||||||
|  | DZV | ||||||
|  | 20*5.0 | ||||||
|  | / | ||||||
|  |  | ||||||
|  |  | ||||||
|  | PORO | ||||||
|  | 20*0.2 | ||||||
|  | / | ||||||
|  |  | ||||||
|  |  | ||||||
|  | PERMZ | ||||||
|  |   20*1.0 | ||||||
|  | / | ||||||
|  |  | ||||||
|  | PERMY | ||||||
|  | 20*100.0 | ||||||
|  | / | ||||||
|  |  | ||||||
|  | PERMX | ||||||
|  | 20*100.0 | ||||||
|  | / | ||||||
|  |  | ||||||
|  | BOX | ||||||
|  |  1 1 1 1 1 1 / | ||||||
|  |  | ||||||
|  | TOPS | ||||||
|  | 0.0 | ||||||
|  | / | ||||||
|  |  | ||||||
|  | PROPS     ====== | ||||||
|  |  | ||||||
|  |  | ||||||
| PVTO | PVTO | ||||||
| --     Rs       Pbub       Bo        Vo | --     Rs       Pbub       Bo        Vo | ||||||
|          0          1.    1.0000     1.20  / |          0          1.    1.0000     1.20  / | ||||||
|        100         40.    1.0120     1.17  / |         20         40.    1.0120     1.17  / | ||||||
|        200         80.    1.0255     1.14  / |         40         80.    1.0255     1.14  / | ||||||
|        300        120.    1.0380     1.11  / |         60        120.    1.0380     1.11  / | ||||||
|        400        160.    1.0510     1.08  / |         80        160.    1.0510     1.08  / | ||||||
|        500        200.    1.0630     1.06  / |        100        200.    1.0630     1.06  / | ||||||
|        600        240.    1.0750     1.03  / |        120        240.    1.0750     1.03  / | ||||||
|        700        280.    1.0870     1.00  / |        140        280.    1.0870     1.00  / | ||||||
|        800        320.    1.0985      .98  / |        160        320.    1.0985      .98  / | ||||||
|        900        360.    1.1100      .95  / |        180        360.    1.1100      .95  / | ||||||
|       1000        400.    1.1200      .94 |        200        400.    1.1200      .94 | ||||||
|                   500.    1.1189      .94  / |                   500.    1.1189      .94  / | ||||||
|  / |  / | ||||||
|  |  | ||||||
|  |  | ||||||
| PVDG | PVDG | ||||||
| 100 0.010 0.1 | 100 0.010 0.1 | ||||||
| 200 0.005 0.2 | 200 0.005 0.2 | ||||||
| @@ -37,10 +104,37 @@ SGOF | |||||||
| 0.8 1 0 0.5 | 0.8 1 0 0.5 | ||||||
| / | / | ||||||
|  |  | ||||||
|  | PVTW | ||||||
|  | --RefPres  Bw      Comp   Vw    Cv | ||||||
|  |    1.      1.0   4.0E-5  0.96  0.0 / | ||||||
|  |     | ||||||
|  |  | ||||||
|  | ROCK | ||||||
|  | --RefPres  Comp | ||||||
|  |    1.   5.0E-5 / | ||||||
|  |  | ||||||
| DENSITY | DENSITY | ||||||
| 700 1000 1 | 700 1000 1 | ||||||
| / | / | ||||||
|  |  | ||||||
|  | SOLUTION  ====== | ||||||
|  |  | ||||||
| EQUIL | EQUIL | ||||||
| 45 150 50 0.25 45 0.35 | 45 150 50 0.25 45 0.35 1* 1* 0 | ||||||
| / | / | ||||||
|  |  | ||||||
|  | RPTSOL | ||||||
|  | 'PRES' 'PGAS' 'PWAT' 'SOIL' 'SWAT' 'SGAS' 'RS' 'RESTART=2' / | ||||||
|  |  | ||||||
|  | SUMMARY   ====== | ||||||
|  | RUNSUM | ||||||
|  |  | ||||||
|  | SEPARATE | ||||||
|  |  | ||||||
|  | SCHEDULE  ====== | ||||||
|  |  | ||||||
|  | RPTSCHED | ||||||
|  | 'PRES' 'PGAS' 'PWAT' 'SOIL' 'SWAT' 'SGAS' 'RS' 'RESTART=3' 'NEWTON=2' / | ||||||
|  |  | ||||||
|  |  | ||||||
|  | END | ||||||
|   | |||||||
| @@ -27,6 +27,9 @@ | |||||||
| #include <opm/core/props/BlackoilPropertiesFromDeck.hpp> | #include <opm/core/props/BlackoilPropertiesFromDeck.hpp> | ||||||
| #include <opm/core/props/BlackoilPhases.hpp> | #include <opm/core/props/BlackoilPhases.hpp> | ||||||
|  |  | ||||||
|  | #include <opm/parser/eclipse/Parser/Parser.hpp> | ||||||
|  | #include <opm/parser/eclipse/Deck/Deck.hpp> | ||||||
|  |  | ||||||
| #include <opm/core/pressure/msmfem/partition.h> | #include <opm/core/pressure/msmfem/partition.h> | ||||||
|  |  | ||||||
| #include <opm/core/utility/parameters/ParameterGroup.hpp> | #include <opm/core/utility/parameters/ParameterGroup.hpp> | ||||||
| @@ -339,9 +342,9 @@ BOOST_AUTO_TEST_CASE (DeckAllDead) | |||||||
|     // solver, and it is unclear if we should check it against |     // solver, and it is unclear if we should check it against | ||||||
|     // the true answer or something else. |     // the true answer or something else. | ||||||
|     const double reltol = 1.0e-3; |     const double reltol = 1.0e-3; | ||||||
|     BOOST_CHECK_CLOSE(pressures[0][first] , 14955e3   , reltol); |     BOOST_CHECK_CLOSE(pressures[0][first] , 1.496329839e7   , reltol); | ||||||
|     BOOST_CHECK_CLOSE(pressures[0][last ] , 15045e3   , reltol); |     BOOST_CHECK_CLOSE(pressures[0][last ] , 1.50473245e7   , reltol); | ||||||
|     BOOST_CHECK_CLOSE(pressures[1][last] , 1.50473e7   , reltol); |     BOOST_CHECK_CLOSE(pressures[1][last] , 1.50473245e7   , reltol); | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| @@ -416,9 +419,9 @@ BOOST_AUTO_TEST_CASE (DeckWithCapillary) | |||||||
|     // solver, and it is unclear if we should check it against |     // solver, and it is unclear if we should check it against | ||||||
|     // the true answer or something else. |     // the true answer or something else. | ||||||
|     const double reltol = 1.0e-6; |     const double reltol = 1.0e-6; | ||||||
|     BOOST_CHECK_CLOSE(pressures[0][first] , 1.45e7   , reltol); |     BOOST_CHECK_CLOSE(pressures[0][first] , 1.469769063e7   , reltol); | ||||||
|     BOOST_CHECK_CLOSE(pressures[0][last ] , 1.545e7   , reltol); |     BOOST_CHECK_CLOSE(pressures[0][last ] , 1.545e7   , reltol); | ||||||
|     BOOST_CHECK_CLOSE(pressures[1][last] , 1.5351621345e7   , reltol); |     BOOST_CHECK_CLOSE(pressures[1][last] , 1.546e7   , reltol); | ||||||
|  |  | ||||||
|     const auto& sats = comp.saturation(); |     const auto& sats = comp.saturation(); | ||||||
|     const std::vector<double> s[3]{ |     const std::vector<double> s[3]{ | ||||||
| @@ -443,7 +446,7 @@ BOOST_AUTO_TEST_CASE (DeckWithCapillaryOverlap) | |||||||
|     Opm::EclipseGridParser deck("capillary_overlap.DATA"); |     Opm::EclipseGridParser deck("capillary_overlap.DATA"); | ||||||
|     Opm::BlackoilPropertiesFromDeck props(deck, grid, false); |     Opm::BlackoilPropertiesFromDeck props(deck, grid, false); | ||||||
|  |  | ||||||
|     Opm::Equil::DeckDependent::InitialStateComputer<Opm::EclipseGridParser> comp(props, deck, grid, 10.0); |     Opm::Equil::DeckDependent::InitialStateComputer<Opm::EclipseGridParser> comp(props, deck, grid, 9.80665); | ||||||
|     const auto& pressures = comp.press(); |     const auto& pressures = comp.press(); | ||||||
|     BOOST_REQUIRE(pressures.size() == 3); |     BOOST_REQUIRE(pressures.size() == 3); | ||||||
|     BOOST_REQUIRE(int(pressures[0].size()) == grid.number_of_cells); |     BOOST_REQUIRE(int(pressures[0].size()) == grid.number_of_cells); | ||||||
| @@ -454,9 +457,15 @@ BOOST_AUTO_TEST_CASE (DeckWithCapillaryOverlap) | |||||||
|     // solver, and it is unclear if we should check it against |     // solver, and it is unclear if we should check it against | ||||||
|     // the true answer or something else. |     // the true answer or something else. | ||||||
|     const double reltol = 1.0e-6; |     const double reltol = 1.0e-6; | ||||||
|     BOOST_CHECK_CLOSE(pressures[0][first] , 1.45e7   , reltol); |     const double reltol_ecl = 1.0; | ||||||
|     BOOST_CHECK_CLOSE(pressures[0][last ] , 1.545e7   , reltol); |     BOOST_CHECK_CLOSE(pressures[0][first], 1.48324e+07, reltol_ecl);  // eclipse  | ||||||
|     BOOST_CHECK_CLOSE(pressures[1][last] , 1.5351621345e7   , reltol); |     BOOST_CHECK_CLOSE(pressures[0][last],  1.54801e+07, reltol_ecl); | ||||||
|  |     BOOST_CHECK_CLOSE(pressures[1][first], 1.49224e+07, reltol_ecl); | ||||||
|  |     BOOST_CHECK_CLOSE(pressures[1][last],  1.54901e+07, reltol_ecl); | ||||||
|  |      | ||||||
|  |     BOOST_CHECK_CLOSE(pressures[0][first] , 14832467.14, reltol); // opm | ||||||
|  |     BOOST_CHECK_CLOSE(pressures[0][last ] , 15479883.47, reltol); | ||||||
|  |     BOOST_CHECK_CLOSE(pressures[1][last ] , 15489883.47, reltol); | ||||||
|  |  | ||||||
|     const auto& sats = comp.saturation(); |     const auto& sats = comp.saturation(); | ||||||
|     // std::cout << "Saturations:\n"; |     // std::cout << "Saturations:\n"; | ||||||
| @@ -466,15 +475,24 @@ BOOST_AUTO_TEST_CASE (DeckWithCapillaryOverlap) | |||||||
|     //     } |     //     } | ||||||
|     //     std::cout << std::endl; |     //     std::cout << std::endl; | ||||||
|     // } |     // } | ||||||
|     const std::vector<double> s[3]{ |     | ||||||
|         { 0.2, 0.2, 0.2, 0.2, 0.2, 0.2, 0.2, 0.223141818182, 0.532269090909, 0.78471, 0.91526, 1, 1, 1, 1, 1, 1, 1, 1, 1 }, |     const std::vector<double> s_ecl[3]{// eclipse | ||||||
|         { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0.207743333333, 0.08474, 0, 0, 0, 0, 0, 0, 0, 0, 0 }, |         { 0.2, 0.2, 0.2, 0.2, 0.2, 0.2, 0.2, 0.22874042, 0.53397995, 0.78454906,  0.91542006, 1, 1, 1, 1, 1, 1, 1, 1, 1 }, | ||||||
|         { 0.8, 0.8, 0.8, 0.8, 0.8, 0.8, 0.8, 0.776858181818, 0.467730909091, 0.0075466666666, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } |         { 0,   0,   0,   0,   0,   0,   0,   0,          0,          0.20039,     0.08458,    0, 0, 0, 0, 0, 0, 0, 0, 0 }, | ||||||
|  |         { 0.8, 0.8, 0.8, 0.8, 0.8, 0.8, 0.8, 0.77125955, 0.46602005, 0.015063271, 0,          0, 0, 0, 0, 0, 0, 0, 0, 0 } | ||||||
|  |     }; | ||||||
|  |  | ||||||
|  |     const std::vector<double> s_opm[3]{ // opm  | ||||||
|  |         { 0.2, 0.2, 0.2, 0.2, 0.2, 0.2, 0.2, 0.2289309090909091,  0.53406545454545451, 0.78458,              0.9154, 1, 1, 1, 1, 1, 1, 1, 1, 1 }, | ||||||
|  |         { 0,   0,   0,   0,   0,   0,   0,   0,                   0,                   0.2002466666666666,   0.0846, 0, 0, 0, 0, 0, 0, 0, 0, 0 }, | ||||||
|  |         { 0.8, 0.8, 0.8, 0.8, 0.8, 0.8, 0.8, 0.77106909090909093, 0.46593454545454549, 0.015173333333333336, 0,      0, 0, 0, 0, 0, 0, 0, 0, 0 } | ||||||
|     }; |     }; | ||||||
|     for (int phase = 0; phase < 3; ++phase) { |     for (int phase = 0; phase < 3; ++phase) { | ||||||
|         BOOST_REQUIRE(sats[phase].size() == s[phase].size()); |         BOOST_REQUIRE(sats[phase].size() == s_opm[phase].size()); | ||||||
|         for (size_t i = 0; i < s[phase].size(); ++i) { |         for (size_t i = 0; i < s_opm[phase].size(); ++i) { | ||||||
|             BOOST_CHECK_CLOSE(sats[phase][i], s[phase][i], reltol); |             //std::cout << std::setprecision(10) << sats[phase][i] << '\n'; | ||||||
|  |             BOOST_CHECK_CLOSE(sats[phase][i], s_ecl[phase][i], reltol_ecl); | ||||||
|  |             BOOST_CHECK_CLOSE(sats[phase][i], s_opm[phase][i], reltol); | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| } | } | ||||||
| @@ -485,10 +503,12 @@ BOOST_AUTO_TEST_CASE (DeckWithLiveOil) | |||||||
| { | { | ||||||
|     Opm::GridManager gm(1, 1, 20, 1.0, 1.0, 5.0); |     Opm::GridManager gm(1, 1, 20, 1.0, 1.0, 5.0); | ||||||
|     const UnstructuredGrid& grid = *(gm.c_grid()); |     const UnstructuredGrid& grid = *(gm.c_grid()); | ||||||
|     Opm::EclipseGridParser deck("equil_liveoil.DATA"); |     Opm::ParserPtr parser(new Opm::Parser() ); | ||||||
|  |     Opm::DeckConstPtr deck = parser->parseFile("equil_liveoil.DATA"); | ||||||
|  |     //Opm::EclipseGridParser deck("equil_liveoil.DATA"); | ||||||
|     Opm::BlackoilPropertiesFromDeck props(deck, grid, false); |     Opm::BlackoilPropertiesFromDeck props(deck, grid, false); | ||||||
|  |  | ||||||
|     Opm::Equil::DeckDependent::InitialStateComputer<Opm::EclipseGridParser> comp(props, deck, grid, 10.0); |     Opm::Equil::DeckDependent::InitialStateComputer<Opm::DeckConstPtr> comp(props, deck, grid, 9.80665); | ||||||
|     const auto& pressures = comp.press(); |     const auto& pressures = comp.press(); | ||||||
|     BOOST_REQUIRE(pressures.size() == 3); |     BOOST_REQUIRE(pressures.size() == 3); | ||||||
|     BOOST_REQUIRE(int(pressures[0].size()) == grid.number_of_cells); |     BOOST_REQUIRE(int(pressures[0].size()) == grid.number_of_cells); | ||||||
| @@ -499,9 +519,16 @@ BOOST_AUTO_TEST_CASE (DeckWithLiveOil) | |||||||
|     // solver, and it is unclear if we should check it against |     // solver, and it is unclear if we should check it against | ||||||
|     // the true answer or something else. |     // the true answer or something else. | ||||||
|     const double reltol = 1.0e-6; |     const double reltol = 1.0e-6; | ||||||
|     BOOST_CHECK_CLOSE(pressures[0][first], 1.4551302072306179e7, reltol); |     const double reltol_ecl = 1.0; | ||||||
|     BOOST_CHECK_CLOSE(pressures[0][last],  1.5501302072306179e7, reltol); |     BOOST_CHECK_CLOSE(pressures[0][first], 1.48324e+07, reltol_ecl);  // eclipse | ||||||
|     BOOST_CHECK_CLOSE(pressures[1][last],  1.5538684664272346e7, reltol); |     BOOST_CHECK_CLOSE(pressures[0][last],  1.54801e+07, reltol_ecl); | ||||||
|  |     BOOST_CHECK_CLOSE(pressures[1][first], 1.49224e+07, reltol_ecl); | ||||||
|  |     BOOST_CHECK_CLOSE(pressures[1][last],  1.54901e+07, reltol_ecl); | ||||||
|  |      | ||||||
|  |     BOOST_CHECK_CLOSE(pressures[0][first], 1.483246714e7, reltol);  // opm | ||||||
|  |     BOOST_CHECK_CLOSE(pressures[0][last],  1.547991652e7, reltol); | ||||||
|  |     BOOST_CHECK_CLOSE(pressures[1][first], 1.492246714e7, reltol); | ||||||
|  |     BOOST_CHECK_CLOSE(pressures[1][last],  1.548991652e7, reltol); | ||||||
|  |  | ||||||
|     const auto& sats = comp.saturation(); |     const auto& sats = comp.saturation(); | ||||||
|     // std::cout << "Saturations:\n"; |     // std::cout << "Saturations:\n"; | ||||||
| @@ -511,16 +538,24 @@ BOOST_AUTO_TEST_CASE (DeckWithLiveOil) | |||||||
|     //     } |     //     } | ||||||
|     //     std::cout << std::endl; |     //     std::cout << std::endl; | ||||||
|     // } |     // } | ||||||
|     const std::vector<double> s[3]{ |     const std::vector<double> s_ecl[3]{ // eclipse | ||||||
|         { 0.2, 0.2, 0.2, 0.2, 0.2, 0.2, 0.2, 0.223141818182, 0.532269090909, 0.78471, 0.91526, 1, 1, 1, 1, 1, 1, 1, 1, 1 }, |         { 0.2, 0.2, 0.2, 0.2, 0.2, 0.2, 0.2, 0.22898, 0.53422, 0.78470, 0.91531, 1, 1, 1, 1, 1, 1, 1, 1, 1 }, | ||||||
|         { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0.207743333333, 0.08474, 0, 0, 0, 0, 0, 0, 0, 0, 0 }, |         { 0,   0,   0,   0,   0,   0,   0,   0,       0,       0.20073, 0.08469, 0, 0, 0, 0, 0, 0, 0, 0, 0 }, | ||||||
|         { 0.8, 0.8, 0.8, 0.8, 0.8, 0.8, 0.8, 0.776858181818, 0.467730909091, 0.0075466666666, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } |         { 0.8, 0.8, 0.8, 0.8, 0.8, 0.8, 0.8, 0.77102, 0.46578, 0.01458, 0,       0, 0, 0, 0, 0, 0, 0, 0, 0 } | ||||||
|     }; |     }; | ||||||
|  |  | ||||||
|  |     const std::vector<double> s_opm[3]{ // opm  | ||||||
|  |         { 0.2, 0.2, 0.2, 0.2, 0.2, 0.2, 0.2, 0.2291709091, 0.5343054545, 0.78472,        0.91529, 1, 1, 1, 1, 1, 1, 1, 1, 1 }, | ||||||
|  |         { 0,   0,   0,   0,   0,   0,   0,   0,            0,            0.2005866667,   0.08471, 0, 0, 0, 0, 0, 0, 0, 0, 0 }, | ||||||
|  |         { 0.8, 0.8, 0.8, 0.8, 0.8, 0.8, 0.8, 0.7708290909, 0.4656945455, 0.01469333333,  0,       0, 0, 0, 0, 0, 0, 0, 0, 0 } | ||||||
|  |     }; | ||||||
|  |  | ||||||
|     for (int phase = 0; phase < 3; ++phase) { |     for (int phase = 0; phase < 3; ++phase) { | ||||||
|         BOOST_REQUIRE(sats[phase].size() == s[phase].size()); |         BOOST_REQUIRE(sats[phase].size() == s_opm[phase].size()); | ||||||
|         for (size_t i = 0; i < s[phase].size(); ++i) { |         for (size_t i = 0; i < s_opm[phase].size(); ++i) { | ||||||
|             std::cout << sats[phase][i] << '\n'; |             //std::cout << std::setprecision(10) << sats[phase][i] << '\n'; | ||||||
|             //BOOST_CHECK_CLOSE(sats[phase][i], s[phase][i], reltol); |             BOOST_CHECK_CLOSE(sats[phase][i], s_opm[phase][i], reltol); | ||||||
|  |             BOOST_CHECK_CLOSE(sats[phase][i], s_ecl[phase][i], reltol_ecl); | ||||||
|         } |         } | ||||||
|         std::cout << std::endl; |         std::cout << std::endl; | ||||||
|     } |     } | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user