///////////////////////////////////////////////////////////////////////////////// // // Copyright (C) 2011-2012 Statoil ASA, Ceetron AS // // ResInsight 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. // // ResInsight 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 at // for more details. // ///////////////////////////////////////////////////////////////////////////////// #include "RIStdInclude.h" #include "RimReservoirView.h" #include "RimStatisticalCollection.h" #include "RimIdenticalGridCaseGroup.h" CAF_PDM_SOURCE_INIT(RimStatisticalCollection, "RimStatisticalCollection"); //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- RimStatisticalCollection::RimStatisticalCollection() : PdmObject() { CAF_PDM_InitObject("Derived Statistics", "", "", ""); CAF_PDM_InitFieldNoDefault(&reservoirs, "Reservoirs", "", "", "", ""); } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- RimStatisticalCollection::~RimStatisticalCollection() { reservoirs.deleteAllChildObjects(); } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- RimStatisticalCalculation* RimStatisticalCollection::createAndAppendStatisticalCalculation() { RimStatisticalCalculation* newObject = new RimStatisticalCalculation; RimIdenticalGridCaseGroup* gridCaseGroup = parentCaseGroup(); CVF_ASSERT(gridCaseGroup); CVF_ASSERT(gridCaseGroup->mainGrid()); newObject->setMainGrid(gridCaseGroup->mainGrid()); newObject->caseName = QString("Statistics ") + QString::number(reservoirs.size()+1); reservoirs.push_back(newObject); return newObject; } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- RimIdenticalGridCaseGroup* RimStatisticalCollection::parentCaseGroup() { std::vector parentObjects; this->parentObjectsOfType(parentObjects); if (parentObjects.size() > 0) { return parentObjects[0]; } return NULL; }