{
  "original_problem": {
    "instance_id": "astropy__astropy-6938",
    "repo": "astropy/astropy",
    "created_at": "2017-12-07T00:01:14Z",
    "problem_statement": "Possible bug in io.fits related to D exponents\nI came across the following code in ``fitsrec.py``:\r\n\r\n```python\r\n        # Replace exponent separator in floating point numbers\r\n        if 'D' in format:\r\n            output_field.replace(encode_ascii('E'), encode_ascii('D'))\r\n```\r\n\r\nI think this may be incorrect because as far as I can tell ``replace`` is not an in-place operation for ``chararray`` (it returns a copy). Commenting out this code doesn't cause any tests to fail so I think this code isn't being tested anyway.\n",
    "patch": "diff --git a/astropy/io/fits/fitsrec.py b/astropy/io/fits/fitsrec.py\n--- a/astropy/io/fits/fitsrec.py\n+++ b/astropy/io/fits/fitsrec.py\n@@ -1261,7 +1261,7 @@ def _scale_back_ascii(self, col_idx, input_field, output_field):\n \n         # Replace exponent separator in floating point numbers\n         if 'D' in format:\n-            output_field.replace(encode_ascii('E'), encode_ascii('D'))\n+            output_field[:] = output_field.replace(b'E', b'D')\n \n \n def _get_recarray_field(array, key):\n"
  },
  "candidates_evaluated": 5,
  "judgment_result": {
    "candidates": [
      {
        "idx": 1,
        "id": "similar_5118",
        "decision": "Not useful",
        "confidence": "Medium",
        "reason": "The issue involves header keyword positioning, which is unrelated to in-place operations or testing coverage."
      },
      {
        "idx": 2,
        "id": "similar_2711",
        "decision": "Not useful",
        "confidence": "Medium",
        "reason": "The issue is about type mismatch and error handling, not about in-place operations or untested code."
      },
      {
        "idx": 3,
        "id": "similar_5342",
        "decision": "Not useful",
        "confidence": "Medium",
        "reason": "The issue deals with unit handling in tables, which does not relate to in-place operations or testing coverage."
      },
      {
        "idx": 4,
        "id": "similar_5594",
        "decision": "Not useful",
        "confidence": "Medium",
        "reason": "The issue is about a regression due to an undefined variable, unrelated to in-place operations or testing coverage."
      },
      {
        "idx": 5,
        "id": "similar_6283",
        "decision": "Not useful",
        "confidence": "Medium",
        "reason": "The issue involves coordinate transformation errors, not in-place operations or untested code."
      }
    ]
  },
  "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:\n\nThis issue pertains to a problem encountered when converting an existing `ImageHDU` object containing `BSCALE` and `BZERO` header keywords into a `CompImageHDU` within the Astropy library, a popular Python package used for astronomy-related computations and data handling. The specific problem arises because the `TFIELDS` keyword, which is critical for the proper definition of a `CompImageHDU`, is not positioned correctly in the header. Instead of appearing immediately after the `GCOUNT` keyword, it is misplaced, leading to the creation of an invalid `CompImageHDU`.\n\n### Key Symptoms and Behaviors Observed:\n\nThe main symptom of this issue is the generation of an invalid `CompImageHDU`, which fails verification processes. Specifically, the `fitsverify` tool, based on cfitsio, fails to recognize more than the first Header Data Unit (HDU) in the affected file, indicating a breakdown in expected behavior when handling multiple HDUs.\n\n### Affected Components or Systems:\n\nThe components affected by this issue are primarily within the Astropy library, specifically in the modules responsible for handling FITS (Flexible Image Transport System) files. The relevant code elements are located in `astropy/io/fits/hdu/base.py` and `astropy/io/fits/hdu/compressed.py`, with specific functions `_BaseHDU._update_uint_scale_keywords` and `CompImageHDU._update_header_data` being modified to address the issue.\n\n### Potential Impact or Severity:\n\nThe potential impact of this issue is significant for users relying on the accurate processing and compression of FITS files, especially in scientific and astronomical applications where data integrity is paramount. Although the issue was identified and a fix was implemented, the lack of extensive test coverage for `CompImageHDUs` in the library means that the fix, while believed to align more closely with the FITS standard, cannot be guaranteed to be completely safe without further testing.\n\n### Relevant Technical Details Abstracted for Broader Understanding:\n\nThe issue highlights the importance of maintaining compliance with data standards such as the FITS format, which is widely used in the scientific community for data exchange. It also underscores the need for comprehensive test coverage in software development to ensure the reliability of code changes. The problem and its resolution involve manipulating header keywords within FITS files, a task common in data processing workflows in astronomy and other fields dealing with large-scale scientific data.",
      "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:\nThis issue is a software bug in the Astropy library, specifically within the module responsible for handling FITS (Flexible Image Transport System) file operations. The problem arises when attempting to read data from a FITS file that contains an unexpected 'BLANK' keyword, causing the program to crash. The crash is due to an `AttributeError` triggered when the code incorrectly assumes that a variable (`blanks`) is an array with a `sum` method, whereas it is, in fact, a boolean. This logical error prevents the successful reading of the data, resulting in a program termination.\n\nKey symptoms include the inability to read data from a FITS file, evidenced by an error traceback pointing to the `_get_scaled_image_data` function within the `image.py` module. The issue particularly affects the `getdata` function, which is commonly used to extract data from FITS files. The error message specifies that a 'bool' object does not possess a 'sum' attribute, indicating a type mismatch issue.\n\nThe affected component is the `astropy.io.fits` module, specifically the `hdu` (Header Data Unit) functionality related to image data handling. The potential impact is significant for users needing to process FITS files, as it prevents them from accessing data when the 'BLANK' keyword is present. This could disrupt workflows in astronomy and data analysis where FITS files are a standard data format.\n\nIn terms of severity, this bug can be considered moderate to high, as it directly crashes the application, blocking specific data reading operations that are crucial for scientific analysis. The problem is mitigated by a user-suggested workaround that involves initializing the `blanks` variable as an array before the offending 'if' statement, but a more robust, permanent fix would involve updating the code to correctly handle cases where `blanks` is a boolean. The code changes primarily impact the `_get_scaled_image_data` function within the `astropy.io.fits.hdu.image` module.",
      "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": "Handling of logarithmic units in tables inconsistent and breaks matching",
        "issue_body": "I have tried to use logarithmic units in my table columns but this seems to work less than optimal - at least the way I have created them. I have an example piece of code below, but the two problems are:\n1. A column created to have  a logarithmic unit [e.g.: t['log_R'] = u.dex(u.pc)], is created as a Quantity column and has no 'physical' attribute:\n   e.g. t['log_R'].quantity.value works, but t['log_R'].quantity.physical gives\n\n```\n/Users/jarle/anaconda/lib/python2.7/site-packages/astropy/units/quantity.pyc in __getattr__(self, attr)\n    732                 \"'{0}' object has no '{1}' member\".format(\n    733                     self.__class__.__name__,\n--> 734                     attr))\n    735 \n    736         def get_virtual_unit_attribute():\n\nAttributeError: 'Quantity' object has no 'physical' member\n```\n1. When trying to join tables with logarithmic quantities, the join fails with:\n\n```\nTraceback (most recent call last):\n  File \"/Users/jarle/Desktop/example_problem.py\", line 27, in <module>\n    print astropy.table.join(tbl1, tbl2, keys=['col1'])\n  File \"/Users/jarle/anaconda/lib/python2.7/site-packages/astropy/table/operations.py\", line 188, in join\n    _merge_col_meta(out, [left, right], col_name_map, metadata_conflicts=metadata_conflicts)\n  File \"/Users/jarle/anaconda/lib/python2.7/site-packages/astropy/table/operations.py\", line 70, in _merge_col_meta\n    elif left_attr != right_attr:\n  File \"/Users/jarle/anaconda/lib/python2.7/site-packages/astropy/units/function/core.py\", line 291, in __ne__\n    self.funtional_unit != getattr(other, 'function_unit', other))\nAttributeError: 'DexUnit' object has no attribute 'funtional_unit'\n```\n\nAn example code that reproduces this is given below. \n\nThis is certainly not what I expected, but it might be that I have misunderstood the way I should indicate units on the columns! \n\n```\n# Show how joins break when logarithmic units are included  - the first join succeeds \n# and prints out the combined table, while the second fails\nimport astropy.units as u\nfrom astropy.io import ascii\nimport astropy.table\n\n# Create two simple example tables\nt1 = \"\"\"\na 5.2\nb 7.2\n\"\"\"\n\nt2 = \"\"\"\na 6.3\nc 7.4\nb 1.2\n\"\"\"\n\ntbl1 = ascii.read(t1, format='fixed_width_no_header', delimiter=' ')\ntbl2 = ascii.read(t2, format='fixed_width_no_header', delimiter=' ')\n\n# Simple units:\ntbl1['col2'].unit = u.kilometer\n\nprint astropy.table.join(tbl1, tbl2, keys=['col1'])\n\n# Logarithmic units\ntbl1['col2'].unit = u.dex()\nprint astropy.table.join(tbl1, tbl2, keys=['col1'])\n\n```\n",
        "issue_id": 5342,
        "pr_number": 5345,
        "pr_title": "Ensure column is converted correctly if unit is set to logarithmic unit",
        "pr_body": "Fixes #5342.\n\nThe main fix is to adapt `QTable._convert_col_for_table`. But it also turned out `!=` never worked for function units, so that is fixed as well.\n\nAssigned to @taldcrof as the main change is in `table`.\n",
        "issue_closed_at": "2016-09-24T15:09:40Z",
        "base_commit": "f3a5da293bb4e806855986b449dcdae5f2ad5891"
      },
      "summary": "### Summary:\nThis issue pertains to the handling of logarithmic units within tables in the Astropy library, which results in inconsistent behavior and failure during table operations, specifically joins. \n\n1. **Problem description in general terms:** The issue arises when using logarithmic units, such as `u.dex`, in table columns. The implementation does not handle these units correctly, leading to errors in certain operations.\n\n2. **Key symptoms and behaviors observed:**\n   - Columns created with logarithmic units do not possess expected attributes, such as 'physical', which leads to attribute errors when trying to access these attributes.\n   - Joining tables that contain columns with logarithmic units fails due to mismatched or missing attributes, causing an operation exception.\n\n3. **Affected components or systems:** The problem affects the `astropy.table` module where tables with `Quantity` columns utilizing logarithmic units are manipulated, specifically in the `join` operation. Additionally, the `astropy.units` module's handling of `DexUnit` is implicated due to an attribute error.\n\n4. **Potential impact or severity:** This issue can significantly affect users relying on Astropy for scientific data analysis involving logarithmic scales, as it prevents seamless integration and manipulation of datasets. Users could experience halted workflows or incorrect data processing, especially when trying to merge tables containing columns with such units.\n\n5. **Relevant technical details abstracted for broader understanding:** \n   - The error occurs due to the absence of expected attributes in `Quantity` objects when logarithmic units are applied, suggesting a need for proper handling of these units within the library's codebase.\n   - Specific errors include `AttributeError` due to missing attributes like 'physical' and 'function_unit', indicating inadequate checks or definitions within the units' implementation.\n\nThe code fix likely involves updates to the functions handling table column mixins and unit equality checks, ensuring proper handling of logarithmic units in table 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: Handling of logarithmic units in tables inconsistent and breaks matching\n\nBody:\nI have tried to use logarithmic units in my table columns but this seems to work less than optimal - at least the way I have created them. I have an example piece of code below, but the two problems are:\n1. A column created to have  a logarithmic unit [e.g.: t['log_R'] = u.dex(u.pc)], is created as a Quantity column and has no 'physical' attribute:\n   e.g. t['log_R'].quantity.value works, but t['log_R'].quantity.physical gives\n\n```\n/Users/jarle/anaconda/lib/python2.7/site-packages/astropy/units/quantity.pyc in __getattr__(self, attr)\n    732                 \"'{0}' object has no '{1}' member\".format(\n    733                     self.__class__.__name__,\n--> 734                     attr))\n    735 \n    736         def get_virtual_unit_attribute():\n\nAttributeError: 'Quantity' object has no 'physical' member\n```\n1. When trying to join tables with logarithmic quantities, the join fails with:\n\n```\nTraceback (most recent call last):\n  File \"/Users/jarle/Desktop/example_problem.py\", line 27, in <module>\n    print astropy.table.join(tbl1, tbl2, keys=['col1'])\n  File \"/Users/jarle/anaconda/lib/python2.7/site-packages/astropy/table/operations.py\", line 188, in join\n    _merge_col_meta(out, [left, right], col_name_map, metadata_conflicts=metadata_conflicts)\n  File \"/Users/jarle/anaconda/lib/python2.7/site-packages/astropy/table/operations.py\", line 70, in _merge_col_meta\n    elif left_attr != right_attr:\n  File \"/Users/jarle/anaconda/lib/python2.7/site-packages/astropy/units/function/core.py\", line 291, in __ne__\n    self.funtional_unit != getattr(other, 'function_unit', other))\nAttributeError: 'DexUnit' object has no attribute 'funtional_unit'\n```\n\nAn example code that reproduces this is given below. \n\nThis is certainly not what I expected, but it might be that I have misunderstood the way I should indicate units on the columns! \n\n```\n# Show how joins break when logarithmic units are included  - the first join succeeds \n# and prints out the combined table, while the second fails\nimport astropy.units as u\nfrom astropy.io import ascii\nimport astropy.table\n\n# Create two simple example tables\nt1 = \"\"\"\na 5.2\nb 7.2\n\"\"\"\n\nt2 = \"\"\"\na 6.3\nc 7.4\nb 1.2\n\"\"\"\n\ntbl1 = ascii.read(t1, format='fixed_width_no_header', delimiter=' ')\ntbl2 = ascii.read(t2, format='fixed_width_no_header', delimiter=' ')\n\n# Simple units:\ntbl1['col2'].unit = u.kilometer\n\nprint astropy.table.join(tbl1, tbl2, keys=['col1'])\n\n# Logarithmic units\ntbl1['col2'].unit = u.dex()\nprint astropy.table.join(tbl1, tbl2, keys=['col1'])\n\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/table/table.py\n  function: QTable._add_as_mixin_column\n\nastropy/units/function/core.py\n  function: FunctionQuantity.__eq__\n"
    },
    {
      "similar_issue": {
        "issue_title": "Regression in io.fits due to undefined variable",
        "issue_body": "@mwcraig @embray  - I'm running into the following failure in glue due to the recent changes in io.fits:\r\n\r\n```python\r\n    def _read_next_hdu(self):\r\n        \"\"\"\r\n            Lazily load a single HDU from the fileobj or data string the `HDUList`\r\n            was opened from, unless no further HDUs are found.\r\n    \r\n            Returns True if a new HDU was loaded, or False otherwise.\r\n            \"\"\"\r\n    \r\n        if self._read_all:\r\n            return False\r\n    \r\n        saved_compression_enabled = compressed.COMPRESSION_ENABLED\r\n        fileobj, data, kwargs = self._file, self._data, self._open_kwargs\r\n    \r\n        try:\r\n            self._in_read_next_hdu = True\r\n    \r\n            if ('disable_image_compression' in kwargs and\r\n                kwargs['disable_image_compression']):\r\n                compressed.COMPRESSION_ENABLED = False\r\n    \r\n            # read all HDUs\r\n            try:\r\n                if fileobj is not None:\r\n                    try:\r\n                        # Make sure we're back to the end of the last read\r\n                        # HDU\r\n                        if len(self) > 0:\r\n                            last = self[len(self) - 1]\r\n                            if last._data_offset is not None:\r\n                                offset = last._data_offset + last._data_size\r\n                                fileobj.seek(offset, os.SEEK_SET)\r\n    \r\n                        hdu = _BaseHDU.readfrom(fileobj, **kwargs)\r\n                    except EOFError:\r\n                        self._read_all = True\r\n                        return False\r\n                    except ValueError:\r\n                        # A ValueError can occur when trying to perform I/O\r\n                        # on a closed file\r\n                        if fileobj.closed:\r\n                            self._read_all = True\r\n                            return False\r\n                        else:\r\n                            raise\r\n                    except IOError:\r\n                        if fileobj.writeonly:\r\n                            self._read_all = True\r\n                            return False\r\n                        else:\r\n                            raise\r\n                else:\r\n                    if not data:\r\n                        self._read_all = True\r\n                        return False\r\n                    hdu = _BaseHDU.fromstring(data, **kwargs)\r\n                    self._data = data[hdu._data_offset + hdu._data_size:]\r\n    \r\n                super(HDUList, self).append(hdu)\r\n                if len(self) == 1:\r\n                    # Check for an extension HDU and update the EXTEND\r\n                    # keyword of the primary HDU accordingly\r\n                    self.update_extend()\r\n    \r\n                hdu._new = False\r\n                if 'checksum' in kwargs:\r\n                    hdu._output_checksum = kwargs['checksum']\r\n            # check in the case there is extra space after the last HDU or\r\n            # corrupted HDU\r\n            except (VerifyError, ValueError) as exc:\r\n                warnings.warn(\r\n                    'Error validating header for HDU #{} (note: Astropy '\r\n                    'uses zero-based indexing).\\n{}\\n'\r\n                    'There may be extra bytes after the last HDU or the '\r\n                    'file is corrupted.'.format(\r\n>                       len(hdulist), indent(str(exc))), VerifyWarning)\r\nE                       NameError: global name 'hdulist' is not defined\r\n\r\n../../../miniconda/envs/test/lib/python2.7/site-packages/astropy/io/fits/hdu/hdulist.py:1150: NameError\r\n============================ pytest-warning summary ============================\r\n```",
        "issue_id": 5594,
        "pr_number": 5589,
        "pr_title": "Fix up lazy loading issues",
        "pr_body": "Fix or address these issues which resulted from lazy loading. In each case the goal is to maintain the current (1.x) behavior of io.fits.\r\n\r\n- [x] Handling of invalid key in the `in` operator (closes #5583)\r\n- [x] Slices not working (closes #5585)\r\n- [x] Variable name incorrect (closes #5594)\r\n- ~~[ ] Address behavior of `close` #5582~~ Won't change unless someone requests it.\r\n\r\n@eteq -- I believe I've milestoned this correctly, but please modify if not.\r\n\r\nedit: changed text of second todo.",
        "issue_closed_at": "2016-12-13T01:48:53Z",
        "base_commit": "a72fdfb6b07356805182cb3a2fc20487404b073f"
      },
      "summary": "### Summary:\n\nThis issue is a regression bug in the `astropy.io.fits` module, specifically in the handling of HDUs (Header Data Units) within the `HDUList` class. The problem arises due to an undefined variable `hdulist` within the `_read_next_hdu` method, resulting in a `NameError` during execution. This error is likely due to recent changes in the codebase that inadvertently introduced this bug.\n\n1. **Problem Description in General Terms:**\n   The problem occurs when attempting to read the next HDU from a FITS file, where an undefined variable is referenced, causing the program to terminate unexpectedly with a `NameError`.\n\n2. **Key Symptoms and Behaviors Observed:**\n   The primary symptom is a `NameError` indicating that the global name 'hdulist' is not defined. This error arises when the code attempts to handle errors during header validation, specifically when issuing a warning about potential extra bytes or corruption after the last HDU.\n\n3. **Affected Components or Systems:**\n   The affected component is the `astropy.io.fits` module, particularly the `HDUList` class and its method `_read_next_hdu`, which is responsible for reading HDUs from a FITS file or data string.\n\n4. **Potential Impact or Severity:**\n   The impact is significant, as the regression prevents the successful reading of HDUs in certain scenarios, potentially affecting any application or library relying on the `astropy.io.fits` module to process FITS files. This could impede data analysis workflows that depend on FITS file handling.\n\n5. **Relevant Technical Details Abstracted for Broader Understanding:**\n   The issue is related to error handling when validating HDU headers. The undefined variable `hdulist` should be correctly scoped or defined to avoid the `NameError`. The symptoms suggest the need for careful review and testing of recent code changes to prevent similar regressions in error handling logic.\n\nThe changes made to resolve this issue include modifications to various functions within the `HDUList` class in the `astropy.io.fits` module, ensuring proper handling and definition of variables used during HDU processing.",
      "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: Regression in io.fits due to undefined variable\n\nBody:\n@mwcraig @embray  - I'm running into the following failure in glue due to the recent changes in io.fits:\r\n\r\n```python\r\n    def _read_next_hdu(self):\r\n        \"\"\"\r\n            Lazily load a single HDU from the fileobj or data string the `HDUList`\r\n            was opened from, unless no further HDUs are found.\r\n    \r\n            Returns True if a new HDU was loaded, or False otherwise.\r\n            \"\"\"\r\n    \r\n        if self._read_all:\r\n            return False\r\n    \r\n        saved_compression_enabled = compressed.COMPRESSION_ENABLED\r\n        fileobj, data, kwargs = self._file, self._data, self._open_kwargs\r\n    \r\n        try:\r\n            self._in_read_next_hdu = True\r\n    \r\n            if ('disable_image_compression' in kwargs and\r\n                kwargs['disable_image_compression']):\r\n                compressed.COMPRESSION_ENABLED = False\r\n    \r\n            # read all HDUs\r\n            try:\r\n                if fileobj is not None:\r\n                    try:\r\n                        # Make sure we're back to the end of the last read\r\n                        # HDU\r\n                        if len(self) > 0:\r\n                            last = self[len(self) - 1]\r\n                            if last._data_offset is not None:\r\n                                offset = last._data_offset + last._data_size\r\n                                fileobj.seek(offset, os.SEEK_SET)\r\n    \r\n                        hdu = _BaseHDU.readfrom(fileobj, **kwargs)\r\n                    except EOFError:\r\n                        self._read_all = True\r\n                        return False\r\n                    except ValueError:\r\n                        # A ValueError can occur when trying to perform I/O\r\n                        # on a closed file\r\n                        if fileobj.closed:\r\n                            self._read_all = True\r\n                            return False\r\n                        else:\r\n                            raise\r\n                    except IOError:\r\n                        if fileobj.writeonly:\r\n                            self._read_all = True\r\n                            return False\r\n                        else:\r\n                            raise\r\n                else:\r\n                    if not data:\r\n                        self._read_all = True\r\n                        return False\r\n                    hdu = _BaseHDU.fromstring(data, **kwargs)\r\n                    self._data = data[hdu._data_offset + hdu._data_size:]\r\n    \r\n                super(HDUList, self).append(hdu)\r\n                if len(self) == 1:\r\n                    # Check for an extension HDU and update the EXTEND\r\n                    # keyword of the primary HDU accordingly\r\n                    self.update_extend()\r\n    \r\n                hdu._new = False\r\n                if 'checksum' in kwargs:\r\n                    hdu._output_checksum = kwargs['checksum']\r\n            # check in the case there is extra space after the last HDU or\r\n            # corrupted HDU\r\n            except (VerifyError, ValueError) as exc:\r\n                warnings.warn(\r\n                    'Error validating header for HDU #{} (note: Astropy '\r\n                    'uses zero-based indexing).\\n{}\\n'\r\n                    'There may be extra bytes after the last HDU or the '\r\n                    'file is corrupted.'.format(\r\n>                       len(hdulist), indent(str(exc))), VerifyWarning)\r\nE                       NameError: global name 'hdulist' is not defined\r\n\r\n../../../miniconda/envs/test/lib/python2.7/site-packages/astropy/io/fits/hdu/hdulist.py:1150: NameError\r\n============================ pytest-warning summary ============================\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/fits/hdu/hdulist.py\n  function: HDUList.__getitem__\n  function: HDUList.fromstring\n  function: HDUList.index_of\n  function: HDUList._positive_index_of\n  function: HDUList._read_next_hdu\n"
    },
    {
      "similar_issue": {
        "issue_title": "Full-space velocity but unit-spherical position doesn't transform properly",
        "issue_body": "After #6219 was merged, I found what looks like a remaining bug - this fails:\r\n\r\n```python\r\nc1 = coord.FK5(ra=150*u.deg, dec=-17*u.deg, radial_velocity=83*u.km/u.s,\r\n               pm_ra_cosdec=-41*u.mas/u.yr, pm_dec=16*u.mas/u.yr)\r\nc1.transform_to(coord.Galactic)\r\n```\r\nwith\r\n```TypeError: need a base of the correct representation type, <class 'astropy.coordinates.representation.SphericalRepresentation'>, not <class 'astropy.coordinates.representation.UnitSphericalRepresentation'>```\r\n\r\ncc @eteq ",
        "issue_id": 6283,
        "pr_number": 6286,
        "pr_title": "Coordinates/velocity bugfix",
        "pr_body": "I think this is a change that I had meant to include in #6219 - this relaxes the `_check_base()` method on any differential to only check that the class is compatible with the representation base (i.e. that the differential class is in `rep._compatible_differentials`). This is needed so that, e.g., transformations like this can succeed (`UnitSphericalRepresentation` + `SphericalCosLatDifferential`):\r\n```python\r\nc1 = coord.FK5(ra=150*u.deg, dec=-17*u.deg, radial_velocity=83*u.km/u.s,\r\n               pm_ra_cosdec=-41*u.mas/u.yr, pm_dec=16*u.mas/u.yr)\r\nc1.transform_to(coord.Galactic)\r\n```\r\n\r\nFixes #6283 \r\n\r\ncc @eteq @mhvk ",
        "issue_closed_at": "2017-06-27T14:54:42Z",
        "base_commit": "abefd8ffffafcd1f99c72751a66b249f18f1a928"
      },
      "summary": "### Summary:\n\nThis issue is related to the transformation of astronomical coordinate systems when handling velocity vectors in a mixed representation format. Specifically, the problem arises during the transformation from the FK5 coordinate system to the Galactic coordinate system in the Astropy library. After a prior update (#6219), users encountered a TypeError due to an inconsistency between the expected representation types. The transformation process failed because the input coordinate object utilized a full-space velocity representation (which includes radial velocity) but a unit-spherical positional representation, causing a mismatch. The error message indicated that the transformation required a base of the SphericalRepresentation type, but instead, a UnitSphericalRepresentation was provided.\n\n1. **Problem Description:** The issue concerns the transformation of coordinate systems in astrophysics software, where mixed representation types for position and velocity data lead to errors during processing.\n\n2. **Key Symptoms and Behaviors:** The primary symptom observed was a TypeError during coordinate transformation, specifically when converting an FK5 coordinate with full-space velocity attributes to the Galactic coordinate system. The error message highlighted a mismatch between the expected and actual representation types.\n\n3. **Affected Components or Systems:** The problem affects the Astropy library, particularly the coordinate transformation functionality within the `astropy.coordinates.representation` module.\n\n4. **Potential Impact or Severity:** This issue could significantly impact astronomers and astrophysicists using the Astropy library for coordinate transformations, potentially leading to incorrect data processing or analysis results if not addressed.\n\n5. **Relevant Technical Details:** The root cause involves the handling of mixed representation types for position and velocity data. The underlying code changes that addressed the issue included modifications to the `BaseRepresentation._validate_differentials` function and the `BaseDifferential` class, ensuring that the transformation process correctly validates and processes differentials according to their representation types.",
      "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: Full-space velocity but unit-spherical position doesn't transform properly\n\nBody:\nAfter #6219 was merged, I found what looks like a remaining bug - this fails:\r\n\r\n```python\r\nc1 = coord.FK5(ra=150*u.deg, dec=-17*u.deg, radial_velocity=83*u.km/u.s,\r\n               pm_ra_cosdec=-41*u.mas/u.yr, pm_dec=16*u.mas/u.yr)\r\nc1.transform_to(coord.Galactic)\r\n```\r\nwith\r\n```TypeError: need a base of the correct representation type, <class 'astropy.coordinates.representation.SphericalRepresentation'>, not <class 'astropy.coordinates.representation.UnitSphericalRepresentation'>```\r\n\r\ncc @eteq \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/representation.py\n  function: BaseRepresentation._validate_differentials\n  class: BaseDifferential\n  function: BaseDifferential._get_deriv_key\n"
    }
  ]
}