{
    "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 shares structural similarity since both bugs relate to DataArray outputs and their representation in Python interactions. The issue with trailing whitespaces in DatasetGroupBy's representation may be conceptually connected to how other xarray functions, such as resample, generate outputs that aren't as expected, as highlighted by the user concerns over streamlining outputs for consistency with tools like flake8. Addressing formatting inconsistencies, as in both cases, would be critical in the debugging and patching processes, particularly relevant since the fix in Candidate A involves core data structures of xarray. This makes it the most helpful report for understanding and resolving the current issue."
}