{
    "Selected_candidate": {
        "pr_number": 2796,
        "pr_title": "Add check for np.ma.nomask in NDData mask setter",
        "pr_body": "Adds a check for a passed value of `np.ma.nomask` in the NDData mask setter.  This prevents a `ValueError` being raised when passing a numpy masked array which has no masked entries to `NDData()` (issue #2784).\n",
        "issue_id": 2784,
        "issue_title": "Initialising NDData objects with a numpy masked array object fails if there are no masked entries",
        "issue_body": "If you attempt to initialise an NDData object using a numpy masked array object which happens to have no masked entries it raises an exception, e.g.\n\n```\nmaskedarray = numpy.ma.array(numpy.ones((10,10)))\nastropy.nddata.NDData(maskedarray)\n```\n\nresults in `ValueError: dimensions of mask do not match data` (confirmed with Python 3.4.1, numpy 1.8.1 and astropy 0.4).\n\nThe problem is the mask setter code in nddata.py:\n\n```\n@mask.setter\ndef mask(self, value):\n    if value is not None:\n        mask = np.array(value, dtype=np.bool_, copy=False)\n        if mask.shape != self.shape:\n            raise ValueError(\"dimensions of mask do not match data\")\n        else:\n            self._mask = mask\n    else:\n        # internal representation should be one numpy understands\n        self._mask = np.ma.nomask\n```\n\nThe 3rd line tests whether the provided mask `value` is equal to `None` but the mask of a numpy masked array with no masked elements is not `None`, it is `numpy.ma.nomask` (which evaluates to `False`).  As a result the expression in the if statement evaluates as `True` and the setter goes ahead to convert `numpy.ma.nomask` to a single element boolean array `[False,]` before raising an exception because the shape doesn't match that of the data.\n\nI think all that is required here is to replace \n\n`if value is not None:` \n\nwith \n\n`if (value is not None) and (value != np.ma.nomask):`\n",
        "issue_closed_at": "2014-08-01T15:42:33Z",
        "base_commit": "ecaa91e59e3acc314f197e2abbfd4c43df8f10ad",
        "changes": [
            {
                "file": "astropy/nddata/nddata.py",
                "type": "function",
                "name": "mask",
                "class_name": "NDData",
                "code": "def mask(self, value):\n        if value is not None:\n            mask = np.array(value, dtype=np.bool_, copy=False)\n            if mask.shape != self.shape:\n                raise ValueError(\"dimensions of mask do not match data\")\n            else:\n                self._mask = mask\n        else:\n            # internal representation should be one numpy understands\n            self._mask = np.ma.nomask"
            }
        ]
    },
    "Justification": "Candidate A is the most helpful bug report overall because it addresses similar functionality within the `nddata` module where the CURRENT bug is localized. The nature of the mask handling failing in the case of `NDData` initialization due to `None` values aligns closely with the issue description in the CURRENT bug. This shared context and focus on mask management could provide crucial insights and relevant patches to resolve the ongoing issue."
}