{
  "original_problem": {
    "instance_id": "astropy__astropy-14365",
    "repo": "astropy/astropy",
    "created_at": "2023-02-06T19:20:34Z",
    "problem_statement": "ascii.qdp Table format assumes QDP commands are upper case\n### Description\n\nascii.qdp assumes that commands in a QDP file are upper case, for example, for errors they must be \"READ SERR 1 2\" whereas QDP itself is not case sensitive and case use \"read serr 1 2\". \r\n\r\nAs many QDP files are created by hand, the expectation that all commands be all-caps should be removed.\n\n### Expected behavior\n\nThe following qdp file should read into a `Table` with errors, rather than crashing.\r\n```\r\nread serr 1 2 \r\n1 0.5 1 0.5\r\n```\n\n### How to Reproduce\n\nCreate a QDP file:\r\n```\r\n> cat > test.qdp\r\nread serr 1 2 \r\n1 0.5 1 0.5\r\n<EOF>\r\n\r\n > python\r\nPython 3.10.9 (main, Dec  7 2022, 02:03:23) [Clang 13.0.0 (clang-1300.0.29.30)] on darwin\r\nType \"help\", \"copyright\", \"credits\" or \"license\" for more information.\r\n>>> from astropy.table import Table\r\n>>> Table.read('test.qdp',format='ascii.qdp')\r\nWARNING: table_id not specified. Reading the first available table [astropy.io.ascii.qdp]\r\nTraceback (most recent call last):\r\n...\r\n    raise ValueError(f'Unrecognized QDP line: {line}')\r\nValueError: Unrecognized QDP line: read serr 1 2\r\n```\r\n\r\nRunning \"qdp test.qdp\" works just fine.\r\n\n\n### Versions\n\nPython 3.10.9 (main, Dec  7 2022, 02:03:23) [Clang 13.0.0 (clang-1300.0.29.30)]\r\nastropy 5.1\r\nNumpy 1.24.1\r\npyerfa 2.0.0.1\r\nScipy 1.10.0\r\nMatplotlib 3.6.3\r\n\n",
    "patch": "diff --git a/astropy/io/ascii/qdp.py b/astropy/io/ascii/qdp.py\n--- a/astropy/io/ascii/qdp.py\n+++ b/astropy/io/ascii/qdp.py\n@@ -68,7 +68,7 @@ def _line_type(line, delimiter=None):\n     _new_re = rf\"NO({sep}NO)+\"\n     _data_re = rf\"({_decimal_re}|NO|[-+]?nan)({sep}({_decimal_re}|NO|[-+]?nan))*)\"\n     _type_re = rf\"^\\s*((?P<command>{_command_re})|(?P<new>{_new_re})|(?P<data>{_data_re})?\\s*(\\!(?P<comment>.*))?\\s*$\"\n-    _line_type_re = re.compile(_type_re)\n+    _line_type_re = re.compile(_type_re, re.IGNORECASE)\n     line = line.strip()\n     if not line:\n         return \"comment\"\n@@ -306,7 +306,7 @@ def _get_tables_from_qdp_file(qdp_file, input_colnames=None, delimiter=None):\n \n             values = []\n             for v in line.split(delimiter):\n-                if v == \"NO\":\n+                if v.upper() == \"NO\":\n                     values.append(np.ma.masked)\n                 else:\n                     # Understand if number is int or float\n"
  },
  "candidates_evaluated": 5,
  "judgment_result": {
    "candidates": [
      {
        "idx": 1,
        "id": "similar_5118",
        "decision": "Not useful",
        "confidence": "Medium",
        "reason": "The issue involves keyword placement in headers, which is unrelated to case sensitivity or command parsing."
      },
      {
        "idx": 2,
        "id": "similar_2711",
        "decision": "Not useful",
        "confidence": "Medium",
        "reason": "The issue is about handling a specific keyword in data extraction, not related to case sensitivity or command parsing."
      },
      {
        "idx": 3,
        "id": "similar_13840",
        "decision": "Not useful",
        "confidence": "Medium",
        "reason": "The issue involves data duplication and column renaming, which does not relate to case sensitivity or command parsing."
      },
      {
        "idx": 4,
        "id": "similar_7145",
        "decision": "Not useful",
        "confidence": "Medium",
        "reason": "The issue is about missing header keywords, unrelated to case sensitivity or command parsing."
      },
      {
        "idx": 5,
        "id": "similar_4711",
        "decision": "Not useful",
        "confidence": "Medium",
        "reason": "The issue involves metadata inheritance, which is not related to case sensitivity or command parsing."
      }
    ]
  },
  "raw_summaries": [
    {
      "similar_issue": {
        "issue_title": "Fix CompImageHDU's made from ImageHDUs with BSCALE/BZERO.",
        "issue_body": "If an existing ImageHDU containing BSCALE/BZERO is turned into a CompImageHDU,\nthe TFIELDS keyword don't get placed in the correct location (immediately\nfollowing GCOUNT), resulting in an invalid CompImageHDU. This fixes this behavior in the file I originally had trouble with, but I was not able to come up with a minimal example to turn into a proper test. It passes all the io.fits tests on my local copy, but it appears CompImageHDUs don't have good test coverage, so I can't promise this change is safe (though I believe it more closely matches the FITS standard, which is the important thing).\n\nSaid minimal example should look something like the below, but this doesn't actually produce the failure on the old code:\n\n``` python\nfrom astropy.io import fits\nimport numpy as np\n\nx = np.random.random((100, 100))*100\n\nx0 = fits.PrimaryHDU()\nx1 = fits.ImageHDU(x)\nx2 = fits.ImageHDU(np.array(x-50, dtype=int), uint=True)\nx2.header['BZERO'] = 32768\nx2.header['BSCALE'] = 1\nx3 = fits.ImageHDU(x*3)\nx4 = fits.BinTableHDU()\nhdus = fits.HDUList([x0, x1, x2, x3, x4])\nhdus.writeto('3hdus.fits')\n\n# fitsverify (based on cfitsio) should fail on this file, only seeing the first HDU.\ndata = fits.open('3hdus.fits')\nfor i in [1, 2, 3]:\n    data[i] = fits.CompImageHDU(data=data[i].data, header=data[i].header)\ndata.writeto('3hdus_comp.fits')\n```\n\nFor further details, see my recent emails to astropy and astropy-dev.\n",
        "issue_id": 5118,
        "pr_number": 5125,
        "pr_title": "Fix to CompImageHDU from 5118 with regression test",
        "pr_body": "I managed to reproduce the failure that #5118 fixes, so I'm starting by adding a regression test to make sure it fails, then I'll cherry-pick the fix from #5118. I think the data passed to `CompImageHDU` had to be integer so that the BSCALE and BZERO still applied.\n\ncc @parejkoj @eteq @embray\n\nEDIT: Closes #5118 \n",
        "issue_closed_at": "2016-06-22T14:05:25Z",
        "base_commit": "c2de3ec51a24a0f93e90c7e1c178c2627814c06b"
      },
      "summary": "### Summary:\nThis issue pertains to the incorrect placement of the TFIELDS keyword when converting an ImageHDU containing BSCALE/BZERO values into a CompImageHDU within the Astropy library. The primary symptom of this problem is the creation of an invalid CompImageHDU due to the TFIELDS keyword not being immediately positioned after the GCOUNT keyword, which deviates from the expected FITS standard. This misplacement leads to validation failures when processed by FITS verification tools such as fitsverify. The components affected include the handling of CompImageHDU objects within the Astropy library, specifically within the modules responsible for updating header data in both base and compressed HDU implementations. The potential impact of this issue is significant, as it may result in data integrity issues when working with compressed image data, though the lack of comprehensive test coverage for CompImageHDU increases the uncertainty regarding the scope of this fix. Technical adjustments were made to the relevant functions in the codebase to ensure that the header data is updated correctly, aligning the behavior more closely with the FITS standard.",
      "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: Fix CompImageHDU's made from ImageHDUs with BSCALE/BZERO.\n\nBody:\nIf an existing ImageHDU containing BSCALE/BZERO is turned into a CompImageHDU,\nthe TFIELDS keyword don't get placed in the correct location (immediately\nfollowing GCOUNT), resulting in an invalid CompImageHDU. This fixes this behavior in the file I originally had trouble with, but I was not able to come up with a minimal example to turn into a proper test. It passes all the io.fits tests on my local copy, but it appears CompImageHDUs don't have good test coverage, so I can't promise this change is safe (though I believe it more closely matches the FITS standard, which is the important thing).\n\nSaid minimal example should look something like the below, but this doesn't actually produce the failure on the old code:\n\n``` python\nfrom astropy.io import fits\nimport numpy as np\n\nx = np.random.random((100, 100))*100\n\nx0 = fits.PrimaryHDU()\nx1 = fits.ImageHDU(x)\nx2 = fits.ImageHDU(np.array(x-50, dtype=int), uint=True)\nx2.header['BZERO'] = 32768\nx2.header['BSCALE'] = 1\nx3 = fits.ImageHDU(x*3)\nx4 = fits.BinTableHDU()\nhdus = fits.HDUList([x0, x1, x2, x3, x4])\nhdus.writeto('3hdus.fits')\n\n# fitsverify (based on cfitsio) should fail on this file, only seeing the first HDU.\ndata = fits.open('3hdus.fits')\nfor i in [1, 2, 3]:\n    data[i] = fits.CompImageHDU(data=data[i].data, header=data[i].header)\ndata.writeto('3hdus_comp.fits')\n```\n\nFor further details, see my recent emails to astropy and astropy-dev.\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/base.py\n  function: _BaseHDU._update_uint_scale_keywords\n\nastropy/io/fits/hdu/compressed.py\n  function: CompImageHDU._update_header_data\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:\n\n1. **Problem Description in General Terms:**\n   The issue pertains to a malfunction occurring when reading data from a FITS file, specifically involving the handling of the 'BLANK' keyword. This problem arises during data extraction processes, leading to a system crash.\n\n2. **Key Symptoms and Behaviors Observed:**\n   When attempting to retrieve data using the `getdata` function, an `AttributeError` is triggered. This error is caused by an inappropriate handling of the 'BLANK' keyword, where a boolean object is incorrectly assumed to have a `sum` method, resulting in a crash.\n\n3. **Affected Components or Systems:**\n   The issue impacts the Astropy library, particularly within the FITS module. More specifically, it affects the `astropy/io/fits/hdu/image.py` file, where the `_get_scaled_image_data` function is responsible for the error.\n\n4. **Potential Impact or Severity:**\n   The severity is significant for users who rely on reading FITS files, as the crash prevents access to data. This issue could disrupt data analysis workflows that depend on smoothly processing FITS files, particularly for users handling multi-dimensional data cubes.\n\n5. **Relevant Technical Details Abstracted for Broader Understanding:**\n   The root of the problem lies in an incorrect assumption about the data type of the `blanks` variable. A straightforward workaround involved initializing `blanks` as a numpy array with a default value when it is determined to be `False`. The error suggests a need for improved type checking and handling within the affected function to ensure compatibility with different data scenarios.\n\nChanges Summary:\nThe issue was addressed by modifying the `astropy/io/fits/hdu/image.py` file, specifically targeting the `_get_scaled_image_data` function to properly handle the 'BLANK' keyword without causing a crash.",
      "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": "Creating a mixin column in a new table from columns of another table renames columns in original table.",
        "issue_body": "### Description\r\n\r\nConsider the following code, where a subset of columns from another table should be included in a new table with new names, prerably without copying the actual payload data:\r\n\r\n```python\r\nfrom astropy.table import QTable, Table\r\nimport astropy.units as u\r\n\r\n\r\ntable1 = QTable({\r\n    'foo': [1, 2, 3] * u.deg,\r\n    'bar': [4, 5, 6] * u.m,\r\n    'baz': [7, 8, 9] * u.TeV,\r\n})\r\n\r\nprint(table1.colnames)\r\ntable2 = QTable({\r\n    \"new\": table1[\"foo\"],\r\n    \"name\": table1[\"bar\"]\r\n}, copy=False)\r\nprint(table1.colnames)\r\n```\r\n\r\nIf any of the two classes or both are a `Table`, not a `QTable`, the code works as expected.\r\n\r\n### Expected behavior\r\n\r\nData in the columns is not copied, but column names in original table stay the same.\r\n\r\n```\r\n['foo', 'bar', 'baz']\r\n['foo', 'bar', 'baz']\r\n```\r\n\r\n### Actual behavior\r\n\r\nColumn names do change in both tables:\r\n\r\n```\r\n['foo', 'bar', 'baz']\r\n['new', 'name', 'baz']\r\n```\r\n\r\n### Steps to Reproduce\r\n\r\nSee above.\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 erfa; print(\"pyerfa\", erfa.__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\n\r\n```\r\nLinux-5.15.71-1-MANJARO-x86_64-with-glibc2.36\r\nPython 3.10.6 | packaged by conda-forge | (main, Aug 22 2022, 20:35:26) [GCC 10.4.0]\r\nNumpy 1.23.3\r\npyerfa 2.0.0.1\r\nastropy 5.1\r\nScipy 1.9.1\r\nMatplotlib 3.6.1\r\n```\r\n\r\n(also tested with current `main` branch)",
        "issue_id": 13840,
        "pr_number": 13842,
        "pr_title": "Ensure we get a new mixin instance even when copy=False",
        "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 ensures that when a mixin column of one table is added to another with `copy=False`, the columns will, as requested, share the data, but ensure that they are not the same instance.\r\n\r\nThis turned out to be much easier than worried about in #13840 - just take a full slice `[:]` of the column (which every mixin has to support).\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 #13840\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. Codestyle issues can be fixed by the [bot](https://docs.astropy.org/en/latest/development/workflow/development_workflow.html#pre-commit).\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-10-20T10:44:42Z",
        "base_commit": "3b448815e21b117d34fe63007b8ef63ee084fefb"
      },
      "summary": "### Summary:\n\nThis issue pertains to an unexpected behavior when creating a new table using a subset of columns from an existing table, specifically when using the `QTable` class from the `astropy` library. The problem arises when attempting to create a new table without duplicating the underlying data, which inadvertently results in the renaming of column names in the original table. This behavior is observed only when both tables are instances of `QTable` and does not occur if either or both are instances of the `Table` class.\n\nThe key symptoms include the unexpected alteration of column names in the original table when a new table is created, which should ideally preserve the original table's column names. This issue specifically affects the `QTable` class, a component of the `astropy` library, which is used for handling tables with quantity columns that have units.\n\nThe potential impact of this issue is moderate, as it affects the integrity of data management operations within the `astropy` library, potentially leading to confusion or errors in data processing when column names are unintentionally altered. This issue could be particularly problematic for users relying on consistent column naming for downstream operations or analysis.\n\nTechnical details abstracted for broader understanding include the use of the `copy=False` parameter, which is intended to prevent data duplication but inadvertently causes column renaming due to the underlying implementation. The issue has been addressed by modifying the `Table._convert_data_to_col` function in `astropy/table/table.py` and the `ArrayWrapper.__getitem__` function in `astropy/table/table_helpers.py` to ensure that the original table's column names remain unchanged when creating a new table without data copying.",
      "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 mixin column in a new table from columns of another table renames columns in original table.\n\nBody:\n### Description\r\n\r\nConsider the following code, where a subset of columns from another table should be included in a new table with new names, prerably without copying the actual payload data:\r\n\r\n```python\r\nfrom astropy.table import QTable, Table\r\nimport astropy.units as u\r\n\r\n\r\ntable1 = QTable({\r\n    'foo': [1, 2, 3] * u.deg,\r\n    'bar': [4, 5, 6] * u.m,\r\n    'baz': [7, 8, 9] * u.TeV,\r\n})\r\n\r\nprint(table1.colnames)\r\ntable2 = QTable({\r\n    \"new\": table1[\"foo\"],\r\n    \"name\": table1[\"bar\"]\r\n}, copy=False)\r\nprint(table1.colnames)\r\n```\r\n\r\nIf any of the two classes or both are a `Table`, not a `QTable`, the code works as expected.\r\n\r\n### Expected behavior\r\n\r\nData in the columns is not copied, but column names in original table stay the same.\r\n\r\n```\r\n['foo', 'bar', 'baz']\r\n['foo', 'bar', 'baz']\r\n```\r\n\r\n### Actual behavior\r\n\r\nColumn names do change in both tables:\r\n\r\n```\r\n['foo', 'bar', 'baz']\r\n['new', 'name', 'baz']\r\n```\r\n\r\n### Steps to Reproduce\r\n\r\nSee above.\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 erfa; print(\"pyerfa\", erfa.__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\n\r\n```\r\nLinux-5.15.71-1-MANJARO-x86_64-with-glibc2.36\r\nPython 3.10.6 | packaged by conda-forge | (main, Aug 22 2022, 20:35:26) [GCC 10.4.0]\r\nNumpy 1.23.3\r\npyerfa 2.0.0.1\r\nastropy 5.1\r\nScipy 1.9.1\r\nMatplotlib 3.6.1\r\n```\r\n\r\n(also tested with current `main` branch)\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/table/table.py\n  function: Table._convert_data_to_col\n\nastropy/table/table_helpers.py\n  function: ArrayWrapper.__getitem__\n"
    },
    {
      "similar_issue": {
        "issue_title": "New FITS table column attributes break existing code",
        "issue_body": "Change in behaviour of binTableHDU.fromcolumns:\r\n\r\nVersion 2.0.3: passing a header containing keywords with names like \"TCRPX2\" to from_columns creates an hdu object with these keywords in the header\r\n\r\nVersion 3.dev: passing a header with such keywords results in them not making it to the header of the output\r\n\r\nThis code demonstrates:\r\n\r\n```python\r\n#! /usr/bin/env python\r\nimport astropy\r\nfrom astropy.io import fits\r\nimport numpy as np\r\n\r\ndef test_fromcolumns():\r\n    print(astropy.__version__)\r\n    cd = create_column_descriptions()\r\n    header = create_header()\r\n\r\n    print(\"Header that is input to fits.BinTableHDU.from_columns:\")\r\n    print(header)\r\n\r\n    hdu = fits.BinTableHDU.from_columns(cd, header)\r\n\r\n    print(\"Header of hdu object returned from fits.BinTableHDU.from_columns:\")\r\n    print(hdu.header)\r\n\r\n    return\r\n\r\ndef create_column_descriptions():\r\n    col = []\r\n    col.append(fits.Column(name=\"TIME\", format=\"1E\", unit=\"s\"))\r\n    col.append(fits.Column(name=\"RAWX\", format=\"1I\", unit=\"pixel\"))\r\n    col.append(fits.Column(name=\"RAWY\", format=\"1I\", unit=\"pixel\"))\r\n    cd = fits.ColDefs(col)\r\n\r\n    return cd\r\n\r\ndef create_header():\r\n    hdr = fits.Header()\r\n    hdr['RA'] = (1.581250000000E+00, 'RA of reference aperture center ')\r\n    hdr['DEC'] = (2.020277777778E+01, 'Declination of reference aperture center')\r\n    hdr['TCTYP2'] = ('RA---TAN', 'axis type for dimension 1')\r\n    hdr['TCTYP3'] = ('ANGLE   ', 'axis type for dimension 2')\r\n    hdr['TCRVL2'] = (-999.0, 'sky coordinates of 1st axis')\r\n    hdr['TCRVL3'] = (-999.0, 'sky coordinates of 2nd axis')\r\n    hdr['TCRPX2'] = (1.0, 'axis1 pixel of tangent plane direction')\r\n    hdr['TCRPX3'] = (1.0, 'axis2 pixel of tangent plane direction')\r\n    hdr['TALEN2'] = (16384, 'length of axis 1')\r\n    hdr['TALEN3'] = (1024, 'length of axis 2')\r\n    hdr['TC2_2'] = (0.0, 'partial of first axis coordinate w.r.t. x')\r\n    hdr['TC2_3'] = (0.0, 'partial of first axis coordinate w.r.t. y')\r\n    hdr['TC3_2'] = (0.0, 'partial of second axis coordinate w.r.t. x')\r\n    hdr['TC3_3'] = (0.0, 'partial of second axis coordinate w.r.t. y')\r\n    hdr['TCUNI2'] = ('angstrom', 'units of first coordinate value')\r\n    hdr['TCUNI3'] = ('deg     ', 'units of second coordinate value')\r\n\r\n    return hdr\r\n\r\n```\r\n\r\nEdit: Added syntax highlighting.",
        "issue_id": 7145,
        "pr_number": 7157,
        "pr_title": "Alternate fix for FITS regression with table keywords",
        "pr_body": "This is an alternative to https://github.com/astropy/astropy/pull/7153 to fix #7145 - basically it just prevents time-related keywords from being automatically removed from the Header. Time-related keywords can still be overwritten if the corresponding attributes are set on Column objects, but this doesn't affect backward-compatibility since those Column attributes didn't exist before. This approach thus guarantees full backward-compatibility (unless I've overlooked something), and emits a deprecation warning to mention that these keywords will be dropped in future. Example usage:\r\n\r\n```python\r\nIn [1]: import astropy\r\n   ...: from astropy.io import fits\r\n   ...: import numpy as np\r\n   ...: \r\n   ...: def create_column_descriptions():\r\n   ...:     col = []\r\n   ...:     col.append(fits.Column(name=\"TIME\", format=\"1E\", unit=\"s\"))\r\n   ...:     col.append(fits.Column(name=\"RAWX\", format=\"1I\", unit=\"pixel\"))\r\n   ...:     cd = fits.ColDefs(col)\r\n   ...: \r\n   ...:     return cd\r\n   ...: \r\n   ...: def create_header():\r\n   ...:     hdr = fits.Header()\r\n   ...:     hdr['RA'] = (1.581250000000E+00, 'RA of reference aperture center ')\r\n   ...:     hdr['DEC'] = (2.020277777778E+01, 'Declination of reference aperture center')\r\n   ...:     hdr['TCTYP2'] = ('RA---TAN', 'axis type for dimension 1')\r\n   ...:     hdr['TCRVL2'] = (-999.0, 'sky coordinates of 1st axis')\r\n   ...: \r\n   ...:     return hdr\r\n   ...: \r\n   ...: columns = create_column_descriptions()\r\n   ...: header = create_header()\r\n   ...: \r\n\r\nIn [2]: print(header.tostring(sep='\\n'))\r\n   ...: print(columns)\r\n   ...: \r\nRA      =              1.58125 / RA of reference aperture center                \r\nDEC     =       20.20277777778 / Declination of reference aperture center       \r\nTCTYP2  = 'RA---TAN'           / axis type for dimension 1                      \r\nTCRVL2  =               -999.0 / sky coordinates of 1st axis                    \r\nEND                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         \r\nColDefs(\r\n    name = 'TIME'; format = '1E'; unit = 's'\r\n    name = 'RAWX'; format = '1I'; unit = 'pixel'\r\n)\r\n```\r\n\r\nSo far so good. Let's make a new HDU from the columns and header:\r\n\r\n```python\r\nIn [3]: hdu = fits.BinTableHDU.from_columns(columns, header)\r\n   ...: \r\n/Users/tom/Dropbox/Code/Astropy/astropy/astropy/io/fits/hdu/table.py:341: UserWarning: The following keywords are now recognized as special column-related attributes and should be set via the Column objects: TCRVLn, TCTYPn. In future, these values will be dropped from manually specified headers automatically and replaced with values generated based on the Column objects.\r\n  \"Column objects.\".format(keys))\r\n```\r\n\r\nWe see that this causes the above warning. The header still contains those keywords, and the columns don't (consistent with previous behavior):\r\n\r\n```\r\nIn [4]: print(hdu.header.tostring(sep='\\n'))\r\n   ...: print(hdu.columns)\r\n   ...: \r\nXTENSION= 'BINTABLE'           / binary table extension                         \r\nBITPIX  =                    8 / array data type                                \r\nNAXIS   =                    2 / number of array dimensions                     \r\nNAXIS1  =                    6 / length of dimension 1                          \r\nNAXIS2  =                    0 / length of dimension 2                          \r\nPCOUNT  =                    0 / number of group parameters                     \r\nGCOUNT  =                    1 / number of groups                               \r\nTFIELDS =                    2 / number of table fields                         \r\nRA      =              1.58125 / RA of reference aperture center                \r\nDEC     =       20.20277777778 / Declination of reference aperture center       \r\nTCTYP2  = 'RA---TAN'           / axis type for dimension 1                      \r\nTCRVL2  =               -999.0 / sky coordinates of 1st axis                    \r\nTTYPE1  = 'TIME    '                                                            \r\nTFORM1  = '1E      '                                                            \r\nTUNIT1  = 's       '                                                            \r\nTTYPE2  = 'RAWX    '                                                            \r\nTFORM2  = '1I      '                                                            \r\nTUNIT2  = 'pixel   '                                                            \r\nEND                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           \r\nColDefs(\r\n    name = 'TIME'; format = '1E'; unit = 's'\r\n    name = 'RAWX'; format = '1I'; unit = 'pixel'\r\n)\r\n```\r\n\r\nNow let's write out the file and read in back in:\r\n\r\n```python\r\nIn [5]: hdu.writeto('time.fits', overwrite=True)\r\n   ...: \r\n   ...: hdu2 = fits.open('time.fits')[1]\r\n   ...: \r\n\r\nIn [6]: print(hdu2.header.tostring(sep='\\n'))\r\n   ...: print(hdu2.columns)\r\n   ...: \r\nXTENSION= 'BINTABLE'           / binary table extension                         \r\nBITPIX  =                    8 / array data type                                \r\nNAXIS   =                    2 / number of array dimensions                     \r\nNAXIS1  =                    6 / length of dimension 1                          \r\nNAXIS2  =                    0 / length of dimension 2                          \r\nPCOUNT  =                    0 / number of group parameters                     \r\nGCOUNT  =                    1 / number of groups                               \r\nTFIELDS =                    2 / number of table fields                         \r\nRA      =              1.58125 / RA of reference aperture center                \r\nDEC     =       20.20277777778 / Declination of reference aperture center       \r\nTCTYP2  = 'RA---TAN'           / axis type for dimension 1                      \r\nTCRVL2  =               -999.0 / sky coordinates of 1st axis                    \r\nTTYPE1  = 'TIME    '                                                            \r\nTFORM1  = '1E      '                                                            \r\nTUNIT1  = 's       '                                                            \r\nTTYPE2  = 'RAWX    '                                                            \r\nTFORM2  = '1I      '                                                            \r\nTUNIT2  = 'pixel   '                                                            \r\nEND                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           \r\nColDefs(\r\n    name = 'TIME'; format = '1E'; unit = 's'\r\n    name = 'RAWX'; format = '1I'; unit = 'pixel'; coord_type = 'RA---TAN'; coord_ref_value = -999.0\r\n)\r\n```\r\n\r\nAt this point, the new column attributes are picked up (as expected) and they are still in the header as everything is now in sync. No warning was emitted when reading a file.\r\n\r\nLet's just set a column attribute:\r\n\r\n```python\r\nIn [9]: hdu2.columns[1].coord_type = 'DEC--TAN'\r\n\r\nIn [10]: hdu2.header['TCTYP2']\r\nOut[10]: 'DEC--TAN'\r\n```\r\n\r\nThe attributes in the header are now kept in sync and are not cleared by default when initializing from a header.",
        "issue_closed_at": "2018-02-05T17:19:56Z",
        "base_commit": "c7651ff2c95e7bfa62c326a4453e12ef632444ee"
      },
      "summary": "### Summary:\n\nThis issue concerns a change in behavior in the `astropy` library, specifically within the `fits` module's `BinTableHDU.from_columns` function, between versions 2.0.3 and 3.dev. The problem is that headers with specific keyword names, such as \"TCRPX2\", are no longer included in the output header when using `from_columns` in version 3.dev, whereas they were correctly propagated in version 2.0.3. This discrepancy has been observed during attempts to create an HDU (Header Data Unit) using a FITS table where certain header keywords crucial for astronomical data representation are omitted, potentially leading to incomplete or incorrect data processing.\n\nKey symptoms include the absence of specific header keywords in the resulting HDU object, which were previously present and correctly passed through in earlier library versions. This behavior affects users relying on the correct propagation of these keywords for their data analysis workflows, particularly in the context of astronomical data processing using FITS files.\n\nThe affected component is the `BinTableHDU.from_columns` function in the `astropy.io.fits` module, with potential impacts on users who rely on this function for handling FITS table columns and headers. The severity can be considered significant for users needing those specific header attributes for their applications, as it may lead to the loss of critical metadata.\n\nTechnical details abstracted for broader understanding include the method of creating a FITS table with column descriptions and headers, highlighting how certain keywords critical for the description of astronomical data coordinates and dimensions are not retained in the output. The resolution may involve ensuring that the `_clear_table_keywords` function within the `_TableBaseHDU` class properly manages the inclusion of these necessary header keywords during table initialization.",
      "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: New FITS table column attributes break existing code\n\nBody:\nChange in behaviour of binTableHDU.fromcolumns:\r\n\r\nVersion 2.0.3: passing a header containing keywords with names like \"TCRPX2\" to from_columns creates an hdu object with these keywords in the header\r\n\r\nVersion 3.dev: passing a header with such keywords results in them not making it to the header of the output\r\n\r\nThis code demonstrates:\r\n\r\n```python\r\n#! /usr/bin/env python\r\nimport astropy\r\nfrom astropy.io import fits\r\nimport numpy as np\r\n\r\ndef test_fromcolumns():\r\n    print(astropy.__version__)\r\n    cd = create_column_descriptions()\r\n    header = create_header()\r\n\r\n    print(\"Header that is input to fits.BinTableHDU.from_columns:\")\r\n    print(header)\r\n\r\n    hdu = fits.BinTableHDU.from_columns(cd, header)\r\n\r\n    print(\"Header of hdu object returned from fits.BinTableHDU.from_columns:\")\r\n    print(hdu.header)\r\n\r\n    return\r\n\r\ndef create_column_descriptions():\r\n    col = []\r\n    col.append(fits.Column(name=\"TIME\", format=\"1E\", unit=\"s\"))\r\n    col.append(fits.Column(name=\"RAWX\", format=\"1I\", unit=\"pixel\"))\r\n    col.append(fits.Column(name=\"RAWY\", format=\"1I\", unit=\"pixel\"))\r\n    cd = fits.ColDefs(col)\r\n\r\n    return cd\r\n\r\ndef create_header():\r\n    hdr = fits.Header()\r\n    hdr['RA'] = (1.581250000000E+00, 'RA of reference aperture center ')\r\n    hdr['DEC'] = (2.020277777778E+01, 'Declination of reference aperture center')\r\n    hdr['TCTYP2'] = ('RA---TAN', 'axis type for dimension 1')\r\n    hdr['TCTYP3'] = ('ANGLE   ', 'axis type for dimension 2')\r\n    hdr['TCRVL2'] = (-999.0, 'sky coordinates of 1st axis')\r\n    hdr['TCRVL3'] = (-999.0, 'sky coordinates of 2nd axis')\r\n    hdr['TCRPX2'] = (1.0, 'axis1 pixel of tangent plane direction')\r\n    hdr['TCRPX3'] = (1.0, 'axis2 pixel of tangent plane direction')\r\n    hdr['TALEN2'] = (16384, 'length of axis 1')\r\n    hdr['TALEN3'] = (1024, 'length of axis 2')\r\n    hdr['TC2_2'] = (0.0, 'partial of first axis coordinate w.r.t. x')\r\n    hdr['TC2_3'] = (0.0, 'partial of first axis coordinate w.r.t. y')\r\n    hdr['TC3_2'] = (0.0, 'partial of second axis coordinate w.r.t. x')\r\n    hdr['TC3_3'] = (0.0, 'partial of second axis coordinate w.r.t. y')\r\n    hdr['TCUNI2'] = ('angstrom', 'units of first coordinate value')\r\n    hdr['TCUNI3'] = ('deg     ', 'units of second coordinate value')\r\n\r\n    return hdr\r\n\r\n```\r\n\r\nEdit: Added syntax highlighting.\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/table.py\n  line: line 29\n  class: _TableBaseHDU\n  function: BinTableHDU.__init__\n  function: BinTableHDU.__init__\n  function: _TableBaseHDU._clear_table_keywords\n"
    },
    {
      "similar_issue": {
        "issue_title": "Make Table inherit primary_key attribute from its parent Table. Fix for [#4672]",
        "issue_body": "This is a fix for issue #4672.\n\nIn the issue, running an example from the astropy docs for [Table indexing](http://astropy.readthedocs.org/en/latest/table/indexing.html) would run into an error. The error was a missing `primary_key` for the table in question. The error arises when a new Table is made from an existing one, either by slicing or reference, but the `primary_key` attribute is not transferred to the new Table. This PR fixes that.\n\nI added one test for this case, but I couldn't figure out a way to test for `.loc` as @taldcroft suggested in the issue. I'm actually not that familiar with Tables or with writing test cases (this is my first attempt to do so), so any feedback would be appreciated.   \n",
        "issue_id": 4711,
        "pr_number": 4930,
        "pr_title": "Make Table inherit primary_key attribute from its parent Table.",
        "pr_body": "This is just a rebased version of #4711.\n\nCloses #4711.\nFixes #4672.\n",
        "issue_closed_at": "2016-05-16T13:01:26Z",
        "base_commit": "3c47c1067036a6cf3dc13ebc0fc268948d4ccc29"
      },
      "summary": "### Summary: This issue pertains to the inheritance of attributes in a hierarchical data structure. Specifically, when deriving a new instance (or subset) from an existing data entity, certain critical attributes, such as the `primary_key`, are not being propagated to the new instance. This omission leads to operational errors when attempting to utilize the derived entity in contexts that depend on these attributes. The issue is part of a larger software library used for managing and manipulating structured data, specifically in the context of data tables. The problem is particularly relevant when the data tables are used in scientific computing environments, which rely heavily on such metadata for data integrity and operations.\n\n1. **Problem Description in General Terms**: The problem involves the failure to inherit essential metadata attributes when creating a new data object from an existing one within a tabular data management library. This results in incomplete or erroneous data objects that lack necessary identifiers.\n\n2. **Key Symptoms and Behaviors Observed**: Users encounter errors indicating missing primary key attributes when working with sliced or referenced tables. This issue surfaces when performing operations that require a complete set of metadata attributes for correct execution.\n\n3. **Affected Components or Systems**: The primary affected component is the table management system in a scientific data processing library. Specifically, the functions responsible for initializing new table instances from existing ones are impacted.\n\n4. **Potential Impact or Severity**: The severity of the issue is moderate, as it disrupts workflows that depend on table metadata propagation. Users may experience interruptions or need to implement workarounds, which can be particularly problematic in automated data processing pipelines.\n\n5. **Relevant Technical Details Abstracted for Broader Understanding**: The core of the issue lies in the functions responsible for creating new table instances (`Table._init_from_table` and `Table._new_from_slice`). These functions require adjustments to ensure the complete and correct transfer of metadata attributes, such as `primary_key`, from parent to child entities. The resolution involves modifying these functions to include attribute inheritance logic.",
      "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: Make Table inherit primary_key attribute from its parent Table. Fix for [#4672]\n\nBody:\nThis is a fix for issue #4672.\n\nIn the issue, running an example from the astropy docs for [Table indexing](http://astropy.readthedocs.org/en/latest/table/indexing.html) would run into an error. The error was a missing `primary_key` for the table in question. The error arises when a new Table is made from an existing one, either by slicing or reference, but the `primary_key` attribute is not transferred to the new Table. This PR fixes that.\n\nI added one test for this case, but I couldn't figure out a way to test for `.loc` as @taldcroft suggested in the issue. I'm actually not that familiar with Tables or with writing test cases (this is my first attempt to do so), so any feedback would be appreciated.   \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/table/table.py\n  function: Table._init_from_table\n  function: Table._new_from_slice\n"
    }
  ]
}