{
    "Selected_candidate": {
        "pr_number": 2603,
        "pr_title": "Support HighLevelGraphs",
        "pr_body": "Fixes https://github.com/dask/dask/issues/4291\r\n\r\n - [x] Fully documented, including `whats-new.rst` for all changes and `api.rst` for new API\r\n",
        "issue_id": 4291,
        "issue_title": "resample function gives 0s instead of NaNs",
        "issue_body": "<!-- Please include a self-contained copy-pastable example that generates the issue if possible.\r\n\r\nPlease be concise with code posted. See guidelines below on how to provide a good bug report:\r\n\r\n- Craft Minimal Bug Reports: http://matthewrocklin.com/blog/work/2018/02/28/minimal-bug-reports\r\n- Minimal Complete Verifiable Examples: https://stackoverflow.com/help/mcve\r\n\r\nBug reports that follow these guidelines are easier to diagnose, and so are often handled much more quickly.\r\n-->\r\n\r\n**What happened**:\r\nWhen I use `resample(time='1d').sum(dim='time')` to resample a time series with NaNs, the resampled result gives me 0s instead of NaNs, while NaNs should be the correct answer.\r\n\r\n**What you expected to happen**:\r\n\r\nNaNs should be the correct answer.\r\n\r\n**Minimal Complete Verifiable Example**:\r\n\r\n```python\r\nimport xarray as xr\r\n\r\ndates =  pd.date_range('20200101', '20200601', freq='h')\r\ndata = np.linspace(0, 10, num=len(dates))\r\ndata[0:30*24] = np.nan\r\n\r\nda = xr.DataArray(data, coords=[dates], dims='time')\r\nda.plot()\r\n\r\n# Instead of NaNs, the resampled time series in January 20202 give us 0s, which not right.\r\nda.resample(time='1d', skipna=True).sum(dim='time', skipna=True).plot()\r\n```\r\n\r\n**Anything else we need to know?**:\r\n\r\nDid I misunderstand something here? Thanks!\r\n\r\n\r\n**Environment**:\r\nxarray - '0.15.1' \r\n\r\n<details><summary>Output of <tt>xr.show_versions()</tt></summary>\r\n\r\nxarray - '0.15.1' \r\n\r\n\r\n</details>\r\n",
        "issue_closed_at": "2020-08-05T16:55:58Z",
        "base_commit": "82789bc6f72a76d69ace4bbabd00601e28e808da",
        "changes": [
            {
                "file": "xarray/core/dataarray.py",
                "type": "function",
                "name": "__dask_graph__",
                "class_name": "DataArray",
                "code": "def __dask_graph__(self):\n        return self._to_temp_dataset().__dask_graph__()"
            },
            {
                "file": "xarray/core/dataset.py",
                "type": "function",
                "name": "__dask_graph__",
                "class_name": "Dataset",
                "code": "def __dask_graph__(self):\n        graphs = {k: v.__dask_graph__() for k, v in self.variables.items()}\n        graphs = {k: v for k, v in graphs.items() if v is not None}\n        if not graphs:\n            return None\n        else:\n            from dask import sharedict\n            return sharedict.merge(*graphs.values())"
            },
            {
                "file": "xarray/core/variable.py",
                "type": "function",
                "name": "__dask_graph__",
                "class_name": "Variable",
                "code": "def __dask_graph__(self):\n        if isinstance(self._data, dask_array_type):\n            return self._data.__dask_graph__()\n        else:\n            return None"
            }
        ]
    },
    "Justification": "Candidate A is the most relevant to the CURRENT bug report as both involve the handling of xarray DataArray objects. The issue with `DataSet.update` resulting in a DataArray losing its chunked property relates to the internal handling of DataArrays and how their underlying data is managed. The structural and module similarities are strong, as they both share core xarray functionalities concerning data handling. Additionally, the bug report shows a misconception similar to the confusion in Candidate A about when data is computed. Insights from Candidate A's resolution will help understand potential computational behavior in the CURRENT bug context."
}