AI Usage#
Core Principle for the Use of AI in Contributions#
Contributing to the SunPy project requires human judgment, contextual understanding, and familiarity with the SunPy project’s structure and goals. It is not suitable for automatic processing by AI tools; please refrain from submitting issues or pull requests generated by fully-automated tools. The SunPy project will accept the responsible use of AI-assisted tools by both contributors and maintainers. These tools can be valuable aids for exploration, debugging, documentation, and code improvement. However, AI cannot replace human effort and intellect, and its use must not shift disproportionate effort or responsibility onto the project. The core principle can be summarised as:
Any contribution should be worth more to the project than the effort required to review it.
Non-Compliance#
Contributions which that appear to violate this principle can be summarily closed or removed.
Repeated non-compliance may be considered a code of conduct violation.
Responsible Uses of AI#
Contributions should be prepared with the expectation that they must be worth more to the project than the effort required to review. This includes, but is not limited to:
Initial code review and discussion
Follow-up review cycles and revisions
Testing, validation, and debugging
Long-term maintenance and user support
AI assistance does not reduce the expected level of contributor effort. Submissions that require maintainers to spend significant time understanding, validating, or correcting work that the contributor has not fully reviewed or understood place an unfair burden on already scarce project resources. Regardless of whether AI tools are used, the human contributor remains the clear owner of their contribution and is responsible for:
Understanding and being able to explain all changes
Ensuring, to the best of their ability and knowledge, correctness, scientific validity, and reproducibility
Following sunpy’s Coding Standards, Documentation style, and design principles
Addressing review feedback in a timely and constructive manner
Ensuring copyrighted material does not appear in their contributions
Maintainers may also use AI tools to assist with review, triage, or debugging, but this does not replace the need for human judgment, project knowledge, and accountability.
Examples of appropriate use:#
A contributor uses AI to help diagnose a failing test or isolate a bug in a pull request they authored and understand
A contributor uses AI to help improve or reword PR summaries and or comments they have written
AI is used to suggest improvements to documentation, error messages, or small refactors, followed by careful human verification.
Maintainers use AI tools to summarize discussions, explore alternative implementations, or assist in reviewing well-scoped, clearly explained changes.
Examples of inappropriate use:#
Generating an entire pull request directly from an issue description and submitting it with minimal human understanding or validation.
Pasting AI generated text in the description of issues, PRs or in comments.
Using AI-generated changes as a substitute for learning the codebase or engaging with review feedback.
Expecting maintainers to serve as the primary filter for correctness, design decisions, or AI hallucinations.
Passing off AI generated content as created by a human
Transparency and Sustainable Collaboration#
Contributors should be transparent about AI assistance and be prepared to explain how AI tools were used and how the resulting work was validated. Transparency supports trust, effective collaboration, and sustainable maintenance. The intent of this policy is not to discourage AI use, but to ensure that all contributions, AI-assisted or not, respect the time, expertise, and long-term responsibilities of both contributors and maintainers.
This document may evolve over time as generative AI tooling and community expectations change. Contributors should refer to the latest version when preparing contributions. This document was inspired by many other open source projects AI usage polices and documents such as scikit-learn and LLVM.