-
Notifications
You must be signed in to change notification settings - Fork 12
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Bias correction #292
Bias correction #292
Conversation
Update calls and dependencies to support newest xclim version
Else `make develop` fail to install the newer `gdal` using `pip` (compile error below). `gdal` was updated in requirements.txt in this commit 0c57bb4. ``` gcc -pthread -B /home/lvu/.conda/envs/raven/compiler_compat -Wl,--sysroot=/ -Wsign-compare -DNDEBUG -g -fwrapv -O3 -Wall -Wstrict-prototypes -fPIC -I../../port -I../../gcore -I../../alg -I../../ogr/ -I../../og r/ogrsf_frmts -I../../gnm -I../../apps -I/home/lvu/.conda/envs/raven/include/python3.7m -I/home/lvu/.conda/envs/raven/lib/python3.7/site-packages/numpy/core/include -I/home/lvu/.conda/envs/raven/include -c exten sions/gdal_wrap.cpp -o build/temp.linux-x86_64-3.7/extensions/gdal_wrap.o -I/home/lvu/.conda/envs/raven/include cc1plus: warning: command line option ‘-Wstrict-prototypes’ is valid for C/ObjC but not for C++ extensions/gdal_wrap.cpp: In function ‘OSRSpatialReferenceShadow* GDALDatasetShadow_GetSpatialRef(GDALDatasetShadow*)’: extensions/gdal_wrap.cpp:4672:32: error: ‘GDALGetSpatialRef’ was not declared in this scope OGRSpatialReferenceH ref = GDALGetSpatialRef(self); ^~~~~~~~~~~~~~~~~ ```
environment.yml: sync gdal version with requirements.txt Else `make develop` fail to install the newer `gdal` using `pip` (compile error below). `gdal` was updated in `requirements.txt` in this commit 0c57bb4. ``` gcc -pthread -B /home/lvu/.conda/envs/raven/compiler_compat -Wl,--sysroot=/ -Wsign-compare -DNDEBUG -g -fwrapv -O3 -Wall -Wstrict-prototypes -fPIC -I../../port -I../../gcore -I../../alg -I../../ogr/ -I../../og r/ogrsf_frmts -I../../gnm -I../../apps -I/home/lvu/.conda/envs/raven/include/python3.7m -I/home/lvu/.conda/envs/raven/lib/python3.7/site-packages/numpy/core/include -I/home/lvu/.conda/envs/raven/include -c exten sions/gdal_wrap.cpp -o build/temp.linux-x86_64-3.7/extensions/gdal_wrap.o -I/home/lvu/.conda/envs/raven/include cc1plus: warning: command line option ‘-Wstrict-prototypes’ is valid for C/ObjC but not for C++ extensions/gdal_wrap.cpp: In function ‘OSRSpatialReferenceShadow* GDALDatasetShadow_GetSpatialRef(GDALDatasetShadow*)’: extensions/gdal_wrap.cpp:4672:32: error: ‘GDALGetSpatialRef’ was not declared in this scope OGRSpatialReferenceH ref = GDALGetSpatialRef(self); ^~~~~~~~~~~~~~~~~ ```
"birdhouse/1-Datasets" was the first version and won't receive auto NCML deploy update anymore. Will be removed eventually to avoid future confusions.
tests + notebooks: use new official NCML link "birdhouse/1-Datasets" was the first version and won't receive auto NCML deploy update anymore. Will be removed eventually to avoid future confusions.
@tvlu can you check for the conflicts please? |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@Zeitsperre Few questions for you since I have not been following this branch.
.travis.yml
Outdated
@@ -56,6 +52,7 @@ jobs: | |||
branches: | |||
only: | |||
- master | |||
- bias_correction |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Why do we want to limit Travis-CI to only master
branch, then we have to add each dev branch manually, like this bias_correction
branch? @Zeitsperre (b5a3566)
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This can be removed. It was placed in order to trigger the bias_correction branch that PRs were merging to in a few instances. The reason why I set only to master is that otherwise we tend to get two duplicate sets of builds; one that is the pushes set against master and another that is the pushes set against the last version of master it stemmed from.
Since we only care about the current state of master, as all pushes must integrate these changes, there's nothing to gain except more redundant build checks.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I think the redundant build checks on master
branch will happen only once, when the PR is merged to master
.
Whereas instructions to build only the master
branch will not test any commits on any devel branches and force all devel branches to hardcode the devel branch name like we just saw.
I think having the redundant build on master
is a less bad of the 2 problems. Wonder what's your opinion about removing this "build only master
branch" instruction for all birds?
.travis.yml
Outdated
# - raven start --daemon --bind-host 0.0.0.0 --port 5000 | ||
- bash -c "source $HOME/miniconda3/bin/activate raven && make start" | ||
# - raven start --daemon --bind-host 0.0.0.0 --port 5000 | ||
- bash -c "source $HOME/miniconda3/bin/activate raven && pip install git+https://github.com/pydata/xarray.git@master" |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Is this install from xarray.git@master still necessary with xarray 0.16 from master
branch? @Zeitsperre (a125ff4)
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
With xarray at 0.16, the sdba functions that Pascal was working on are integrated, so no. This workaround can blissfully be thrown in the trash.
Running pep8 code style checks ... tests/test_bias_correction.py:8:1: W293 blank line contains whitespace tests/test_bias_correction.py:9:17: E225 missing whitespace around operator tests/test_bias_correction.py:9:121: E501 line too long (141 > 120 characters) tests/test_bias_correction.py:10:17: E225 missing whitespace around operator tests/test_bias_correction.py:10:121: E501 line too long (147 > 120 characters) tests/test_bias_correction.py:11:18: E225 missing whitespace around operator tests/test_bias_correction.py:12:1: W293 blank line contains whitespace tests/test_bias_correction.py:13:12: E225 missing whitespace around operator tests/test_bias_correction.py:14:12: E225 missing whitespace around operator tests/test_bias_correction.py:14:20: W291 trailing whitespace tests/test_bias_correction.py:15:1: W293 blank line contains whitespace tests/test_bias_correction.py:18:121: E501 line too long (143 > 120 characters) tests/test_bias_correction.py:19:73: E231 missing whitespace after ',' tests/test_bias_correction.py:19:121: E501 line too long (204 > 120 characters) tests/test_bias_correction.py:19:130: E231 missing whitespace after ',' tests/test_bias_correction.py:19:132: E231 missing whitespace after ',' tests/test_bias_correction.py:19:153: E231 missing whitespace after ',' tests/test_bias_correction.py:19:156: E231 missing whitespace after ',' tests/test_bias_correction.py:23:73: E231 missing whitespace after ',' tests/test_bias_correction.py:23:121: E501 line too long (204 > 120 characters) tests/test_bias_correction.py:23:130: E231 missing whitespace after ',' tests/test_bias_correction.py:23:132: E231 missing whitespace after ',' tests/test_bias_correction.py:23:153: E231 missing whitespace after ',' tests/test_bias_correction.py:23:156: E231 missing whitespace after ',' tests/test_bias_correction.py:24:73: E231 missing whitespace after ',' tests/test_bias_correction.py:24:121: E501 line too long (204 > 120 characters) tests/test_bias_correction.py:24:130: E231 missing whitespace after ',' tests/test_bias_correction.py:24:132: E231 missing whitespace after ',' tests/test_bias_correction.py:24:153: E231 missing whitespace after ',' tests/test_bias_correction.py:24:156: E231 missing whitespace after ',' tests/test_bias_correction.py:25:1: W293 blank line contains whitespace tests/test_bias_correction.py:27:1: W293 blank line contains whitespace tests/test_bias_correction.py:30:27: E231 missing whitespace after ',' tests/test_bias_correction.py:31:9: F841 local variable 'Scen' is assigned to but never used tests/test_bias_correction.py:33:1: W293 blank line contains whitespace Makefile:246: recipe for target 'pep8' failed make: *** [pep8] Error 1
$ make pep8 Running pep8 code style checks ... tests/test_bias_correction.py:9:121: E501 line too long (143 > 120 characters) tests/test_bias_correction.py:10:121: E501 line too long (149 > 120 characters) tests/test_bias_correction.py:18:121: E501 line too long (143 > 120 characters) tests/test_bias_correction.py:57:9: F841 local variable 'Scen' is assigned to but never used Makefile:246: recipe for target 'pep8' failed make: *** [pep8] Error 1
Undo temp commit b5a3566.
xarray 0.16 already contain what we need. Undo commit a125ff4.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@richardarsenault I've resolved all the conflicts with master
branch, fixed pep8, removed temporary changes from Trevor.
You can merge this PR when ready (probably wait until Travis-CI is done and is green). Thanks.
@richardarsenault I've deleted branch You can create a new branch to continue working on your feature. You can even re-create the same branch name if you wish. At least it'll be starting at the good new location. |
OK thanks, I am always kind of reticent of deleting branches and stuff so I usually do it a few weeks later to make sure we don't need anything still, but I guess that is futile, isn't it :) I will take note to delete after merging. Thanks for your patience with me :) |
No worries. Git basically uses branches to keep track of commits. If a commit and its ancestors have no branch pointing to it, it'll be eligible to be garbage collected. By merging to From the point of view of us the developers, once we merge to Hope this further re-assure you that it's safe to delete a dev branch after it has been merged to |
Sounds good, thanks! |
So all new dev branches are built automatically without having to either manually add the branch name to .travis.yml or being forced to create a PR. This creates redundant build on the same commit when PR is created but otherwise no other harms. No redundant build on PR merge since a brand new commit is created for both merge commit or squash commit scenario. See discussion Ouranosinc/raven#292 (comment)
travis-ci: build all branches instead of only master So all new dev branches are built automatically without having to either manually add the branch name to .travis.yml or being forced to create a PR. This creates redundant build on the same commit when PR is created but otherwise no other harms. No redundant build on PR merge since a brand new commit is created for both merge commit or squash commit scenario. See discussion Ouranosinc/raven#292 (comment)
…in-autodoc-directive Fix RtD silent build failure in autodoc directive. This PR fixes RtD silent build failure in autodoc directive. The process list https://pavics-sdi.readthedocs.io/projects/raven/en/latest/processes.html is currently empty and it's not supposed to be like that. We never got alerted because it's failing silently. Fixed RtD build: https://pavics-sdi.readthedocs.io/projects/raven/en/test-rtd-build/processes.html and matching RtD build log https://readthedocs.org/api/v2/build/11555558.txt (commit baba22f) Changes: * Turn RtD warnings to build failure so they do not fail silently. * Change Travis-CI build config to also build Epub and Latex doc format to catch RtD failure on Travis-CI before PR is merged. * Various changes to remove all warnings in doc build since warnings will now fail the doc build. Unrelated changes part of this PR (sorry !): * Refresh cookiecutter (first commit in this PR is technically not part of the intended fix of this PR). * Remove Travis-CI directive to only build `master` branch so all dev branch gets build on Travis-CI. Otherwise we either have to create a PR when branch is not even ready or hardcode branch name in `.travis.yml` and have to remember to remove it at the end, very annoying. See comment in #292 (comment) ## Additional Information Matching cookiecutter PR bird-house/cookiecutter-birdhouse#96 @richardarsenault You are probably not interested in the low level details in this PR. I just want to draw your attention to the fact that I found 2 notebooks missing in the toctree (Region_selection.ipynb, Running_models_with_multiple_timeseries_files.ipynb). I added them to the end of the toctree, wonder if you are okay with the ordering or these 2 notebooks were intended to not appear in the doc.
…in-autodoc-directive Fix RtD silent build failure in autodoc directive. This PR fixes RtD silent build failure in autodoc directive. The process list https://pavics-sdi.readthedocs.io/projects/raven/en/latest/processes.html is currently empty and it's not supposed to be like that. We never got alerted because it's failing silently. Fixed RtD build: https://pavics-sdi.readthedocs.io/projects/raven/en/test-rtd-build/processes.html and matching RtD build log https://readthedocs.org/api/v2/build/11555558.txt (commit 5521c48) Changes: * Turn RtD warnings to build failure so they do not fail silently. * Change Travis-CI build config to also build Epub and Latex doc format to catch RtD failure on Travis-CI before PR is merged. * Various changes to remove all warnings in doc build since warnings will now fail the doc build. Unrelated changes part of this PR (sorry !): * Refresh cookiecutter (first commit in this PR is technically not part of the intended fix of this PR). * Remove Travis-CI directive to only build `master` branch so all dev branch gets build on Travis-CI. Otherwise we either have to create a PR when branch is not even ready or hardcode branch name in `.travis.yml` and have to remember to remove it at the end, very annoying. See comment in #292 (comment) ## Additional Information Matching cookiecutter PR bird-house/cookiecutter-birdhouse#96 @richardarsenault You are probably not interested in the low level details in this PR. I just want to draw your attention to the fact that I found 2 notebooks missing in the toctree (Region_selection.ipynb, Running_models_with_multiple_timeseries_files.ipynb). I added them to the end of the toctree, wonder if you are okay with the ordering or these 2 notebooks were intended to not appear in the doc.
Adds interacton with Xclim for bias correction with a simple test suite.