{
  "original_problem": {
    "instance_id": "astropy__astropy-14995",
    "repo": "astropy/astropy",
    "created_at": "2023-06-27T19:48:18Z",
    "problem_statement": "In v5.3, NDDataRef mask propagation fails when one of the operand does not have a mask\n### Description\n\nThis applies to v5.3. \r\n\r\nIt looks like when one of the operand does not have a mask, the mask propagation when doing arithmetic, in particular with `handle_mask=np.bitwise_or` fails.  This is not a problem in v5.2.\r\n\r\nI don't know enough about how all that works, but it seems from the error that the operand without a mask is set as a mask of None's and then the bitwise_or tries to operate on an integer and a None and fails.\n\n### Expected behavior\n\nWhen one of the operand does not have mask, the mask that exists should just be copied over to the output.  Or whatever was done in that situation in v5.2 where there's no problem.\n\n### How to Reproduce\n\nThis is with v5.3.   With v5.2, there are no errors.\r\n\r\n```\r\n>>> import numpy as np\r\n>>> from astropy.nddata import NDDataRef\r\n\r\n>>> array = np.array([[0, 1, 0], [1, 0, 1], [0, 1, 0]])\r\n>>> mask = np.array([[0, 1, 64], [8, 0, 1], [2, 1, 0]])\r\n\r\n>>> nref_nomask = NDDataRef(array)\r\n>>> nref_mask = NDDataRef(array, mask=mask)\r\n\r\n# multiply no mask by constant (no mask * no mask)\r\n>>> nref_nomask.multiply(1., handle_mask=np.bitwise_or).mask   # returns nothing, no mask,  OK\r\n\r\n# multiply no mask by itself (no mask * no mask)\r\n>>> nref_nomask.multiply(nref_nomask, handle_mask=np.bitwise_or).mask # return nothing, no mask, OK\r\n\r\n# multiply mask by constant (mask * no mask)\r\n>>> nref_mask.multiply(1., handle_mask=np.bitwise_or).mask\r\n...\r\nTypeError: unsupported operand type(s) for |: 'int' and 'NoneType'\r\n\r\n# multiply mask by itself (mask * mask)\r\n>>> nref_mask.multiply(nref_mask, handle_mask=np.bitwise_or).mask\r\narray([[ 0,  1, 64],\r\n       [ 8,  0,  1],\r\n       [ 2,  1,  0]])\r\n\r\n# multiply mask by no mask (mask * no mask)\r\n>>> nref_mask.multiply(nref_nomask, handle_mask=np.bitwise_or).mask\r\n...\r\nTypeError: unsupported operand type(s) for |: 'int' and 'NoneType'\r\n```\r\n\n\n### Versions\n\n>>> import sys; print(\"Python\", sys.version)\r\nPython 3.10.11 | packaged by conda-forge | (main, May 10 2023, 19:07:22) [Clang 14.0.6 ]\r\n>>> import astropy; print(\"astropy\", astropy.__version__)\r\nastropy 5.3\r\n>>> import numpy; print(\"Numpy\", numpy.__version__)\r\nNumpy 1.24.3\r\n>>> import erfa; print(\"pyerfa\", erfa.__version__)\r\npyerfa 2.0.0.3\r\n>>> import scipy; print(\"Scipy\", scipy.__version__)\r\nScipy 1.10.1\r\n>>> import matplotlib; print(\"Matplotlib\", matplotlib.__version__)\r\nMatplotlib 3.7.1\r\n\n",
    "patch": "diff --git a/astropy/nddata/mixins/ndarithmetic.py b/astropy/nddata/mixins/ndarithmetic.py\n--- a/astropy/nddata/mixins/ndarithmetic.py\n+++ b/astropy/nddata/mixins/ndarithmetic.py\n@@ -520,10 +520,10 @@ def _arithmetic_mask(self, operation, operand, handle_mask, axis=None, **kwds):\n         elif self.mask is None and operand is not None:\n             # Make a copy so there is no reference in the result.\n             return deepcopy(operand.mask)\n-        elif operand is None:\n+        elif operand.mask is None:\n             return deepcopy(self.mask)\n         else:\n-            # Now lets calculate the resulting mask (operation enforces copy)\n+            # Now let's calculate the resulting mask (operation enforces copy)\n             return handle_mask(self.mask, operand.mask, **kwds)\n \n     def _arithmetic_wcs(self, operation, operand, compare_wcs, **kwds):\n"
  },
  "candidates_evaluated": 5,
  "judgment_result": {
    "candidates": [
      {
        "idx": 1,
        "id": "similar_2784",
        "decision": "Useful",
        "confidence": "High",
        "reason": "Both issues involve incorrect handling of mask attributes in NDData, with similar root causes related to conditional logic errors."
      },
      {
        "idx": 2,
        "id": "similar_886",
        "decision": "Not useful",
        "confidence": "High",
        "reason": "The issue is unrelated to mask handling or NDData, focusing instead on time format validation."
      },
      {
        "idx": 3,
        "id": "similar_13008",
        "decision": "Not useful",
        "confidence": "High",
        "reason": "This issue deals with time conversion precision, unrelated to mask propagation or NDData."
      },
      {
        "idx": 4,
        "id": "similar_2711",
        "decision": "Not useful",
        "confidence": "High",
        "reason": "The issue is about type mismatch in FITS file processing, not related to mask handling in NDData."
      },
      {
        "idx": 5,
        "id": "similar_5857",
        "decision": "Not useful",
        "confidence": "High",
        "reason": "This issue concerns coordinate frame transformations, unrelated to mask handling in NDData."
      }
    ]
  },
  "raw_summaries": [
    {
      "similar_issue": {
        "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_id": 2784,
        "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_closed_at": "2014-08-01T15:42:33Z",
        "base_commit": "ecaa91e59e3acc314f197e2abbfd4c43df8f10ad"
      },
      "summary": "### Summary:\nThis issue pertains to a problem encountered when initializing NDData objects using numpy masked array objects that contain no masked entries. The problem arises due to an incorrect handling of the mask attribute in the NDData class. Specifically, the code does not appropriately recognize a numpy masked array with no masked elements, as it evaluates the mask attribute incorrectly, leading to an exception.\n\n1. **Problem description in general terms:**\n   The general issue is the failure to correctly initialize objects when using a specific type of input data that lacks masked values, due to improper conditional checks within the code that handles data masking.\n\n2. **Key symptoms and behaviors observed:**\n   When attempting to initialize an NDData object with a numpy masked array that has no masked entries, the process results in a `ValueError` with the message \"dimensions of mask do not match data\". This is due to the mask being misinterpreted as a boolean array with incorrect dimensions.\n\n3. **Affected components or systems:**\n   This issue affects the `NDData` class within the `astropy.nddata` module, specifically the mask setter function in the `nddata.py` file.\n\n4. **Potential impact or severity:**\n   The impact is significant for users who need to work with numpy masked arrays in NDData objects, especially when such arrays do not have any masked entries. The failure to initialize these objects correctly can disrupt workflows and lead to data processing errors in the affected applications.\n\n5. **Relevant technical details abstracted for broader understanding:**\n   The root cause lies in the mask setter's conditional logic, which fails to correctly interpret `numpy.ma.nomask`. The proposed solution is to adjust the condition to explicitly check for `numpy.ma.nomask` in addition to `None`, ensuring that the mask is handled appropriately when no elements are masked.\n\nChanges Summary:\nastropy/nddata/nddata.py\n  function: NDData.mask",
      "prompt_used": "You are an expert in software issue reasoning analysis.\nGiven the following problem report and its fixed code elements, generate a comprehensive summary based on the entire document. Your goal is to abstract the information in the problem description into a more general description.\n\n## Original Issue Report:\nTitle: Initialising NDData objects with a numpy masked array object fails if there are no masked entries\n\nBody:\nIf 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\n\n## Code elements fixed by the patch:\n{FIXED_CODE_ELEMENTS}\n\nPlease analyze the above issue report and provide a structured summary that includes:\n1. Problem description in general terms\n2. Key symptoms and behaviors observed\n3. Affected components or systems\n4. Potential impact or severity\n5. Any relevant technical details abstracted for broader understanding\n\nPlease return the summary with “### Summary:\", For example:\n### Summary: This issue is ...\n\nChanges Summary:\nastropy/nddata/nddata.py\n  function: NDData.mask\n"
    },
    {
      "similar_issue": {
        "issue_title": "creating a Time with multiple Time(format=datetime) objects gives an error",
        "issue_body": "I've noticed some unexpected behavior with the `datetime` support in `time` recently added by @taldcroft in #860.  It may not actually be related to that (that is, it might be true for all formats), but I first noticed it after the #860 merge, so it _might_ be connected.\n\nWhen I do `Time([dt1,dt2],scale='utc')` (`dt1` and `dt2` are `datetime.datetime` objects), I get exactly what I expect: A `Time` object that contains an array with two elements.  Similarly, when I do `Time(t1)` (where `t1` is a time object) I get out the natural expectation: a copy of `t1`.  However, if I do this:\n\n```\nt1 = Time(dt1, scale='utc')\nt2 = Time(dt2, scale='utc')\ntarr = Time([t1, t2])\n```\n\nI get an error about it being an invalid format.  I would have instead expected to get back a new `Time` object with a two-element array that looks just like `Time([dt1,dt2],scale='utc')`\n",
        "issue_id": 886,
        "pr_number": 889,
        "pr_title": "Add TimeAstropyTime format to instantiate from list of Times",
        "pr_body": "This will close #886.  (Sorry, don't have hub setup on my mac to attach code to that issue).\n",
        "issue_closed_at": "2013-03-22T06:27:44Z",
        "base_commit": "dad4904adda976bcb01a1216ba20cb05dbd4bb21"
      },
      "summary": "### Summary:\n\nThis issue is related to the handling of `datetime` objects within the `Time` class in the Astropy library, specifically when creating a `Time` object from multiple `Time` instances. The problem arises when users attempt to create a `Time` object from a list of `Time` objects initialized with `datetime.datetime` values. Instead of successfully creating a `Time` object containing an array of these time values, an error regarding an invalid format is encountered.\n\nKey symptoms and behaviors observed include the successful creation of a `Time` object from a list of `datetime` objects directly, but failure when initializing a `Time` object from an array of `Time` instances created from `datetime` objects. This inconsistency suggests a possible flaw in how format validation is performed during the initialization of `Time` objects from existing `Time` instances.\n\nThe affected component is the Astropy `Time` class, particularly its methods for initializing and validating time formats. The problem could potentially affect any users relying on the seamless conversion and manipulation of time data involving `datetime` formats within the library.\n\nThe potential impact of this issue includes interruptions in workflows that require batch processing of multiple time objects, leading to unexpected errors and the need for workarounds. It can affect scientific computations or applications that depend on accurate and reliable time data handling.\n\nRelevant technical details include modifications to the `Time._init_from_vals` and `Time._get_time_fmt` functions, as well as the `TimeUnique` class in `astropy/time/core.py`. These changes likely address the validation logic and ensure consistent behavior across different ways of initializing `Time` objects from `datetime` values.",
      "prompt_used": "You are an expert in software issue reasoning analysis.\nGiven the following problem report and its fixed code elements, generate a comprehensive summary based on the entire document. Your goal is to abstract the information in the problem description into a more general description.\n\n## Original Issue Report:\nTitle: creating a Time with multiple Time(format=datetime) objects gives an error\n\nBody:\nI've noticed some unexpected behavior with the `datetime` support in `time` recently added by @taldcroft in #860.  It may not actually be related to that (that is, it might be true for all formats), but I first noticed it after the #860 merge, so it _might_ be connected.\n\nWhen I do `Time([dt1,dt2],scale='utc')` (`dt1` and `dt2` are `datetime.datetime` objects), I get exactly what I expect: A `Time` object that contains an array with two elements.  Similarly, when I do `Time(t1)` (where `t1` is a time object) I get out the natural expectation: a copy of `t1`.  However, if I do this:\n\n```\nt1 = Time(dt1, scale='utc')\nt2 = Time(dt2, scale='utc')\ntarr = Time([t1, t2])\n```\n\nI get an error about it being an invalid format.  I would have instead expected to get back a new `Time` object with a two-element array that looks just like `Time([dt1,dt2],scale='utc')`\n\n\n## Code elements fixed by the patch:\n{FIXED_CODE_ELEMENTS}\n\nPlease analyze the above issue report and provide a structured summary that includes:\n1. Problem description in general terms\n2. Key symptoms and behaviors observed\n3. Affected components or systems\n4. Potential impact or severity\n5. Any relevant technical details abstracted for broader understanding\n\nPlease return the summary with “### Summary:\", For example:\n### Summary: This issue is ...\n\nChanges Summary:\nastropy/time/core.py\n  function: Time._init_from_vals\n  function: Time._get_time_fmt\n  class: TimeUnique\n"
    },
    {
      "similar_issue": {
        "issue_title": "Time from astropy.time not precise",
        "issue_body": "Hello,\r\n\r\nI encounter difficulties with Time. I'm working on a package to perform photometry and occultation. \r\n\r\nFor this last case, data need times values accurately estimated. Of course, data coming from different camera will will have different time format in the header.\r\n\r\nto manage this without passing long time to build a time parser, i decided to use Time object which do exactly what i need. The problem is, i dont arrive to make accurate conversion between different format using Time.\r\n\r\nlet's do an exemple:\r\n\r\n```\r\nt1 = '2022-03-24T23:13:41.390999'\r\nt1 = Time(t1, format = 'isot', precision = len(t1.split('.')[-1]))\r\nt2 = t1.to_value('jd')\r\n# result is 2459663.4678401737\r\n```\r\nnow let's do reverse\r\n\r\n```\r\nt2 = Time(t2, format = 'jd', precision = len(str(t2).split('.')[-1]))\r\nt3 = t2.to_value('isot')\r\n# result is 2022-03-24T23:13:41.0551352177\r\n```\r\nas you can see i don't fall back on the same value and the difference is quite high. I would like to fall back on the original one.\r\n\r\nthank you in advance\r\n",
        "issue_id": 13008,
        "pr_number": 13068,
        "pr_title": "Issue #13008, Time() precision should be 0-9",
        "pr_body": "<!-- This comments are hidden when you submit the pull request,\r\nso you do not need to remove them! -->\r\n\r\n<!-- Please be sure to check out our contributing guidelines,\r\nhttps://github.com/astropy/astropy/blob/main/CONTRIBUTING.md .\r\nPlease be sure to check out our code of conduct,\r\nhttps://github.com/astropy/astropy/blob/main/CODE_OF_CONDUCT.md . -->\r\n\r\n<!-- If you are new or need to be re-acquainted with Astropy\r\ncontributing workflow, please see\r\nhttp://docs.astropy.org/en/latest/development/workflow/development_workflow.html .\r\nThere is even a practical example at\r\nhttps://docs.astropy.org/en/latest/development/workflow/git_edit_workflow_examples.html#astropy-fix-example . -->\r\n\r\n<!-- Astropy coding style guidelines can be found here:\r\nhttps://docs.astropy.org/en/latest/development/codeguide.html#coding-style-conventions\r\nOur testing infrastructure enforces to follow a subset of the PEP8 to be\r\nfollowed. You can check locally whether your changes have followed these by\r\nrunning the following command:\r\n\r\ntox -e codestyle\r\n\r\n-->\r\n\r\n<!-- Please just have a quick search on GitHub to see if a similar\r\npull request has already been posted.\r\nWe have old closed pull requests that might provide useful code or ideas\r\nthat directly tie in with your pull request. -->\r\n\r\n<!-- We have several automatic features that run when a pull request is open.\r\nThey can appear daunting but do not worry because maintainers will help\r\nyou navigate them, if necessary. -->\r\n\r\n### Description\r\n<!-- Provide a general description of what your pull request does.\r\nComplete the following sentence and add relevant details as you see fit. -->\r\n\r\n<!-- In addition please ensure that the pull request title is descriptive\r\nand allows maintainers to infer the applicable subpackage(s). -->\r\n\r\n<!-- READ THIS FOR MANUAL BACKPORT FROM A MAINTAINER:\r\nApply \"skip-basebranch-check\" label **before** you open the PR! -->\r\n\r\nThis pull request is to address: `astropy.time.Time()` has a precision attribute that should be an int in the range 0-9 (inclusive). The setter has already been coded to raise an exception if the precision is outside that range (see [here](https://github.com/astropy/astropy/blob/main/astropy/time/core.py#L610-L611)). However, `Time()` can still be _initialized_ with a precision outside of this range. Thus,\r\n```\r\n>>> from astropy.time import Time\r\n>>> t1 = Time(123, fromat=\"jd\")\r\n>>> t1.precision = 10\r\nTraceback (most recent call last):\r\n  File \"<stdin>\", line 1, in <module>\r\n  File \"/home/brett/env/lib/python3.8/site-packages/astropy/time/core.py\", line 610, in precision\r\n    raise ValueError('precision attribute must be an int between '\r\nValueError: precision attribute must be an int between 0 and 9\r\n```\r\nproduces an exception, but \r\n```\r\n>>> t2 = Time(123, format=\"jd\", precision=10)\r\n>>> \r\n```\r\ndoes not.\r\n\r\nApologies if this PR is unnecessary or if I didn't follow the contributing guidelines. I'm at work rn, but I can certainly update this PR if needed.\r\n\r\n<!-- If the pull request closes any open issues you can add this.\r\nIf you replace <Issue Number> with a number, GitHub will automatically link it.\r\nIf this pull request is unrelated to any issues, please remove\r\nthe following line. -->\r\n\r\nFixes #13008\r\n\r\n### Checklist for package maintainer(s)\r\n<!-- This section is to be filled by package maintainer(s) who will\r\nreview this pull request. -->\r\n\r\nThis checklist is meant to remind the package maintainer(s) who will review this pull request of some common things to look for. This list is not exhaustive.\r\n\r\n- [x] Do the proposed changes actually accomplish desired goals?\r\n- [x] Do the proposed changes follow the [Astropy coding guidelines](https://docs.astropy.org/en/latest/development/codeguide.html)?\r\n- [x] Are tests added/updated as required? If so, do they follow the [Astropy testing guidelines](https://docs.astropy.org/en/latest/development/testguide.html)?\r\n- [x] Are docs added/updated as required? If so, do they follow the [Astropy documentation guidelines](https://docs.astropy.org/en/latest/development/docguide.html#astropy-documentation-rules-and-guidelines)?\r\n- [x] Is rebase and/or squash necessary? If so, please provide the author with appropriate instructions. Also see [\"When to rebase and squash commits\"](https://docs.astropy.org/en/latest/development/when_to_rebase.html).\r\n- [x] Did the CI pass? If no, are the failures related? If you need to run daily and weekly cron jobs as part of the PR, please apply the `Extra CI` label.\r\n- [x] Is a change log needed? If yes, did the change log check pass? If no, add the `no-changelog-entry-needed` label. If this is a manual backport, use the `skip-changelog-checks` label unless special changelog handling is necessary.\r\n- [x] Is this a big PR that makes a \"What's new?\" entry worthwhile and if so, is (1) a \"what's new\" entry included in this PR and (2) the \"whatsnew-needed\" label applied?\r\n- [x] Is a milestone set? Milestone must be set but `astropy-bot` check might be missing; do not let the green checkmark fool you.\r\n- [x] At the time of adding the milestone, if the milestone set requires a backport to release branch(es), apply the appropriate `backport-X.Y.x` label(s) *before* merge.\r\n",
        "issue_closed_at": "2022-06-27T13:08:16Z",
        "base_commit": "2288ecd4e9c4d3722d72b7f4a6555a34f4f04fc7"
      },
      "summary": "### Summary:\nThis issue pertains to the imprecision observed when using the `Time` object from the `astropy.time` module for converting between different time formats, specifically from ISO time to Julian Date (JD) and back. The user experienced significant discrepancies when attempting to revert a time value back to its original format after conversion, which is critical for their work in photometry and occultation that demands high precision in time measurements. The underlying problem was identified in the `TimeBase.precision` function within `astropy/time/core.py` and the `TimeFormat.masked` function within `astropy/time/formats.py`, which likely contributed to the inaccurate conversions. This issue affects the reliability of time conversions in the `astropy` library, potentially impacting any scientific calculations or applications that depend on precise time data, thus indicating a high severity for users in fields requiring exact time synchronization.",
      "prompt_used": "You are an expert in software issue reasoning analysis.\nGiven the following problem report and its fixed code elements, generate a comprehensive summary based on the entire document. Your goal is to abstract the information in the problem description into a more general description.\n\n## Original Issue Report:\nTitle: Time from astropy.time not precise\n\nBody:\nHello,\r\n\r\nI encounter difficulties with Time. I'm working on a package to perform photometry and occultation. \r\n\r\nFor this last case, data need times values accurately estimated. Of course, data coming from different camera will will have different time format in the header.\r\n\r\nto manage this without passing long time to build a time parser, i decided to use Time object which do exactly what i need. The problem is, i dont arrive to make accurate conversion between different format using Time.\r\n\r\nlet's do an exemple:\r\n\r\n```\r\nt1 = '2022-03-24T23:13:41.390999'\r\nt1 = Time(t1, format = 'isot', precision = len(t1.split('.')[-1]))\r\nt2 = t1.to_value('jd')\r\n# result is 2459663.4678401737\r\n```\r\nnow let's do reverse\r\n\r\n```\r\nt2 = Time(t2, format = 'jd', precision = len(str(t2).split('.')[-1]))\r\nt3 = t2.to_value('isot')\r\n# result is 2022-03-24T23:13:41.0551352177\r\n```\r\nas you can see i don't fall back on the same value and the difference is quite high. I would like to fall back on the original one.\r\n\r\nthank you in advance\r\n\n\n## Code elements fixed by the patch:\n{FIXED_CODE_ELEMENTS}\n\nPlease analyze the above issue report and provide a structured summary that includes:\n1. Problem description in general terms\n2. Key symptoms and behaviors observed\n3. Affected components or systems\n4. Potential impact or severity\n5. Any relevant technical details abstracted for broader understanding\n\nPlease return the summary with “### Summary:\", For example:\n### Summary: This issue is ...\n\nChanges Summary:\nastropy/time/core.py\n  function: TimeBase.precision\n\nastropy/time/formats.py\n  function: TimeFormat.masked\n"
    },
    {
      "similar_issue": {
        "issue_title": "FITS: 'BLANK' keyword causes crash when reading data",
        "issue_body": "Hello,\nI already notice since a while an issue while trying to read, e.g., data fits cube (so simply (x,y,z))  see below for the full error which originate from 'hdu/image.py'.\nMy dummy, quickest fix was to add, right before the offending 'if':\n                `if blanks==False: blanks=np.array([False])`\n\nI don't know if it is really appropriate, but it does the trick for me.\n\nregards,\nGilles\n\n```\nIn [120]: array=py.getdata(cube_file)\n---------------------------------------------------------------------------\nAttributeError                            Traceback (most recent call last)\n<ipython-input-120-5d145d1683de> in <module>()\n----> 1 array=py.getdata(cube_file)\n\n/usr/local/lib/python2.7/dist-packages/astropy-0.3.2-py2.7-linux-x86_64.egg/astropy/io/fits/convenience.pyc in getdata(filename, *args, **kwargs)\n    186     hdulist, extidx = _getext(filename, mode, *args, **kwargs)\n    187     hdu = hdulist[extidx]\n--> 188     data = hdu.data\n    189     if data is None and extidx == 0:\n    190         try:\n\n/usr/local/lib/python2.7/dist-packages/astropy-0.3.2-py2.7-linux-x86_64.egg/astropy/utils/misc.pyc in __get__(self, obj, owner)\n    277         key = self._fget.__name__\n    278         if key not in obj.__dict__:\n--> 279             val = self._fget(obj)\n    280             obj.__dict__[key] = val\n    281             return val\n\n/usr/local/lib/python2.7/dist-packages/astropy-0.3.2-py2.7-linux-x86_64.egg/astropy/io/fits/hdu/image.pyc in data(self)\n    213             return\n    214 \n--> 215         data = self._get_scaled_image_data(self._data_offset, self.shape)\n    216         self._update_header_scale_info(data.dtype)\n    217 \n\n/usr/local/lib/python2.7/dist-packages/astropy-0.3.2-py2.7-linux-x86_64.egg/astropy/io/fits/hdu/image.pyc in _get_scaled_image_data(self, offset, shape)\n    582                 # So if the number of blank items is fewer than\n    583                 # len(raw_data.flat) / 8, using np.where will use less memory\n--> 584                 if blanks.sum() < len(blanks) / 8:\n    585                     blanks = np.where(blanks)\n    586 \n\nAttributeError: 'bool' object has no attribute 'sum'\n```\n",
        "issue_id": 2711,
        "pr_number": 2711,
        "pr_title": "FITS: 'BLANK' keyword causes crash when reading data",
        "pr_body": "Hello,\nI already notice since a while an issue while trying to read, e.g., data fits cube (so simply (x,y,z))  see below for the full error which originate from 'hdu/image.py'.\nMy dummy, quickest fix was to add, right before the offending 'if':\n                `if blanks==False: blanks=np.array([False])`\n\nI don't know if it is really appropriate, but it does the trick for me.\n\nregards,\nGilles\n\n```\nIn [120]: array=py.getdata(cube_file)\n---------------------------------------------------------------------------\nAttributeError                            Traceback (most recent call last)\n<ipython-input-120-5d145d1683de> in <module>()\n----> 1 array=py.getdata(cube_file)\n\n/usr/local/lib/python2.7/dist-packages/astropy-0.3.2-py2.7-linux-x86_64.egg/astropy/io/fits/convenience.pyc in getdata(filename, *args, **kwargs)\n    186     hdulist, extidx = _getext(filename, mode, *args, **kwargs)\n    187     hdu = hdulist[extidx]\n--> 188     data = hdu.data\n    189     if data is None and extidx == 0:\n    190         try:\n\n/usr/local/lib/python2.7/dist-packages/astropy-0.3.2-py2.7-linux-x86_64.egg/astropy/utils/misc.pyc in __get__(self, obj, owner)\n    277         key = self._fget.__name__\n    278         if key not in obj.__dict__:\n--> 279             val = self._fget(obj)\n    280             obj.__dict__[key] = val\n    281             return val\n\n/usr/local/lib/python2.7/dist-packages/astropy-0.3.2-py2.7-linux-x86_64.egg/astropy/io/fits/hdu/image.pyc in data(self)\n    213             return\n    214 \n--> 215         data = self._get_scaled_image_data(self._data_offset, self.shape)\n    216         self._update_header_scale_info(data.dtype)\n    217 \n\n/usr/local/lib/python2.7/dist-packages/astropy-0.3.2-py2.7-linux-x86_64.egg/astropy/io/fits/hdu/image.pyc in _get_scaled_image_data(self, offset, shape)\n    582                 # So if the number of blank items is fewer than\n    583                 # len(raw_data.flat) / 8, using np.where will use less memory\n--> 584                 if blanks.sum() < len(blanks) / 8:\n    585                     blanks = np.where(blanks)\n    586 \n\nAttributeError: 'bool' object has no attribute 'sum'\n```\n",
        "issue_closed_at": "2014-09-16T19:18:56Z",
        "base_commit": "0307f793cf700560673ff482d37de447958db437"
      },
      "summary": "### Summary: This issue is related to the handling of a 'BLANK' keyword within the FITS (Flexible Image Transport System) file processing in the Astropy library, which causes a crash when attempting to read data from a FITS file. The problem arises from a type mismatch where a boolean object 'blanks' is mistakenly expected to have attributes typical of a NumPy array. \n\n1. **Problem Description in General Terms**: The issue occurs when reading data from a FITS file using the Astropy library. Specifically, the problem is triggered by the presence of a 'BLANK' keyword, which leads to a type error due to improper handling of the 'blanks' variable.\n\n2. **Key Symptoms and Behaviors Observed**: The primary symptom is a crash with an `AttributeError` indicating that a 'bool' object does not have a 'sum' attribute. This error occurs when the program attempts to perform operations on the 'blanks' variable as if it were a NumPy array, but it is actually a boolean.\n\n3. **Affected Components or Systems**: The issue affects the Astropy library, particularly the FITS module within the file `astropy/io/fits/hdu/image.py`. The specific function involved is `_get_scaled_image_data`.\n\n4. **Potential Impact or Severity**: The impact of this issue is significant for users attempting to read data from FITS files that include the 'BLANK' keyword. This issue can lead to data processing interruptions or failures in scientific computations or analyses that rely on FITS files.\n\n5. **Relevant Technical Details Abstracted for Broader Understanding**: The problem stems from a type discrepancy where a boolean value is being used in a context that expects a NumPy array. A practical workaround is to ensure that 'blanks' is correctly initialized as a NumPy array even when it should logically represent a boolean state. This prevents the erroneous attribute access that causes the crash. The fix involves modifying the handling of the 'blanks' variable in the function `_get_scaled_image_data` within the image HDU (Header Data Unit) processing code.",
      "prompt_used": "You are an expert in software issue reasoning analysis.\nGiven the following problem report and its fixed code elements, generate a comprehensive summary based on the entire document. Your goal is to abstract the information in the problem description into a more general description.\n\n## Original Issue Report:\nTitle: FITS: 'BLANK' keyword causes crash when reading data\n\nBody:\nHello,\nI already notice since a while an issue while trying to read, e.g., data fits cube (so simply (x,y,z))  see below for the full error which originate from 'hdu/image.py'.\nMy dummy, quickest fix was to add, right before the offending 'if':\n                `if blanks==False: blanks=np.array([False])`\n\nI don't know if it is really appropriate, but it does the trick for me.\n\nregards,\nGilles\n\n```\nIn [120]: array=py.getdata(cube_file)\n---------------------------------------------------------------------------\nAttributeError                            Traceback (most recent call last)\n<ipython-input-120-5d145d1683de> in <module>()\n----> 1 array=py.getdata(cube_file)\n\n/usr/local/lib/python2.7/dist-packages/astropy-0.3.2-py2.7-linux-x86_64.egg/astropy/io/fits/convenience.pyc in getdata(filename, *args, **kwargs)\n    186     hdulist, extidx = _getext(filename, mode, *args, **kwargs)\n    187     hdu = hdulist[extidx]\n--> 188     data = hdu.data\n    189     if data is None and extidx == 0:\n    190         try:\n\n/usr/local/lib/python2.7/dist-packages/astropy-0.3.2-py2.7-linux-x86_64.egg/astropy/utils/misc.pyc in __get__(self, obj, owner)\n    277         key = self._fget.__name__\n    278         if key not in obj.__dict__:\n--> 279             val = self._fget(obj)\n    280             obj.__dict__[key] = val\n    281             return val\n\n/usr/local/lib/python2.7/dist-packages/astropy-0.3.2-py2.7-linux-x86_64.egg/astropy/io/fits/hdu/image.pyc in data(self)\n    213             return\n    214 \n--> 215         data = self._get_scaled_image_data(self._data_offset, self.shape)\n    216         self._update_header_scale_info(data.dtype)\n    217 \n\n/usr/local/lib/python2.7/dist-packages/astropy-0.3.2-py2.7-linux-x86_64.egg/astropy/io/fits/hdu/image.pyc in _get_scaled_image_data(self, offset, shape)\n    582                 # So if the number of blank items is fewer than\n    583                 # len(raw_data.flat) / 8, using np.where will use less memory\n--> 584                 if blanks.sum() < len(blanks) / 8:\n    585                     blanks = np.where(blanks)\n    586 \n\nAttributeError: 'bool' object has no attribute 'sum'\n```\n\n\n## Code elements fixed by the patch:\n{FIXED_CODE_ELEMENTS}\n\nPlease analyze the above issue report and provide a structured summary that includes:\n1. Problem description in general terms\n2. Key symptoms and behaviors observed\n3. Affected components or systems\n4. Potential impact or severity\n5. Any relevant technical details abstracted for broader understanding\n\nPlease return the summary with “### Summary:\", For example:\n### Summary: This issue is ...\n\nChanges Summary:\nastropy/io/fits/hdu/image.py\n  line: line 1\n  function: _KeyType.__init__\n  function: _ImageBaseHDU._get_scaled_image_data\n"
    },
    {
      "similar_issue": {
        "issue_title": "Match catalog frames should use exact catalog frame",
        "issue_body": "In #5722 it was noted that the fact that `transform_to` overrides default frame attributes is sometimes problematic. The fix for position angle and separation is in #5762, but there @taldcroft realised that catalog matching would also be affected. It turns out the transformation to the catalog frame is done twice, both in the `SkyCoord.match*` method, and in `matching.py`. So, one has to be chosen and that one should gain a `merge_attributes=False` flag.\r\n\r\nIdeally, we still do this for 1.3.1, but not essential, so milestone can be moved if need be.",
        "issue_id": 5857,
        "pr_number": 11449,
        "pr_title": "Bug Fix #5857: Match catalog frames should use exact catalog frame",
        "pr_body": "Transformation to catalog frame is done twice. Once in matching.py and then in sky_coordinate.py.\r\n\r\nWe remove the transformation from sky_coordinate.py.\r\nInside matching.py, it checks if matchcoord is an instance of ``SkyCoord``, if it is, then we set the ``merge_attribute`` to ``False`` while calling ``transform_to``.\r\n\r\n<!-- This comments are hidden when you submit the pull request,\r\nso you do not need to remove them! -->\r\n\r\n<!-- Please be sure to check out our contributing guidelines,\r\nhttps://github.com/astropy/astropy/blob/master/CONTRIBUTING.md .\r\nPlease be sure to check out our code of conduct,\r\nhttps://github.com/astropy/astropy/blob/master/CODE_OF_CONDUCT.md . -->\r\n\r\n<!-- If you are new or need to be re-acquainted with Astropy\r\ncontributing workflow, please see\r\nhttp://docs.astropy.org/en/latest/development/workflow/development_workflow.html .\r\nThere is even a practical example at\r\nhttps://docs.astropy.org/en/latest/development/workflow/git_edit_workflow_examples.html#astropy-fix-example . -->\r\n\r\n<!-- Astropy coding style guidelines can be found here:\r\nhttps://docs.astropy.org/en/latest/development/codeguide.html#coding-style-conventions\r\nOur testing infrastructure enforces to follow a subset of the PEP8 to be\r\nfollowed. You can check locally whether your changes have followed these by\r\nrunning the following command:\r\n\r\ntox -e codestyle\r\n\r\n-->\r\n\r\n<!-- Please just have a quick search on GitHub to see if a similar\r\npull request has already been posted.\r\nWe have old closed pull requests that might provide useful code or ideas\r\nthat directly tie in with your pull request. -->\r\n\r\n<!-- We have several automatic features that run when a pull request is open.\r\nThey can appear daunting but do not worry because maintainers will help\r\nyou navigate them, if necessary. -->\r\n\r\n### Description\r\n<!-- Provide a general description of what your pull request does.\r\nComplete the following sentence and add relevant details as you see fit. -->\r\n\r\n<!-- In addition please ensure that the pull request title is descriptive\r\nand allows maintainers to infer the applicable subpackage(s). -->\r\n\r\nThis pull request is to address #5857.\r\n\r\n<!-- If the pull request closes any open issues you can add this.\r\nIf you replace <Issue Number> with a number, GitHub will automatically link it.\r\nIf this pull request is unrelated to any issues, please remove\r\nthe following line. -->\r\n\r\nFixes #5857.\r\n",
        "issue_closed_at": "2021-04-12T19:37:50Z",
        "base_commit": "522d5cd8f5b77fd1c42f80b1d57b68ae46aef44f"
      },
      "summary": "### Summary:\nThis issue is related to the transformation of astronomical coordinate frames within the Astropy library, specifically concerning the catalog frame matching process. The problem arises due to the overriding of default frame attributes during the `transform_to` operations, which can lead to inconsistencies and unexpected behaviors during coordinate transformations. This issue affects the catalog matching functionality, as the transformation to the catalog frame is redundantly executed in different parts of the codebase, namely within the `SkyCoord.match*` methods and the `matching.py` module. The proposed solution involves selecting one transformation pathway and introducing a `merge_attributes=False` flag to prevent the override of frame attributes. The problem was initially identified while addressing a related issue with position angle and separation. Although resolving this issue for version 1.3.1 would be ideal, it is not critical and can be deferred to a later release if necessary.\n\nKey symptoms and behaviors include redundant transformations and potential inconsistencies in frame attribute handling. The affected components are primarily the `SkyCoord` class methods and the `matching.py` module within the Astropy coordinates package. The severity of the issue is not critical but could lead to incorrect results in catalog matching, impacting users relying on precise astronomical data analyses. The technical solution involves code changes in the `astropy/coordinates/matching.py` and `astropy/coordinates/sky_coordinate.py` modules, focusing on refining the transformation logic and ensuring consistent handling of frame attributes.",
      "prompt_used": "You are an expert in software issue reasoning analysis.\nGiven the following problem report and its fixed code elements, generate a comprehensive summary based on the entire document. Your goal is to abstract the information in the problem description into a more general description.\n\n## Original Issue Report:\nTitle: Match catalog frames should use exact catalog frame\n\nBody:\nIn #5722 it was noted that the fact that `transform_to` overrides default frame attributes is sometimes problematic. The fix for position angle and separation is in #5762, but there @taldcroft realised that catalog matching would also be affected. It turns out the transformation to the catalog frame is done twice, both in the `SkyCoord.match*` method, and in `matching.py`. So, one has to be chosen and that one should gain a `merge_attributes=False` flag.\r\n\r\nIdeally, we still do this for 1.3.1, but not essential, so milestone can be moved if need be.\n\n## Code elements fixed by the patch:\n{FIXED_CODE_ELEMENTS}\n\nPlease analyze the above issue report and provide a structured summary that includes:\n1. Problem description in general terms\n2. Key symptoms and behaviors observed\n3. Affected components or systems\n4. Potential impact or severity\n5. Any relevant technical details abstracted for broader understanding\n\nPlease return the summary with “### Summary:\", For example:\n### Summary: This issue is ...\n\nChanges Summary:\nastropy/coordinates/matching.py\n  line: line 9\n  function: match_coordinates_3d\n  function: match_coordinates_sky\n\nastropy/coordinates/sky_coordinate.py\n  function: SkyCoord.match_to_catalog_sky\n  function: SkyCoord.match_to_catalog_3d\n"
    }
  ]
}