Ejemplo n.º 1
0
    def test_runpath(self):
        with ErtTestContext("ert/server/rpc/simulation_context_runpath",
                            self.config2) as test_context:
            ert = test_context.getErt()
            sys.stderr.write("cwd: %s \n" % os.getcwd())
            size = 10

            fs = ert.getEnkfFsManager().getCurrentFileSystem()
            parameters = ert.ensembleConfig().getKeylistFromVarType(
                EnkfVarType.PARAMETER)
            ert.getEnkfFsManager().initializeFromScratch(
                parameters, 0, size - 1)
            simulation_context = SimulationContext(ert, size)

            for iens in range(size):
                state = ert.getRealisation(iens)
                if iens % 2 == 0:
                    state.addSubstKeyword("GEO_ID", "EVEN")
                else:
                    state.addSubstKeyword("GEO_ID", "ODD")
                simulation_context.addSimulation(iens, fs)

            while simulation_context.isRunning():
                time.sleep(1.0)

            for iens in range(size):
                if iens % 2 == 0:
                    path = "simulations/EVEN/realisation-%d/iter-%d" % (iens,
                                                                        0)
                    self.assertTrue(os.path.isdir(path))
                else:
                    path = "simulations/ODD/realisation-%d/iter-%d" % (iens, 0)
                    self.assertTrue(os.path.isdir(path))
Ejemplo n.º 2
0
    def test_runpath(self):
        with ErtTestContext("ert/server/rpc/simulation_context_runpath", self.config2) as test_context:
            ert = test_context.getErt()
            sys.stderr.write("cwd: %s \n" % os.getcwd())
            size = 10

            fs = ert.getEnkfFsManager().getCurrentFileSystem()
            parameters = ert.ensembleConfig().getKeylistFromVarType(EnkfVarType.PARAMETER)
            ert.getEnkfFsManager().initializeFromScratch(parameters, 0, size - 1)
            simulation_context = SimulationContext(ert, size)
            
            for iens in range(size):
                state = ert.getRealisation(iens)
                if iens % 2 == 0:
                    state.addSubstKeyword("GEO_ID", "EVEN")
                else:
                    state.addSubstKeyword("GEO_ID", "ODD")
                simulation_context.addSimulation(iens , fs)

            while simulation_context.isRunning():
                time.sleep(1.0)

            for iens in range(size):
                if iens % 2 == 0:
                    path = "simulations/EVEN/realisation-%d/iter-%d" % (iens , 0)
                    self.assertTrue( os.path.isdir(path) )
                else:
                    path = "simulations/ODD/realisation-%d/iter-%d" % (iens , 0)
                    self.assertTrue( os.path.isdir(path) )

            pfx = 'SimulationContext('
            self.assertEqual(pfx, repr(simulation_context)[:len(pfx)])
Ejemplo n.º 3
0
    def startSimulationBatch(self, initialization_case_name, simulation_count):
        with self._session.lock:
            if not self.isRunning():
                self._session.simulation_context = None
                self._session.init_case_name = initialization_case_name

                self.ert.addDataKW("<WPRO_RUN_COUNT>", str(self._session.batch_number))
                self.ert.addDataKW("<ELCO_RUN_COUNT>", str(self._session.batch_number))
                self._session.batch_number += 1
                self._session.simulation_context = SimulationContext(self.ert, simulation_count, verbose=self._verbose_queue)
Ejemplo n.º 4
0
    def test_simulation_context(self):
        with ErtTestContext("ert/server/rpc/simulation_context",
                            self.config1) as test_context:
            ert = test_context.getErt()

            size = 4
            first_half = initializeCase(ert, "first_half", size)
            other_half = initializeCase(ert, "other_half", size)

            simulation_context = SimulationContext(ert, size)

            for iens in range(size):
                if iens % 2 == 0:
                    simulation_context.addSimulation(iens, first_half)
                else:
                    simulation_context.addSimulation(iens, other_half)
                self.assertFalse(
                    simulation_context.isRealizationFinished(iens))

            with self.assertRaises(UserWarning):
                simulation_context.addSimulation(size, first_half)

            with self.assertRaises(UserWarning):
                simulation_context.addSimulation(0, first_half)

            while simulation_context.isRunning():
                time.sleep(1.0)

            self.assertEqual(simulation_context.getNumFailed(), 0)
            self.assertEqual(simulation_context.getNumRunning(), 0)
            self.assertEqual(simulation_context.getNumSuccess(), size)

            first_half_state_map = first_half.getStateMap()
            other_half_state_map = other_half.getStateMap()

            for iens in range(size):
                self.assertTrue(simulation_context.didRealizationSucceed(iens))
                self.assertFalse(simulation_context.didRealizationFail(iens))
                self.assertTrue(simulation_context.isRealizationFinished(iens))
                if iens % 2 == 0:
                    self.assertEqual(first_half_state_map[iens],
                                     RealizationStateEnum.STATE_HAS_DATA)
                    self.assertEqual(other_half_state_map[iens],
                                     RealizationStateEnum.STATE_INITIALIZED)
                else:
                    self.assertEqual(first_half_state_map[iens],
                                     RealizationStateEnum.STATE_INITIALIZED)
                    self.assertEqual(other_half_state_map[iens],
                                     RealizationStateEnum.STATE_HAS_DATA)
Ejemplo n.º 5
0
    def test_simulation_context(self):
        with ErtTestContext("ert/server/rpc/simulation_context", self.config1) as test_context:
            ert = test_context.getErt()
            
            size = 4
            first_half = initializeCase(ert, "first_half", size)
            other_half = initializeCase(ert, "other_half", size)

            simulation_context = SimulationContext(ert, size)

            for iens in range(size):
                if iens % 2 == 0:
                    simulation_context.addSimulation(iens, first_half)
                else:
                    simulation_context.addSimulation(iens, other_half)
                self.assertFalse(simulation_context.isRealizationFinished(iens))

            with self.assertRaises(UserWarning):
                simulation_context.addSimulation(size, first_half)

            with self.assertRaises(UserWarning):
                simulation_context.addSimulation(0, first_half)

            while simulation_context.isRunning():
                time.sleep(1.0)

            self.assertEqual(simulation_context.getNumFailed(), 0)
            self.assertEqual(simulation_context.getNumRunning(), 0)
            self.assertEqual(simulation_context.getNumSuccess(), size)

            first_half_state_map = first_half.getStateMap()
            other_half_state_map = other_half.getStateMap()

            for iens in range(size):
                self.assertTrue(simulation_context.didRealizationSucceed(iens))
                self.assertFalse(simulation_context.didRealizationFail(iens))
                self.assertTrue(simulation_context.isRealizationFinished(iens))
                if iens % 2 == 0:
                    self.assertEqual(first_half_state_map[iens], RealizationStateEnum.STATE_HAS_DATA)
                    self.assertEqual(other_half_state_map[iens], RealizationStateEnum.STATE_INITIALIZED)
                else:
                    self.assertEqual(first_half_state_map[iens], RealizationStateEnum.STATE_INITIALIZED)
                    self.assertEqual(other_half_state_map[iens], RealizationStateEnum.STATE_HAS_DATA)

            pfx = 'SimulationContext('
            self.assertEqual(pfx, repr(simulation_context)[:len(pfx)])