Skip to content

Commit

Permalink
issue #33
Browse files Browse the repository at this point in the history
  • Loading branch information
Alexander-Barth committed May 29, 2019
1 parent 95f3cd5 commit 68a8f0c
Show file tree
Hide file tree
Showing 3 changed files with 47 additions and 2 deletions.
42 changes: 40 additions & 2 deletions docs/src/index.md
Original file line number Diff line number Diff line change
Expand Up @@ -171,12 +171,13 @@ ds = Dataset("test.nc","a")
v_cf = ds["var"]
```

The variable `v_cf` has the type `CFVariable`. No data is actually loaded from disk, but you can query its size, number of dimensions, number elements, ... by the functions `size`, `ndims`, `length` as ordinary Julia arrays. Once you index, the variable `v_cf`, then the data is loaded and stored into a `DataArray`:
The variable `v_cf` has the type `CFVariable`. No data is actually loaded from disk, but you can query its size, number of dimensions, number elements, ... by the functions `size`, `ndims`, `length` as ordinary Julia arrays. Once you index, the variable `v_cf`, then the data is loaded and stored as an `Array`:

```julia
v_da = v_cf[:,:]
v_da = v_cf[:,:] # or v_da = v_cf[:]
```

Note that even if the variable `v_cf` has 2 (or more dimension), the index operation `v_cf[:]` preserves its actual shape and does not generate a flat vector of the data (unlike regular Julia arrays). As load operations are very common, it was consired advantageous to have a consice syntax.


## Attributes
Expand Down Expand Up @@ -272,6 +273,43 @@ nomissing
varbyattrib
```

# Performance tips

* Reading data from a file is not type-stable, because the type of the output of the read operation does depedent on the type defined in the NetCDF files and the value of various attribute (like `scale_factor`, `add_offset` and `units` for time convertion). All this information cannot be inferred from a static analysis of the source code. It is therefore recommended to use

This comment has been minimized.

Copy link
@Balinus

Balinus May 30, 2019

Contributor

typo : convertion -> conversion

This comment has been minimized.

Copy link
@Alexander-Barth

Alexander-Barth Jun 3, 2019

Author Member

Thanks!!

[type annotation](https://docs.julialang.org/en/v1/manual/types/index.html#Type-Declarations-1)
if resulting type of a read operation in known:

```julia
ds = Dataset("file.nc")
temperature = ds["temperature"][:] :: Array{Float64,2}
close(ds)
```

Alternatively, one can also use so called "[function barriers]"(https://docs.julialang.org/en/v1/manual/performance-tips/index.html#kernel-functions-1) or the in-place `load!` function:

```julia
ds = Dataset("file.nc")

temperature = zeros(10,20)
load!(ds["temperature"],temperature,:,:)
```

* Most julia functions (like `mean`, `sum`,... from the module Statistics) access an array element-wise. It is generally much faster to load the data in memory (if possible) to make the computation.

```
using NCDatasets, BenchmarkTools, Statistics
ds = Dataset("file.nc","c")
data = randn(100,100);
defVar(ds,"myvar",data,("lon","lat"))
close(ds)
ds = Dataset("file.nc")
@btime mean(ds["myvar"]) # takes 107.357 ms
@btime mean(ds["myvar"][:]) # takes 106.873 μs, 1000 times faster
close(ds)
```


# Multi-file support (experimental)

Multiple files can also be aggregated over a given dimensions (or the record dimension). In this example, 3 sea surface temperature fields from the
Expand Down
4 changes: 4 additions & 0 deletions src/NCDatasets.jl
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,8 @@ import Base.convert
import Compat: @debug, findfirst

import Base: close
import Base: Array

include("CFTime.jl")
using .CFTime

Expand Down Expand Up @@ -1427,13 +1429,15 @@ Base.show(io::IO,v::CFVariable; indent="") = Base.show(io::IO,v.var; indent=inde

Base.display(v::Union{Variable,CFVariable}) = show(Compat.stdout,v)

Base.Array(v::Union{CFVariable,Variable}) = v[:]

# Common methods

const NCIterable = Union{BaseAttributes,AbstractDimensions,AbstractDataset,AbstractGroups}

Base.length(a::NCIterable) = length(keys(a))


"""
haskey(ds::Dataset,varname)
Expand Down
3 changes: 3 additions & 0 deletions test/test_variable.jl
Original file line number Diff line number Diff line change
Expand Up @@ -41,6 +41,9 @@ NCDatasets.Dataset(filename,"c") do ds
v[:,:] = data
@test v[:,:] == data[:,:]

# issue #33
@test Array(v) == data

@test v[2,:] == data[2,:]

@test v[:,3] == data[:,3]
Expand Down

0 comments on commit 68a8f0c

Please sign in to comment.