Относительно xarray apply_ufunc - PullRequest
0 голосов
/ 25 мая 2018

Я пытаюсь рассчитать суточную Tmax из трехчасового набора глобальных данных.Я могу сделать это с помощью groupby, но я хотел бы выяснить, как я могу сократить время вычислений, используя параллельные операции dask (например, используя apply_ufunc).Если есть хорошая документация по ufunc, пожалуйста, дайте мне знать (документация по xarray не была достаточно подробной для меня, оставила меня немного смущенным, так как у меня нет никакого предыдущего опыта работы с dask).Спасибо !!

Вот как выглядит мой код:

    TAS = xr.open_dataset(INFILE_template.format(YR, YR), chunks={'time':8})
    DAYMAX  = TAS.groupby('time.dayofyear').max(dim='time')
    DAYMAX.to_netcdf(OUTFILE_template.format(YR, YR))

Размеры TAS указаны ниже:

    <xarray.Dataset>
    Dimensions:  (lat: 720, lon: 1440, time: 2928)
    Coordinates:
    * lon      (lon) float64 0.125 0.375 0.625 0.875 1.125 1.375 1.625 1.875 ...
    * lat      (lat) float64 -89.88 -89.62 -89.38 -89.12 -88.88 -88.62 -88.38 ...
    * time     (time) datetime64[ns] 2008-01-01 2008-01-01T03:00:00 ...
    Data variables:
    tas      (time, lat, lon) float32 dask.array<shape=(2928, 720, 1440),   

1 Ответ

0 голосов
/ 25 мая 2018

Если вы уже можете написать свой анализ с помощью groupby() и других методов xarray, все они уже распараллелены с помощью dask.apply_ufunc облегчает упаковку новой функциональности для поддержки xarray и dask, но все встроенные подпрограммы в xarray уже используют apply_ufunc или что-то подобное для поддержки dask.

В качестве примечания: если вы любезно уточните, что вы нашли запутанным или отсутствующим в документах xarray, мы всегда стремимся улучшить их!

...