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

Change Variables and Symbols page into a Glossary of terms #2234

Merged
merged 30 commits into from
Oct 31, 2024

Conversation

RDaxini
Copy link
Contributor

@RDaxini RDaxini commented Sep 29, 2024

The glossary would replace the variables and symbols page. This is a limited example. Links:
Glossary
Function (see parameters surface_tilt and dni, and second paragraph in docstring)

Points to discuss: see this comment


Note:

  • Took the liberty of alphabetizing the list since I did not see a logical order in the original
  • Added/updated dni and surface_tilt definition to show example enhancements (linked to the example function)

Generally, I think adding/updating definitions (description, units, etc.) and adding/removing new/duplicate variables (#1421, #1253) probably requires a case-by-case discussion so I have not gone further here save for the two examples

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

Irradiation is energy (e.g., Wh/m^2) whereas irradiance is power (e.g., W/m^2). I think it's better to use irradiance

@RDaxini RDaxini marked this pull request as ready for review October 9, 2024 18:27
@RDaxini RDaxini changed the title [WIP] Change Variables and Symbols page into a Glossary of terms Change Variables and Symbols page into a Glossary of terms Oct 9, 2024
@RDaxini
Copy link
Contributor Author

RDaxini commented Oct 9, 2024

Thoughts on retaining any of the following text from variables_style_rules.rst before deleting the file? I haven't reviewed each link to verify it is an optimal source of information, but each link is still working and, overall, I think it's nice to include general educational content via external links. I am in favour of copying this over to the new page.

For a definition and further explanation on the variables, common symbols and units refer to the following sources:
* `IEC 61724-1:2017 -- Photovoltaic system performance - Part 1: Monitoring <https://webstore.iec.ch/publication/33622>`_ section: 3 -- Terms and definitions; the Indian Standard referencing the withdrawn earlier global IEC standard IEC 61724:1998 is available online: `IS/IEC 61724 (1998) <https://archive.org/details/gov.in.is.iec.61724.1998>`_ and can provide relevant contents.
* Explanation of Solar irradiation and solar geometry by `SoDa Service <http://www.soda-pro.com/home>`_
* `Acronyms, Terminology and Units <https://www.soda-pro.com/help/general/acronyms-terminology-and-units>`_
* `Plane orientations and radiation components <https://www.soda-pro.com/help/general/plane-orientations-and-radiation-components>`_
* `Time references <https://www.soda-pro.com/help/general/time-references>`_
.. note:: These further references might not use the same terminology as *pvlib*. But the physical process referred to is the same.

@cwhanse
Copy link
Member

cwhanse commented Oct 9, 2024

I think its worth keeping the SodaPro references. We could drop the IEC 61724 links.

@echedey-ls
Copy link
Contributor

A random thought, without any intentions: maybe instead of splitting and creating a whole new page, both of them could be put into the same one.

@kandersolar kandersolar added this to the v0.11.2 milestone Oct 9, 2024
@kandersolar
Copy link
Member

If the old page is being removed, then these references need to be updated:

$ git grep -n -F "variables_style_rules"
docs/sphinx/source/contributing/style_guide.rst:16::ref:`variables_style_rules`. We could be better about consistency.
docs/sphinx/source/index.rst:29:There is a :ref:`variable naming convention <variables_style_rules>` to
docs/sphinx/source/user_guide/index.rst:18:   variables_style_rules
docs/sphinx/source/user_guide/variables_style_rules.rst:1:.. _variables_style_rules:
docs/sphinx/source/user_guide/variables_style_rules.rst:9:   :file: ../../../../pvlib/data/variables_style_rules.csv
docs/sphinx/source/user_guide/weather_data.rst:86:into standard pvlib names (see :ref:`variables_style_rules`).
docs/sphinx/source/whatsnew/v0.3.0.txt:50:    * :ref:`variables_style_rules` (:issue:`102`)
pvlib/iotools/midc.py:196:    :ref:`variables_style_rules`.

@RDaxini
Copy link
Contributor Author

RDaxini commented Oct 19, 2024

If the old page is being removed, then these references need to be updated:

$ git grep -n -F "variables_style_rules"
docs/sphinx/source/contributing/style_guide.rst:16::ref:`variables_style_rules`. We could be better about consistency.
docs/sphinx/source/index.rst:29:There is a :ref:`variable naming convention <variables_style_rules>` to
docs/sphinx/source/user_guide/index.rst:18:   variables_style_rules
docs/sphinx/source/user_guide/variables_style_rules.rst:1:.. _variables_style_rules:
docs/sphinx/source/user_guide/variables_style_rules.rst:9:   :file: ../../../../pvlib/data/variables_style_rules.csv
docs/sphinx/source/user_guide/weather_data.rst:86:into standard pvlib names (see :ref:`variables_style_rules`).
docs/sphinx/source/whatsnew/v0.3.0.txt:50:    * :ref:`variables_style_rules` (:issue:`102`)
pvlib/iotools/midc.py:196:    :ref:`variables_style_rules`.

@kandersolar done, except for the 0.3.0 whatsnew entry. Anything needed there? Doesn't make sense to change the reference to "glossary", but should the :ref:`` be removed since the link won't work anyway (a warning is probably generated somewhere), or add something to say the page was removed in 11.2, or just leave it?

@AdamRJensen
Copy link
Member

The terms Nomenclature or Terminology seem to be more correct than Glossary, as the list includes both terms and symbols/variables. Glossary I believe should only contain terms/definitions.

Terminology seems preferred to me as it's more easily understandable to non-native speakers.

@RDaxini
Copy link
Contributor Author

RDaxini commented Oct 19, 2024

The terms Nomenclature or Terminology seem to be more correct than Glossary, as the list includes both terms and symbols/variables. Glossary I believe should only contain terms/definitions.

Terminology seems preferred to me as it's more easily understandable to non-native speakers.

I don't mind "glossary", but I'm not opposed to changing the name. Just another thought: how about going back to the old name then, "Variables and Symbols"? I don't have a strong preference

Copy link
Contributor

@IoannisSifnaios IoannisSifnaios left a comment

Choose a reason for hiding this comment

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

Looks good overall! I left one or two comments. Regarding the name of the section, I also agree that Nomenclature (assigning of a word or phrase to a particular object, event, or property) would be a more suitable term than Glossary (terms that are either newly introduced, uncommon, or specialized)

docs/sphinx/source/user_guide/glossary.rst Outdated Show resolved Hide resolved
docs/sphinx/source/user_guide/glossary.rst Outdated Show resolved Hide resolved
docs/sphinx/source/user_guide/glossary.rst Outdated Show resolved Hide resolved
@AdamRJensen
Copy link
Member

I don't mind "glossary", but I'm not opposed to changing the name. Just another thought: how about going back to the old name then, "Variables and Symbols"? I don't have a strong preference

I would be ok with either "Terminology" or "Variables and Symbols".

@echedey-ls
Copy link
Contributor

I don't really like "Variables and Symbols"; to be precise it's more about "Common Parameters" - but I agree "Terminology" is good if it gets expanded to other terms in the future.

An small side-note, the supposed link in https://pvlib-python--2234.org.readthedocs.build/en/2234/contributing/style_guide.html (first section "Code Style", second paragraph, second sentence) to the glossary is pointing to CPython's glossary: https://docs.python.org/3/glossary.html#glossary . It may be due to the crossreference at the top of the file missing an underscore at the beginning.

@RDaxini
Copy link
Contributor Author

RDaxini commented Oct 27, 2024

@IoannisSifnaios thanks for reviewing. I was thinking it'd be better to keep the scope of this PR focused on creating the glossary. DNI was expanded as an example (definition+link in function docs). I agree the others need updating, but I think that deciding how best to define each term / groups of terms might be better addressed in a separate PR.
Happy to revisit this if you or anyone else thinks otherwise

@RDaxini RDaxini mentioned this pull request Oct 30, 2024
7 tasks
@RDaxini
Copy link
Contributor Author

RDaxini commented Oct 30, 2024

is pointing to CPython's glossary: https://docs.python.org/3/glossary.html#glossary

Well spotted
The other links worked fine and the _ didn't solve the problem for that link so I have changed the label from glossary to pvlib-glossary. Should be working now

@RDaxini
Copy link
Contributor Author

RDaxini commented Oct 30, 2024

I created #2284 to keep track of additional suggestions and address the comments from @IoannisSifnaios and @AdamRJensen (thanks for the suggestions)

Is deciding the name the only task remaining? From @IoannisSifnaios's definition, nomenclature sounds like the most technically accurate. Terminology makes me think more of words/phrases, but we have abbreviations and initialisms. That might just be my own inaccurate subjective impression though. I guess the four options now are:

Nomenclature, Variables and Symbols, Glossary, Terminology

How do we decide?

@cwhanse
Copy link
Member

cwhanse commented Oct 30, 2024

Nomenclature, Variables and Symbols, Glossary, Terminology

I'm OK with any of these.

How do we decide?

Sometimes the PR originator just chooses what color to paint the bikeshed.

@RDaxini
Copy link
Contributor Author

RDaxini commented Oct 30, 2024

Sometimes the PR originator just chooses what color to paint the bikeshed.

So much pressure 👀
Let's go with nomenclature! It's a mouthful, but I get the impression it's the most accurate. It's also widely used, including in many journals, so it should be familiar to most if not all users.

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.

Will merge later today if no objections are raised by then

@RDaxini
Copy link
Contributor Author

RDaxini commented Oct 31, 2024

Will merge later today if no objections are raised by then

I'm still happy to make changes to any aspect if necessary, anyone please feel free to leave a comment 👍🏽

@kandersolar kandersolar merged commit 0781787 into pvlib:main Oct 31, 2024
21 checks passed
@kandersolar
Copy link
Member

Thanks @RDaxini and all other participants! It's fun to see this idea finally implemented :)

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.

6 participants