-
Notifications
You must be signed in to change notification settings - Fork 51
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
Survey: Frontend Language Support #625
Comments
C++ FrontendAs of today, I (only) need support for
You can update your vote at any time, e.g., if your code-base updated. Note: C++ compiler defaults and C++ compiler support. |
Python FrontendAs of today, I (only) need support for
You can update your vote at any time, e.g., if your code-base updated. |
C FrontendWe do not yet provide a C-frontend. If one would spend time developing one, I (only) need support for
You can update your vote at any time, e.g., if your code-base updated. Note: C compiler defaults. Potential library usage: shroud |
Fortran FrontendCurrently, there are at least two implementations of a HDF5-Fortran openPMD library [ref1] which we hightly recommend to check out and use. If one would add Fortran bindings to openPMD-api, I (only) need support for
Note: Fortran bindings prior to the 2008 standard are extremely cumbersome (read as: not worth spending time developing), since iso-C-bindings were first standardized in version 2008. You can update your vote at any time, e.g., if your code-base updated. |
More Exotic BindingsIt's in principle possible to add bindings for further (modern) languages in case there is a sufficiently large user-base for it. Just tell us what you currently use in production workflows, maybe someone wants to team up with you and build bindings! I use the following languages in my workflows and I would benefit from adding bindings to
(Multiple answers are welcome, too.) |
I know I should use the front-end already ... Will do when I have time. I envision only c++11 & py3.5+ for now |
Sounds great, feel free to ping us if you need help with anything when adopting to the API (reviews, more examples, etc.). Since Python 3.5's EOL is in Q3 2020 I do not expect any drop of our supported versions soon until it runs into this. |
Announcement: since most user-level distributions already dropped Python 3.5 and it will not receive any updates after September 2019, we anticipate to drop Python 3.5 support in upcoming releases. This approach is on par with other major projects such as Numpy dropping Python 3.5 in upcoming releases (1.19.0+). We continue to support Python 3.6-3.8 and anticipate addition of Python 3.9 after its October release. Please see: https://devguide.python.org/#status-of-python-branches Update: Python 3.5 dropped and 3.9 added in #828 (0.13.0 release). We already ship Python 3.9 via conda-forge for 0.12.0. |
I see a label for Julia, are you guys invested on it? I'm currently evaluating its use and seems very promising now that it's been stable for a year. |
Unfortunately not, I know exactly one person in our community that does Julia @berceanu |
Hi William, yes, Julia support would be lovely. As ax3l pointed out, community-wise the interest is unfortunately limited, so the manpower is as well. Julia is IMHO quite o.k., but the parallelism does not come out of the box as promised (it never did). Why would you got for Julia? What would be the features you are missing with Python? |
@ax3l @bussmann thanks for chiming in. Python is great, nothing is missing with the added ecosystem (numpy, scipy, matplotlib, etc.), still dependency versions must be tracked when packaging with conda, pip, etc.. We are mostly exploring Julia for the long run (still young in 2020, I just hit a wall myself with IDE support) as it presents interesting concepts built into the language (type declarations, the parallelism you mentioned, math) targeting the kind of work we do in their roadmap. I just got mostly curious as I saw the label in this issue and I wanted to learn more about your view/experiences. Thanks. |
With our main downstream consumers now upgraded to C++14 code bases, we'll soon migrate to C++14, too. This will simplify the maintenance of the library and we can stop testing some ancient compilers that only came with now deprecated operating systems. Many compilers already switched to build with C++14 by default and some already set C++17 as their default compilation language. C++ is generally forward-compatible and we make sure in our CI that our C++ standard (e.g. 14) requirement will built with C++17 and 20 flags, too. We will generally aim to continue to adopt new C++ standards, as soon as vendor compilers and HPC systems provide stable support for them; and thus once our main downstream users can make the switch. Update: transition to C++14 and newer will happen with the 0.13.0 release #825 |
@axl3 Incidentally, I started working on a Julia package |
C++: C++17 |
Awesome, thanks for the update & contributions @eschnett! :) |
C++ Frontend Announcement: |
Python Frontend Announcement: |
A short update regarding Probably @williamfgc has more details on this, as first author on both studies |
@williamfgc Note: There is a Bmad (https://www.classe.cornell.edu/bmad/) port to Julia project in development and part of this project will be a Julia front end for the EXT_BeamPhysics.md extension. |
Dear @openPMD/general-contributors,
this issue is pinned to keep track of your needs for our reference API in terms of minimum supported language features.
So far we support Python 3.6+ and C++14 or newer. But as compilers and languages progress, we would love to drop old language revisions in newer releases to keep maintenance at a minimum and make use of newer language features in public interfaces. Please vote in the following comments according to the minimum requirements you have in your downstream code-bases. This will help us to plan potentially breaking changes with minimum hazzle.
Voting in the C++ and Python frontend will help us to ping and interact with you in case we would like to drop, e.g. C++14 bindings (for C++17 and newer) or older Python bindings in the future.
Voting on new language bindings does not implicate someone will find the time to provide such implementations, but it potentially motivates volunteers to step forward and add further bindings or share their own implementations where needed.
The text was updated successfully, but these errors were encountered: