{
  "id": "astropy__astropy-7746",
  "question": "Issue when passing empty lists/arrays to WCS transformations\nThe following should not fail but instead should return empty lists/arrays:\r\n\r\n```\r\nIn [1]: from astropy.wcs import WCS\r\n\r\nIn [2]: wcs = WCS('2MASS_h.fits')\r\n\r\nIn [3]: wcs.wcs_pix2world([], [], 0)\r\n---------------------------------------------------------------------------\r\nInconsistentAxisTypesError                Traceback (most recent call last)\r\n<ipython-input-3-e2cc0e97941a> in <module>()\r\n----> 1 wcs.wcs_pix2world([], [], 0)\r\n\r\n~/Dropbox/Code/Astropy/astropy/astropy/wcs/wcs.py in wcs_pix2world(self, *args, **kwargs)\r\n   1352         return self._array_converter(\r\n   1353             lambda xy, o: self.wcs.p2s(xy, o)['world'],\r\n-> 1354             'output', *args, **kwargs)\r\n   1355     wcs_pix2world.__doc__ = \"\"\"\r\n   1356         Transforms pixel coordinates to world coordinates by doing\r\n\r\n~/Dropbox/Code/Astropy/astropy/astropy/wcs/wcs.py in _array_converter(self, func, sky, ra_dec_order, *args)\r\n   1267                     \"a 1-D array for each axis, followed by an origin.\")\r\n   1268 \r\n-> 1269             return _return_list_of_arrays(axes, origin)\r\n   1270 \r\n   1271         raise TypeError(\r\n\r\n~/Dropbox/Code/Astropy/astropy/astropy/wcs/wcs.py in _return_list_of_arrays(axes, origin)\r\n   1223             if ra_dec_order and sky == 'input':\r\n   1224                 xy = self._denormalize_sky(xy)\r\n-> 1225             output = func(xy, origin)\r\n   1226             if ra_dec_order and sky == 'output':\r\n   1227                 output = self._normalize_sky(output)\r\n\r\n~/Dropbox/Code/Astropy/astropy/astropy/wcs/wcs.py in <lambda>(xy, o)\r\n   1351             raise ValueError(\"No basic WCS settings were created.\")\r\n   1352         return self._array_converter(\r\n-> 1353             lambda xy, o: self.wcs.p2s(xy, o)['world'],\r\n   1354             'output', *args, **kwargs)\r\n   1355     wcs_pix2world.__doc__ = \"\"\"\r\n\r\nInconsistentAxisTypesError: ERROR 4 in wcsp2s() at line 2646 of file cextern/wcslib/C/wcs.c:\r\nncoord and/or nelem inconsistent with the wcsprm.\r\n```\n",
  "answer": "{\"task_id\": \"74547525-a5da-4b5c-9272-d45ad6c54bb3\", \"workflow_run_id\": \"1f084f33-f1e6-4a92-9e4c-eee7418a9040\", \"data\": {\"id\": \"1f084f33-f1e6-4a92-9e4c-eee7418a9040\", \"workflow_id\": \"bc5a1a30-852f-4fd7-98f0-8fca2f23c564\", \"status\": \"succeeded\", \"outputs\": {\"ranked_patches\": \"```json\\n{\\n  \\\"ranked_patches\\\": [\\n    {\\n      \\\"patch_id\\\": 1,\\n      \\\"patch\\\": \\\"diff --git a/astropy/wcs/wcs.py b/astropy/wcs/wcs.py\\\\nindex abcdefg..hijklmn 100644\\\\n--- a/astropy/wcs/wcs.py\\\\n+++ b/astropy/wcs/wcs.py\\\\n@@ -1222,6 +1222,11 @@ class WCS:\\\\n         \\\\n         def _return_list_of_arrays(axes, origin):\\\\n             if ra_dec_order and sky == 'input':\\\\n+                # Handle empty input arrays\\\\n+                if xy.size == 0:\\\\n+                    return [np.array([]) for _ in range(len(axes))]\\\\n+\\\\n                 xy = self._denormalize_sky(xy)\\\\n             output = func(xy, origin)\\\\n             if ra_dec_order and sky == 'output':\\\\n\\\",\\n      \\\"rank\\\": 1,\\n      \\\"score\\\": 0.95,\\n      \\\"evaluation\\\": {\\n        \\\"correctness\\\": 0.9,\\n        \\\"code_quality\\\": 0.95,\\n        \\\"risk_level\\\": 0.1,\\n        \\\"best_practices\\\": 0.9,\\n        \\\"test_coverage\\\": 0.85\\n      },\\n      \\\"reasoning\\\": \\\"This patch correctly handles empty input arrays by returning empty arrays for each axis, which aligns well with the expected behavior. It uses numpy arrays, which is consistent with the rest of the codebase, ensuring maintainability and reducing the risk of introducing new bugs.\\\",\\n      \\\"recommendation\\\": \\\"Highly recommended\\\"\\n    },\\n    {\\n      \\\"patch_id\\\": 3,\\n      \\\"patch\\\": \\\"diff --git a/astropy/wcs/wcs.py b/astropy/wcs/wcs.py\\\\nindex abcdefg..vwxyzab 100644\\\\n--- a/astropy/wcs/wcs.py\\\\n+++ b/astropy/wcs/wcs.py\\\\n@@ -1222,6 +1222,12 @@ class WCS:\\\\n         \\\\n         def _return_list_of_arrays(axes, origin):\\\\n             if ra_dec_order and sky == 'input':\\\\n+                # If input lists are empty, return empty lists for each output axis\\\\n+                if isinstance(xy, list) and len(xy) == 0:\\\\n+                    return [[] for _ in range(len(axes))]\\\\n+\\\\n                 xy = self._denormalize_sky(xy)\\\\n             output = func(xy, origin)\\\\n             if ra_dec_order and sky == 'output':\\\\n\\\",\\n      \\\"rank\\\": 2,\\n      \\\"score\\\": 0.85,\\n      \\\"evaluation\\\": {\\n        \\\"correctness\\\": 0.85,\\n        \\\"code_quality\\\": 0.85,\\n        \\\"risk_level\\\": 0.15,\\n        \\\"best_practices\\\": 0.85,\\n        \\\"test_coverage\\\": 0.8\\n      },\\n      \\\"reasoning\\\": \\\"This patch handles empty input lists by returning empty lists for each axis. While it correctly addresses the issue, using lists instead of numpy arrays may lead to inconsistencies with other parts of the codebase that expect numpy arrays, potentially increasing the risk of future bugs.\\\",\\n      \\\"recommendation\\\": \\\"Recommended with caution\\\"\\n    },\\n    {\\n      \\\"patch_id\\\": 2,\\n      \\\"patch\\\": \\\"diff --git a/astropy/wcs/wcs.py b/astropy/wcs/wcs.py\\\\nindex abcdefg..opqrstu 100644\\\\n--- a/astropy/wcs/wcs.py\\\\n+++ b/astropy/wcs/wcs.py\\\\n@@ -1222,6 +1222,13 @@ class WCS:\\\\n         \\\\n         def _return_list_of_arrays(axes, origin):\\\\n             if ra_dec_order and sky == 'input':\\\\n+                # Return empty arrays for each axis if input is empty\\\\n+                if not xy:\\\\n+                    # Determine the correct shape\\\\n+                    empty_shape = (0, len(axes))\\\\n+                    return [np.empty(empty_shape) for _ in range(len(axes))]\\\\n+\\\\n                 xy = self._denormalize_sky(xy)\\\\n             output = func(xy, origin)\\\\n             if ra_dec_order and sky == 'output':\\\\n\\\",\\n      \\\"rank\\\": 3,\\n      \\\"score\\\": 0.75,\\n      \\\"evaluation\\\": {\\n        \\\"correctness\\\": 0.8,\\n        \\\"code_quality\\\": 0.75,\\n        \\\"risk_level\\\": 0.2,\\n        \\\"best_practices\\\": 0.75,\\n        \\\"test_coverage\\\": 0.8\\n      },\\n      \\\"reasoning\\\": \\\"This patch attempts to handle empty inputs by creating empty numpy arrays with a specific shape. However, the approach of determining the shape might introduce unnecessary complexity and potential errors if the shape is not handled correctly. This increases the risk of introducing new bugs.\\\",\\n      \\\"recommendation\\\": \\\"Not recommended unless necessary adjustments are made\\\"\\n    }\\n  ],\\n  \\\"evaluation_summary\\\": \\\"Patch 1 is the most suitable solution as it effectively handles empty inputs using numpy arrays, maintaining consistency with the codebase and minimizing risk. Patch 3 is a viable alternative but uses lists, which may lead to inconsistencies. Patch 2 introduces unnecessary complexity and potential risks, making it the least recommended option.\\\"\\n}\\n```\", \"generated_tests\": \"{\\n  \\\"reproduction_tests\\\": [\\n    {\\n      \\\"test_name\\\": \\\"test_reproduce_original_issue_with_empty_lists\\\",\\n      \\\"test_code\\\": \\\"def test_reproduce_original_issue_with_empty_lists():\\\\n    from astropy.wcs import WCS\\\\n    import numpy as np\\\\n    wcs = WCS('2MASS_h.fits')\\\\n    result = wcs.wcs_pix2world([], [], 0)\\\\n    assert result == [[], []]\\\",\\n      \\\"description\\\": \\\"Reproduces the original issue by passing empty lists to wcs_pix2world\\\",\\n      \\\"expected_behavior\\\": \\\"The test should fail before applying the patch and pass after applying the patch\\\"\\n    },\\n    {\\n      \\\"test_name\\\": \\\"test_reproduce_original_issue_with_empty_arrays\\\",\\n      \\\"test_code\\\": \\\"def test_reproduce_original_issue_with_empty_arrays():\\\\n    from astropy.wcs import WCS\\\\n    import numpy as np\\\\n    wcs = WCS('2MASS_h.fits')\\\\n    result = wcs.wcs_pix2world(np.array([]), np.array([]), 0)\\\\n    assert np.array_equal(result, [np.array([]), np.array([])])\\\",\\n      \\\"description\\\": \\\"Reproduces the original issue by passing empty arrays to wcs_pix2world\\\",\\n      \\\"expected_behavior\\\": \\\"The test should fail before applying the patch and pass after applying the patch\\\"\\n    }\\n  ],\\n  \\\"validation_tests\\\": [\\n    {\\n      \\\"test_name\\\": \\\"test_patch_validation_patch_1\\\",\\n      \\\"test_code\\\": \\\"def test_patch_validation_patch_1():\\\\n    from astropy.wcs import WCS\\\\n    import numpy as np\\\\n    wcs = WCS('2MASS_h.fits')\\\\n    result = wcs.wcs_pix2world([], [], 0)\\\\n    assert result == [[], []]\\\",\\n      \\\"description\\\": \\\"Validates Patch 1 by passing empty lists to wcs_pix2world\\\",\\n      \\\"expected_behavior\\\": \\\"The test should pass after applying Patch 1\\\"\\n    },\\n    {\\n      \\\"test_name\\\": \\\"test_patch_validation_patch_2\\\",\\n      \\\"test_code\\\": \\\"def test_patch_validation_patch_2():\\\\n    from astropy.wcs import WCS\\\\n    import numpy as np\\\\n    wcs = WCS('2MASS_h.fits')\\\\n    result = wcs.wcs_pix2world([], [], 0)\\\\n    assert result == [[], []]\\\",\\n      \\\"description\\\": \\\"Validates Patch 2 by passing empty lists to wcs_pix2world\\\",\\n      \\\"expected_behavior\\\": \\\"The test should pass after applying Patch 2\\\"\\n    },\\n    {\\n      \\\"test_name\\\": \\\"test_patch_validation_patch_3\\\",\\n      \\\"test_code\\\": \\\"def test_patch_validation_patch_3():\\\\n    from astropy.wcs import WCS\\\\n    import numpy as np\\\\n    wcs = WCS('2MASS_h.fits')\\\\n    result = wcs.wcs_pix2world([], [], 0)\\\\n    assert result == [[], []]\\\",\\n      \\\"description\\\": \\\"Validates Patch 3 by passing empty lists to wcs_pix2world\\\",\\n      \\\"expected_behavior\\\": \\\"The test should pass after applying Patch 3\\\"\\n    }\\n  ],\\n  \\\"test_summary\\\": \\\"Comprehensive tests generated to reproduce the original issue with empty lists/arrays and validate the three provided patches.\\\"\\n}\"}, \"error\": \"\", \"elapsed_time\": 341.764512, \"total_tokens\": 22382, \"total_steps\": 9, \"created_at\": 1753280815, \"finished_at\": 1753281157}}"
}