Open slevang opened 2 years ago
All plot methods use the **kwargs to pass additional options to matplotlib.
Hey @headtr1ck I am trying out open source for the first time through Outreachy. Could you please guide me a little so that I could proceed with this issue.
I am trying out open source for the first time through Outreachy. Could you please guide me a little so that I could proceed with this issue.
Welcome to xarray! I think this issue requires some discussion before we can actually address code changes. It would be better to start with a different issue first.
What is your issue?
Follow on from #6891 and #6978 to discuss how we could homogenize the passing of keyword arguments to wrapped external functions across xarray methods.
There are quite a few methods like this where we are ultimately passing data to numpy, scipy, or some other library and want the option to send variable length kwargs to that underlying function. There are two different ways of doing this today:
**kwargs
so these can be written directly in the xarray callkwargs
(sometimes named differently) and passes these along in expanded form via**kwargs
I could only find a few examples of the latter:
Dataset.interp
, which takeskwargs
Dataset.curvefit
, which takeskwargs
(although the docstring is wrong here)xr.apply_ufunc
, which takeskwargs
passed tofunc
anddask_gufunc_kwargs
passed todask.array.apply_gufunc
xr.open_dataset
, which takes either**kwargs
orbackend_kwargs
and merges the twoAllowing direct passage with
**kwargs
seems nice from a user perspective. But, this could occasionally be problematic, for example in theDataset.interp
case where this method also accepts the kwarg form ofcoords
with**coords_kwargs
. There are many methods like this that use**indexers_kwargs
or**chunks_kwargs
witheither_dict_or_kwargs
but don't happen to wrap external functions.