{
  "original_problem": {
    "instance_id": "astropy__astropy-12907",
    "repo": "astropy/astropy",
    "created_at": "2022-03-03T15:14:54Z",
    "problem_statement": "Modeling's `separability_matrix` does not compute separability correctly for nested CompoundModels\nConsider the following model:\r\n\r\n```python\r\nfrom astropy.modeling import models as m\r\nfrom astropy.modeling.separable import separability_matrix\r\n\r\ncm = m.Linear1D(10) & m.Linear1D(5)\r\n```\r\n\r\nIt's separability matrix as you might expect is a diagonal:\r\n\r\n```python\r\n>>> separability_matrix(cm)\r\narray([[ True, False],\r\n       [False,  True]])\r\n```\r\n\r\nIf I make the model more complex:\r\n```python\r\n>>> separability_matrix(m.Pix2Sky_TAN() & m.Linear1D(10) & m.Linear1D(5))\r\narray([[ True,  True, False, False],\r\n       [ True,  True, False, False],\r\n       [False, False,  True, False],\r\n       [False, False, False,  True]])\r\n```\r\n\r\nThe output matrix is again, as expected, the outputs and inputs to the linear models are separable and independent of each other.\r\n\r\nIf however, I nest these compound models:\r\n```python\r\n>>> separability_matrix(m.Pix2Sky_TAN() & cm)\r\narray([[ True,  True, False, False],\r\n       [ True,  True, False, False],\r\n       [False, False,  True,  True],\r\n       [False, False,  True,  True]])\r\n```\r\nSuddenly the inputs and outputs are no longer separable?\r\n\r\nThis feels like a bug to me, but I might be missing something?\n",
    "patch": "diff --git a/astropy/modeling/separable.py b/astropy/modeling/separable.py\n--- a/astropy/modeling/separable.py\n+++ b/astropy/modeling/separable.py\n@@ -242,7 +242,7 @@ def _cstack(left, right):\n         cright = _coord_matrix(right, 'right', noutp)\n     else:\n         cright = np.zeros((noutp, right.shape[1]))\n-        cright[-right.shape[0]:, -right.shape[1]:] = 1\n+        cright[-right.shape[0]:, -right.shape[1]:] = right\n \n     return np.hstack([cleft, cright])\n \n"
  },
  "candidates_evaluated": 5,
  "judgment_result": {
    "candidates": [
      {
        "idx": 1,
        "id": "similar_9979",
        "decision": "Not useful",
        "confidence": "Low",
        "reason": "The issue involves time handling and does not relate to model separability or nested structures."
      },
      {
        "idx": 2,
        "id": "similar_10414",
        "decision": "Not useful",
        "confidence": "Medium",
        "reason": "The issue is about unit handling in compound models, which is unrelated to separability matrix computation."
      },
      {
        "idx": 3,
        "id": "similar_9921",
        "decision": "Useful",
        "confidence": "High",
        "reason": "Both issues involve handling of compound models and incorrect assumptions about model structure, suggesting similar debugging strategies."
      },
      {
        "idx": 4,
        "id": "similar_8614",
        "decision": "Not useful",
        "confidence": "Low",
        "reason": "The issue is about data type conversion, which does not relate to model separability or nested structures."
      },
      {
        "idx": 5,
        "id": "similar_11087",
        "decision": "Not useful",
        "confidence": "Low",
        "reason": "The issue involves metadata saving, unrelated to model separability or nested model handling."
      }
    ]
  },
  "raw_summaries": [
    {
      "similar_issue": {
        "issue_title": "radial_velocity_correction needs more careful handling of obstime for objects with high proper motion",
        "issue_body": "<!-- This comments are hidden when you submit the issue,\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<!-- Please have a search on our GitHub repository to see if a similar\r\nissue has already been posted.\r\nIf a similar issue is closed, have a quick look to see if you are satisfied\r\nby the resolution.\r\nIf not please go ahead and open an issue! -->\r\n\r\n<!-- Please check that the development version still produces the same bug.\r\nYou can install development version with\r\npip install git+https://github.com/astropy/astropy\r\ncommand. -->\r\n\r\n### Description\r\n<!-- Provide a general description of the bug. -->\r\nWhilst working on #9645 I noticed a subtlety in the radial velocity correction that is important at the metres/second level for objects with high proper motion (arcsecs/year).\r\n\r\nThe issue is that, in order to calculate the RV correction one needs to know the ICRS position of the source *at the time of observation*. To do this, one needs to apply space motion of the ```SkyCoord``` itself, in order to find the position of the source at the observation time. However, this requires knowing the epoch of the coordinates. \r\n\r\nAt the moment, we apply no space motion - i.e we assume the epoch of the coordinates is equal to the RV observation time. We need a way of knowing both the ```obstime``` of the RV measurement and the epoch of the coordinates.  However, at the moment, only one Time is allowed for the whole calculation, which is the time of observation of the radial velocity. In fact, if the user tries to fix this and supplies ```obstime``` argument when the ```SkyCoord``` already has an obstime set then we raise an error.\r\n\r\n### Expected behavior\r\n<!-- What did you expect to happen. -->\r\nWhat I think should happen is this:\r\n\r\n##### Case 1 (User supplies a single ```obstime``` argument, ```SkyCoord.obstime``` is set):\r\nAssume ```SkyCoord.obstime``` is the epoch of the coordinates, apply space motion to find position of source at ```obstime```.\r\n\r\n##### Case 2 (User supplies no ```obstime``` but ```SkyCoord.obstime``` is set):\r\nAssume epoch and RV observation time are the same. Do not apply space motion.\r\n\r\n##### Case 3 (User supplies ```obstime``` but ```SkyCoord.obstime``` is not set):\r\nThis is the only awkward case. We could assume the epoch is equal to the equinox and apply space motion, or we could assume case 2 and apply no space motion. Either way I think we ought to warn the user they are potentially doing something inaccurate.\r\n\r\nThe documentation for this method will also need changing to clarify what is happening.",
        "issue_id": 9979,
        "pr_number": 10094,
        "pr_title": "Apply space motion of SkyCoords for rv corrections",
        "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/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\nNow that we no longer throw an Exception when ```SkyCoord```s with velocity information are passed to ```SkyCoord.radial_velocity_correction``` we have to address a bug that is unfortunately baked into the API.\r\n\r\nCurrently if the passed ```SkyCoord``` had it's own obstime, and it was inconsistent with the passed obstime, we raised an Exception. However, the correct thing to do is to correct the ```SkyCoord``` for it's space motion so that it points to the proper location at the *passed* obstime. \r\n\r\nFailure to do so for nearby or fast moving objects (e.g tau Ceti below) leads to errors of metres/second:\r\n\r\n![RVs_before](https://user-images.githubusercontent.com/4570807/78016482-c518e400-7342-11ea-9833-93ecfe50bba3.png)\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\nThis PR fixes #9979 by updating the object's position to the passed obstime, resulting in better than 10 mm/s agreement with TEMPO2 or BARYCORR.\r\n\r\n![RVs_after](https://user-images.githubusercontent.com/4570807/78016666-04dfcb80-7343-11ea-84b9-715124af3ea5.png)\r\n\r\nUnfortunately I don't think this can be considered a bug fix, since code that used to raise an exception will now run. \r\n\r\nNote that the test I have added for regression downloads the TEMPO2/BARYCORR corrections for tau Ceti from an external website. I have submitted a seperate PR (https://github.com/astropy/astropy-data/pull/88)  to astropy-data to host those corrections there, and then update this PR accordingly, so perhaps hold off until then to merge.",
        "issue_closed_at": "2020-04-16T09:14:21Z",
        "base_commit": "60fb417789abd03269f4d3af412ee2004983e869"
      },
      "summary": "### Summary:\nThis issue is related to the handling of observation time (`obstime`) for celestial objects with high proper motion when calculating radial velocity corrections in the Astropy library. The problem arises from the need to accurately determine the position of a celestial object at the time of observation, which requires accounting for the object's space motion. However, the current implementation assumes that the epoch of the coordinates is the same as the observation time, which can lead to inaccuracies at the meters-per-second level, particularly for objects with significant proper motion.\n\nKey symptoms and behaviors include the lack of space motion application due to the assumption that coordinate epoch equals observation time, and an error being raised if a user attempts to provide an `obstime` when one is already set in the `SkyCoord` object. The affected component is the `SkyCoord.radial_velocity_correction` function within the Astropy library.\n\nThe potential impact of this issue is significant for precise astronomical observations and calculations where high accuracy is required. The issue could lead to erroneous results in radial velocity measurements for high proper motion objects if not addressed.\n\nTechnical details include the need for a mechanism to differentiate between the epoch of the coordinates and the observation time, with considerations for various user-supplied `obstime` scenarios. The documentation for the method needs updating to clarify the assumptions and the behavior in different cases, ensuring users are aware of potential inaccuracies in their calculations.",
      "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: radial_velocity_correction needs more careful handling of obstime for objects with high proper motion\n\nBody:\n<!-- This comments are hidden when you submit the issue,\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<!-- Please have a search on our GitHub repository to see if a similar\r\nissue has already been posted.\r\nIf a similar issue is closed, have a quick look to see if you are satisfied\r\nby the resolution.\r\nIf not please go ahead and open an issue! -->\r\n\r\n<!-- Please check that the development version still produces the same bug.\r\nYou can install development version with\r\npip install git+https://github.com/astropy/astropy\r\ncommand. -->\r\n\r\n### Description\r\n<!-- Provide a general description of the bug. -->\r\nWhilst working on #9645 I noticed a subtlety in the radial velocity correction that is important at the metres/second level for objects with high proper motion (arcsecs/year).\r\n\r\nThe issue is that, in order to calculate the RV correction one needs to know the ICRS position of the source *at the time of observation*. To do this, one needs to apply space motion of the ```SkyCoord``` itself, in order to find the position of the source at the observation time. However, this requires knowing the epoch of the coordinates. \r\n\r\nAt the moment, we apply no space motion - i.e we assume the epoch of the coordinates is equal to the RV observation time. We need a way of knowing both the ```obstime``` of the RV measurement and the epoch of the coordinates.  However, at the moment, only one Time is allowed for the whole calculation, which is the time of observation of the radial velocity. In fact, if the user tries to fix this and supplies ```obstime``` argument when the ```SkyCoord``` already has an obstime set then we raise an error.\r\n\r\n### Expected behavior\r\n<!-- What did you expect to happen. -->\r\nWhat I think should happen is this:\r\n\r\n##### Case 1 (User supplies a single ```obstime``` argument, ```SkyCoord.obstime``` is set):\r\nAssume ```SkyCoord.obstime``` is the epoch of the coordinates, apply space motion to find position of source at ```obstime```.\r\n\r\n##### Case 2 (User supplies no ```obstime``` but ```SkyCoord.obstime``` is set):\r\nAssume epoch and RV observation time are the same. Do not apply space motion.\r\n\r\n##### Case 3 (User supplies ```obstime``` but ```SkyCoord.obstime``` is not set):\r\nThis is the only awkward case. We could assume the epoch is equal to the equinox and apply space motion, or we could assume case 2 and apply no space motion. Either way I think we ought to warn the user they are potentially doing something inaccurate.\r\n\r\nThe documentation for this method will also need changing to clarify what is happening.\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/sky_coordinate.py\n  function: SkyCoord.radial_velocity_correction\n  function: SkyCoord.radial_velocity_correction\n  function: SkyCoord.radial_velocity_correction\n"
    },
    {
      "similar_issue": {
        "issue_title": "Fitting of compound models too restrictive",
        "issue_body": "### Description\r\n<!-- Provide a general description of the bug. -->\r\n@karllark reported on Slack:\r\n\r\nI'm getting an interesting error when fitting a compound model.  The error is:\r\n```\r\nValueError: Fitting a compound model without units can only be performed on\r\ncompound models that only use the arithmetic operators + and -\r\n```\r\nThe model I'm fitting has units for a summed set of models including BlackBody, Drude1D, Gaussian1D models with units of MJy/sr that are then multiplied by a dust attenuation model that does not have units.\r\n\r\nAn example to reproduce the error:\r\n```\r\nimport numpy as np\r\nfrom astropy.modeling import fitting, models\r\n\r\nfitter = fitting.LevMarLSQFitter()\r\nmodel = models.BlackBody(temperature=3000 * u.K) * models.Const1D(amplitude=1.0)\r\n    \r\nx = [1.0, 2.0, 3.0] * u.micron\r\nn = np.random.normal(3)\r\ny = model(x) * (1.0 + n)\r\nres = fitter(model, x, y)\r\n\r\n```\r\n\r\n",
        "issue_id": 10414,
        "pr_number": 10415,
        "pr_title": "Allow fitting of a wider range of compound models ",
        "pr_body": "Fixes #10414\r\n",
        "issue_closed_at": "2020-06-15T18:50:02Z",
        "base_commit": "1a065d5ce403e226799cfb3d606fda33be0a6c08"
      },
      "summary": "### Summary:\n\nThis issue involves a limitation in the Astropy library, specifically in the modeling component, where fitting compound models with mixed units is overly restrictive. The problem manifests as an error when trying to fit compound models that involve both unit-bearing and unit-less components. The error message indicates that fitting without units is constrained to compound models using only '+' and '-' operators. The specific scenario described involves attempting to fit a model consisting of a combination of BlackBody, Drude1D, and Gaussian1D models (with units of MJy/sr) multiplied by a unit-less dust attenuation model, resulting in a ValueError. \n\nKey symptoms include the inability to perform fitting operations on compound models that mix arithmetic operations (multiplication in this case) with unit-bearing and unit-less elements, leading to an error during execution. The components affected are primarily within the Astropy modeling framework, specifically the methods handling the initialization and operation of compound models, as well as the derivative calculations for exponential models. \n\nThe potential impact is significant for users who require flexibility in combining models with differing unit specifications, as it restricts the complexity of models that can be fit using the library. The severity is moderate, as it impedes certain fitting operations but can be worked around by ensuring consistent unit usage or limiting operations to addition and subtraction. \n\nTechnical details indicate that changes were made to core functions in the modeling module, including the handling of models without units and the initialization of compound models. These adjustments aim to broaden the capabilities of the fitting functions to accommodate a wider variety of compound models.",
      "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: Fitting of compound models too restrictive\n\nBody:\n### Description\r\n<!-- Provide a general description of the bug. -->\r\n@karllark reported on Slack:\r\n\r\nI'm getting an interesting error when fitting a compound model.  The error is:\r\n```\r\nValueError: Fitting a compound model without units can only be performed on\r\ncompound models that only use the arithmetic operators + and -\r\n```\r\nThe model I'm fitting has units for a summed set of models including BlackBody, Drude1D, Gaussian1D models with units of MJy/sr that are then multiplied by a dust attenuation model that does not have units.\r\n\r\nAn example to reproduce the error:\r\n```\r\nimport numpy as np\r\nfrom astropy.modeling import fitting, models\r\n\r\nfitter = fitting.LevMarLSQFitter()\r\nmodel = models.BlackBody(temperature=3000 * u.K) * models.Const1D(amplitude=1.0)\r\n    \r\nx = [1.0, 2.0, 3.0] * u.micron\r\nn = np.random.normal(3)\r\ny = model(x) * (1.0 + n)\r\nres = fitter(model, x, y)\r\n\r\n```\r\n\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/modeling/core.py\n  function: Model.without_units_for_data\n  function: CompoundModel.__init__\n  function: CompoundModel._make_leaflist\n\nastropy/modeling/functional_models.py\n  function: Exponential1D.fit_deriv\n  function: Exponential1D.fit_deriv\n"
    },
    {
      "similar_issue": {
        "issue_title": "CompoundModel.return_units assumes that outputs will have have same names as inputs",
        "issue_body": "### Description\r\nWhen a CompoundModel is constructed from a component model that has different input and output names, its return_units method fails with a KeyError.\r\n\r\n### Steps to Reproduce\r\n```python\r\nfrom astropy.modeling import Model\r\nfrom astropy import units as u\r\n\r\nclass ExampleModel(Model):\r\n    n_inputs = 1\r\n    n_outputs = 1\r\n    def __init__(self):\r\n        self._input_units = {\"x\": u.m}\r\n        self._return_units = {\"y\": u.s}\r\n        super().__init__()\r\n \r\n    def evaluate(self, input):\r\n        return u.Quantity(1, u.s)\r\n\r\nm = ExampleModel()\r\n\r\n(m & m).return_units\r\n```\r\nResult:\r\n```\r\nKeyError                                  Traceback (most recent call last)\r\n<ipython-input-1-6d0cb817f1ae> in <module>\r\n     15 m = ExampleModel()\r\n     16\r\n---> 17 (m & m).return_units\r\n\r\n~/repos/astropy/astropy/modeling/core.py in return_units(self)\r\n   3129         inputs_map = self.inputs_map()\r\n   3130         return {key: inputs_map[key][0].return_units[orig_key]\r\n-> 3131                 for key, (mod, orig_key) in inputs_map.items()\r\n   3132                 if inputs_map[key][0].return_units is not None}\r\n   3133\r\n\r\n~/repos/astropy/astropy/modeling/core.py in <dictcomp>(.0)\r\n   3130         return {key: inputs_map[key][0].return_units[orig_key]\r\n   3131                 for key, (mod, orig_key) in inputs_map.items()\r\n-> 3132                 if inputs_map[key][0].return_units is not None}\r\n   3133\r\n   3134     def outputs_map(self):\r\n\r\nKeyError: 'x'\r\n```\r\n\r\n### System Details\r\n```\r\nDarwin-17.7.0-x86_64-i386-64bit\r\nPython 3.7.6 | packaged by conda-forge | (default, Jan  7 2020, 22:05:27)\r\n[Clang 9.0.1 ]\r\nNumpy 1.18.1\r\nastropy 4.1.dev503+g1cb6c81e8.d20200129\r\nScipy 1.4.1\r\n```",
        "issue_id": 9921,
        "pr_number": 10158,
        "pr_title": "fix units of compound models",
        "pr_body": "Fixes #9921\r\n\r\nMap `input_units` and `return_units` of compound models correctly.",
        "issue_closed_at": "2020-04-21T18:50:33Z",
        "base_commit": "59df4c077c3a0530af4735c44be3db8f2083ad6e"
      },
      "summary": "### Summary:\nThis issue is related to the `CompoundModel` class within the Astropy library, specifically concerning its `return_units` method. The problem arises when a compound model is constructed from component models that have differing input and output names. The `return_units` method, which is responsible for mapping the units of the inputs to the units of the outputs, fails due to a `KeyError`. This error occurs because the method incorrectly assumes that the names of the outputs will match those of the inputs, leading to a failure when they differ. This issue affects the `return_units` method in the `astropy/modeling/core.py` file, specifically within the `CompoundModel` class and its related functions, such as `inputs_map`, `input_units_strict`, and `outputs_map`.\n\nThe key symptom observed is the `KeyError`, indicating that the method is attempting to access a dictionary key that does not exist. The affected system involves the interaction between input and output unit mappings within compound models that have been constructed from components with mismatched naming conventions. The impact of this issue is significant for users relying on the correct functionality of compound models in scientific computations, as it prevents them from properly retrieving output units, potentially disrupting workflows that depend on unit conversions.\n\nThe technical details abstracted for broader understanding include the need for the `return_units` method to accommodate different naming schemes between inputs and outputs, ensuring robust and flexible handling of unit mappings in compound models. This requires modifications to the internal logic of the `inputs_map` and `outputs_map` functions to correctly align and translate between the differing input and output names.",
      "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: CompoundModel.return_units assumes that outputs will have have same names as inputs\n\nBody:\n### Description\r\nWhen a CompoundModel is constructed from a component model that has different input and output names, its return_units method fails with a KeyError.\r\n\r\n### Steps to Reproduce\r\n```python\r\nfrom astropy.modeling import Model\r\nfrom astropy import units as u\r\n\r\nclass ExampleModel(Model):\r\n    n_inputs = 1\r\n    n_outputs = 1\r\n    def __init__(self):\r\n        self._input_units = {\"x\": u.m}\r\n        self._return_units = {\"y\": u.s}\r\n        super().__init__()\r\n \r\n    def evaluate(self, input):\r\n        return u.Quantity(1, u.s)\r\n\r\nm = ExampleModel()\r\n\r\n(m & m).return_units\r\n```\r\nResult:\r\n```\r\nKeyError                                  Traceback (most recent call last)\r\n<ipython-input-1-6d0cb817f1ae> in <module>\r\n     15 m = ExampleModel()\r\n     16\r\n---> 17 (m & m).return_units\r\n\r\n~/repos/astropy/astropy/modeling/core.py in return_units(self)\r\n   3129         inputs_map = self.inputs_map()\r\n   3130         return {key: inputs_map[key][0].return_units[orig_key]\r\n-> 3131                 for key, (mod, orig_key) in inputs_map.items()\r\n   3132                 if inputs_map[key][0].return_units is not None}\r\n   3133\r\n\r\n~/repos/astropy/astropy/modeling/core.py in <dictcomp>(.0)\r\n   3130         return {key: inputs_map[key][0].return_units[orig_key]\r\n   3131                 for key, (mod, orig_key) in inputs_map.items()\r\n-> 3132                 if inputs_map[key][0].return_units is not None}\r\n   3133\r\n   3134     def outputs_map(self):\r\n\r\nKeyError: 'x'\r\n```\r\n\r\n### System Details\r\n```\r\nDarwin-17.7.0-x86_64-i386-64bit\r\nPython 3.7.6 | packaged by conda-forge | (default, Jan  7 2020, 22:05:27)\r\n[Clang 9.0.1 ]\r\nNumpy 1.18.1\r\nastropy 4.1.dev503+g1cb6c81e8.d20200129\r\nScipy 1.4.1\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/modeling/core.py\n  function: CompoundModel.inputs_map\n  function: CompoundModel.input_units_strict\n  function: CompoundModel.outputs_map\n  function: CompoundModel.outputs_map\n"
    },
    {
      "similar_issue": {
        "issue_title": "Implicit dtype conversion happening when indexing CartesianRepresentation",
        "issue_body": "When a `CartesianRepresentation` object is created from a `np.float32` object, indexing it automatically upgrades it to `np.float64`.\r\n\r\nNormal behavior:\r\n\r\n```\r\nIn [83]: xyz = np.array([[1, 0, 0], [0.9, 0.1, 0]])\r\n\r\nIn [84]: CartesianRepresentation(xyz.astype(np.float32), xyz_axis=-1, unit=\"km\").xyz.dtype\r\nOut[84]: dtype('float32')\r\n\r\nIn [85]: CartesianRepresentation(xyz.astype(np.float32), xyz_axis=-1, unit=\"km\").xyz[0].dtype\r\nOut[85]: dtype('float32')\r\n```\r\n\r\nHowever, when indexing the representation object itself:\r\n\r\n```\r\nIn [86]: CartesianRepresentation(xyz.astype(np.float32), xyz_axis=-1, unit=\"km\")[0].xyz.dtype\r\nOut[86]: dtype('float64')\r\n```\r\n\r\n*Not to be confused* with #8613, which also changes the dtype but probably because of the internal conversion to `Quantity`:\r\n\r\n```\r\nIn [87]: CartesianRepresentation(xyz.astype(np.float16), xyz_axis=-1, unit=\"km\").xyz.dtype\r\nOut[87]: dtype('float64')\r\n```",
        "issue_id": 8614,
        "pr_number": 8876,
        "pr_title": "Let scalar Quantity.value return a numpy scalar",
        "pr_body": "Benefits: more consistent with `ndarray`, fixes odd problems like #8614.\r\n\r\nDisadvantages: numpy scalars do not always behave the same as python ones. E.g., `(-4.) ** 0.5` returns a complex number (`0+2j`), but `np.float_(-4.) ** 0.5` returns `nan`.\r\n\r\nfixes #8614 \r\n\r\nEDIT: @astrofrog - requested your review since this goes back a *long* time...\r\n\r\nEDIT: partially addresses #6389 as well; but fully addressing it would require returning an array scalar.",
        "issue_closed_at": "2019-07-03T11:39:55Z",
        "base_commit": "872a7a1d7fdea083f8936c4ecbb5a2f5f7d1b020"
      },
      "summary": "### Summary:\nThis issue is related to an unexpected behavior in data type conversion that occurs when indexing a `CartesianRepresentation` object in the Astropy library. Specifically, when the object is initially created using `np.float32` data type, indexing the object directly leads to an automatic and unintended upgrade to `np.float64`, whereas indexing the object's `xyz` attribute does not cause this conversion. This inconsistency can lead to unintended data type changes, which might affect performance and precision, especially in applications where data type consistency is critical.\n\n1. **Problem Description in General Terms:**  \n   There is an unintended automatic data type conversion from `np.float32` to `np.float64` when directly indexing a `CartesianRepresentation` object, which does not align with the expected behavior of maintaining the original data type.\n\n2. **Key Symptoms and Behaviors Observed:**  \n   - The data type of the `xyz` attribute remains `np.float32` when accessed directly.\n   - Indexing the `CartesianRepresentation` object results in the `xyz` attribute being converted to `np.float64`.\n\n3. **Affected Components or Systems:**  \n   - The issue affects the `CartesianRepresentation` class within the Astropy library, specifically when dealing with data type handling during indexing.\n   - Related functions in `astropy/units/quantity.py` and `astropy/units/utils.py` are involved in the conversion process.\n\n4. **Potential Impact or Severity:**  \n   - This behavior can lead to unintended precision changes and performance overhead due to the larger `np.float64` data type.\n   - It can affect scientific computations where maintaining the original data type is crucial for consistency and accuracy.\n\n5. **Relevant Technical Details Abstracted for Broader Understanding:**  \n   - The problem arises due to internal mechanisms that convert data types when indexing the `CartesianRepresentation` object.\n   - The issue is distinct from other data type conversion issues noted in the library, indicating a specific handling requirement for indexing operations.",
      "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: Implicit dtype conversion happening when indexing CartesianRepresentation\n\nBody:\nWhen a `CartesianRepresentation` object is created from a `np.float32` object, indexing it automatically upgrades it to `np.float64`.\r\n\r\nNormal behavior:\r\n\r\n```\r\nIn [83]: xyz = np.array([[1, 0, 0], [0.9, 0.1, 0]])\r\n\r\nIn [84]: CartesianRepresentation(xyz.astype(np.float32), xyz_axis=-1, unit=\"km\").xyz.dtype\r\nOut[84]: dtype('float32')\r\n\r\nIn [85]: CartesianRepresentation(xyz.astype(np.float32), xyz_axis=-1, unit=\"km\").xyz[0].dtype\r\nOut[85]: dtype('float32')\r\n```\r\n\r\nHowever, when indexing the representation object itself:\r\n\r\n```\r\nIn [86]: CartesianRepresentation(xyz.astype(np.float32), xyz_axis=-1, unit=\"km\")[0].xyz.dtype\r\nOut[86]: dtype('float64')\r\n```\r\n\r\n*Not to be confused* with #8613, which also changes the dtype but probably because of the internal conversion to `Quantity`:\r\n\r\n```\r\nIn [87]: CartesianRepresentation(xyz.astype(np.float16), xyz_axis=-1, unit=\"km\").xyz.dtype\r\nOut[87]: dtype('float64')\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/units/quantity.py\n  function: Quantity.to_value\n\nastropy/units/utils.py\n  function: sanitize_scale\n"
    },
    {
      "similar_issue": {
        "issue_title": "Saving a VOTable with an array of fixed size to a file only saves first element",
        "issue_body": "### Description\r\n<!-- Provide a general description of the bug. -->\r\nI am trying to add metadata to a VOTable that I'm creating. This metadata corresponds to a tuple of known length. The data seems to be ok when inserted into the table but, when I save the table to a file, only the first element is saved.\r\n\r\n### Expected behavior\r\n<!-- What did you expect to happen. -->\r\nWhat I expect to see is the entire tuple saved in the file. The tuple is `(1.0, 2.0, 3.0)`, what I see when I print `params` is  `[<PARAM ID=\"sampling\" arraysize=\"3\" datatype=\"double\" name=\"sampling\" value=\"(1.0, 2.0, 3.0)\"/>]`\r\n\r\n### Actual behavior\r\n<!-- What actually happened. -->\r\n<!-- Was the output confusing or poorly described? -->\r\nOnly the first element is saved in the file. When I open it, I see: `PARAM` section I see: `<PARAM ID=\"sampling\" arraysize=\"3\" datatype=\"double\" name=\"sampling\" value=\"1\"/>`\r\n\r\n### Steps to Reproduce\r\n<!-- Ideally a code example could be provided so we can run it ourselves. -->\r\n<!-- If you are pasting code, use triple backticks (```) around\r\nyour code snippet. -->\r\n<!-- If necessary, sanitize your screen output to be pasted so you do not\r\nreveal secrets like tokens and passwords. -->\r\n\r\nWhat I'm doing to create the table and add the metadata is the following:\r\n```\r\n# Create a new VOTable file\r\nvotable = VOTableFile()\r\n# Add a resource\r\nresource = Resource(); votable.resources.append(resource)\r\n# Add a table for the spectra (and add the sampling as metadata)\r\nspectra_table = Table(votable); resource.tables.append(spectra_table)\r\n# Add sampling as param\r\nsampling = tuple([1.0, 2.0, 3.0])\r\n# I'm using a list because, later, I could have more than one param\r\nparams = [Param(votable, name='sampling', datatype='double', arraysize='3', value=sampling)]\r\nspectra_table.params.extend(params)\r\n```\r\n\r\nWhen I print `params`, I see `[<PARAM ID=\"sampling\" arraysize=\"3\" datatype=\"double\" name=\"sampling\" value=\"(1.0, 2.0, 3.0)\"/>]` which seems to be ok. However, when I save this to a file: \r\n```\r\nvotable.to_xml('table_with_params.xml')\r\n```\r\nIn the `PARAM` section I see: `<PARAM ID=\"sampling\" arraysize=\"3\" datatype=\"double\" name=\"sampling\" value=\"1\"/>`.\r\n\r\nI tried sampling being a tuple, list and numpy array, but they all lead to the same result. If I use `*` instead of the fixed known length, the entire array is saved.\r\n\r\n### System Details\r\n<!-- Even if you do not think this is necessary, it is useful information for the maintainers.\r\nPlease run the following snippet and paste the output below:\r\nimport platform; print(platform.platform())\r\nimport sys; print(\"Python\", sys.version)\r\nimport numpy; print(\"Numpy\", numpy.__version__)\r\nimport astropy; print(\"astropy\", astropy.__version__)\r\nimport scipy; print(\"Scipy\", scipy.__version__)\r\nimport matplotlib; print(\"Matplotlib\", matplotlib.__version__)\r\n-->\r\nLinux-5.4.0-52-generic-x86_64-with-glibc2.29\r\nPython 3.8.5 (default, Jul 28 2020, 12:59:40) \r\n[GCC 9.3.0]\r\nNumpy 1.18.2\r\nastropy 4.3.dev268+g883a7c4f5\r\nScipy 1.4.1\r\nMatplotlib 3.2.1\r\n",
        "issue_id": 11087,
        "pr_number": 11157,
        "pr_title": "BUG: VOTable NumericArray to broadcast mask",
        "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/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 handle mask broadcasting for `NumericArray` converter in `io.votable`.\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 #11087 \r\n\r\ncc @druzmieres  ",
        "issue_closed_at": "2021-01-05T17:05:25Z",
        "base_commit": "9c79f08d72cdd7982ea990d9b01553ac9c4d657b"
      },
      "summary": "### Summary:\nThis issue pertains to a bug encountered when saving metadata to a VOTable file within the Astropy library, specifically when the metadata consists of an array of a fixed size. The problem arises when attempting to save a tuple of known length as metadata; only the first element of the tuple is successfully saved to the file, instead of the entire array. The expected behavior is for the entire tuple, such as `(1.0, 2.0, 3.0)`, to be saved as a complete array with the specified length, but the actual behavior results in only the first element being saved, e.g., `1`.\n\nKey symptoms include the successful creation and parameter setup of the VOTable object in memory, where the parameters appear correctly formatted, but a discrepancy occurs upon saving the object to a file. The VOTable file's `PARAM` section incorrectly represents the metadata as a single value instead of an array.\n\nThe affected component is the VOTable handling within the Astropy library, specifically the process of converting and saving metadata arrays to XML format. The issue impacts the correct persistence of metadata in VOTable files, potentially leading to data loss or misinterpretation in scientific applications relying on accurate metadata representation.\n\nThe severity of the issue can be considered moderate, as it directly affects data integrity when saving files, which is critical in data processing and storage scenarios.\n\nRelevant technical details include the use of Python 3.8.5, NumPy 1.18.2, and a development version of Astropy. The bug is related to the handling of fixed-size arrays in the library's VOTable I/O module, suggesting that the conversion or serialization logic may not correctly interpret or write array values of fixed size.",
      "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: Saving a VOTable with an array of fixed size to a file only saves first element\n\nBody:\n### Description\r\n<!-- Provide a general description of the bug. -->\r\nI am trying to add metadata to a VOTable that I'm creating. This metadata corresponds to a tuple of known length. The data seems to be ok when inserted into the table but, when I save the table to a file, only the first element is saved.\r\n\r\n### Expected behavior\r\n<!-- What did you expect to happen. -->\r\nWhat I expect to see is the entire tuple saved in the file. The tuple is `(1.0, 2.0, 3.0)`, what I see when I print `params` is  `[<PARAM ID=\"sampling\" arraysize=\"3\" datatype=\"double\" name=\"sampling\" value=\"(1.0, 2.0, 3.0)\"/>]`\r\n\r\n### Actual behavior\r\n<!-- What actually happened. -->\r\n<!-- Was the output confusing or poorly described? -->\r\nOnly the first element is saved in the file. When I open it, I see: `PARAM` section I see: `<PARAM ID=\"sampling\" arraysize=\"3\" datatype=\"double\" name=\"sampling\" value=\"1\"/>`\r\n\r\n### Steps to Reproduce\r\n<!-- Ideally a code example could be provided so we can run it ourselves. -->\r\n<!-- If you are pasting code, use triple backticks (```) around\r\nyour code snippet. -->\r\n<!-- If necessary, sanitize your screen output to be pasted so you do not\r\nreveal secrets like tokens and passwords. -->\r\n\r\nWhat I'm doing to create the table and add the metadata is the following:\r\n```\r\n# Create a new VOTable file\r\nvotable = VOTableFile()\r\n# Add a resource\r\nresource = Resource(); votable.resources.append(resource)\r\n# Add a table for the spectra (and add the sampling as metadata)\r\nspectra_table = Table(votable); resource.tables.append(spectra_table)\r\n# Add sampling as param\r\nsampling = tuple([1.0, 2.0, 3.0])\r\n# I'm using a list because, later, I could have more than one param\r\nparams = [Param(votable, name='sampling', datatype='double', arraysize='3', value=sampling)]\r\nspectra_table.params.extend(params)\r\n```\r\n\r\nWhen I print `params`, I see `[<PARAM ID=\"sampling\" arraysize=\"3\" datatype=\"double\" name=\"sampling\" value=\"(1.0, 2.0, 3.0)\"/>]` which seems to be ok. However, when I save this to a file: \r\n```\r\nvotable.to_xml('table_with_params.xml')\r\n```\r\nIn the `PARAM` section I see: `<PARAM ID=\"sampling\" arraysize=\"3\" datatype=\"double\" name=\"sampling\" value=\"1\"/>`.\r\n\r\nI tried sampling being a tuple, list and numpy array, but they all lead to the same result. If I use `*` instead of the fixed known length, the entire array is saved.\r\n\r\n### System Details\r\n<!-- Even if you do not think this is necessary, it is useful information for the maintainers.\r\nPlease run the following snippet and paste the output below:\r\nimport platform; print(platform.platform())\r\nimport sys; print(\"Python\", sys.version)\r\nimport numpy; print(\"Numpy\", numpy.__version__)\r\nimport astropy; print(\"astropy\", astropy.__version__)\r\nimport scipy; print(\"Scipy\", scipy.__version__)\r\nimport matplotlib; print(\"Matplotlib\", matplotlib.__version__)\r\n-->\r\nLinux-5.4.0-52-generic-x86_64-with-glibc2.29\r\nPython 3.8.5 (default, Jul 28 2020, 12:59:40) \r\n[GCC 9.3.0]\r\nNumpy 1.18.2\r\nastropy 4.3.dev268+g883a7c4f5\r\nScipy 1.4.1\r\nMatplotlib 3.2.1\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/io/votable/converters.py\n  function: Boolean.output\n"
    }
  ]
}