Skip to content

Commit

Permalink
Merge pull request usgs#248 from jtwhite79/feat_mou
Browse files Browse the repository at this point in the history
Feat mou
  • Loading branch information
jtwhite79 authored Apr 25, 2023
2 parents 4381ae0 + 7994d04 commit 0c315a4
Show file tree
Hide file tree
Showing 20 changed files with 757 additions and 428 deletions.
28 changes: 14 additions & 14 deletions .github/workflows/ci.yml
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,7 @@ jobs:
fail-fast: false
matrix:
os: [windows-latest, ubuntu-latest]
python-version: [3.8] # , 3.7, 3.6]
python-version: [3.9] # , 3.7, 3.6]
run-type: [std]
# test_repo: [""]
# test_dir: [""]
Expand Down Expand Up @@ -51,14 +51,14 @@ jobs:
# if: ${{ runner.os == 'Windows' }}
- uses: seanmiddleditch/gha-setup-ninja@master

- name: Cache Miniconda
uses: actions/[email protected]
env:
# Increase this value to reset cache if environment.yml has changed
CACHE_NUMBER: 0
with:
path: ~/conda_pkgs_dir
key: ${{ runner.os }}-${{ matrix.python-version }}-${{ matrix.run-type }}-${{ env.CACHE_NUMBER }}-${{ hashFiles('etc/environment.yml') }}
# - name: Cache Miniconda
# uses: actions/[email protected]
# env:
# # Increase this value to reset cache if environment.yml has changed
# CACHE_NUMBER: 0
# with:
# path: ~/conda_pkgs_dir
# key: ${{ runner.os }}-${{ matrix.python-version }}-${{ matrix.run-type }}-${{ env.CACHE_NUMBER }}-${{ hashFiles('etc/environment.yml') }}

- name: Set Windows ENV
if: runner.os == 'Windows'
Expand Down Expand Up @@ -115,11 +115,11 @@ jobs:
- name: Install Flopy & pyemu?
shell: bash -l {0}
run: |
git clone -b develop --depth 1 https://github.com/modflowpy/flopy.git
cd flopy
python setup.py install
cd ..
pip install https://github.com/modflowpy/pymake/zipball/master
# git clone -b develop --depth 1 https://github.com/modflowpy/flopy.git
# cd flopy
# python setup.py install
# cd ..
# pip install https://github.com/modflowpy/pymake/zipball/master
git clone -b develop --depth 1 https://github.com/pypest/pyemu.git
cd pyemu
python setup.py install
Expand Down
Binary file added documentation/pestpp_users_guide_v5.2.2.docx
Binary file not shown.
61 changes: 31 additions & 30 deletions documentation/pestpp_users_manual.md

Large diffs are not rendered by default.

28 changes: 17 additions & 11 deletions etc/environment.yml
Original file line number Diff line number Diff line change
@@ -1,15 +1,21 @@
name: pyemu
channels:
- defaults
dependencies:
- numpy
- pandas
- conda-forge
dependencies:
# required
- python>=3.9
- numpy>=1.15.0
- pandas
- scipy
# optional
- matplotlib>=1.4.0
- pyshp
- jinja2
# tests
- coveralls
- nose-timer
- nbsphinx
- matplotlib
- coverage
- scipy
- shapely>=1.8
- tomli
- pip
- pytest-xdist
- nbmake
- shapely
- flopy
- mfpymake
2 changes: 1 addition & 1 deletion src/libs/common/config_os.h
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@
#define CONFIG_OS_H_


#define PESTPP_VERSION "5.2.1";
#define PESTPP_VERSION "5.2.3";

#if defined(_WIN32) || defined(_WIN64)
#define OS_WIN
Expand Down
80 changes: 52 additions & 28 deletions src/libs/pestpp_common/EnsembleMethodUtils.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -4406,28 +4406,36 @@ void ParChangeSummarizer::summarize(ParameterEnsemble &pe, string filename)
stringstream ss;
ofstream &frec = file_manager_ptr->rec_ofstream();
ss << endl << " --- parameter group change summmary --- " << endl;
ss << " (compared to the initial ensemble using active realizations)" << endl;
//ss << " (compared to the initial ensemble using active realizations)" << endl;
cout << ss.str();
frec << ss.str();
ss.str("");
ss << setw(mxlen) << left << "group" << setw(12) << right << "mean change" << setw(12) << "std change" << setw(16);
ss << "n at/near bnds" << setw(16) << "% at/near bnds";
ss << setw(10) << "init CV" << setw(10) << "curr CV" << setw(10) << "n CV decr" << endl;
ss << setw(mxlen) << left << "group" << setw(10) << right << "mean chg" << setw(10) << "std chg";
ss << setw(10) << "n at ubnd" << setw(10) << "% at ubnd";
ss << setw(10) << "n at lbnd" << setw(10) << "% at lbnd";
ss << setw(10) << "init CV" << setw(10) << "curr CV" << setw(10) << endl;
cout << ss.str();
frec << ss.str();


int i = 0;
int num_out;
int percent_out;
for (auto &grp_name : grp_names)
{
double mean_diff = mean_change[grp_name];
double std_diff = std_change[grp_name];
int num_out = num_at_bounds[grp_name];
int percent_out = percent_at_bounds[grp_name];

ss.str("");
ss << setw(mxlen) << left << pest_utils::lower_cp(grp_name) << setw(12) << right << mean_diff * 100.0 << setw(12) << std_diff * 100.0 << setw(16);
ss << num_out << setw(16) << setprecision(2) << percent_out;
ss << setw(10) << setprecision(2) << init_cv[grp_name] << setw(10) << curr_cv[grp_name] << setw(10) << setprecision(2) << num_dec_cv[grp_name] << endl;
ss << setw(mxlen) << left << pest_utils::lower_cp(grp_name) << setw(10) << setprecision(2) << right << mean_diff * 100.0;
ss << setw(10) << setprecision(2) << std_diff * 100.0;
num_out = num_at_ubound[grp_name];
percent_out = percent_at_ubound[grp_name];
ss << setw(10) << num_out << setw(10) << setprecision(2) << percent_out;
num_out = num_at_lbound[grp_name];
percent_out = percent_at_lbound[grp_name];
ss << setw(10) << num_out << setw(10) << setprecision(2) << percent_out;
ss << setw(10) << setprecision(2) << init_cv[grp_name] << setw(10) << curr_cv[grp_name] << setw(10) << setprecision(2) << endl;
if (i < 15)
cout << ss.str();
frec << ss.str();
Expand All @@ -4436,7 +4444,9 @@ void ParChangeSummarizer::summarize(ParameterEnsemble &pe, string filename)

ss.str("");
ss << " Note: parameter change summary sorted according to abs 'mean change'." << endl;
ss << " 'n CV decr' is the number of parameters with current CV less " << cv_dec_threshold*100.0 << "% of the initial CV" << endl;
//ss << " 'n CV decr' is the number of parameters with current CV less " << cv_dec_threshold*100.0 << "% of the initial CV" << endl;
ss << " Note: the parameter change statistics implicitly include the effect of " << endl;
ss << " realizations that have failed or have been dropped." << endl;
cout << ss.str();
frec << ss.str();
if (grp_names.size() > 15)
Expand All @@ -4460,11 +4470,13 @@ void ParChangeSummarizer::write_to_csv(string& filename)
if (f.bad())
throw runtime_error("ParChangeSummarizer::write_to_csv() error opening file " + filename);

f << "group,mean_change,std_change,num_at_near_bounds,percent_at_near_bounds,initial_cv,current_cv,num_cv_dec" << endl;
f << "group,mean_change,std_change,num_at_near_lbound,percent_at_near_lbound,num_at_near_ubound,percent_at_near_ubound,initial_cv,current_cv" << endl;
for (auto grp_name : base_pe_ptr->get_pest_scenario_ptr()->get_ctl_ordered_par_group_names())
{
f << pest_utils::lower_cp(grp_name) << "," << mean_change[grp_name]*100.0 << "," << std_change[grp_name]*100.0 << ",";
f << num_at_bounds[grp_name] << "," << percent_at_bounds[grp_name] <<","<< init_cv[grp_name] << "," << curr_cv[grp_name] << "," << num_dec_cv[grp_name] << endl;
f << num_at_lbound[grp_name] << "," << percent_at_lbound[grp_name];
f << num_at_ubound[grp_name] << "," << percent_at_ubound[grp_name];
f <<","<< init_cv[grp_name] << "," << curr_cv[grp_name] << endl;
}
f.close();
file_manager_ptr->rec_ofstream() << "...saved parameter change summary to " << filename << endl;
Expand All @@ -4477,11 +4489,13 @@ void ParChangeSummarizer:: update(ParameterEnsemble& pe)
{
mean_change.clear();
std_change.clear();
num_at_bounds.clear();
percent_at_bounds.clear();
num_at_ubound.clear();
percent_at_ubound.clear();
num_at_lbound.clear();
percent_at_lbound.clear();
init_cv.clear();
curr_cv.clear();
num_dec_cv.clear();

//pair<map<string, double>, map<string, double>> moments = pe.get_moment_maps();
//init_moments = base_pe_ptr->get_moment_maps(pe.get_real_names());
map<string, double> mean_map, std_map;
Expand All @@ -4506,7 +4520,7 @@ void ParChangeSummarizer:: update(ParameterEnsemble& pe)
map<string, int> idx_map;
for (int i = 0; i < pnames.size(); i++)
idx_map[pnames[i]] = i;
int num_out, num_pars;
int num_out_u,num_out_l, num_pars;
int num_reals = pe.get_real_names().size();
Eigen::ArrayXd arr;
int mean_size, std_size,icv_size,ccv_size;
Expand All @@ -4517,7 +4531,8 @@ void ParChangeSummarizer:: update(ParameterEnsemble& pe)
icv_size = 0; ccv_size = 0;
ndec_cv = 0;
num_pars = pargp2par_map[grp_name].size();
num_out = 0;
num_out_u = 0;
num_out_l = 0;
mean_size = 0;
std_size = 0;
for (auto& par_name : pargp2par_map[grp_name])
Expand All @@ -4526,8 +4541,10 @@ void ParChangeSummarizer:: update(ParameterEnsemble& pe)
for (int i = 0; i < num_reals; i++)
{
v = arr[i];
if ((v > (ub[par_name] * 1.01)) || (v < (lb[par_name] * 0.99)))
num_out++;
if (v > (ub[par_name] * 1.01))
num_out_u++;
else if (v < (lb[par_name] * 0.99))
num_out_l++;
}
value1 = init_moments.first[par_name];
value2 = value1 - mean_map[par_name];
Expand Down Expand Up @@ -4590,17 +4607,22 @@ void ParChangeSummarizer:: update(ParameterEnsemble& pe)


double percent_out = 0;
if (num_pars > 0)
percent_out = double(num_out) / double(num_pars * num_reals) * 100;


mean_change[grp_name] = mean_diff;
std_change[grp_name] = std_diff;
num_at_bounds[grp_name] = num_out;
percent_at_bounds[grp_name] = percent_out;
curr_cv[grp_name] = ccv;
num_at_lbound[grp_name] = num_out_l;
num_at_ubound[grp_name] = num_out_u;
percent_out = 0.0;
if (num_pars > 0)
percent_out = double(num_out_l) / double(num_pars * num_reals) * 100;
percent_at_lbound[grp_name] = percent_out;
percent_out = 0.0;
if (num_pars > 0)
percent_out = double(num_out_u) / double(num_pars * num_reals) * 100;
percent_at_ubound[grp_name] = percent_out;
curr_cv[grp_name] = ccv;
init_cv[grp_name] = icv;
num_dec_cv[grp_name] = ndec_cv;

}
}

Expand Down Expand Up @@ -5524,7 +5546,8 @@ void EnsembleMethod::initialize(int cycle, bool run, bool use_existing)
{
message(1, "initializing localizer");
bool forgive_missing = pest_scenario.get_pestpp_options().get_ies_localizer_forgive_missing();
use_localizer = localizer.initialize(performance_log, forgive_missing);
ofstream& frec = file_manager.rec_ofstream();
use_localizer = localizer.initialize(performance_log, frec, forgive_missing);
}
num_threads = pest_scenario.get_pestpp_options().get_ies_num_threads();
if (!use_localizer)
Expand Down Expand Up @@ -6130,7 +6153,8 @@ void EnsembleMethod::initialize(int cycle, bool run, bool use_existing)
message(1, "updating localizer");
if (localizer.get_use())
localizer.get_orgmat_ptr()->clear_names();
use_localizer = localizer.initialize(performance_log, true);
ofstream& frec = file_manager.rec_ofstream();
use_localizer = localizer.initialize(performance_log, frec, true);
}
}
}
Expand Down
7 changes: 4 additions & 3 deletions src/libs/pestpp_common/EnsembleMethodUtils.h
Original file line number Diff line number Diff line change
Expand Up @@ -175,9 +175,10 @@ class ParChangeSummarizer
map<string, double> std_change;
map<string, double> init_cv;
map<string, double> curr_cv;
map<string, int> num_dec_cv;
map<string, int> num_at_bounds;
map<string, int> percent_at_bounds;
map<string, int> num_at_ubound;
map<string, int> percent_at_ubound;
map<string, int> num_at_lbound;
map<string, int> percent_at_lbound;

void update(ParameterEnsemble& pe);
void write_to_csv(string& filename);
Expand Down
1 change: 1 addition & 0 deletions src/libs/pestpp_common/Jacobian.cpp
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
/*
This file is part of PEST++.
PEST++ is free software: you can redistribute it and/or modify
Expand Down
Loading

0 comments on commit 0c315a4

Please sign in to comment.