Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/georust/netcdf
High-level netCDF bindings for Rust
https://github.com/georust/netcdf
Last synced: about 5 hours ago
JSON representation
High-level netCDF bindings for Rust
- Host: GitHub
- URL: https://github.com/georust/netcdf
- Owner: georust
- License: apache-2.0
- Created: 2015-06-27T16:54:59.000Z (over 9 years ago)
- Default Branch: master
- Last Pushed: 2024-10-03T09:10:56.000Z (4 months ago)
- Last Synced: 2024-10-29T20:23:39.243Z (3 months ago)
- Language: Rust
- Homepage:
- Size: 732 KB
- Stars: 81
- Watchers: 16
- Forks: 28
- Open Issues: 8
-
Metadata Files:
- Readme: README.md
- License: LICENSE-APACHE
Awesome Lists containing this project
- awesome-rust - georust/netcdf - level netCDF bindings, allowing easy reading and writing of array-like structures to a file. (Libraries / Encoding)
- awesome-rust - georust/netcdf - Medium-level netCDF bindings, allowing easy reading and writing of array-like structures to a file. (Libraries / Encoding)
- fucking-awesome-rust - georust/netcdf - Medium-level netCDF bindings, allowing easy reading and writing of array-like structures to a file. (Libraries / Encoding)
- fucking-awesome-rust - georust/netcdf - Medium-level netCDF bindings, allowing easy reading and writing of array-like structures to a file. (Libraries / Encoding)
README
# netcdf
[![Docs](https://docs.rs/netcdf/badge.svg)](https://docs.rs/netcdf)
![Build Status](https://github.com/georust/netcdf/workflows/CI/badge.svg)
[![Crates.io](https://img.shields.io/crates/d/netcdf.svg)](https://crates.io/crates/netcdf)
[![](http://meritbadge.herokuapp.com/netcdf)](https://crates.io/crates/netcdf)
[![codecov](https://codecov.io/gh/georust/netcdf/branch/master/graph/badge.svg)](https://codecov.io/gh/georust/netcdf)
![Crates.io](https://img.shields.io/crates/l/netcdf)Medium-level [netCDF](http://www.unidata.ucar.edu/software/netcdf/) bindings for Rust, allowing easy reading and writing of array-like structures to a file.
netCDF can read and write `hdf5` files, which is a commonly used file format in scientific computing.## Status
Supported:
* Variables
* Normal Dimensions
* Attributes
* Subgroups
* Open/Append/Create modes
* Reading from memory
* Unlimited dimensions
* User defined types, using the feature `derive` (enum, compound, other types requires additional work)Not (yet) supported (PRs welcome):
* Writing using memory-mapped fileAll variable data is read into a contiguous buffer, or into an [ndarray](https://github.com/rust-ndarray/ndarray) if the `ndarray` feature is activated.
## Building
This crate depends on `libnetcdf`, but a static build from source is also supported, which can be enabled using the `static` feature.
The crate is built on several platforms using github actions, and is currently known to build form from source on all major platforms (linux, macos, windows (gnu+msvc)), and through the package installers `conda` and `apt`.
If during compilation there is an error in building the `hdf5` crate, consider using the `static` feature which will include a compatible version of both `netcdf` and `hdf5`. This is likely to be an issue [upstream](https://github.com/aldanor/hdf5-rust/issues/262).
### Building without `libnetcdf` or building statically
1. `git clone https://github.com/georust/netcdf`
2. `git submodule update --init --recursive`
3. `cargo build --features static`## Documentation
Some examples of usage can be found in the [tests/lib.rs](netcdf/tests/lib.rs) file. The documentation can also be generated using `cargo doc`.
## Thread safety
The `netcdf` crate is thread-safe, although the `netcdf-c` library is not itself threadsafe. To render a safe interface, a global mutex is used to serialize access to the underlying library. Consider using a non threadsafe version of `hdf5` to avoid double locking (performance consideration).
Use of `netcdf-sys` is not thread-safe. Users of this library must take care that calls do not interfere with simultaneous use of e.g. `netcdf` or `hdf5-sys`. Use the lock provided by `netcdf-sys` to serialise access to the `hdf5` and `netCDF` libraries.
## License
Licensed under either of
* Apache License, Version 2.0, ([LICENSE-APACHE](LICENSE-APACHE) or http://www.apache.org/licenses/LICENSE-2.0)
* MIT license ([LICENSE-MIT](LICENSE-MIT) or http://opensource.org/licenses/MIT)at your option.
### Contribution
Unless you explicitly state otherwise, any contribution intentionally submitted
for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any
additional terms or conditions.