Skip to content
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

Continuous version of the Perez transposition model implementation #1876

Merged
merged 19 commits into from
Oct 16, 2023

Conversation

adriesse
Copy link
Member

@adriesse adriesse commented Sep 26, 2023

  • Closes Continuous version of the Perez transposition model #1841
  • I am familiar with the contributing guidelines
  • Tests added
  • Updates entries in docs/sphinx/source/reference for API changes.
  • Adds description and name entries in the appropriate "what's new" file in docs/sphinx/source/whatsnew for all changes. Includes link to the GitHub Issue with :issue:`num` or this Pull Request with :pull:`num`. Includes contributor name and/or GitHub username (link with :ghuser:`user`).
  • New code is fully documented. Includes numpydoc compliant docstrings, examples, and comments where necessary.
  • Pull request is nearly complete and ready for detailed review.
  • Maintainer: Appropriate GitHub Labels (including remote-data) and Milestone are assigned to the Pull Request and linked Issue.

Create a new version of the Perez model having smooth transitions, but without changing the overall performance w.r.t. the original. The solution uses quadratic splines as described in recent presentations and posters, and documented in a paper just accepted for publication in the Solar Energy Journal. (Link will be provided later; the pre-print is available to PR reviewers on request.)

@adriesse adriesse marked this pull request as draft September 26, 2023 18:06
@adriesse adriesse marked this pull request as ready for review September 27, 2023 12:57
@adriesse
Copy link
Member Author

Ok, you can run it now if you want!

I have made the airmass argument optional and could do the same in the original perez. Opinions?

We have recommended an upper limit of 0.9 on F1 in our paper. I think I should put it in the original perez too. Opinions?

I will probably just copy the whole suite of tests for the original perez. Opinions?

@cwhanse
Copy link
Member

cwhanse commented Sep 27, 2023

We have recommended an upper limit of 0.9 on F1 in our paper. I think I should put it in the original perez too. Opinions?

Would F1 <= 0.9 be correcting an error or omission in the original paper, or is this a model improvement that has emerged from the recent work?

@adriesse
Copy link
Member Author

We have recommended an upper limit of 0.9 on F1 in our paper. I think I should put it in the original perez too. Opinions?

Would F1 <= 0.9 be correcting an error or omission in the original paper, or is this a model improvement that has emerged from the recent work?

Quoting from the paper:

While preparing Figure 2 we noticed that the value of F1
could exceed 1.0 for zenith angles less than 30°, which would
be physically incoherent and produce a negative irradiance for
the isotropic sky component. However, in our validation data
sets, we observed only isolated cases with F1 over 0.7, and for
one equatorial location (the BSRN station DWN) the natural
limit was approximately 0.9. Consequently, there appears to
be a low likelihood of reaching 1.0. Nevertheless, to guarantee
physically coherent transposition results, we recommend that a
limit of 0.9 be imposed on F1 in implementations of both the
original and the continuous models

@cwhanse
Copy link
Member

cwhanse commented Sep 27, 2023

Let's modify the perez function in its own PR. It would be nice to have (in GH comments, if not more formally) a comparison of model output before and after the change, to answer "how much difference does this make"

@adriesse
Copy link
Member Author

Ok, the main code is a ready. I will not touch the existing perez function.

Comments on whether to duplicate the whole test suite are still welcome.

@cwhanse cwhanse added this to the v0.10.3 milestone Sep 28, 2023
@cwhanse
Copy link
Member

cwhanse commented Sep 28, 2023

Share my thoughts: the implementation changes relatively few lines from irradiance.perez. My reaction was "can this be a kwarg-activated variant in irradiance.perez?" However, I view the Perez-Driesse calculation as distinct from the original Perez model, rather than a variation on the Perez model. The two share a conceptual structure, but differ (importantly) in their parameterization. For this reason, I think it is better to have both irradiance.perez and irradiance.perez_driesse in the API.

@adriesse
Copy link
Member Author

The duplicated code in the two function bothers me a bit as well. I would say a future move of the common code to a helper function could be considered, which would not affect the API.

@adriesse
Copy link
Member Author

Ok, I've copied all tests but one from perez and added some specific ones for perez_driesse.

Ready for complete review!

Copy link
Member

@cwhanse cwhanse left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I suggest that we add a See Also block to the perez function.

pvlib/irradiance.py Show resolved Hide resolved
pvlib/irradiance.py Outdated Show resolved Hide resolved
pvlib/irradiance.py Outdated Show resolved Hide resolved
pvlib/irradiance.py Outdated Show resolved Hide resolved
@adriesse
Copy link
Member Author

adriesse commented Oct 1, 2023

I suggest that we add a See Also block to the perez function.

There are several little things that could be mirrored from this function to the old one, I think. A new issue and PR might be best for this.

Copy link
Member

@kandersolar kandersolar left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

One comment about the zeta calculation below but otherwise LGTM! There's now also a merge conflict.

pvlib/irradiance.py Outdated Show resolved Hide resolved
pvlib/irradiance.py Outdated Show resolved Hide resolved
pvlib/irradiance.py Outdated Show resolved Hide resolved
pvlib/irradiance.py Outdated Show resolved Hide resolved
pvlib/irradiance.py Outdated Show resolved Hide resolved
pvlib/irradiance.py Outdated Show resolved Hide resolved
@adriesse
Copy link
Member Author

I'm happy to entertain more comments and reviews, but if there are none in the pipeline I would suggest merging so I can continue with things that depend on this.

@adriesse
Copy link
Member Author

@kandersolar @cwhanse Regarding the calculations in _calc_zeta, do you think I should add these equations in the journal paper (if still possible).

@kandersolar
Copy link
Member

Regarding the calculations in _calc_zeta, do you think I should add these equations in the journal paper (if still possible).

I like the paper the way it is now. I think the code comments are sufficient to link these calculations to the paper.

@cwhanse
Copy link
Member

cwhanse commented Oct 10, 2023

@kandersolar @cwhanse Regarding the calculations in _calc_zeta, do you think I should add these equations in the journal paper (if still possible).

Yes that would be of value.

@adriesse
Copy link
Member Author

I get a merge conflict on those two opinions. :) I'll see if it can be done when @AdamRJensen gets back from Nepal.

@adriesse
Copy link
Member Author

Are any further changes needed before merging?

@kandersolar kandersolar merged commit af8dde5 into pvlib:main Oct 16, 2023
@kandersolar
Copy link
Member

Thanks @adriesse! (and sorry for needing a reminder to merge this)

kandersolar added a commit that referenced this pull request Nov 29, 2023
* Remove various repeated words in documentation (#1872)

* Remove repeated words

* Update pvlib/ivtools/sdm.py

Co-authored-by: Kevin Anderson <[email protected]>

---------

Co-authored-by: Kevin Anderson <[email protected]>

* fix invalid escape sequence '\c' (#1879)

* fix invalid escape sequence '\c'

pvlib/iam.py:843: DeprecationWarning: invalid escape sequence '\c'

Occurence is actually in line 854: `IAM = 1 - (1 - \cos(aoi))^5`

* Add to list of contributors

* Replace use of deprecated `pkg_resources` (#1881) (#1882)

* Update infinite_sheds.py to add shaded fraction to returned variables in infinite_sheds.get_irradiance and infinite_sheds.get_irradiance_poa (#1871)

* Update infinite_sheds.py

Added shaded fraction to returned variables.

* Update v0.10.3.rst

* Update test_infinite_sheds.py

added tests for shaded fraction

* Update test_infinite_sheds.py

Corrected the shaded fraction tests in the haydavies portion.

* Update pvlib/bifacial/infinite_sheds.py

Co-authored-by: Kevin Anderson <[email protected]>

* Update infinite_sheds.py

* Update infinite_sheds.py

* Update infinite_sheds.py

fixed indentation issues

---------

Co-authored-by: Kevin Anderson <[email protected]>

* Continuous version of the Perez transposition model implementation (#1876)

* Definitely not ready for review!

* Big step forward.

* Add entry in docs.

* A working model but just one test sofar.

* Add new model as option in get_sky_diffuse.  Docstring edits pending.

* Completed doc strings.  Also a bit of fine-tuning code.

* Updated whatsnew.

* Bugfix, formatting fix, and add all tests.

* Test warning plus some other small changes.

* Make flake happy.

* Update pvlib/irradiance.py

Co-authored-by: Cliff Hansen <[email protected]>

* Address comments.

* Add contributor code comments.

* Update pvlib/irradiance.py

Co-authored-by: Adam R. Jensen <[email protected]>

* Adapt to reviewer preferences.

* Adapt to flake preferences.

* Remove model pseudo-option.

* Flake

---------

Co-authored-by: Cliff Hansen <[email protected]>
Co-authored-by: Adam R. Jensen <[email protected]>

* Fix spurious test error with pandas 2.1 (#1891)

pandas-dev/pandas#55014

* Fix plotting in plot_singlediode.py gallery page (#1895)

* Update plot_singlediode.py

fixed plot annotations by moving plt.show() further down

* Update whatsnew.rst

* Update v0.10.3.rst

* Update docs/sphinx/source/whatsnew.rst

Undoing changes to whatsnew.rst

* Address pandas FutureWarnings in test suite (#1900)

* Cahnged expected reference in test_detect_clearskY_window to 1 from True to avoid Futurewarning

* Change reference to etr in ibird function to avoid FutureWarning

* In test_modelchain, update all instances when referring to series by position to using iloc to get rid of FutureWarning

* Update to iloc method for referencing by position in test_irradiance to get rid of FutureWarning

* In test_singlediode change applymap to map to get rid of FutureWarning

* Test_srml update to select using iloc to get rid of FutureWarning

* Substitute changing to float64 dtype using map with base functionality that's accessible across Pandas versions

* Added username to Contributors

* Update line break in test_clearsky to adhere to line length limit

* add comparisons to other tools

* Apply suggestions from code review

Co-authored-by: Cliff Hansen <[email protected]>

* revision re: other open-source projects

* bibtex tweaks

* clarify pvlib matlab comparison

---------

Co-authored-by: Miroslav Šedivý <[email protected]>
Co-authored-by: Arjan Keeman <[email protected]>
Co-authored-by: Miguel Sánchez de León Peque <[email protected]>
Co-authored-by: Will Hobbs <[email protected]>
Co-authored-by: Anton Driesse <[email protected]>
Co-authored-by: Cliff Hansen <[email protected]>
Co-authored-by: Adam R. Jensen <[email protected]>
Co-authored-by: matsuobasho <[email protected]>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

Successfully merging this pull request may close these issues.

Continuous version of the Perez transposition model
4 participants