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

Add complex number support #1295

Merged
merged 11 commits into from
Dec 11, 2023
Merged

Conversation

ZedThree
Copy link
Contributor

Closes #1280

This adds support for reading/writing complex numbers in a variety of conventions, using my nc-complex library to do the heavy lifting. It's taken awhile because I had to go back and polish up the base library. It now supports writing complex numbers to netCDF3/classic model by automatically creating the complex dimension.

Complex number support is enabled by passing auto_complex=True to Dataset:

import netCDF4
import numpy as np

complex_array = np.array([0 + 0j, 1 + 0j, 0 + 1j, 1 + 1j, 0.25 + 0.75j], dtype="c16")

filename = "complex.nc"
with netCDF4.Dataset(filename, "w", auto_complex=True) as f:
    f.createDimension("x", size=len(complex_array))
    c_var = f.createVariable("data", "c16", ("x",))
    c_var[:] = complex_array

with netCDF4.Dataset(filename, "r", auto_complex=True) as f:
    print(f["data"])

# <class 'netCDF4._netCDF4.Variable'>
# compound data(x)
# compound data type: complex128
# unlimited dimensions: 
# current shape = (5,)

Internally, auto_complex is then used to switch between calling the nc_* and pfnc_* versions of the various functions. pfnc_def_var is always used to create variables, as this just falls through to nc_def_var if it's not a complex datatype.

I still need to add an example and update the docs, but all the code is working and I've added some tests, so I thought I'd open the PR so you can see what it looks like and maybe try it out.

There's probably still some sharp edges around vlen or compound types with nested complex numbers. I've not tested them.

@ZedThree ZedThree force-pushed the add-complex-number-support branch from a5f2e27 to df42ae1 Compare November 17, 2023 09:18
@jswhit
Copy link
Collaborator

jswhit commented Nov 18, 2023

thanks @ZedThree! I see you are adding a submodule that points to your repo - which is fine, but I think it should still be possible to build netcdf4-python without that submodule. How hard would it be to add the ability to bypass the complex number support?

and BTW, do you plan to try to get this integrated into netcdf-c?

@ZedThree
Copy link
Contributor Author

How hard would it be to add the ability to bypass the complex number support?

Definitely possible, but a little complicated. We'd need to do something like I added for the optional parallel support, switching out a .pxi header at build time. And then a runtime check if auto_complex=True but complex support is disabled.

The intention with the current implementation is that the complex number support is completely opt-in anyway. The underlying nc-complex C library is a single file and very cheap to build, so using the default auto_complex=False shouldn't add any overhead.

Happy to do this, but honestly I'm not sure it's worth making it optional at build-time.

do you plan to try to get this integrated into netcdf-c?

From this discussion: Unidata/netcdf-c#2652 it seems unlikely to be accepted unfortunately.

@jswhit
Copy link
Collaborator

jswhit commented Nov 20, 2023

I guess I was thinking there were two reasons to make it easily disable-able.

  1. in case it was included upstream in netcdf-c (agree this does not seem likely in the foreseeable future)
  2. in case your repo is broken or unavailable at build time (again unlikely, but possible)
    I wouldn't want to a lot more complexity to make it happen though.

@ZedThree
Copy link
Contributor Author

in case your repo is broken or unavailable at build time

That was exactly my thinking for including it as a submodule, so that it would always be available :)

@ZedThree ZedThree marked this pull request as ready for review November 21, 2023 17:38
@jswhit
Copy link
Collaborator

jswhit commented Nov 29, 2023

Looks good - guess all it needs is a Changelog entry

@ZedThree
Copy link
Contributor Author

ZedThree commented Dec 4, 2023

Yep, will do! There's one more thing I want to add to the base library first, will get on that this week

@ZedThree
Copy link
Contributor Author

ZedThree commented Dec 8, 2023

Ok, I think this is complete from my side

@jswhit jswhit merged commit f26e944 into Unidata:master Dec 11, 2023
30 checks passed
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

Interest in extension for complex numbers?
2 participants