2014-05-26 00:50:25 -05:00
|
|
|
/*
|
2014-05-26 11:47:15 -05:00
|
|
|
Copyright 2014 Statoil ASA.
|
2014-05-26 00:50:25 -05:00
|
|
|
|
|
|
|
This file is part of the Open Porous Media project (OPM).
|
|
|
|
|
|
|
|
OPM is free software: you can redistribute it and/or modify
|
|
|
|
it under the terms of the GNU General Public License as published by
|
|
|
|
the Free Software Foundation, either version 3 of the License, or
|
|
|
|
(at your option) any later version.
|
|
|
|
|
|
|
|
OPM is distributed in the hope that it will be useful,
|
|
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
GNU General Public License for more details.
|
|
|
|
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
|
|
along with OPM. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <stdexcept>
|
|
|
|
#include <iostream>
|
2014-05-26 11:47:15 -05:00
|
|
|
#include <memory>
|
2014-05-26 00:50:25 -05:00
|
|
|
|
2014-05-26 11:47:15 -05:00
|
|
|
#define BOOST_TEST_MODULE BoxManagereTests
|
2015-08-10 06:06:50 -05:00
|
|
|
|
2014-05-26 00:50:25 -05:00
|
|
|
#include <boost/test/unit_test.hpp>
|
2015-08-10 06:06:50 -05:00
|
|
|
#include <boost/filesystem.hpp>
|
2014-05-26 00:50:25 -05:00
|
|
|
#include <boost/date_time/posix_time/posix_time.hpp>
|
|
|
|
|
|
|
|
#include <opm/parser/eclipse/EclipseState/Grid/Box.hpp>
|
2017-05-24 07:48:27 -05:00
|
|
|
#include <opm/parser/eclipse/EclipseState/Grid/BoxManager.hpp>
|
2014-05-26 00:50:25 -05:00
|
|
|
|
|
|
|
BOOST_AUTO_TEST_CASE(CreateBox) {
|
2019-10-04 09:49:18 -05:00
|
|
|
Opm::EclipseGrid grid(4,3,2);
|
|
|
|
Opm::Box box(grid);
|
2014-05-26 00:50:25 -05:00
|
|
|
BOOST_CHECK_EQUAL( 24U , box.size() );
|
|
|
|
BOOST_CHECK( box.isGlobal() );
|
2020-09-29 06:54:21 -05:00
|
|
|
BOOST_CHECK_EQUAL( 4U , box.getDim(0) );
|
|
|
|
BOOST_CHECK_EQUAL( 3U , box.getDim(1) );
|
|
|
|
BOOST_CHECK_EQUAL( 2U , box.getDim(2) );
|
2014-12-08 09:34:28 -06:00
|
|
|
|
2014-05-26 00:50:25 -05:00
|
|
|
BOOST_CHECK_THROW( box.getDim(5) , std::invalid_argument);
|
2014-05-26 11:47:15 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
BOOST_AUTO_TEST_CASE(CreateSubBox) {
|
2019-10-04 09:49:18 -05:00
|
|
|
Opm::EclipseGrid grid(10,10,10);
|
|
|
|
Opm::Box globalBox(grid);
|
2014-05-26 11:47:15 -05:00
|
|
|
|
2019-10-04 09:49:18 -05:00
|
|
|
BOOST_CHECK_THROW( new Opm::Box( grid , -1 , 9 , 1 , 8 , 1, 8) , std::invalid_argument); // Negative throw
|
|
|
|
BOOST_CHECK_THROW( new Opm::Box( grid , 1 , 19 , 1 , 8 , 1, 8) , std::invalid_argument); // Bigger than global: throw
|
|
|
|
BOOST_CHECK_THROW( new Opm::Box( grid , 9 , 1 , 1 , 8 , 1, 8) , std::invalid_argument); // Inverted order: throw
|
2014-12-08 09:34:28 -06:00
|
|
|
|
2019-10-04 09:49:18 -05:00
|
|
|
Opm::Box subBox1(grid, 0,9,0,9,0,9);
|
2014-05-26 11:47:15 -05:00
|
|
|
BOOST_CHECK( subBox1.isGlobal());
|
|
|
|
|
2014-12-08 09:34:28 -06:00
|
|
|
|
2019-10-04 09:49:18 -05:00
|
|
|
Opm::Box subBox2(grid, 1,3,1,4,1,5);
|
2014-05-26 11:47:15 -05:00
|
|
|
BOOST_CHECK( !subBox2.isGlobal());
|
|
|
|
BOOST_CHECK_EQUAL( 60U , subBox2.size() );
|
2014-05-26 00:50:25 -05:00
|
|
|
}
|
2014-05-27 11:30:36 -05:00
|
|
|
|
|
|
|
|
|
|
|
BOOST_AUTO_TEST_CASE(BoxEqual) {
|
2019-10-04 09:49:18 -05:00
|
|
|
Opm::EclipseGrid grid1(10,10,10);
|
|
|
|
Opm::EclipseGrid grid3(10,10,11);
|
|
|
|
Opm::EclipseGrid grid4(20,20,20);
|
|
|
|
Opm::Box globalBox1( grid1 );
|
|
|
|
Opm::Box globalBox2( grid1 );
|
|
|
|
Opm::Box globalBox3( grid3 );
|
|
|
|
|
|
|
|
Opm::Box globalBox4(grid4);
|
|
|
|
Opm::Box subBox1( grid1 , 0 , 9 , 0 , 9 , 0, 9);
|
|
|
|
Opm::Box subBox4( grid4 , 0 , 9 , 0 , 9 , 0, 9);
|
|
|
|
Opm::Box subBox5( grid4 , 10 , 19 , 10 , 19 , 10, 19);
|
2014-12-08 09:34:28 -06:00
|
|
|
|
2014-05-27 11:30:36 -05:00
|
|
|
BOOST_CHECK( globalBox1.equal( globalBox2 ));
|
|
|
|
BOOST_CHECK( !globalBox1.equal( globalBox3 ));
|
|
|
|
BOOST_CHECK( globalBox1.equal( subBox1 ));
|
|
|
|
|
|
|
|
BOOST_CHECK( !globalBox4.equal( subBox4 ));
|
|
|
|
BOOST_CHECK( !subBox4.equal( subBox5 ));
|
|
|
|
}
|
2014-05-30 03:08:35 -05:00
|
|
|
|
2017-05-24 07:48:27 -05:00
|
|
|
BOOST_AUTO_TEST_CASE(CreateBoxManager) {
|
2019-10-04 09:49:18 -05:00
|
|
|
Opm::EclipseGrid grid(10,10,10);
|
|
|
|
Opm::BoxManager boxManager(grid);
|
|
|
|
Opm::Box box(grid);
|
2017-05-24 07:48:27 -05:00
|
|
|
|
|
|
|
BOOST_CHECK( box.equal( boxManager.getActiveBox()) );
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
BOOST_AUTO_TEST_CASE(TestInputBox) {
|
2019-10-04 09:49:18 -05:00
|
|
|
Opm::EclipseGrid grid(10,10,10);
|
|
|
|
Opm::BoxManager boxManager(grid);
|
|
|
|
Opm::Box inputBox( grid, 0,4,0,4,0,4);
|
|
|
|
Opm::Box globalBox( grid );
|
2017-05-24 07:48:27 -05:00
|
|
|
|
|
|
|
boxManager.setInputBox( 0,4,0,4,0,4 );
|
|
|
|
BOOST_CHECK( inputBox.equal( boxManager.getActiveBox()) );
|
|
|
|
boxManager.endSection();
|
2019-10-04 09:49:18 -05:00
|
|
|
BOOST_CHECK( boxManager.getActiveBox().equal(globalBox));
|
2017-05-24 07:48:27 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
BOOST_AUTO_TEST_CASE(TestKeywordBox) {
|
2019-10-04 09:49:18 -05:00
|
|
|
Opm::EclipseGrid grid(10,10,10);
|
|
|
|
Opm::BoxManager boxManager(grid);
|
|
|
|
Opm::Box inputBox( grid, 0,4,0,4,0,4);
|
|
|
|
Opm::Box keywordBox( grid, 0,2,0,2,0,2);
|
|
|
|
Opm::Box globalBox( grid );
|
2017-05-24 07:48:27 -05:00
|
|
|
|
|
|
|
|
|
|
|
boxManager.setInputBox( 0,4,0,4,0,4 );
|
2019-10-04 09:49:18 -05:00
|
|
|
BOOST_CHECK( inputBox.equal( boxManager.getActiveBox()) );
|
|
|
|
|
2017-05-24 07:48:27 -05:00
|
|
|
boxManager.setKeywordBox( 0,2,0,2,0,2 );
|
|
|
|
BOOST_CHECK( keywordBox.equal( boxManager.getActiveBox()) );
|
|
|
|
|
|
|
|
// Must end keyword first
|
|
|
|
BOOST_CHECK_THROW( boxManager.endSection() , std::invalid_argument );
|
|
|
|
|
|
|
|
boxManager.endKeyword();
|
|
|
|
BOOST_CHECK( inputBox.equal( boxManager.getActiveBox()) );
|
|
|
|
|
|
|
|
boxManager.endSection();
|
2019-10-04 09:49:18 -05:00
|
|
|
BOOST_CHECK( boxManager.getActiveBox().equal(globalBox));
|
2017-05-24 07:48:27 -05:00
|
|
|
}
|
2018-01-17 11:19:12 -06:00
|
|
|
|
|
|
|
|
|
|
|
BOOST_AUTO_TEST_CASE(BoxNineArg) {
|
|
|
|
const size_t nx = 10;
|
|
|
|
const size_t ny = 7;
|
|
|
|
const size_t nz = 6;
|
2019-10-04 09:49:18 -05:00
|
|
|
Opm::EclipseGrid grid(nx,ny,nz);
|
|
|
|
BOOST_CHECK_NO_THROW( Opm::Box(grid,0,7,0,5,1,2) );
|
2018-01-17 11:19:12 -06:00
|
|
|
|
|
|
|
// J2 < J1
|
2019-10-04 09:49:18 -05:00
|
|
|
BOOST_CHECK_THROW( Opm::Box(grid,1,1,4,3,2,2), std::invalid_argument);
|
2018-01-17 11:19:12 -06:00
|
|
|
|
|
|
|
// K2 >= Nz
|
2019-10-04 09:49:18 -05:00
|
|
|
BOOST_CHECK_THROW( Opm::Box(grid,1,1,2,2,3,nz), std::invalid_argument);
|
|
|
|
}
|
|
|
|
|
|
|
|
BOOST_AUTO_TEST_CASE(TestKeywordBox2) {
|
|
|
|
Opm::EclipseGrid grid(10,10,10);
|
|
|
|
std::vector<int> actnum(grid.getCartesianSize(), 1);
|
|
|
|
actnum[0] = 0;
|
|
|
|
grid.resetACTNUM(actnum);
|
|
|
|
|
|
|
|
Opm::BoxManager boxManager(grid);
|
|
|
|
const auto& box = boxManager.getActiveBox();
|
|
|
|
|
|
|
|
for (const auto& p : box.index_list())
|
2019-10-21 08:45:39 -05:00
|
|
|
BOOST_CHECK_EQUAL(p.active_index + 1, p.global_index);
|
2019-10-04 09:49:18 -05:00
|
|
|
BOOST_CHECK_EQUAL(box.index_list().size() + 1, grid.getCartesianSize());
|
2019-10-21 08:45:39 -05:00
|
|
|
|
2020-09-03 10:17:38 -05:00
|
|
|
const auto& global_index_list = box.global_index_list();
|
|
|
|
BOOST_CHECK_EQUAL( global_index_list.size(), grid.getCartesianSize());
|
|
|
|
const auto& c0 = global_index_list[0];
|
2020-09-29 06:54:21 -05:00
|
|
|
BOOST_CHECK_EQUAL(c0.global_index, 0U);
|
2020-09-03 10:17:38 -05:00
|
|
|
BOOST_CHECK_EQUAL(c0.active_index, c0.global_index);
|
2020-09-29 06:54:21 -05:00
|
|
|
BOOST_CHECK_EQUAL(c0.data_index, 0U);
|
2019-10-21 08:45:39 -05:00
|
|
|
|
|
|
|
Opm::Box box2(grid,9,9,9,9,0,9);
|
|
|
|
const auto& il = box2.index_list();
|
2020-09-29 06:54:21 -05:00
|
|
|
BOOST_CHECK_EQUAL(il.size(), 10U);
|
2019-10-21 08:45:39 -05:00
|
|
|
|
|
|
|
for (std::size_t i=0; i < 10; i++) {
|
|
|
|
BOOST_CHECK_EQUAL(il[i].data_index, i);
|
|
|
|
BOOST_CHECK_EQUAL(il[i].global_index, 99 + i*100);
|
|
|
|
BOOST_CHECK_EQUAL(il[i].active_index, 98 + i*100);
|
|
|
|
}
|
2018-01-17 11:19:12 -06:00
|
|
|
}
|