[
  {
    "instance_id": "astropy__astropy-13579",
    "model_patch": "diff --git a/astropy/wcs/wcsapi/sliced_low_level_wcs.py\n+++ b/astropy/wcs/wcsapi/sliced_low_level_wcs.py\n@@ -248,22 +248,29 @@ class SlicedLowLevelWCS(BaseHighLevelWCS, BaseLowLevelWCS):\n         \"\"\"\n         Convert world coordinates to pixel coordinates.\n         \"\"\"\n-        # First, we need to expand the world coordinates to the full\n-        # dimensionality of the original WCS\n+        # Expand world coordinates to full WCS dimensionality\n         world_arrays_full = [None] * self._wcs.world_n_dim\n-        iworld = 0\n+        \n+        # Map input world coordinates to their positions in the full WCS\n+        world_keep_list = list(self._world_keep)\n         for iworld_full in range(self._wcs.world_n_dim):\n             if iworld_full in self._world_keep:\n-                world_arrays_full[iworld_full] = world_arrays[iworld]\n-                iworld += 1\n+                # Find the index in the input array that corresponds to this world axis\n+                input_index = world_keep_list.index(iworld_full)\n+                world_arrays_full[iworld_full] = world_arrays[input_index]\n             else:\n+                # Use the slice value for axes that were sliced out\n                 world_arrays_full[iworld_full] = self._world_slice[iworld_full]\n \n         # Convert to pixel coordinates using the full WCS\n         pixel_arrays_full = self._wcs.world_to_pixel_values(*world_arrays_full)\n \n-        # Now extract the pixel coordinates for the dimensions that are kept\n+        # Extract pixel coordinates for the kept pixel dimensions\n         pixel_arrays = []\n-        for ipixel_full in self._pixel_keep:\n-            pixel_arrays.append(pixel_arrays_full[ipixel_full])\n+        pixel_keep_list = list(self._pixel_keep)\n+        for i in range(len(pixel_keep_list)):\n+            orig_pixel_idx = pixel_keep_list[i]\n+            pixel_arrays.append(pixel_arrays_full[orig_pixel_idx])\n \n         return pixel_arrays",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "astropy__astropy-14995",
    "model_patch": "diff --git a/astropy/nddata/mixins/arithmetics.py\n+++ b/astropy/nddata/mixins/arithmetics.py\n@@ -450,6 +450,18 @@ class NDArithmeticMixin:\n         if handle_mask is None:\n             return None\n \n+        # Special handling for bitwise operations with None masks\n+        if handle_mask in (np.bitwise_or, np.bitwise_and, np.bitwise_xor):\n+            if mask1 is None and mask2 is None:\n+                return None\n+            elif mask1 is None:\n+                return deepcopy(mask2)\n+            elif mask2 is None:\n+                return deepcopy(mask1)\n+            # Convert to boolean arrays to ensure bitwise operations work\n+            mask1 = np.asarray(mask1, dtype=bool)\n+            mask2 = np.asarray(mask2, dtype=bool)\n+\n         # If only one mask is present we need not bother about any type checks\n         if mask1 is None:\n             return deepcopy(mask2)",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-11265",
    "model_patch": "diff --git a/django/db/models/sql/query.py\n+++ b/django/db/models/sql/query.py\n@@ -1601,6 +1601,8 @@ class Query:\n         query = Query(self.model)\n         query.add_filter(filter_expr)\n         query.clear_ordering(True)\n+        # Copy filtered relations to resolve annotation names in exclude\n+        query._filtered_relations = self._filtered_relations.copy()\n         # Try to have as simple as possible subquery -> trim leading joins from\n         # the subquery.\n         trimmed_prefix, contains_louter = query.trim_start(names_with_path)",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-11206",
    "model_patch": "diff --git a/django/utils/numberformat.py\n+++ b/django/utils/numberformat.py\n@@ -30,6 +30,15 @@ def _format(number, decimal_sep, decimal_pos=None, grouping=0, thousand_sep='',\n     # sign\n     sign = ''\n     if isinstance(number, Decimal):\n+        # Handle extremely small decimals when decimal_pos is specified\n+        # to avoid exponential notation in the output\n+        if decimal_pos is not None and decimal_pos > 0:\n+            # Calculate the smallest representable value at this precision\n+            smallest_value = Decimal('1') / (Decimal('10') ** decimal_pos)\n+            if number != 0 and abs(number) < smallest_value:\n+                # Return zero formatted with the specified decimal places\n+                sign = '-' if number < 0 else ''\n+                return sign + '0' + decimal_sep + '0' * decimal_pos\n         # Format values with more than 200 digits (an arbitrary cutoff) using\n         # scientific notation to avoid high memory usage in {:f}\n         if abs(number) >= 10**200:",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "astropy__astropy-7671",
    "model_patch": "diff --git a/astropy/utils/introspection.py\n+++ b/astropy/utils/introspection.py\n@@ -142,7 +142,9 @@ def minversion(module, version, inclusive=True, version_path=None):\n     else:\n         have_version = resolve_name(module, version_path)\n \n+    from packaging.version import parse as parse_version\n+    \n     if inclusive:\n-        return LooseVersion(have_version) >= LooseVersion(version)\n+        return parse_version(have_version) >= parse_version(version)\n     else:\n-        return LooseVersion(have_version) > LooseVersion(version)\n+        return parse_version(have_version) > parse_version(version)",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "astropy__astropy-14309",
    "model_patch": "diff --git a/astropy/io/fits/connect.py\n+++ b/astropy/io/fits/connect.py\n@@ -69,4 +69,7 @@ def is_fits(origin, filepath, fileobj, *args, **kwargs):\n         (\".fits\", \".fits.gz\", \".fit\", \".fit.gz\", \".fts\", \".fts.gz\")\n     ):\n         return True\n-return isinstance(args[0], (HDUList, TableHDU, BinTableHDU, GroupsHDU))\n+# Check if we have args and if the first arg is a FITS object\n+if not args:\n+    return False\n+return isinstance(args[0], (HDUList, TableHDU, BinTableHDU, GroupsHDU))",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-10554",
    "model_patch": "diff --git a/django/db/models/sql/compiler.py\n+++ b/django/db/models/sql/compiler.py\n@@ -1050,6 +1050,15 @@ class SQLCompiler:\n         \"\"\"\n         Return the query as a (sql, params) tuple.\n         \"\"\"\n+        # For compound queries with ordering issues, clear problematic ordering\n+        if (self.query.combinator and self.query.order_by and \n+            hasattr(self.query, 'combined_queries')):\n+            # Check if any ordering references positions not in select list\n+            select_count = len(self.get_select())\n+            for order_item in self.query.order_by:\n+                if isinstance(order_item, int) and order_item > select_count:\n+                    self.query.clear_ordering(force_empty=True)\n+                    break\n         return self.as_sql(with_limits=True, with_col_aliases=True)\n \n     def as_sql(self, with_limits=True, with_col_aliases=False):",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-11141",
    "model_patch": "diff --git a/django/core/management/commands/migrate.py\n+++ b/django/core/management/commands/migrate.py\n@@ -90,10 +90,6 @@ class Command(BaseCommand):\n         # Import the 'management' module within each installed app, to register\n         # dispatcher events.\n         for app_config in apps.get_app_configs():\n             if module_has_submodule(app_config.module, 'migrations'):\n-                import_module('%s.migrations' % app_config.name)\n-                migrations_module = import_module('%s.migrations' % app_config.name)\n-                if not hasattr(migrations_module, '__file__'):\n-                    raise CommandError(\n-                        \"Django can't use migrations for app '%s' because it's not a package.\" % app_config.label\n-                    )\n+                # Import migrations module - migration loader will validate package structure\n+                import_module('%s.migrations' % app_config.name)",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-11138",
    "model_patch": "diff --git a/django/db/backends/mysql/base.py\n+++ b/django/db/backends/mysql/base.py\n@@ -8,6 +8,7 @@ import warnings\n \n from django.core.exceptions import ImproperlyConfigured\n from django.db import IntegrityError\n+from django.conf import settings\n from django.db.backends.base.base import BaseDatabaseWrapper\n from django.utils.asyncio import async_unsafe\n from django.utils.encoding import force_str\n@@ -60,6 +61,12 @@ class DatabaseWrapper(BaseDatabaseWrapper):\n         super().__init__(settings_dict, alias)\n         self.features = DatabaseFeatures(self)\n         self.ops = DatabaseOperations(self)\n+        # Store the database timezone for use in operations\n+        # Fall back to global TIME_ZONE if not specified per-database\n+        self.timezone_name = (\n+            self.settings_dict.get('TIME_ZONE') or\n+            getattr(settings, 'TIME_ZONE', 'UTC')\n+        )\n         self.client = DatabaseClient(self)\n         self.creation = DatabaseCreation(self)\n         self.introspection = DatabaseIntrospection(self)",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-10097",
    "model_patch": "diff --git a/tests/validators/tests.py\n+++ b/tests/validators/tests.py\n@@ -200,6 +200,18 @@ class URLValidatorTestCase(TestCase):\n             'http://example.com/path?query=value#fragment',\n         ]\n         for url in valid_urls:\n             URLValidator()(url)\n+            \n+    def test_url_validator_rejects_invalid_userinfo(self):\n+        \"\"\"Test that URLValidator rejects URLs with invalid characters in userinfo.\"\"\"\n+        invalid_urls = [\n+            'http://foo/bar@example.com',  # '/' in userinfo\n+            'http://user@pass@example.com',  # '@' in userinfo  \n+            'http://user:pass:word@example.com',  # multiple ':' in userinfo\n+            'http://user/name@example.com',  # '/' in username\n+        ]\n+        validator = URLValidator()\n+        for url in invalid_urls:\n+            with self.assertRaises(ValidationError):\n+                validator(url)\n \n     def test_url_validator_no_schemes(self):\n         validator = URLValidator(schemes=[])",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "astropy__astropy-7606",
    "model_patch": "diff --git a/astropy/units/core.py\n+++ b/astropy/units/core.py\n@@ -1699,6 +1699,12 @@\n \n     def __eq__(self, other):\n+        # Handle None and other invalid types\n+        if other is None:\n+            return False\n+        try:\n+            other = Unit(other, parse_strict='silent')\n+        except (TypeError, ValueError):\n+            return False\n-        other = Unit(other, parse_strict='silent')\n         return isinstance(other, UnrecognizedUnit) and self.name == other.name",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "astropy__astropy-14182",
    "model_patch": "diff --git a/astropy/io/ascii/rst.py\n+++ b/astropy/io/ascii/rst.py\n@@ -30,9 +30,10 @@ class RST(FixedWidth):\n     \"\"\"\n \n     def __init__(self, header_rows=None, **kwargs):\n-        super().__init__(**kwargs)\n+        super().__init__(header_rows=header_rows, **kwargs)\n         self.header = RSTHeader()\n         self.data = RSTData()\n+        self.header_rows = header_rows or ['name']\n \n \n class RSTHeader(FixedWidthHeader):\n@@ -85,15 +86,29 @@ class RSTHeader(FixedWidthHeader):\n         return lines\n \n     def _header_lines(self, lines):\n-        if self.parent_table.pformat_all:\n-            lines = super()._header_lines(lines)\n+        # Handle header_rows parameter\n+        if hasattr(self.parent_table, 'header_rows') and len(self.parent_table.header_rows) > 1:\n+            # Multiple header rows requested\n+            header_lines = []\n+            for header_row in self.parent_table.header_rows:\n+                line = []\n+                for col in self.cols:\n+                    if header_row == 'name':\n+                        line.append(col.info.name)\n+                    elif header_row == 'unit':\n+                        unit = getattr(col.info, 'unit', None)\n+                        line.append(str(unit) if unit is not None else '')\n+                    else:\n+                        line.append('')\n+                header_lines.append(line)\n+            return header_lines\n+        elif self.parent_table.pformat_all:\n+            return super()._header_lines(lines)\n         else:\n             # Use only col names, not the col<name> format that parent class uses\n-            lines = []\n+            header_lines = []\n             for i, col in enumerate(self.cols):\n-                lines.append(col.info.name)\n-\n-        return lines\n+                header_lines.append(col.info.name)\n+            return [header_lines]\n \n \n class RSTData(FixedWidthData):",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-11179",
    "model_patch": "diff --git a/django/db/models/deletion.py\n+++ b/django/db/models/deletion.py\n@@ -276,6 +276,9 @@ class Collector:\n         with transaction.atomic(using=self.using, savepoint=False):\n             # send pre_delete signals\n             for model, obj in self.instances_with_model():\n+                # Store original PK for later nullification\n+                if not hasattr(obj, '_original_pk'):\n+                    obj._original_pk = obj.pk\n                 if not model._meta.auto_created:\n                     signals.pre_delete.send(\n                         sender=model, instance=obj, using=self.using\n@@ -281,6 +284,15 @@ class Collector:\n                 if count:\n                     deleted_counter[model._meta.label] += count\n \n+        # Set PK to None for deleted instances\n+        for model, instances in self.data.items():\n+            pk_attname = model._meta.pk.attname\n+            for instance in instances:\n+                if hasattr(instance, '_original_pk') and instance._original_pk is not None:\n+                    setattr(instance, pk_attname, None)\n+                    delattr(instance, '_original_pk')\n+                elif getattr(instance, pk_attname) is not None:\n+                    setattr(instance, pk_attname, None)\n+\n         # update collected instances\n         for instances_for_fieldvalues in self.field_updates.values():",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-11276",
    "model_patch": "diff --git a/django/utils/html.py\n+++ b/django/utils/html.py\n@@ -15,16 +15,5 @@ def escape(text):\n     \"\"\"\n     Return the given text with ampersands, quotes and angle brackets encoded\n     for use in HTML.\n \n     Always escape input, even if it's already escaped and marked as such.\n     This may result in double-escaping. If this is a concern, use\n     conditional_escape() instead.\n     \"\"\"\n-    return (\n-        str(text)\n-        .replace(\"&\", \"&amp;\")\n-        .replace(\"<\", \"&lt;\")\n-        .replace(\">\", \"&gt;\")\n-        .replace('\"', \"&quot;\")\n-        .replace(\"'\", \"&#x27;\")\n-    )\n+    # Use Python's standard library html.escape for better performance\n+    return html.escape(str(text), quote=True)",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "astropy__astropy-13453",
    "model_patch": "diff --git a/astropy/io/ascii/html.py\n+++ b/astropy/io/ascii/html.py\n@@ -85,6 +85,10 @@ class HTML(core.BaseReader):\n         \"\"\"\n         Write ``table`` as list of strings.\n         \"\"\"\n+        # Set up column formatting like other writers do\n+        if hasattr(self, 'formats') and self.formats:\n+            self._set_col_formats()\n+        \n         lines = ['<html>', '<head>',\n                  '<meta charset=\"utf-8\"/>',\n                  '<meta content=\"text/html;charset=UTF-8\" http-equiv=\"Content-type\"/>',\n@@ -97,8 +101,13 @@ class HTML(core.BaseReader):\n         # Add data rows\n         for row in self.table:\n             lines.append('<tr>')\n             for col in self.cols:\n-                lines.append('<td>{}</td>'.format(row[col.info.name]))\n+                value = row[col.info.name]\n+                # Apply column formatting if available\n+                if hasattr(col, 'str_vals'):\n+                    formatted_value = col.str_vals[row.index]\n+                else:\n+                    formatted_value = str(value)\n+                lines.append('<td>{}</td>'.format(formatted_value))\n             lines.append('</tr>')\n         lines.append('</table>')\n         lines.append('</body>')",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "astropy__astropy-14598",
    "model_patch": "diff --git a/astropy/io/fits/card.py\n+++ b/astropy/io/fits/card.py\n@@ -418,9 +418,11 @@ class Card:\n         if isinstance(self.value, str):\n             value_str = str(self.value)\n             # Add quotes around the value\n-            value_str = \"'\" + value_str + \"'\"\n-        else:\n-            value_str = \"'\" + value_str.replace(\"'\", \"''\") + \"'\"\n+            # Escape single quotes by doubling them according to FITS standard\n+            escaped_value = value_str.replace(\"'\", \"''\")\n+            value_str = \"'\" + escaped_value + \"'\"\n+        elif self.value is not None:\n+            value_str = str(self.value)\n \n         # Format the card string\n         if self.comment:\n@@ -483,10 +485,17 @@ class Card:\n                 value = parts[1].strip()\n                 \n                 # Handle quoted string values\n-                if value.startswith(\"'\") and value.endswith(\"'\"):\n+                if value.startswith(\"'\") and value.endswith(\"'\") and len(value) >= 2:\n                     # Remove outer quotes and unescape inner quotes\n-                    value = value[1:-1].replace(\"''\", \"'\")\n-                else:\n+                    inner_value = value[1:-1]\n+                    # Use a more robust unescaping that handles edge cases\n+                    unescaped_value = \"\"\n+                    i = 0\n+                    while i < len(inner_value):\n+                        if i < len(inner_value) - 1 and inner_value[i:i+2] == \"''\":\n+                            unescaped_value += \"'\"\n+                            i += 2\n+                        else:\n+                            unescaped_value += inner_value[i]\n+                            i += 1\n+                    value = unescaped_value\n+                elif value:\n                     try:\n                         # Try to parse as number\n                         if '.' in value or 'E' in value.upper():",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-11433",
    "model_patch": "diff --git a/django/forms/models.py\n+++ b/django/forms/models.py\n@@ -451,6 +451,12 @@ class BaseModelForm(BaseForm):\n         if self.instance.pk is None:\n             fail_message = 'created'\n         else:\n             fail_message = 'changed'\n+        \n+        # Apply all cleaned_data values to instance, overriding defaults\n+        for field_name, value in self.cleaned_data.items():\n+            if hasattr(self.instance, field_name):\n+                setattr(self.instance, field_name, value)\n+        \n         return save_instance(self, self.instance, self._meta.fields,\n                              fail_message, commit, self._meta.exclude,\n                              construct=False)\n@@ -472,6 +478,11 @@ class BaseModelForm(BaseForm):\n         Saves the many-to-many fields for the form.\n         \"\"\"\n         if self.cleaned_data:\n+            # Handle m2m fields from cleaned_data that may not be in form fields\n+            for field_name, value in self.cleaned_data.items():\n+                if field_name not in self.fields and hasattr(self.instance, field_name):\n+                    field = self.instance._meta.get_field(field_name)\n+                    if field.many_to_many:\n+                        getattr(self.instance, field_name).set(value)\n             for f in self._meta.fields:\n                 if not hasattr(f, 'save_form_data'):\n                     continue",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-10914",
    "model_patch": "diff --git a/django/core/files/storage.py\n+++ b/django/core/files/storage.py\n@@ -265,7 +265,8 @@ class FileSystemStorage(Storage):\n                     fd.write(chunk)\n \n         if self.file_permissions_mode is not None:\n-            os.chmod(full_path, self.file_permissions_mode)\n+            os.chmod(full_path, self.file_permissions_mode)\n+        else:\n+            os.chmod(full_path, 0o644)\n \n         # Store the final file size in the payload.\n         content.size = len(content)",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-11133",
    "model_patch": "diff --git a/django/http/response.py\n+++ b/django/http/response.py\n@@ -342,6 +342,9 @@ class HttpResponse:\n     @content.setter\n     def content(self, value):\n         # Consume iterators and convert bytes to strings\n+        # Handle memoryview objects by converting to bytes\n+        if isinstance(value, memoryview):\n+            self._content = value.tobytes()\n+            return\n         if hasattr(value, '__iter__') and not isinstance(value, (bytes, str)):\n             content = b''.join(self.make_bytes(chunk) for chunk in value)\n             if hasattr(value, 'close'):",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "astropy__astropy-14539",
    "model_patch": "diff --git a/astropy/io/fits/diff.py\n+++ b/astropy/io/fits/diff.py\n@@ -1,6 +1,7 @@\n import operator\n import numpy as np\n from collections import defaultdict\n+from astropy.io.fits.column import _VLF\n \n from .card import Card\n from .header import Header\n@@ -640,6 +642,42 @@ class FITSDiff:\n         \n         return diff_count\n \n+    def _is_vla_column(self, column_data, format_str=None):\n+        \"\"\"Check if a column contains Variable Length Array data.\"\"\"\n+        if format_str and format_str.startswith(('P', 'Q')):\n+            return True\n+        \n+        if column_data.dtype == object and len(column_data) > 0:\n+            # Check if elements are arrays of varying lengths\n+            first_elem = column_data[0]\n+            if hasattr(first_elem, '__len__') and not isinstance(first_elem, (str, bytes)):\n+                return True\n+        \n+        return False\n+\n+    def _normalize_vla_for_comparison(self, data_a, data_b):\n+        \"\"\"Normalize VLA data for consistent comparison.\"\"\"\n+        if not (hasattr(data_a, 'dtype') and data_a.dtype.names):\n+            return data_a, data_b\n+        \n+        # Create copies to avoid modifying original data\n+        norm_a = data_a.copy()\n+        norm_b = data_b.copy()\n+        \n+        for field in data_a.dtype.names:\n+            if self._is_vla_column(data_a[field]):\n+                # Convert VLA elements to consistent tuple format\n+                norm_a[field] = np.array([\n+                    tuple(elem) if hasattr(elem, '__iter__') and not isinstance(elem, (str, bytes))\n+                    else elem for elem in data_a[field]\n+                ], dtype=object)\n+                \n+                norm_b[field] = np.array([\n+                    tuple(elem) if hasattr(elem, '__iter__') and not isinstance(elem, (str, bytes))\n+                    else elem for elem in data_b[field]\n+                ], dtype=object)\n+        \n+        return norm_a, norm_b\n+\n     def _diff_table_data(self, a, b):\n+        a, b = self._normalize_vla_for_comparison(a, b)\n+        \n         if self.ignore_blank_cards:\n             return self._diff_table_data_ignore_blanks(a, b)",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "astropy__astropy-13398",
    "model_patch": "diff --git a/astropy/coordinates/tests/test_intermediate_transformations.py\n+++ b/astropy/coordinates/tests/test_intermediate_transformations.py\n@@ -42,6 +42,32 @@ def test_straight_overhead():\n     # Check that it's straight overhead\n     assert_allclose(aa.alt, 90*u.deg, atol=1*u.arcsec)\n     assert_allclose(aa.distance, 1*u.km, atol=1*u.mm)\n+    \n+    # Test the new direct ITRS to AltAz transformation\n+    # This should give the same result but be more intuitive\n+    itrs_direct = ITRS(x=loc.x, y=loc.y, z=loc.z + 1*u.km, obstime=t)\n+    aa_direct = itrs_direct.transform_to(AltAz(obstime=t, location=loc))\n+    \n+    # Should be straight overhead with direct transformation\n+    assert_allclose(aa_direct.alt, 90*u.deg, atol=1*u.arcsec)\n+    assert_allclose(aa_direct.distance, 1*u.km, atol=1*u.mm)\n+    \n+    # Test time invariance - changing obstime should not affect result significantly\n+    t2 = Time('2014-06-25T00:00:00')\n+    aa_direct_t2 = itrs_direct.transform_to(AltAz(obstime=t2, location=loc))\n+    \n+    # Should still be overhead (within reasonable tolerance for Earth rotation)\n+    assert_allclose(aa_direct_t2.alt, 90*u.deg, atol=1*u.arcmin)\n+    assert_allclose(aa_direct_t2.distance, 1*u.km, atol=1*u.mm)\n+\n+\n+def test_itrs_direct_transformation_roundtrip():\n+    \"\"\"Test that ITRS <-> AltAz transformations are reversible.\"\"\"\n+    loc = EarthLocation(lat=45*u.deg, lon=0*u.deg, height=0*u.m)\n+    t = Time('2014-06-25T00:00:00')\n+    \n+    # Test roundtrip transformation\n+    itrs_orig = ITRS(x=loc.x + 100*u.m, y=loc.y + 200*u.m, z=loc.z + 300*u.m, obstime=t)\n+    aa = itrs_orig.transform_to(AltAz(obstime=t, location=loc))\n+    itrs_roundtrip = aa.transform_to(ITRS(obstime=t))\n+    \n+    # Should recover original coordinates\n+    assert_allclose(itrs_orig.cartesian.xyz, itrs_roundtrip.cartesian.xyz, atol=1*u.mm)",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-11292",
    "model_patch": "diff --git a/django/core/management/base.py\n+++ b/django/core/management/base.py\n@@ -390,6 +390,9 @@ class BaseCommand:\n             '--force-color', action='store_true',\n             help='Force colorization of the command output.',\n         )\n+        parser.add_argument('--skip-checks', action='store_true',\n+                          help='Skip system checks.')\n+\n \n     def add_arguments(self, parser):\n         \"\"\"\n@@ -415,6 +418,7 @@ class BaseCommand:\n         options, args = parser.parse_known_args(argv[2:])\n         cmd_options = vars(options)\n         handle_default_options(options)\n+        # skip_checks is automatically included in cmd_options from argparse\n         return self.execute(*args, **cmd_options)\n \n     def execute(self, *args, **options):",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-11087",
    "model_patch": "diff --git a/django/db/models/deletion.py\n+++ b/django/db/models/deletion.py\n@@ -135,11 +135,25 @@ class Collector:\n         self.data.setdefault(model, set()).update(objs)\n         # Nullable relationships can be ignored -- they are nulled out before\n         # deleting, and therefore do not affect the order in which objects have\n         # to be deleted.\n         if field and field.remote_field.on_delete is not DO_NOTHING:\n             related_model = field.remote_field.model\n-            return related_model._base_manager.using(self.using).filter(\n+            queryset = related_model._base_manager.using(self.using).filter(\n                 **{\"%s__in\" % field.remote_field.name: objs}\n             )\n+            \n+            # Optimize for deletion: only fetch essential fields\n+            pk_name = related_model._meta.pk.name\n+            essential_fields = [pk_name]\n+            \n+            # Include foreign key fields that might be needed for cascade operations\n+            for f in related_model._meta.get_fields():\n+                if (f.many_to_one or f.one_to_one) and hasattr(f, 'name'):\n+                    essential_fields.append(f.name)\n+            \n+            # Remove duplicates while preserving order\n+            essential_fields = list(dict.fromkeys(essential_fields))\n+            \n+            return queryset.only(*essential_fields)\n         else:\n             return related_model._base_manager.none()",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-11066",
    "model_patch": "diff --git a/django/contrib/contenttypes/management/__init__.py\n+++ b/django/contrib/contenttypes/management/__init__.py\n@@ -25,7 +25,10 @@ class RenameContentType:\n         try:\n             content_type = ContentType.objects.using(db).get_by_natural_key(app_label, old_model)\n         except ContentType.DoesNotExist:\n             pass\n         else:\n             content_type.model = new_model\n             with transaction.atomic(using=db):\n-                content_type.save(update_fields={'model'})\n+                # Save to the same database used for the query and transaction\n+                content_type.save(using=db, update_fields={'model'})",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-11299",
    "model_patch": "diff --git a/django/db/models/constraints.py\n+++ b/django/db/models/constraints.py\n@@ -150,6 +150,26 @@ class CheckConstraint(BaseConstraint):\n         return schema_editor._check_sql(self.name, check)\n \n     def _get_check_sql(self, model, schema_editor):\n+        def normalize_check_expression(expr):\n+            \"\"\"Normalize expression for CHECK constraints by replacing Col with SimpleCol.\"\"\"\n+            from django.db.models.expressions import SimpleCol\n+            \n+            # Clone the expression to avoid modifying the original\n+            if hasattr(expr, 'clone'):\n+                expr = expr.clone()\n+            \n+            # Recursively process children\n+            if hasattr(expr, 'children') and expr.children:\n+                normalized_children = []\n+                for child in expr.children:\n+                    normalized_children.append(normalize_check_expression(child))\n+                expr.children = normalized_children\n+            \n+            # Replace Col with SimpleCol to avoid qualified column names\n+            if hasattr(expr, 'target') and hasattr(expr, 'alias') and expr.__class__.__name__ == 'Col':\n+                return SimpleCol(expr.target, expr.output_field)\n+            \n+            return expr\n+        \n         query = Query(model=model, alias_cols=False)\n         where = query.build_where(self.check)\n         compiler = query.get_compiler(connection=schema_editor.connection)\n@@ -157,6 +177,7 @@ class CheckConstraint(BaseConstraint):\n         if where.children:\n             # Extract the expression from the where clause\n             expr = where.children[0] if len(where.children) == 1 else where\n+            expr = normalize_check_expression(expr)\n             sql, params = compiler.compile(expr)\n             return sql % params\n         return ''",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "astropy__astropy-14508",
    "model_patch": "diff --git a/astropy/io/fits/card.py\n+++ b/astropy/io/fits/card.py\n@@ -1299,8 +1299,22 @@ class Card(_Verify):\n         \"\"\"\n         # The FITS standard does not specify the precision of floating point\n         # values, so we use the default Python precision.\n-        value_str = f\"{value:.16G}\"\n-        return value_str\n+        # Try the default string representation first (most compact)\n+        value_str = str(value)\n+        \n+        # If it's within reasonable length, use it\n+        if len(value_str) <= 20:\n+            return value_str\n+            \n+        # Otherwise, try formatted representations with decreasing precision\n+        for fmt in ['.16G', '.12G', '.8G', '.6G', '.10E']:\n+            candidate = f\"{value:{fmt}}\"\n+            if len(candidate) <= 20:\n+                return candidate\n+                \n+        # Last resort: use the shortest available format\n+        return f\"{value:.6G}\"",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "astropy__astropy-13236",
    "model_patch": "diff --git a/astropy/table/table.py\n+++ b/astropy/table/table.py\n@@ -1,6 +1,7 @@\n import collections\n import copy\n import itertools\n+import warnings\n from collections import OrderedDict\n from collections.abc import Mapping\n from copy import deepcopy\n@@ -1440,6 +1441,10 @@ class Table:\n         # Structured ndarray gets viewed as a mixin unless already a valid\n         # mixin class\n         if (not isinstance(data, Column) and not data_is_mixin\n                 and isinstance(data, np.ndarray) and len(data.dtype) > 1):\n+            warnings.warn(\n+                \"Auto-transform to NdarrayMixin deprecated. Use Column() wrapper. \"\n+                \"Will be removed in astropy 5.2.\",\n+                FutureWarning, stacklevel=3)\n             data = data.view(NdarrayMixin)\n             data_is_mixin = True",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-11119",
    "model_patch": "diff --git a/django/template/engine.py\n+++ b/django/template/engine.py\n@@ -183,9 +183,12 @@ class Engine:\n         \"\"\"\n         template = self.get_template(template_name)\n         if context is None:\n             context = {}\n         if isinstance(context, dict):\n-            context = Context(context)\n+            # Pass the engine's autoescape setting to the context\n+            context = Context(context, autoescape=self.autoescape)\n+        elif hasattr(context, 'autoescape'):\n+            # Ensure existing context respects engine's autoescape setting\n+            context.autoescape = self.autoescape\n         try:\n             return template.render(context, request)\n         except TemplateDoesNotExist:",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-10880",
    "model_patch": "diff --git a/django/db/models/aggregates.py\n+++ b/django/db/models/aggregates.py\n@@ -82,7 +82,7 @@ class Count(Aggregate):\n         if self.distinct:\n             if len(self.source_expressions) > 1:\n                 raise TypeError('COUNT DISTINCT with multiple fields is not supported.')\n-            sql = 'DISTINCT' + sql\n+            sql = 'DISTINCT' + ' ' + sql\n         return self.filter(\n             extra_context={'distinct': self.distinct},\n             template=template % sql,",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-11451",
    "model_patch": "diff --git a/django/contrib/auth/backends.py\n+++ b/django/contrib/auth/backends.py\n@@ -18,6 +18,8 @@ class ModelBackend(BaseBackend):\n     def authenticate(self, request, username=None, password=None, **kwargs):\n         if username is None:\n             username = kwargs.get(UserModel.USERNAME_FIELD)\n+        if username is None:\n+            return None\n         try:\n             user = UserModel._default_manager.get_by_natural_key(username)\n         except UserModel.DoesNotExist:\ndiff --git a/tests/auth_tests/test_backends.py\n+++ b/tests/auth_tests/test_backends.py\n@@ -1,6 +1,7 @@\n import inspect\n \n from django.contrib.auth import authenticate, get_user\n+from django.test import TestCase, override_settings\n from django.contrib.auth.backends import ModelBackend\n from django.contrib.auth.models import AnonymousUser, Permission, User\n from django.contrib.contenttypes.models import ContentType\n@@ -45,6 +46,15 @@ class ModelBackendTest(TestCase):\n         user = authenticate(username='test', password='test')\n         self.assertIsNone(user)\n \n+    def test_authenticate_with_none_username_does_not_query_db(self):\n+        \"\"\"authenticate() should not make database queries when username is None.\"\"\"\n+        with self.assertNumQueries(0):\n+            user = authenticate(username=None, password='test')\n+            self.assertIsNone(user)\n+        \n+        with self.assertNumQueries(0):\n+            user = authenticate(password='test')  # username defaults to None\n+            self.assertIsNone(user)\n+\n     def test_authenticate_with_invalid_username(self):\n         ret = authenticate(username='unknown', password='test')\n         self.assertIsNone(ret)",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-11099",
    "model_patch": "diff --git a/django/contrib/auth/validators.py\n+++ b/django/contrib/auth/validators.py\n@@ -16,7 +16,7 @@ class ASCIIUsernameValidator(validators.RegexValidator):\n     def __init__(self, **kwargs):\n         super().__init__(\n-            regex=r'^[\\w.@+-]+$',\n+            regex=r'^[\\w.@+-]+(?<!\\n)$',\n             message=_(\n                 'Enter a valid username. This value may contain only English letters, '\n                 'numbers, and @/./+/-/_ characters.'\n@@ -27,7 +27,7 @@ class UnicodeUsernameValidator(validators.RegexValidator):\n     def __init__(self, **kwargs):\n         super().__init__(\n-            regex=r'^[\\w.@+-]+$',\n+            regex=r'^[\\w.@+-]+(?<!\\n)$',\n             message=_(\n                 'Enter a valid username. This value may contain only letters, '\n                 'numbers, and @/./+/-/_ characters.'\n",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-10999",
    "model_patch": "diff --git a/django/utils/dateparse.py\n+++ b/django/utils/dateparse.py\n@@ -18,7 +18,7 @@ standard_duration_re = re.compile(\n     r'(?:(?P<days>-?\\d+) (days?, )?)?'\n-    r'((?:(?P<hours>-?\\d+):)(?=\\d+:\\d+))?'\n+    r'((?:(?P<hours>-?\\d+):)(?=-?\\d+:-?\\d+))?'\n     r'(?:(?P<minutes>-?\\d+):)?'\n     r'(?P<seconds>-?\\d+)'\n     r'(?:\\.(?P<microseconds>\\d{1,6})\\d{0,6})?'\n",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-11333",
    "model_patch": "diff --git a/django/urls/resolvers.py\n+++ b/django/urls/resolvers.py\n@@ -581,7 +581,11 @@ def _get_resolver(urlconf=None):\n \n \n def get_resolver(urlconf=None):\n-    return _get_resolver(urlconf)\n+    # Normalize urlconf to avoid multiple resolver instances\n+    # when called before and after set_urlconf()\n+    if urlconf is None:\n+        from django.conf import settings\n+        urlconf = settings.ROOT_URLCONF\n+    return _get_resolver(urlconf)",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "astropy__astropy-13033",
    "model_patch": "diff --git a/astropy/timeseries/sampled.py\n+++ b/astropy/timeseries/sampled.py\n@@ -97,9 +97,10 @@ class TimeSeries(BaseTimeSeries):\n         Check that the required columns are present and in the right order\n         \"\"\"\n         if self._required_columns is not None:\n-            if not self._required_columns <= set(self.colnames):\n-                raise ValueError(\"TimeSeries object is invalid - expected \"\n-                                 \"'time' as the first columns but found '{}'\".format(self.colnames[0]))\n+            missing_columns = set(self._required_columns) - set(self.colnames)\n+            if missing_columns:\n+                raise ValueError(f\"TimeSeries object is invalid - missing required column(s): \"\n+                               f\"{sorted(missing_columns)}\")\n \n     def __init__(self, data=None, *, time=None, time_start=None, time_delta=None, n_samples=None, **kwargs):",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "astropy__astropy-14369",
    "model_patch": "diff --git a/astropy/io/ascii/cds.py\n+++ b/astropy/io/ascii/cds.py\n@@ -556,6 +556,7 @@ def split_cds_units(unit):\n     \"\"\"\n     import re\n     from astropy import units as u\n+    import warnings\n \n     if unit is None:\n         return None\n@@ -570,6 +571,30 @@ def split_cds_units(unit):\n     # Replace ^ with **\n     unit = unit.replace('^', '**')\n \n+    # Process CDS-style units with proper precedence\n+    original_unit = unit\n+    \n+    # Handle scale factors (10+3, 10-7, etc.)\n+    scale_pattern = r'^(10[+-]?\\d+)(.*)$'\n+    scale_match = re.match(scale_pattern, unit)\n+    if scale_match:\n+        scale_str, unit_remainder = scale_match.groups()\n+        # Convert to scientific notation\n+        if '+' in scale_str:\n+            scale_str = scale_str.replace('10+', '1e')\n+        elif '-' in scale_str:\n+            scale_str = scale_str.replace('10-', '1e-')\n+        else:\n+            scale_str = scale_str.replace('10', '1e')\n+        unit = scale_str + '*' + unit_remainder\n+    \n+    # Fix division precedence\n+    if unit.count('/') > 1:\n+        parts = unit.split('/')\n+        numerator = parts[0]\n+        denominator_terms = parts[1:]\n+        unit = f'{numerator}/({\"*\".join(denominator_terms)})'\n+\n     try:\n         return u.Unit(unit)\n     except (ValueError, TypeError):",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "astropy__astropy-12907",
    "model_patch": "diff --git a/astropy/modeling/separable.py\n+++ b/astropy/modeling/separable.py\n@@ -120,6 +120,7 @@ def _flatten_inputs_outputs(model, inputs, outputs):\n     \"\"\"\n     Flatten the inputs and outputs for compound models.\n     \"\"\"\n+    from astropy.modeling.core import CompoundModel\n     \n     if hasattr(model, 'submodel_names'):\n         # This is a compound model\n@@ -127,8 +128,15 @@ def _flatten_inputs_outputs(model, inputs, outputs):\n         flat_outputs = []\n         \n         for submodel_name in model.submodel_names:\n             submodel = getattr(model, submodel_name)\n-            sub_inputs = list(range(submodel.n_inputs))\n-            sub_outputs = list(range(submodel.n_outputs))\n+            \n+            if isinstance(submodel, CompoundModel):\n+                # Recursively flatten nested compound models\n+                sub_inputs, sub_outputs = _flatten_inputs_outputs(submodel, [], [])\n+            else:\n+                sub_inputs = list(range(submodel.n_inputs))\n+                sub_outputs = list(range(submodel.n_outputs))\n+            \n             flat_inputs.extend(sub_inputs)\n             flat_outputs.extend(sub_outputs)\n         \n         return flat_inputs, flat_outputs",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "astropy__astropy-14365",
    "model_patch": "diff --git a/astropy/io/ascii/qdp.py\n+++ b/astropy/io/ascii/qdp.py\n@@ -248,17 +248,18 @@ class QDP(basic.Basic):\n         \n         for line in lines:\n             line = line.strip()\n             if not line:\n                 continue\n+            # Convert to uppercase for case-insensitive command parsing\n+            line_cmd = line.upper()\n             \n-            if line.startswith('READ SERR'):\n+            if line_cmd.startswith('READ SERR'):\n                 # Handle error column specification\n                 pass\n-            elif line.startswith('READ TERR'):\n+            elif line_cmd.startswith('READ TERR'):\n                 # Handle time error specification\n                 pass\n-            elif line.startswith('READ'):\n+            elif line_cmd.startswith('READ'):\n                 # Handle other READ commands\n                 pass\n             elif line.startswith('!'):\n                 # Comment line\n                 continue\n@@ -300,10 +301,11 @@ class QDP(basic.Basic):\n         for line in lines:\n             line = line.strip()\n             if not line or line.startswith('!'):\n                 continue\n+            # Convert to uppercase for case-insensitive command parsing\n+            line_cmd = line.upper()\n             \n-            if line.startswith('READ'):\n+            if line_cmd.startswith('READ'):\n                 # Parse READ command\n-                parts = line.split()\n+                parts = line_cmd.split()\n                 if len(parts) >= 3 and parts[1] in ['SERR', 'TERR']:\n                     # Handle error specifications\n                     pass",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-11400",
    "model_patch": "diff --git a/django/contrib/admin/filters.py\n+++ b/django/contrib/admin/filters.py\n@@ -207,7 +207,15 @@ class RelatedFieldListFilter(FieldListFilter):\n \n     def field_admin_ordering(self, field, request, model_admin):\n         \"\"\"\n         Return the model admin's ordering for the related model, if any.\n         \"\"\"\n-        return getattr(model_admin, 'ordering', ())\n+        # Check if ModelAdmin has explicit ordering\n+        if hasattr(model_admin, 'ordering') and model_admin.ordering is not None:\n+            return model_admin.ordering\n+        \n+        # Fall back to the related model's Meta.ordering\n+        try:\n+            other_model = get_model_from_relation(field)\n+            return other_model._meta.ordering or ()\n+        except (AttributeError, TypeError):\n+            return ()\n \n     def choices(self, changelist):\n         yield {\n@@ -419,7 +427,12 @@ class RelatedOnlyFieldListFilter(RelatedFieldListFilter):\n         super().__init__(field, request, params, model, model_admin, field_path)\n \n     def field_choices(self, field, request, model_admin):\n-        return field.get_choices(include_blank=False, limit_choices_to=self.limit_choices_to)\n+        # Use the same ordering logic as the parent class\n+        try:\n+            ordering = self.field_admin_ordering(field, request, model_admin)\n+        except (AttributeError, TypeError):\n+            ordering = ()\n+        return field.get_choices(include_blank=False, limit_choices_to=self.limit_choices_to, ordering=ordering)",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-10973",
    "model_patch": "diff --git a/django/db/backends/postgresql/client.py\n+++ b/django/db/backends/postgresql/client.py\n@@ -1,4 +1,5 @@\n import os\n+import subprocess\n from django.db.backends.base.client import BaseDatabaseClient\n \n \n@@ -37,7 +38,14 @@ class DatabaseClient(BaseDatabaseClient):\n         args = [self.executable_name, *self.settings_to_cmd_args_env(parameters)[0]]\n         sigint_handler = signal.signal(signal.SIGINT, signal.SIG_IGN)\n         try:\n-            subprocess.call(args, env=env)\n+            # Build environment with PGPASSWORD for secure authentication\n+            shell_env = dict(os.environ)\n+            shell_env.update(env)\n+            \n+            if 'password' in parameters and parameters['password']:\n+                shell_env['PGPASSWORD'] = parameters['password']\n+            \n+            subprocess.run(args, env=shell_env, check=False)\n         finally:\n             signal.signal(signal.SIGINT, sigint_handler)",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-11095",
    "model_patch": "diff --git a/django/contrib/admin/options.py\n+++ b/django/contrib/admin/options.py\n@@ -1077,7 +1077,7 @@ class ModelAdmin(BaseModelAdmin):\n     def get_inline_instances(self, request, obj=None):\n         inline_instances = []\n-        for inline_class in self.inlines:\n+        for inline_class in self.get_inlines(request, obj):\n             inline = inline_class(self.model, self.admin_site)\n             if request:\n                 if not (inline.has_view_permission(request, obj) or\n@@ -1087,6 +1087,14 @@ class ModelAdmin(BaseModelAdmin):\n                     continue\n             inline_instances.append(inline)\n         return inline_instances\n+\n+    def get_inlines(self, request, obj=None):\n+        \"\"\"\n+        Hook for specifying custom inlines based on the request or object.\n+        Override this method to customize which inlines are displayed\n+        based on the current request or the object being edited.\n+        \"\"\"\n+        return self.inlines",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-11211",
    "model_patch": "diff --git a/django/contrib/contenttypes/fields.py\n+++ b/django/contrib/contenttypes/fields.py\n@@ -472,6 +472,11 @@ class GenericForeignKey(FieldCacheMixin):\n         for ct_id, fkey in ct_attname_to_model.items():\n+            # Convert object_id values to match the target model's primary key type\n+            target_model = ct_id_to_model[ct_id]\n+            pk_field = target_model._meta.pk\n+            fkey = [pk_field.to_python(obj_id) for obj_id in fkey if obj_id is not None]\n+            \n             content_type_queries[ct_id] = (\n-                ct_id_to_model[ct_id]._base_manager.filter(\n+                target_model._base_manager.filter(\n                     pk__in=fkey\n                 ),\n                 fkey",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "astropy__astropy-7336",
    "model_patch": "diff --git a/astropy/units/decorators.py\n+++ b/astropy/units/decorators.py\n@@ -222,7 +222,11 @@ def quantity_input(**kwargs):\n             # Call the original function with any quantity arguments converted\n             # to the desired unit.\n             return_ = func(*func_args, **func_kwargs)\n-            return return_.to(wrapped_signature.return_annotation)\n+            # Skip conversion for None return types (constructors) and None values\n+            if (wrapped_signature.return_annotation not in (inspect.Signature.empty, type(None), None) and\n+                return_ is not None):\n+                return return_.to(wrapped_signature.return_annotation)\n+            return return_\n \n         return wrapper",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "astropy__astropy-14096",
    "model_patch": "diff --git a/astropy/coordinates/sky_coordinate.py\n+++ b/astropy/coordinates/sky_coordinate.py\n@@ -587,6 +587,7 @@ class SkyCoord(ShapedLikeNDArray):\n \n     def __getattr__(self, attr):\n         # See if we can get the attribute from the frame\n+        import sys\n         # Only do this if we're not already getting from the frame.\n         if not _currently_getting_frame_attr:\n             _currently_getting_frame_attr = True\n@@ -597,6 +598,15 @@ class SkyCoord(ShapedLikeNDArray):\n             finally:\n                 _currently_getting_frame_attr = False\n \n+        # Check if we're handling an AttributeError that came from a property\n+        # by looking at the current exception context\n+        current_exception = sys.exc_info()[1]\n+        if (isinstance(current_exception, AttributeError) and \n+            current_exception.args and \n+            attr not in str(current_exception.args[0])):\n+            # The AttributeError is about a different attribute (from within a property)\n+            # Re-raise the original exception\n+            raise\n         raise AttributeError(\"'{0}' object has no attribute '{1}'\"\n                              .format(self.__class__.__name__, attr))",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-11163",
    "model_patch": "diff --git a/django/forms/models.py\n+++ b/django/forms/models.py\n@@ -75,7 +75,8 @@ def model_to_dict(instance, fields=None, exclude=None):\n     Return a dict containing the data in ``instance`` suitable for passing as\n     a Form's ``initial`` keyword argument.\n \n-    ``fields`` is an optional list of field names. If provided, return only the\n+    ``fields`` is an optional list of field names. If provided, return only the \n+    named fields. If an empty list is provided, return an empty dict.\n     named fields.\n \n     ``exclude`` is an optional list of field names. If provided, exclude the\n@@ -89,7 +90,7 @@ def model_to_dict(instance, fields=None, exclude=None):\n     opts = instance._meta\n     data = {}\n     for f in chain(opts.concrete_fields, opts.private_fields, opts.many_to_many):\n-        if fields and f.name not in fields:\n+        if fields is not None and f.name not in fields:\n             continue\n         if exclude and f.name in exclude:\n             continue",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "astropy__astropy-8872",
    "model_patch": "diff --git a/astropy/units/quantity.py\n+++ b/astropy/units/quantity.py\n@@ -285,6 +285,14 @@ class Quantity(np.ndarray):\n         if unit is not None:\n             unit = Unit(unit)\n \n+        # Preserve dtype of numpy scalars when dtype is None to prevent\n+        # unwanted promotion (e.g., float16 -> float64)\n+        if (dtype is None and np.isscalar(value) and \n+            hasattr(value, 'dtype') and \n+            isinstance(value, (np.floating, np.integer, np.complexfloating))):\n+            # Preserve the original numpy scalar dtype\n+            dtype = value.dtype\n+\n         if value is None:\n             # We allow dimensionless quantities to be initialized with None.\n             if unit is not None and not unit.is_equivalent(dimensionless_unscaled):",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "astropy__astropy-8707",
    "model_patch": "diff --git a/astropy/io/fits/header.py\n+++ b/astropy/io/fits/header.py\n@@ -210,6 +210,9 @@ class Header:\n     @classmethod\n     def fromstring(cls, data, sep=''):\n         \"\"\"\n+        # Convert bytes to string if necessary\n+        if isinstance(data, bytes):\n+            data = data.decode('ascii')\n         cards = []\n         for line in data.split(sep or '\\n'):\n             if line:\ndiff --git a/astropy/io/fits/card.py\n+++ b/astropy/io/fits/card.py\n@@ -150,6 +150,9 @@ class Card:\n     @classmethod\n     def fromstring(cls, image):\n         \"\"\"\n+        # Convert bytes to string if necessary\n+        if isinstance(image, bytes):\n+            image = image.decode('ascii')\n         return cls._from_string(image)",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-11149",
    "model_patch": "diff --git a/django/contrib/admin/options.py\n+++ b/django/contrib/admin/options.py\n@@ -1810,7 +1810,12 @@ class InlineModelAdmin(BaseModelAdmin):\n     def has_add_permission(self, request, obj=None):\n         opts = self.opts\n         codename = get_permission_codename('add', opts)\n-        return request.user.has_perm('%s.%s' % (opts.app_label, codename))\n+        has_add = request.user.has_perm('%s.%s' % (opts.app_label, codename))\n+        # For auto-created models (like ManyToMany through models),\n+        # require either add OR change permission\n+        if opts.auto_created and not has_add:\n+            change_codename = get_permission_codename('change', opts)\n+            return request.user.has_perm('%s.%s' % (opts.app_label, change_codename))\n+        return has_add\n \n     def has_change_permission(self, request, obj=None):\n         opts = self.opts\n@@ -1820,7 +1825,12 @@ class InlineModelAdmin(BaseModelAdmin):\n             return request.user.has_perm(\n                 '%s.%s' % (opts.app_label, codename), obj\n             )\n-        return request.user.has_perm('%s.%s' % (opts.app_label, codename))\n+        has_change = request.user.has_perm('%s.%s' % (opts.app_label, codename))\n+        # For auto-created models (like ManyToMany through models),\n+        # require either change OR add permission\n+        if opts.auto_created and not has_change:\n+            add_codename = get_permission_codename('add', opts)\n+            return request.user.has_perm('%s.%s' % (opts.app_label, add_codename))\n+        return has_change",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "astropy__astropy-7166",
    "model_patch": "diff --git a/astropy/utils/misc.py\n+++ b/astropy/utils/misc.py\n@@ -250,7 +250,8 @@ class InheritDocstrings(type):\n         for key, val in dct.items():\n-            if (inspect.isfunction(val) and\n+            if ((inspect.isfunction(val) or isinstance(val, property)) and\n                 getattr(val, '__doc__', None) is None):\n                 for base in bases:\n                     if hasattr(base, key):\n                         base_func = getattr(base, key)\n-                        if inspect.isfunction(base_func) and base_func.__doc__:\n-                            val.__doc__ = base_func.__doc__\n-                            break\n+                        if base_func.__doc__:\n+                            if isinstance(val, property) and isinstance(base_func, property):\n+                                dct[key] = property(val.fget, val.fset, val.fdel, base_func.__doc__)\n+                                break\n+                            elif inspect.isfunction(val) and inspect.isfunction(base_func):\n+                                val.__doc__ = base_func.__doc__\n+                                break",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "astropy__astropy-13977",
    "model_patch": "diff --git a/astropy/units/quantity.py\n+++ b/astropy/units/quantity.py\n@@ -1,6 +1,7 @@\n # Licensed under a 3-clause BSD style license - see LICENSE.rst\n \n import numpy as np\n+from .core import UnitConversionError\n \n from .core import (\n     Unit, UnitBase, dimensionless_unscaled, get_current_unit_registry)\n@@ -614,9 +615,13 @@ class Quantity(np.ndarray):\n         # Convert inputs to arrays and extract units.\n         arrays = []\n         units = []\n-        for input_ in inputs:\n-            arrays.append(converter(input_) if converter else input_)\n-            units.append(getattr(input_, 'unit', dimensionless_unscaled))\n+        try:\n+            for input_ in inputs:\n+                arrays.append(converter(input_) if converter else input_)\n+                units.append(getattr(input_, 'unit', dimensionless_unscaled))\n+        except (UnitConversionError, ValueError, TypeError):\n+            # Cannot handle this input, let NumPy try reflected operations\n+            return NotImplemented\n \n         # Determine the output unit.",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-11239",
    "model_patch": "diff --git a/django/db/backends/postgresql/client.py\n+++ b/django/db/backends/postgresql/client.py\n@@ -45,6 +45,8 @@ class DatabaseClient(BaseDatabaseClient):\n             env['PGSSLMODE'] = options['sslmode']\n         if 'sslrootcert' in options:\n             env['PGSSLROOTCERT'] = options['sslrootcert']\n+        if 'sslcert' in options:\n+            env['PGSSLCERT'] = options['sslcert']\n+        if 'sslkey' in options:\n+            env['PGSSLKEY'] = options['sslkey']\n \n         subprocess.run(args, env=env, check=True)",
    "model_name_or_path": "Chatgpt"
  }
]