-
Notifications
You must be signed in to change notification settings - Fork 108
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Add design matrix valudation in ensemble experiment panel
- Prefil active realization box with realizations from design matrix - Use design_matrix parameters in ensemble experiment - add test run cli with design matrix and poly example
- Loading branch information
Showing
4 changed files
with
164 additions
and
8 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,93 @@ | ||
import os | ||
import stat | ||
from textwrap import dedent | ||
|
||
import numpy as np | ||
import pandas as pd | ||
import pytest | ||
|
||
from ert.config import ErtConfig | ||
from ert.mode_definitions import ENSEMBLE_EXPERIMENT_MODE | ||
from ert.storage import open_storage | ||
from tests.ert.ui_tests.cli.run_cli import run_cli | ||
|
||
|
||
@pytest.mark.usefixtures("copy_poly_case") | ||
def test_run_poly_example_with_design_matrix(): | ||
design_matrix = "poly_design.xlsx" | ||
num_realizations = 10 | ||
a_values = list(range(num_realizations)) | ||
design_matrix_df = pd.DataFrame( | ||
{ | ||
"REAL": list(range(num_realizations)), | ||
"a": a_values, | ||
} | ||
) | ||
default_sheet_df = pd.DataFrame([["b", 1], ["c", 2]]) | ||
with pd.ExcelWriter(design_matrix) as xl_write: | ||
design_matrix_df.to_excel(xl_write, index=False, sheet_name="DesignSheet01") | ||
default_sheet_df.to_excel( | ||
xl_write, index=False, sheet_name="DefaultSheet", header=False | ||
) | ||
|
||
with open("poly.ert", "w", encoding="utf-8") as fout: | ||
fout.write( | ||
dedent( | ||
"""\ | ||
QUEUE_OPTION LOCAL MAX_RUNNING 10 | ||
RUNPATH poly_out/realization-<IENS>/iter-<ITER> | ||
NUM_REALIZATIONS 10 | ||
MIN_REALIZATIONS 1 | ||
GEN_DATA POLY_RES RESULT_FILE:poly.out | ||
DESIGN_MATRIX poly_design.xlsx DESIGN_SHEET:DesignSheet01 DEFAULT_SHEET:DefaultSheet | ||
INSTALL_JOB poly_eval POLY_EVAL | ||
FORWARD_MODEL poly_eval | ||
""" | ||
) | ||
) | ||
|
||
with open("poly_eval.py", "w", encoding="utf-8") as f: | ||
f.write( | ||
dedent( | ||
"""\ | ||
#!/usr/bin/env python | ||
import numpy as np | ||
import sys | ||
import json | ||
def _load_coeffs(filename): | ||
with open(filename, encoding="utf-8") as f: | ||
return json.load(f)["DESIGN_MATRIX"] | ||
def _evaluate(coeffs, x): | ||
return coeffs["a"] * x**2 + coeffs["b"] * x + coeffs["c"] | ||
if __name__ == "__main__": | ||
coeffs = _load_coeffs("parameters.json") | ||
output = [_evaluate(coeffs, x) for x in range(10)] | ||
with open("poly.out", "w", encoding="utf-8") as f: | ||
f.write("\\n".join(map(str, output))) | ||
""" | ||
) | ||
) | ||
os.chmod( | ||
"poly_eval.py", | ||
os.stat("poly_eval.py").st_mode | stat.S_IXUSR | stat.S_IXGRP | stat.S_IXOTH, | ||
) | ||
|
||
run_cli( | ||
ENSEMBLE_EXPERIMENT_MODE, | ||
"--disable-monitor", | ||
"poly.ert", | ||
"--experiment-name", | ||
"test-experiment", | ||
) | ||
storage_path = ErtConfig.from_file("poly.ert").ens_path | ||
with open_storage(storage_path) as storage: | ||
experiment = storage.get_experiment_by_name("test-experiment") | ||
params = experiment.get_ensemble_by_name("default").load_parameters( | ||
"DESIGN_MATRIX" | ||
)["values"] | ||
np.testing.assert_array_equal(params[:, 0], a_values) | ||
np.testing.assert_array_equal(params[:, 1], 10 * [1]) | ||
np.testing.assert_array_equal(params[:, 2], 10 * [2]) |