From be21e083deafa73c32a85e3df33d47e1f54da9ec Mon Sep 17 00:00:00 2001 From: "Yngve S. Kristiansen" Date: Tue, 22 Oct 2024 08:45:09 +0200 Subject: [PATCH] Check combined ds in _has_response --- src/ert/storage/local_ensemble.py | 27 ++++++++++++++++++--------- 1 file changed, 18 insertions(+), 9 deletions(-) diff --git a/src/ert/storage/local_ensemble.py b/src/ert/storage/local_ensemble.py index dfa0399474e..74b8d0e5ae2 100644 --- a/src/ert/storage/local_ensemble.py +++ b/src/ert/storage/local_ensemble.py @@ -301,19 +301,28 @@ def _responses_exist_for_realization( return True path = self._realization_dir(realization) - def _has_response(_key: str) -> bool: - if _key in self.experiment.response_key_to_response_type: - _response_type = self.experiment.response_key_to_response_type[_key] - return (path / f"{_response_type}.parquet").exists() - - return (path / f"{_key}.parquet").exists() + # Note: potential performance bottleneck, + # should be improved greatly by having statemap. + # Should also be faster due to lru cache on load_responses + def _has_response(_response_type: str) -> bool: + if (path / f"{_response_type}.parquet").exists(): + return True + + if (self.mount_point / f"{_response_type}.parquet").exists(): + return ( + realization + in self.load_responses( + _response_type, tuple(range(self.ensemble_size)) + )["realization"] + ) if key: - return _has_response(key) + response_type = self.experiment.response_key_to_response_type.get(key, key) + return _has_response(response_type) return all( - _has_response(response) - for response in self.experiment.response_configuration + _has_response(response_type) + for response_type in self.experiment.response_configuration ) def is_initalized(self) -> List[int]: