Beispiel #1
0
def join_datafiles(datafile_prefix, gridspec_file, tile_dim,
                   datafile_suffix='.nc', directory="./",
                   rename_dict=None, coord_attrs_dict=None, transpose=None) -> str:
    mosaic = load_mosaic(gridspec_file, load_tiles=False)
    directory = Path(directory)

    if rename_dict is None:
        rename_dict = {}
    if coord_attrs_dict is None:
        coord_attrs_dict = {}

    datasets = []
    for tile_name in mosaic.tile_names:
        filename = f"{datafile_prefix}.{tile_name}{datafile_suffix}"
        filepath = directory.joinpath(filename)
        datasets.append(xr.open_dataset(filepath))

    ds = xr.concat(datasets, dim=tile_dim)
    ds = ds.rename(rename_dict)

    for c, a in coord_attrs_dict.items():
        ds.coords[c].attrs.update(a)
    if transpose is not None:
        ds = ds.transpose(*transpose)

    filename = f"{datafile_prefix}{datafile_suffix}"
    filepath = str(directory.joinpath(filename))
    ds.to_netcdf(filepath)
    return filepath
Beispiel #2
0
def test_gridspec_save_and_load(tmp_path):
    mosaic = GridspecGnomonicCubedSphere(12)
    fpath, _ = mosaic.to_netcdf(directory=tmp_path)
    mosaic2 = load_mosaic(fpath)
    assert mosaic == mosaic2
    for t1, t2 in zip(mosaic.tiles, mosaic2.tiles):
        assert t1 == t2
Beispiel #3
0
def touch_datafiles(gridspec_file, datafile_prefix, datafile_suffix='.nc', directory="./",
                    name_dim1='Ydim', name_dim2='Xdim',
                    name_lat_coord='lats', name_lon_coord='lons') -> List[str]:
    mosaic = load_mosaic(gridspec_file)
    directory = Path(directory)

    new_files=[]
    for tile in mosaic.tiles:
        lons = tile.supergrid_lons[1::2, 1::2]
        lats = tile.supergrid_lats[1::2, 1::2]

        ds = xr.Dataset()
        ds.coords[name_lon_coord] = xr.DataArray(
            lons,
            dims=(name_dim1, name_dim2),
            attrs=dict(
                standard_name="geographic_longitude",
                units="degree_east"
            )
        )
        ds.coords[name_lat_coord] = xr.DataArray(
            lats,
            dims=(name_dim1, name_dim2),
            attrs=dict(
                standard_name="geographic_latitude",
                units="degree_north"
            )
        )

        filename = f"{datafile_prefix}.{tile.name}{datafile_suffix}"
        opath = str(directory.joinpath(filename))
        ds.to_netcdf(opath)
        new_files.append(opath)
    return new_files
Beispiel #4
0
def dump(filepath):
    """Print information about a gridspec file
    """
    import xarray as xr
    ds = xr.open_dataset(filepath)

    mosaic = GridspecMosaic()
    is_mosaic = mosaic.load(ds)
    if is_mosaic:
        mosaic = load_mosaic(filepath)  # load_mosaic also loads all the tiles
        print(mosaic)
        return

    tile = GridspecTile()
    is_tile = tile.load(ds)
    if is_tile:
        print(tile)
        return

    cf_single_tile = CFSingleTile()
    is_cf_single_tile = cf_single_tile.load(ds)
    if is_cf_single_tile:
        print(cf_single_tile)
        return

    raise click.BadParameter(f"{filepath} is not a gridspec tile or mosaic")
Beispiel #5
0
def split_datafile(datafile, tile_dim, gridspec_file, directory=None) -> List[str]:
    mosaic = load_mosaic(gridspec_file)
    ds = xr.open_dataset(datafile)

    assert ds.dims[tile_dim] == len(mosaic.tiles)

    # Determine the output directory for the split files
    datafile_path = Path(datafile)
    parent_dir = datafile_path.parent
    if directory is None:
        directory = parent_dir
    directory = Path(directory)

    # Split the files
    split_file_paths=[]
    for i, tile_name in enumerate(mosaic.tile_names):
        tile_ds = ds.isel(**{tile_dim: i})
        filename = f"{datafile_path.stem}.{tile_name}.nc"
        opath = str(directory.joinpath(filename))
        tile_ds.to_netcdf(opath)
        split_file_paths.append(opath)
    return split_file_paths