Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Implement the chi function in sage.crypto.sboxes #39322

Merged
merged 6 commits into from
Jan 18, 2025

Conversation

rusydi
Copy link
Contributor

@rusydi rusydi commented Jan 12, 2025

Fix #39321

📝 Checklist

  • The title is concise and informative.
  • The description explains in detail what this PR is about.
  • I have linked a relevant issue or discussion.
  • I have created tests covering the changes.
  • I have updated the documentation and checked the documentation preview.

⌛ Dependencies

Copy link

github-actions bot commented Jan 12, 2025

Documentation preview for this PR (built with commit 03bb288; changes) is ready! 🎉
This preview will update shortly after each push to this PR.

@kwankyu
Copy link
Collaborator

kwankyu commented Jan 13, 2025

PEP8

 
 def chi(n):
     r"""
-    Return the `\chi` function defined over `\GF{2^n}` used in the nonlinear layer of Keccak and Xoodyak.
+    Return the `\chi` function defined over `\GF{2^n}` used in the nonlinear
+    layer of Keccak and Xoodyak.
 
     INPUT:
...
         sage: chi(4).is_permutation()
         False
         sage: chi(5)
-        (0, 9, 18, 11, 5, 12, 22, 15, 10, 3, 24, 1, 13, 4, 30, 7, 20, 21, 6, 23, 17, 16, 2, 19, 26, 27, 8, 25, 29, 28, 14, 31)
+        (0, 9, 18, 11, 5, 12, 22, 15, 10, 3, 24, 1, 13, 4, 30, 7, 20, 21, 6,
+        23, 17, 16, 2, 19, 26, 27, 8, 25, 29, 28, 14, 31)
     """
     table = [0]*(1 << n)
 

Copy link
Collaborator

@kwankyu kwankyu left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thanks. LGTM.

@rusydi
Copy link
Contributor Author

rusydi commented Jan 13, 2025

Thanks. LGTM.

Thanks for reviewing.

vbraun pushed a commit to vbraun/sage that referenced this pull request Jan 16, 2025
sagemathgh-39322: Implement the chi function in sage.crypto.sboxes
    
<!-- ^ Please provide a concise and informative title. -->
<!-- ^ Don't put issue numbers in the title, do this in the PR
description below. -->
<!-- ^ For example, instead of "Fixes sagemath#12345" use "Introduce new method
to calculate 1 + 2". -->
<!-- v Describe your changes below in detail. -->
<!-- v Why is this change required? What problem does it solve? -->
<!-- v If this PR resolves an open issue, please link to it here. For
example, "Fixes sagemath#12345". -->

Fix sagemath#39321

### 📝 Checklist

<!-- Put an `x` in all the boxes that apply. -->

- [x] The title is concise and informative.
- [x] The description explains in detail what this PR is about.
- [x] I have linked a relevant issue or discussion.
- [x] I have created tests covering the changes.
- [x] I have updated the documentation and checked the documentation
preview.

### ⌛ Dependencies

<!-- List all open PRs that this PR logically depends on. For example,
-->
<!-- - sagemath#12345: short description why this is a dependency -->
<!-- - sagemath#34567: ... -->
    
URL: sagemath#39322
Reported by: Rusydi H. Makarim
Reviewer(s): Kwankyu Lee, Rusydi H. Makarim
@vbraun vbraun merged commit d09850e into sagemath:develop Jan 18, 2025
22 of 23 checks passed
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

Implement the χ function used in the nonlinear part of SHA-3 and Xoodyak
3 participants