passagemath-modules 10.6.31rc3__cp314-cp314-manylinux_2_27_x86_64.manylinux_2_28_x86_64.whl
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Potentially problematic release.
This version of passagemath-modules might be problematic. Click here for more details.
- passagemath_modules-10.6.31rc3.dist-info/METADATA +281 -0
- passagemath_modules-10.6.31rc3.dist-info/RECORD +807 -0
- passagemath_modules-10.6.31rc3.dist-info/WHEEL +6 -0
- passagemath_modules-10.6.31rc3.dist-info/top_level.txt +2 -0
- passagemath_modules.libs/libgfortran-83c28eba.so.5.0.0 +0 -0
- passagemath_modules.libs/libgmp-6e109695.so.10.5.0 +0 -0
- passagemath_modules.libs/libgsl-cda90e79.so.28.0.0 +0 -0
- passagemath_modules.libs/libmpc-7f678fcf.so.3.3.1 +0 -0
- passagemath_modules.libs/libmpfr-82690d50.so.6.2.1 +0 -0
- passagemath_modules.libs/libopenblasp-r0-6dcb67f9.3.29.so +0 -0
- passagemath_modules.libs/libquadmath-2284e583.so.0.0.0 +0 -0
- sage/algebras/all__sagemath_modules.py +20 -0
- sage/algebras/catalog.py +148 -0
- sage/algebras/clifford_algebra.py +3107 -0
- sage/algebras/clifford_algebra_element.cpython-314-x86_64-linux-gnu.so +0 -0
- sage/algebras/clifford_algebra_element.pxd +16 -0
- sage/algebras/clifford_algebra_element.pyx +997 -0
- sage/algebras/commutative_dga.py +4252 -0
- sage/algebras/exterior_algebra_groebner.cpython-314-x86_64-linux-gnu.so +0 -0
- sage/algebras/exterior_algebra_groebner.pxd +55 -0
- sage/algebras/exterior_algebra_groebner.pyx +727 -0
- sage/algebras/finite_dimensional_algebras/all.py +2 -0
- sage/algebras/finite_dimensional_algebras/finite_dimensional_algebra.py +1029 -0
- sage/algebras/finite_dimensional_algebras/finite_dimensional_algebra_element.cpython-314-x86_64-linux-gnu.so +0 -0
- sage/algebras/finite_dimensional_algebras/finite_dimensional_algebra_element.pxd +12 -0
- sage/algebras/finite_dimensional_algebras/finite_dimensional_algebra_element.pyx +706 -0
- sage/algebras/finite_dimensional_algebras/finite_dimensional_algebra_ideal.py +196 -0
- sage/algebras/finite_dimensional_algebras/finite_dimensional_algebra_morphism.py +255 -0
- sage/algebras/finite_gca.py +528 -0
- sage/algebras/group_algebra.py +232 -0
- sage/algebras/lie_algebras/abelian.py +197 -0
- sage/algebras/lie_algebras/affine_lie_algebra.py +1213 -0
- sage/algebras/lie_algebras/all.py +25 -0
- sage/algebras/lie_algebras/all__sagemath_modules.py +1 -0
- sage/algebras/lie_algebras/bch.py +177 -0
- sage/algebras/lie_algebras/bgg_dual_module.py +1184 -0
- sage/algebras/lie_algebras/bgg_resolution.py +232 -0
- sage/algebras/lie_algebras/center_uea.py +767 -0
- sage/algebras/lie_algebras/classical_lie_algebra.py +2516 -0
- sage/algebras/lie_algebras/examples.py +683 -0
- sage/algebras/lie_algebras/free_lie_algebra.py +973 -0
- sage/algebras/lie_algebras/heisenberg.py +820 -0
- sage/algebras/lie_algebras/lie_algebra.py +1562 -0
- sage/algebras/lie_algebras/lie_algebra_element.cpython-314-x86_64-linux-gnu.so +0 -0
- sage/algebras/lie_algebras/lie_algebra_element.pxd +68 -0
- sage/algebras/lie_algebras/lie_algebra_element.pyx +2122 -0
- sage/algebras/lie_algebras/morphism.py +661 -0
- sage/algebras/lie_algebras/nilpotent_lie_algebra.py +457 -0
- sage/algebras/lie_algebras/onsager.py +1324 -0
- sage/algebras/lie_algebras/poincare_birkhoff_witt.py +816 -0
- sage/algebras/lie_algebras/quotient.py +462 -0
- sage/algebras/lie_algebras/rank_two_heisenberg_virasoro.py +355 -0
- sage/algebras/lie_algebras/representation.py +1040 -0
- sage/algebras/lie_algebras/structure_coefficients.py +459 -0
- sage/algebras/lie_algebras/subalgebra.py +967 -0
- sage/algebras/lie_algebras/symplectic_derivation.py +289 -0
- sage/algebras/lie_algebras/verma_module.py +1630 -0
- sage/algebras/lie_algebras/virasoro.py +1186 -0
- sage/algebras/octonion_algebra.cpython-314-x86_64-linux-gnu.so +0 -0
- sage/algebras/octonion_algebra.pxd +20 -0
- sage/algebras/octonion_algebra.pyx +987 -0
- sage/algebras/orlik_solomon.py +907 -0
- sage/algebras/orlik_terao.py +779 -0
- sage/algebras/steenrod/all.py +7 -0
- sage/algebras/steenrod/steenrod_algebra.py +4258 -0
- sage/algebras/steenrod/steenrod_algebra_bases.py +1179 -0
- sage/algebras/steenrod/steenrod_algebra_misc.py +1167 -0
- sage/algebras/steenrod/steenrod_algebra_mult.py +954 -0
- sage/algebras/weyl_algebra.py +1126 -0
- sage/all__sagemath_modules.py +62 -0
- sage/calculus/all__sagemath_modules.py +19 -0
- sage/calculus/expr.py +205 -0
- sage/calculus/integration.cpython-314-x86_64-linux-gnu.so +0 -0
- sage/calculus/integration.pyx +698 -0
- sage/calculus/interpolation.cpython-314-x86_64-linux-gnu.so +0 -0
- sage/calculus/interpolation.pxd +13 -0
- sage/calculus/interpolation.pyx +387 -0
- sage/calculus/interpolators.cpython-314-x86_64-linux-gnu.so +0 -0
- sage/calculus/interpolators.pyx +326 -0
- sage/calculus/ode.cpython-314-x86_64-linux-gnu.so +0 -0
- sage/calculus/ode.pxd +5 -0
- sage/calculus/ode.pyx +610 -0
- sage/calculus/riemann.cpython-314-x86_64-linux-gnu.so +0 -0
- sage/calculus/riemann.pyx +1521 -0
- sage/calculus/test_sympy.py +201 -0
- sage/calculus/transforms/all.py +7 -0
- sage/calculus/transforms/dft.py +844 -0
- sage/calculus/transforms/dwt.cpython-314-x86_64-linux-gnu.so +0 -0
- sage/calculus/transforms/dwt.pxd +7 -0
- sage/calculus/transforms/dwt.pyx +160 -0
- sage/calculus/transforms/fft.cpython-314-x86_64-linux-gnu.so +0 -0
- sage/calculus/transforms/fft.pxd +12 -0
- sage/calculus/transforms/fft.pyx +487 -0
- sage/calculus/wester.py +662 -0
- sage/coding/abstract_code.py +1108 -0
- sage/coding/ag_code.py +868 -0
- sage/coding/ag_code_decoders.cpython-314-x86_64-linux-gnu.so +0 -0
- sage/coding/ag_code_decoders.pyx +2639 -0
- sage/coding/all.py +15 -0
- sage/coding/bch_code.py +494 -0
- sage/coding/binary_code.cpython-314-x86_64-linux-gnu.so +0 -0
- sage/coding/binary_code.pxd +124 -0
- sage/coding/binary_code.pyx +4139 -0
- sage/coding/bounds_catalog.py +43 -0
- sage/coding/channel.py +819 -0
- sage/coding/channels_catalog.py +29 -0
- sage/coding/code_bounds.py +755 -0
- sage/coding/code_constructions.py +804 -0
- sage/coding/codes_catalog.py +111 -0
- sage/coding/cyclic_code.py +1329 -0
- sage/coding/databases.py +316 -0
- sage/coding/decoder.py +373 -0
- sage/coding/decoders_catalog.py +88 -0
- sage/coding/delsarte_bounds.py +709 -0
- sage/coding/encoder.py +390 -0
- sage/coding/encoders_catalog.py +64 -0
- sage/coding/extended_code.py +468 -0
- sage/coding/gabidulin_code.py +1058 -0
- sage/coding/golay_code.py +404 -0
- sage/coding/goppa_code.py +441 -0
- sage/coding/grs_code.py +2371 -0
- sage/coding/guava.py +107 -0
- sage/coding/guruswami_sudan/all.py +1 -0
- sage/coding/guruswami_sudan/gs_decoder.py +897 -0
- sage/coding/guruswami_sudan/interpolation.py +409 -0
- sage/coding/guruswami_sudan/utils.py +176 -0
- sage/coding/hamming_code.py +176 -0
- sage/coding/information_set_decoder.py +1032 -0
- sage/coding/kasami_codes.cpython-314-x86_64-linux-gnu.so +0 -0
- sage/coding/kasami_codes.pyx +351 -0
- sage/coding/linear_code.py +3067 -0
- sage/coding/linear_code_no_metric.py +1354 -0
- sage/coding/linear_rank_metric.py +961 -0
- sage/coding/parity_check_code.py +353 -0
- sage/coding/punctured_code.py +719 -0
- sage/coding/reed_muller_code.py +999 -0
- sage/coding/self_dual_codes.py +942 -0
- sage/coding/source_coding/all.py +2 -0
- sage/coding/source_coding/huffman.py +553 -0
- sage/coding/subfield_subcode.py +423 -0
- sage/coding/two_weight_db.py +399 -0
- sage/combinat/all__sagemath_modules.py +7 -0
- sage/combinat/cartesian_product.py +347 -0
- sage/combinat/family.py +11 -0
- sage/combinat/free_module.py +1977 -0
- sage/combinat/root_system/all.py +147 -0
- sage/combinat/root_system/ambient_space.py +527 -0
- sage/combinat/root_system/associahedron.py +471 -0
- sage/combinat/root_system/braid_move_calculator.py +143 -0
- sage/combinat/root_system/braid_orbit.cpython-314-x86_64-linux-gnu.so +0 -0
- sage/combinat/root_system/braid_orbit.pyx +144 -0
- sage/combinat/root_system/branching_rules.py +2301 -0
- sage/combinat/root_system/cartan_matrix.py +1245 -0
- sage/combinat/root_system/cartan_type.py +3069 -0
- sage/combinat/root_system/coxeter_group.py +162 -0
- sage/combinat/root_system/coxeter_matrix.py +1261 -0
- sage/combinat/root_system/coxeter_type.py +681 -0
- sage/combinat/root_system/dynkin_diagram.py +900 -0
- sage/combinat/root_system/extended_affine_weyl_group.py +2993 -0
- sage/combinat/root_system/fundamental_group.py +795 -0
- sage/combinat/root_system/hecke_algebra_representation.py +1203 -0
- sage/combinat/root_system/integrable_representations.py +1227 -0
- sage/combinat/root_system/non_symmetric_macdonald_polynomials.py +1965 -0
- sage/combinat/root_system/pieri_factors.py +1147 -0
- sage/combinat/root_system/plot.py +1615 -0
- sage/combinat/root_system/root_lattice_realization_algebras.py +1214 -0
- sage/combinat/root_system/root_lattice_realizations.py +4628 -0
- sage/combinat/root_system/root_space.py +487 -0
- sage/combinat/root_system/root_system.py +882 -0
- sage/combinat/root_system/type_A.py +348 -0
- sage/combinat/root_system/type_A_affine.py +227 -0
- sage/combinat/root_system/type_A_infinity.py +241 -0
- sage/combinat/root_system/type_B.py +347 -0
- sage/combinat/root_system/type_BC_affine.py +287 -0
- sage/combinat/root_system/type_B_affine.py +216 -0
- sage/combinat/root_system/type_C.py +317 -0
- sage/combinat/root_system/type_C_affine.py +188 -0
- sage/combinat/root_system/type_D.py +357 -0
- sage/combinat/root_system/type_D_affine.py +208 -0
- sage/combinat/root_system/type_E.py +641 -0
- sage/combinat/root_system/type_E_affine.py +231 -0
- sage/combinat/root_system/type_F.py +387 -0
- sage/combinat/root_system/type_F_affine.py +137 -0
- sage/combinat/root_system/type_G.py +293 -0
- sage/combinat/root_system/type_G_affine.py +132 -0
- sage/combinat/root_system/type_H.py +105 -0
- sage/combinat/root_system/type_I.py +110 -0
- sage/combinat/root_system/type_Q.py +150 -0
- sage/combinat/root_system/type_affine.py +509 -0
- sage/combinat/root_system/type_dual.py +704 -0
- sage/combinat/root_system/type_folded.py +301 -0
- sage/combinat/root_system/type_marked.py +748 -0
- sage/combinat/root_system/type_reducible.py +601 -0
- sage/combinat/root_system/type_relabel.py +730 -0
- sage/combinat/root_system/type_super_A.py +837 -0
- sage/combinat/root_system/weight_lattice_realizations.py +1188 -0
- sage/combinat/root_system/weight_space.py +639 -0
- sage/combinat/root_system/weyl_characters.py +2238 -0
- sage/crypto/__init__.py +4 -0
- sage/crypto/all.py +28 -0
- sage/crypto/block_cipher/all.py +7 -0
- sage/crypto/block_cipher/des.py +1065 -0
- sage/crypto/block_cipher/miniaes.py +2171 -0
- sage/crypto/block_cipher/present.py +909 -0
- sage/crypto/block_cipher/sdes.py +1527 -0
- sage/crypto/boolean_function.cpython-314-x86_64-linux-gnu.so +0 -0
- sage/crypto/boolean_function.pxd +10 -0
- sage/crypto/boolean_function.pyx +1487 -0
- sage/crypto/cipher.py +78 -0
- sage/crypto/classical.py +3668 -0
- sage/crypto/classical_cipher.py +569 -0
- sage/crypto/cryptosystem.py +387 -0
- sage/crypto/key_exchange/all.py +7 -0
- sage/crypto/key_exchange/catalog.py +24 -0
- sage/crypto/key_exchange/diffie_hellman.py +323 -0
- sage/crypto/key_exchange/key_exchange_scheme.py +107 -0
- sage/crypto/lattice.py +312 -0
- sage/crypto/lfsr.py +295 -0
- sage/crypto/lwe.py +840 -0
- sage/crypto/mq/__init__.py +4 -0
- sage/crypto/mq/mpolynomialsystemgenerator.py +204 -0
- sage/crypto/mq/rijndael_gf.py +2345 -0
- sage/crypto/mq/sbox.py +7 -0
- sage/crypto/mq/sr.py +3344 -0
- sage/crypto/public_key/all.py +5 -0
- sage/crypto/public_key/blum_goldwasser.py +776 -0
- sage/crypto/sbox.cpython-314-x86_64-linux-gnu.so +0 -0
- sage/crypto/sbox.pyx +2090 -0
- sage/crypto/sboxes.py +2090 -0
- sage/crypto/stream.py +390 -0
- sage/crypto/stream_cipher.py +297 -0
- sage/crypto/util.py +519 -0
- sage/ext/all__sagemath_modules.py +1 -0
- sage/ext/interpreters/__init__.py +1 -0
- sage/ext/interpreters/all__sagemath_modules.py +2 -0
- sage/ext/interpreters/wrapper_cc.cpython-314-x86_64-linux-gnu.so +0 -0
- sage/ext/interpreters/wrapper_cc.pxd +30 -0
- sage/ext/interpreters/wrapper_cc.pyx +252 -0
- sage/ext/interpreters/wrapper_cdf.cpython-314-x86_64-linux-gnu.so +0 -0
- sage/ext/interpreters/wrapper_cdf.pxd +26 -0
- sage/ext/interpreters/wrapper_cdf.pyx +245 -0
- sage/ext/interpreters/wrapper_rdf.cpython-314-x86_64-linux-gnu.so +0 -0
- sage/ext/interpreters/wrapper_rdf.pxd +23 -0
- sage/ext/interpreters/wrapper_rdf.pyx +221 -0
- sage/ext/interpreters/wrapper_rr.cpython-314-x86_64-linux-gnu.so +0 -0
- sage/ext/interpreters/wrapper_rr.pxd +28 -0
- sage/ext/interpreters/wrapper_rr.pyx +335 -0
- sage/geometry/all__sagemath_modules.py +5 -0
- sage/geometry/toric_lattice.py +1745 -0
- sage/geometry/toric_lattice_element.cpython-314-x86_64-linux-gnu.so +0 -0
- sage/geometry/toric_lattice_element.pyx +432 -0
- sage/groups/abelian_gps/abelian_group.py +1925 -0
- sage/groups/abelian_gps/abelian_group_element.py +164 -0
- sage/groups/abelian_gps/all__sagemath_modules.py +5 -0
- sage/groups/abelian_gps/dual_abelian_group.py +421 -0
- sage/groups/abelian_gps/dual_abelian_group_element.py +179 -0
- sage/groups/abelian_gps/element_base.py +341 -0
- sage/groups/abelian_gps/values.py +488 -0
- sage/groups/additive_abelian/additive_abelian_group.py +476 -0
- sage/groups/additive_abelian/additive_abelian_wrapper.py +857 -0
- sage/groups/additive_abelian/all.py +4 -0
- sage/groups/additive_abelian/qmodnz.py +231 -0
- sage/groups/additive_abelian/qmodnz_element.py +349 -0
- sage/groups/affine_gps/affine_group.py +535 -0
- sage/groups/affine_gps/all.py +1 -0
- sage/groups/affine_gps/catalog.py +17 -0
- sage/groups/affine_gps/euclidean_group.py +246 -0
- sage/groups/affine_gps/group_element.py +562 -0
- sage/groups/all__sagemath_modules.py +12 -0
- sage/groups/galois_group.py +479 -0
- sage/groups/matrix_gps/all.py +4 -0
- sage/groups/matrix_gps/all__sagemath_modules.py +13 -0
- sage/groups/matrix_gps/catalog.py +26 -0
- sage/groups/matrix_gps/coxeter_group.py +927 -0
- sage/groups/matrix_gps/finitely_generated.py +487 -0
- sage/groups/matrix_gps/group_element.cpython-314-x86_64-linux-gnu.so +0 -0
- sage/groups/matrix_gps/group_element.pxd +11 -0
- sage/groups/matrix_gps/group_element.pyx +431 -0
- sage/groups/matrix_gps/linear.py +440 -0
- sage/groups/matrix_gps/matrix_group.py +617 -0
- sage/groups/matrix_gps/named_group.py +296 -0
- sage/groups/matrix_gps/orthogonal.py +544 -0
- sage/groups/matrix_gps/symplectic.py +251 -0
- sage/groups/matrix_gps/unitary.py +436 -0
- sage/groups/misc_gps/all__sagemath_modules.py +1 -0
- sage/groups/misc_gps/argument_groups.py +1905 -0
- sage/groups/misc_gps/imaginary_groups.py +479 -0
- sage/groups/perm_gps/all__sagemath_modules.py +1 -0
- sage/groups/perm_gps/partn_ref/all__sagemath_modules.py +1 -0
- sage/groups/perm_gps/partn_ref/refinement_binary.cpython-314-x86_64-linux-gnu.so +0 -0
- sage/groups/perm_gps/partn_ref/refinement_binary.pxd +41 -0
- sage/groups/perm_gps/partn_ref/refinement_binary.pyx +1167 -0
- sage/groups/perm_gps/partn_ref/refinement_matrices.cpython-314-x86_64-linux-gnu.so +0 -0
- sage/groups/perm_gps/partn_ref/refinement_matrices.pxd +31 -0
- sage/groups/perm_gps/partn_ref/refinement_matrices.pyx +385 -0
- sage/homology/algebraic_topological_model.py +595 -0
- sage/homology/all.py +2 -0
- sage/homology/all__sagemath_modules.py +8 -0
- sage/homology/chain_complex.py +2148 -0
- sage/homology/chain_complex_homspace.py +165 -0
- sage/homology/chain_complex_morphism.py +629 -0
- sage/homology/chain_homotopy.py +604 -0
- sage/homology/chains.py +653 -0
- sage/homology/free_resolution.py +923 -0
- sage/homology/graded_resolution.py +567 -0
- sage/homology/hochschild_complex.py +756 -0
- sage/homology/homology_group.py +188 -0
- sage/homology/homology_morphism.py +422 -0
- sage/homology/homology_vector_space_with_basis.py +1454 -0
- sage/homology/koszul_complex.py +169 -0
- sage/homology/matrix_utils.py +205 -0
- sage/libs/all__sagemath_modules.py +1 -0
- sage/libs/gsl/__init__.py +1 -0
- sage/libs/gsl/airy.pxd +56 -0
- sage/libs/gsl/all.pxd +66 -0
- sage/libs/gsl/array.cpython-314-x86_64-linux-gnu.so +0 -0
- sage/libs/gsl/array.pxd +5 -0
- sage/libs/gsl/array.pyx +102 -0
- sage/libs/gsl/bessel.pxd +208 -0
- sage/libs/gsl/blas.pxd +116 -0
- sage/libs/gsl/blas_types.pxd +34 -0
- sage/libs/gsl/block.pxd +52 -0
- sage/libs/gsl/chebyshev.pxd +37 -0
- sage/libs/gsl/clausen.pxd +12 -0
- sage/libs/gsl/combination.pxd +47 -0
- sage/libs/gsl/complex.pxd +151 -0
- sage/libs/gsl/coulomb.pxd +30 -0
- sage/libs/gsl/coupling.pxd +21 -0
- sage/libs/gsl/dawson.pxd +12 -0
- sage/libs/gsl/debye.pxd +24 -0
- sage/libs/gsl/dilog.pxd +14 -0
- sage/libs/gsl/eigen.pxd +46 -0
- sage/libs/gsl/elementary.pxd +12 -0
- sage/libs/gsl/ellint.pxd +48 -0
- sage/libs/gsl/elljac.pxd +8 -0
- sage/libs/gsl/erf.pxd +32 -0
- sage/libs/gsl/errno.pxd +26 -0
- sage/libs/gsl/exp.pxd +44 -0
- sage/libs/gsl/expint.pxd +44 -0
- sage/libs/gsl/fermi_dirac.pxd +44 -0
- sage/libs/gsl/fft.pxd +121 -0
- sage/libs/gsl/fit.pxd +50 -0
- sage/libs/gsl/gamma.pxd +94 -0
- sage/libs/gsl/gegenbauer.pxd +26 -0
- sage/libs/gsl/histogram.pxd +176 -0
- sage/libs/gsl/hyperg.pxd +52 -0
- sage/libs/gsl/integration.pxd +69 -0
- sage/libs/gsl/interp.pxd +109 -0
- sage/libs/gsl/laguerre.pxd +24 -0
- sage/libs/gsl/lambert.pxd +16 -0
- sage/libs/gsl/legendre.pxd +90 -0
- sage/libs/gsl/linalg.pxd +185 -0
- sage/libs/gsl/log.pxd +26 -0
- sage/libs/gsl/math.pxd +43 -0
- sage/libs/gsl/matrix.pxd +143 -0
- sage/libs/gsl/matrix_complex.pxd +130 -0
- sage/libs/gsl/min.pxd +67 -0
- sage/libs/gsl/monte.pxd +56 -0
- sage/libs/gsl/ntuple.pxd +32 -0
- sage/libs/gsl/odeiv.pxd +70 -0
- sage/libs/gsl/permutation.pxd +78 -0
- sage/libs/gsl/poly.pxd +40 -0
- sage/libs/gsl/pow_int.pxd +12 -0
- sage/libs/gsl/psi.pxd +28 -0
- sage/libs/gsl/qrng.pxd +29 -0
- sage/libs/gsl/random.pxd +257 -0
- sage/libs/gsl/rng.pxd +100 -0
- sage/libs/gsl/roots.pxd +72 -0
- sage/libs/gsl/sort.pxd +36 -0
- sage/libs/gsl/statistics.pxd +59 -0
- sage/libs/gsl/sum.pxd +55 -0
- sage/libs/gsl/synchrotron.pxd +16 -0
- sage/libs/gsl/transport.pxd +24 -0
- sage/libs/gsl/trig.pxd +58 -0
- sage/libs/gsl/types.pxd +137 -0
- sage/libs/gsl/vector.pxd +101 -0
- sage/libs/gsl/vector_complex.pxd +83 -0
- sage/libs/gsl/wavelet.pxd +49 -0
- sage/libs/gsl/zeta.pxd +28 -0
- sage/libs/mpc/__init__.pxd +114 -0
- sage/libs/mpc/types.pxd +28 -0
- sage/libs/mpfr/__init__.pxd +299 -0
- sage/libs/mpfr/types.pxd +26 -0
- sage/libs/mpmath/__init__.py +1 -0
- sage/libs/mpmath/all.py +27 -0
- sage/libs/mpmath/all__sagemath_modules.py +1 -0
- sage/libs/mpmath/utils.cpython-314-x86_64-linux-gnu.so +0 -0
- sage/libs/mpmath/utils.pxd +4 -0
- sage/libs/mpmath/utils.pyx +319 -0
- sage/matrix/action.cpython-314-x86_64-linux-gnu.so +0 -0
- sage/matrix/action.pxd +26 -0
- sage/matrix/action.pyx +596 -0
- sage/matrix/all.py +9 -0
- sage/matrix/args.cpython-314-x86_64-linux-gnu.so +0 -0
- sage/matrix/args.pxd +144 -0
- sage/matrix/args.pyx +1668 -0
- sage/matrix/benchmark.py +1258 -0
- sage/matrix/berlekamp_massey.py +95 -0
- sage/matrix/compute_J_ideal.py +926 -0
- sage/matrix/constructor.cpython-314-x86_64-linux-gnu.so +0 -0
- sage/matrix/constructor.pyx +750 -0
- sage/matrix/docs.py +430 -0
- sage/matrix/echelon_matrix.cpython-314-x86_64-linux-gnu.so +0 -0
- sage/matrix/echelon_matrix.pyx +155 -0
- sage/matrix/matrix.pxd +2 -0
- sage/matrix/matrix0.cpython-314-x86_64-linux-gnu.so +0 -0
- sage/matrix/matrix0.pxd +68 -0
- sage/matrix/matrix0.pyx +6324 -0
- sage/matrix/matrix1.cpython-314-x86_64-linux-gnu.so +0 -0
- sage/matrix/matrix1.pxd +8 -0
- sage/matrix/matrix1.pyx +2851 -0
- sage/matrix/matrix2.cpython-314-x86_64-linux-gnu.so +0 -0
- sage/matrix/matrix2.pxd +25 -0
- sage/matrix/matrix2.pyx +20181 -0
- sage/matrix/matrix_cdv.cpython-314-x86_64-linux-gnu.so +0 -0
- sage/matrix/matrix_cdv.pxd +4 -0
- sage/matrix/matrix_cdv.pyx +93 -0
- sage/matrix/matrix_complex_double_dense.cpython-314-x86_64-linux-gnu.so +0 -0
- sage/matrix/matrix_complex_double_dense.pxd +5 -0
- sage/matrix/matrix_complex_double_dense.pyx +98 -0
- sage/matrix/matrix_dense.cpython-314-x86_64-linux-gnu.so +0 -0
- sage/matrix/matrix_dense.pxd +5 -0
- sage/matrix/matrix_dense.pyx +343 -0
- sage/matrix/matrix_domain_dense.pxd +5 -0
- sage/matrix/matrix_domain_sparse.pxd +5 -0
- sage/matrix/matrix_double_dense.cpython-314-x86_64-linux-gnu.so +0 -0
- sage/matrix/matrix_double_dense.pxd +7 -0
- sage/matrix/matrix_double_dense.pyx +3906 -0
- sage/matrix/matrix_double_sparse.cpython-314-x86_64-linux-gnu.so +0 -0
- sage/matrix/matrix_double_sparse.pxd +6 -0
- sage/matrix/matrix_double_sparse.pyx +248 -0
- sage/matrix/matrix_generic_dense.cpython-314-x86_64-linux-gnu.so +0 -0
- sage/matrix/matrix_generic_dense.pxd +7 -0
- sage/matrix/matrix_generic_dense.pyx +354 -0
- sage/matrix/matrix_generic_sparse.cpython-314-x86_64-linux-gnu.so +0 -0
- sage/matrix/matrix_generic_sparse.pxd +7 -0
- sage/matrix/matrix_generic_sparse.pyx +461 -0
- sage/matrix/matrix_laurent_mpolynomial_dense.cpython-314-x86_64-linux-gnu.so +0 -0
- sage/matrix/matrix_laurent_mpolynomial_dense.pxd +5 -0
- sage/matrix/matrix_laurent_mpolynomial_dense.pyx +115 -0
- sage/matrix/matrix_misc.py +313 -0
- sage/matrix/matrix_numpy_dense.cpython-314-x86_64-linux-gnu.so +0 -0
- sage/matrix/matrix_numpy_dense.pxd +14 -0
- sage/matrix/matrix_numpy_dense.pyx +450 -0
- sage/matrix/matrix_numpy_integer_dense.cpython-314-x86_64-linux-gnu.so +0 -0
- sage/matrix/matrix_numpy_integer_dense.pxd +7 -0
- sage/matrix/matrix_numpy_integer_dense.pyx +59 -0
- sage/matrix/matrix_polynomial_dense.cpython-314-x86_64-linux-gnu.so +0 -0
- sage/matrix/matrix_polynomial_dense.pxd +5 -0
- sage/matrix/matrix_polynomial_dense.pyx +5341 -0
- sage/matrix/matrix_real_double_dense.cpython-314-x86_64-linux-gnu.so +0 -0
- sage/matrix/matrix_real_double_dense.pxd +7 -0
- sage/matrix/matrix_real_double_dense.pyx +122 -0
- sage/matrix/matrix_space.py +2848 -0
- sage/matrix/matrix_sparse.cpython-314-x86_64-linux-gnu.so +0 -0
- sage/matrix/matrix_sparse.pxd +5 -0
- sage/matrix/matrix_sparse.pyx +1222 -0
- sage/matrix/matrix_window.cpython-314-x86_64-linux-gnu.so +0 -0
- sage/matrix/matrix_window.pxd +37 -0
- sage/matrix/matrix_window.pyx +242 -0
- sage/matrix/misc_mpfr.cpython-314-x86_64-linux-gnu.so +0 -0
- sage/matrix/misc_mpfr.pyx +80 -0
- sage/matrix/operation_table.py +1182 -0
- sage/matrix/special.py +3666 -0
- sage/matrix/strassen.cpython-314-x86_64-linux-gnu.so +0 -0
- sage/matrix/strassen.pyx +851 -0
- sage/matrix/symplectic_basis.py +541 -0
- sage/matrix/template.pxd +6 -0
- sage/matrix/tests.py +71 -0
- sage/matroids/advanced.py +77 -0
- sage/matroids/all.py +13 -0
- sage/matroids/basis_exchange_matroid.cpython-314-x86_64-linux-gnu.so +0 -0
- sage/matroids/basis_exchange_matroid.pxd +96 -0
- sage/matroids/basis_exchange_matroid.pyx +2344 -0
- sage/matroids/basis_matroid.cpython-314-x86_64-linux-gnu.so +0 -0
- sage/matroids/basis_matroid.pxd +45 -0
- sage/matroids/basis_matroid.pyx +1217 -0
- sage/matroids/catalog.py +44 -0
- sage/matroids/chow_ring.py +473 -0
- sage/matroids/chow_ring_ideal.py +849 -0
- sage/matroids/circuit_closures_matroid.cpython-314-x86_64-linux-gnu.so +0 -0
- sage/matroids/circuit_closures_matroid.pxd +16 -0
- sage/matroids/circuit_closures_matroid.pyx +559 -0
- sage/matroids/circuits_matroid.cpython-314-x86_64-linux-gnu.so +0 -0
- sage/matroids/circuits_matroid.pxd +38 -0
- sage/matroids/circuits_matroid.pyx +947 -0
- sage/matroids/constructor.py +1086 -0
- sage/matroids/database_collections.py +365 -0
- sage/matroids/database_matroids.py +5338 -0
- sage/matroids/dual_matroid.py +583 -0
- sage/matroids/extension.cpython-314-x86_64-linux-gnu.so +0 -0
- sage/matroids/extension.pxd +34 -0
- sage/matroids/extension.pyx +519 -0
- sage/matroids/flats_matroid.cpython-314-x86_64-linux-gnu.so +0 -0
- sage/matroids/flats_matroid.pxd +28 -0
- sage/matroids/flats_matroid.pyx +715 -0
- sage/matroids/gammoid.py +600 -0
- sage/matroids/graphic_matroid.cpython-314-x86_64-linux-gnu.so +0 -0
- sage/matroids/graphic_matroid.pxd +39 -0
- sage/matroids/graphic_matroid.pyx +2024 -0
- sage/matroids/lean_matrix.cpython-314-x86_64-linux-gnu.so +0 -0
- sage/matroids/lean_matrix.pxd +126 -0
- sage/matroids/lean_matrix.pyx +3667 -0
- sage/matroids/linear_matroid.cpython-314-x86_64-linux-gnu.so +0 -0
- sage/matroids/linear_matroid.pxd +180 -0
- sage/matroids/linear_matroid.pyx +6649 -0
- sage/matroids/matroid.cpython-314-x86_64-linux-gnu.so +0 -0
- sage/matroids/matroid.pxd +243 -0
- sage/matroids/matroid.pyx +8759 -0
- sage/matroids/matroids_catalog.py +190 -0
- sage/matroids/matroids_plot_helpers.py +890 -0
- sage/matroids/minor_matroid.py +480 -0
- sage/matroids/minorfix.h +9 -0
- sage/matroids/named_matroids.py +5 -0
- sage/matroids/rank_matroid.py +268 -0
- sage/matroids/set_system.cpython-314-x86_64-linux-gnu.so +0 -0
- sage/matroids/set_system.pxd +38 -0
- sage/matroids/set_system.pyx +800 -0
- sage/matroids/transversal_matroid.cpython-314-x86_64-linux-gnu.so +0 -0
- sage/matroids/transversal_matroid.pxd +14 -0
- sage/matroids/transversal_matroid.pyx +893 -0
- sage/matroids/union_matroid.cpython-314-x86_64-linux-gnu.so +0 -0
- sage/matroids/union_matroid.pxd +20 -0
- sage/matroids/union_matroid.pyx +331 -0
- sage/matroids/unpickling.cpython-314-x86_64-linux-gnu.so +0 -0
- sage/matroids/unpickling.pyx +843 -0
- sage/matroids/utilities.py +809 -0
- sage/misc/all__sagemath_modules.py +20 -0
- sage/misc/c3.cpython-314-x86_64-linux-gnu.so +0 -0
- sage/misc/c3.pyx +238 -0
- sage/misc/compat.py +87 -0
- sage/misc/element_with_label.py +173 -0
- sage/misc/func_persist.py +79 -0
- sage/misc/pickle_old.cpython-314-x86_64-linux-gnu.so +0 -0
- sage/misc/pickle_old.pyx +19 -0
- sage/misc/proof.py +7 -0
- sage/misc/replace_dot_all.py +472 -0
- sage/misc/sagedoc_conf.py +168 -0
- sage/misc/sphinxify.py +167 -0
- sage/misc/test_class_pickling.py +85 -0
- sage/modules/all.py +42 -0
- sage/modules/complex_double_vector.py +25 -0
- sage/modules/diamond_cutting.py +380 -0
- sage/modules/fg_pid/all.py +1 -0
- sage/modules/fg_pid/fgp_element.py +456 -0
- sage/modules/fg_pid/fgp_module.py +2091 -0
- sage/modules/fg_pid/fgp_morphism.py +550 -0
- sage/modules/filtered_vector_space.py +1271 -0
- sage/modules/finite_submodule_iter.cpython-314-x86_64-linux-gnu.so +0 -0
- sage/modules/finite_submodule_iter.pxd +27 -0
- sage/modules/finite_submodule_iter.pyx +452 -0
- sage/modules/fp_graded/all.py +1 -0
- sage/modules/fp_graded/element.py +346 -0
- sage/modules/fp_graded/free_element.py +298 -0
- sage/modules/fp_graded/free_homspace.py +53 -0
- sage/modules/fp_graded/free_module.py +1060 -0
- sage/modules/fp_graded/free_morphism.py +217 -0
- sage/modules/fp_graded/homspace.py +563 -0
- sage/modules/fp_graded/module.py +1340 -0
- sage/modules/fp_graded/morphism.py +1990 -0
- sage/modules/fp_graded/steenrod/all.py +1 -0
- sage/modules/fp_graded/steenrod/homspace.py +65 -0
- sage/modules/fp_graded/steenrod/module.py +477 -0
- sage/modules/fp_graded/steenrod/morphism.py +404 -0
- sage/modules/fp_graded/steenrod/profile.py +241 -0
- sage/modules/free_module.py +8447 -0
- sage/modules/free_module_element.cpython-314-x86_64-linux-gnu.so +0 -0
- sage/modules/free_module_element.pxd +22 -0
- sage/modules/free_module_element.pyx +5445 -0
- sage/modules/free_module_homspace.py +369 -0
- sage/modules/free_module_integer.py +896 -0
- sage/modules/free_module_morphism.py +823 -0
- sage/modules/free_module_pseudohomspace.py +352 -0
- sage/modules/free_module_pseudomorphism.py +578 -0
- sage/modules/free_quadratic_module.py +1706 -0
- sage/modules/free_quadratic_module_integer_symmetric.py +1790 -0
- sage/modules/matrix_morphism.py +1745 -0
- sage/modules/misc.py +103 -0
- sage/modules/module_functors.py +192 -0
- sage/modules/multi_filtered_vector_space.py +719 -0
- sage/modules/ore_module.py +2208 -0
- sage/modules/ore_module_element.py +178 -0
- sage/modules/ore_module_homspace.py +147 -0
- sage/modules/ore_module_morphism.py +968 -0
- sage/modules/quotient_module.py +699 -0
- sage/modules/real_double_vector.py +22 -0
- sage/modules/submodule.py +255 -0
- sage/modules/tensor_operations.py +567 -0
- sage/modules/torsion_quadratic_module.py +1352 -0
- sage/modules/tutorial_free_modules.py +248 -0
- sage/modules/vector_complex_double_dense.cpython-314-x86_64-linux-gnu.so +0 -0
- sage/modules/vector_complex_double_dense.pxd +6 -0
- sage/modules/vector_complex_double_dense.pyx +117 -0
- sage/modules/vector_double_dense.cpython-314-x86_64-linux-gnu.so +0 -0
- sage/modules/vector_double_dense.pxd +6 -0
- sage/modules/vector_double_dense.pyx +604 -0
- sage/modules/vector_integer_dense.cpython-314-x86_64-linux-gnu.so +0 -0
- sage/modules/vector_integer_dense.pxd +15 -0
- sage/modules/vector_integer_dense.pyx +361 -0
- sage/modules/vector_integer_sparse.cpython-314-x86_64-linux-gnu.so +0 -0
- sage/modules/vector_integer_sparse.pxd +29 -0
- sage/modules/vector_integer_sparse.pyx +406 -0
- sage/modules/vector_modn_dense.cpython-314-x86_64-linux-gnu.so +0 -0
- sage/modules/vector_modn_dense.pxd +12 -0
- sage/modules/vector_modn_dense.pyx +394 -0
- sage/modules/vector_modn_sparse.cpython-314-x86_64-linux-gnu.so +0 -0
- sage/modules/vector_modn_sparse.pxd +21 -0
- sage/modules/vector_modn_sparse.pyx +298 -0
- sage/modules/vector_numpy_dense.cpython-314-x86_64-linux-gnu.so +0 -0
- sage/modules/vector_numpy_dense.pxd +15 -0
- sage/modules/vector_numpy_dense.pyx +304 -0
- sage/modules/vector_numpy_integer_dense.cpython-314-x86_64-linux-gnu.so +0 -0
- sage/modules/vector_numpy_integer_dense.pxd +7 -0
- sage/modules/vector_numpy_integer_dense.pyx +54 -0
- sage/modules/vector_rational_dense.cpython-314-x86_64-linux-gnu.so +0 -0
- sage/modules/vector_rational_dense.pxd +15 -0
- sage/modules/vector_rational_dense.pyx +387 -0
- sage/modules/vector_rational_sparse.cpython-314-x86_64-linux-gnu.so +0 -0
- sage/modules/vector_rational_sparse.pxd +30 -0
- sage/modules/vector_rational_sparse.pyx +413 -0
- sage/modules/vector_real_double_dense.cpython-314-x86_64-linux-gnu.so +0 -0
- sage/modules/vector_real_double_dense.pxd +6 -0
- sage/modules/vector_real_double_dense.pyx +126 -0
- sage/modules/vector_space_homspace.py +430 -0
- sage/modules/vector_space_morphism.py +989 -0
- sage/modules/with_basis/all.py +15 -0
- sage/modules/with_basis/cell_module.py +494 -0
- sage/modules/with_basis/indexed_element.cpython-314-x86_64-linux-gnu.so +0 -0
- sage/modules/with_basis/indexed_element.pxd +13 -0
- sage/modules/with_basis/indexed_element.pyx +1058 -0
- sage/modules/with_basis/invariant.py +1075 -0
- sage/modules/with_basis/morphism.py +1636 -0
- sage/modules/with_basis/representation.py +2939 -0
- sage/modules/with_basis/subquotient.py +685 -0
- sage/numerical/all__sagemath_modules.py +6 -0
- sage/numerical/gauss_legendre.cpython-314-x86_64-linux-gnu.so +0 -0
- sage/numerical/gauss_legendre.pyx +381 -0
- sage/numerical/optimize.py +910 -0
- sage/probability/all.py +10 -0
- sage/probability/probability_distribution.cpython-314-x86_64-linux-gnu.so +0 -0
- sage/probability/probability_distribution.pyx +1242 -0
- sage/probability/random_variable.py +411 -0
- sage/quadratic_forms/all.py +4 -0
- sage/quadratic_forms/all__sagemath_modules.py +15 -0
- sage/quadratic_forms/binary_qf.py +2042 -0
- sage/quadratic_forms/bqf_class_group.py +748 -0
- sage/quadratic_forms/constructions.py +93 -0
- sage/quadratic_forms/count_local_2.cpython-314-x86_64-linux-gnu.so +0 -0
- sage/quadratic_forms/count_local_2.pyx +365 -0
- sage/quadratic_forms/extras.py +195 -0
- sage/quadratic_forms/quadratic_form.py +1753 -0
- sage/quadratic_forms/quadratic_form__count_local_2.py +221 -0
- sage/quadratic_forms/quadratic_form__equivalence_testing.py +708 -0
- sage/quadratic_forms/quadratic_form__evaluate.cpython-314-x86_64-linux-gnu.so +0 -0
- sage/quadratic_forms/quadratic_form__evaluate.pyx +139 -0
- sage/quadratic_forms/quadratic_form__local_density_congruence.py +977 -0
- sage/quadratic_forms/quadratic_form__local_field_invariants.py +1072 -0
- sage/quadratic_forms/quadratic_form__neighbors.py +424 -0
- sage/quadratic_forms/quadratic_form__reduction_theory.py +488 -0
- sage/quadratic_forms/quadratic_form__split_local_covering.py +416 -0
- sage/quadratic_forms/quadratic_form__ternary_Tornaria.py +657 -0
- sage/quadratic_forms/quadratic_form__theta.py +352 -0
- sage/quadratic_forms/quadratic_form__variable_substitutions.py +370 -0
- sage/quadratic_forms/random_quadraticform.py +209 -0
- sage/quadratic_forms/ternary.cpython-314-x86_64-linux-gnu.so +0 -0
- sage/quadratic_forms/ternary.pyx +1154 -0
- sage/quadratic_forms/ternary_qf.py +2027 -0
- sage/rings/all__sagemath_modules.py +28 -0
- sage/rings/asymptotic/all__sagemath_modules.py +1 -0
- sage/rings/asymptotic/misc.py +1252 -0
- sage/rings/cc.py +4 -0
- sage/rings/cfinite_sequence.py +1306 -0
- sage/rings/complex_conversion.cpython-314-x86_64-linux-gnu.so +0 -0
- sage/rings/complex_conversion.pxd +8 -0
- sage/rings/complex_conversion.pyx +23 -0
- sage/rings/complex_double.cpython-314-x86_64-linux-gnu.so +0 -0
- sage/rings/complex_double.pxd +21 -0
- sage/rings/complex_double.pyx +2654 -0
- sage/rings/complex_mpc.cpython-314-x86_64-linux-gnu.so +0 -0
- sage/rings/complex_mpc.pxd +21 -0
- sage/rings/complex_mpc.pyx +2576 -0
- sage/rings/complex_mpfr.cpython-314-x86_64-linux-gnu.so +0 -0
- sage/rings/complex_mpfr.pxd +18 -0
- sage/rings/complex_mpfr.pyx +3602 -0
- sage/rings/derivation.py +2334 -0
- sage/rings/finite_rings/all__sagemath_modules.py +1 -0
- sage/rings/finite_rings/maps_finite_field.py +191 -0
- sage/rings/function_field/all__sagemath_modules.py +8 -0
- sage/rings/function_field/derivations.py +102 -0
- sage/rings/function_field/derivations_rational.py +132 -0
- sage/rings/function_field/differential.py +853 -0
- sage/rings/function_field/divisor.py +1107 -0
- sage/rings/function_field/drinfeld_modules/action.py +199 -0
- sage/rings/function_field/drinfeld_modules/all.py +1 -0
- sage/rings/function_field/drinfeld_modules/charzero_drinfeld_module.py +673 -0
- sage/rings/function_field/drinfeld_modules/drinfeld_module.py +2087 -0
- sage/rings/function_field/drinfeld_modules/finite_drinfeld_module.py +1131 -0
- sage/rings/function_field/drinfeld_modules/homset.py +420 -0
- sage/rings/function_field/drinfeld_modules/morphism.py +820 -0
- sage/rings/function_field/hermite_form_polynomial.cpython-314-x86_64-linux-gnu.so +0 -0
- sage/rings/function_field/hermite_form_polynomial.pyx +188 -0
- sage/rings/function_field/khuri_makdisi.cpython-314-x86_64-linux-gnu.so +0 -0
- sage/rings/function_field/khuri_makdisi.pyx +935 -0
- sage/rings/invariants/all.py +4 -0
- sage/rings/invariants/invariant_theory.py +4597 -0
- sage/rings/invariants/reconstruction.py +395 -0
- sage/rings/polynomial/all__sagemath_modules.py +17 -0
- sage/rings/polynomial/integer_valued_polynomials.py +1230 -0
- sage/rings/polynomial/laurent_polynomial_mpair.cpython-314-x86_64-linux-gnu.so +0 -0
- sage/rings/polynomial/laurent_polynomial_mpair.pxd +15 -0
- sage/rings/polynomial/laurent_polynomial_mpair.pyx +2023 -0
- sage/rings/polynomial/ore_function_element.py +952 -0
- sage/rings/polynomial/ore_function_field.py +1028 -0
- sage/rings/polynomial/ore_polynomial_element.cpython-314-x86_64-linux-gnu.so +0 -0
- sage/rings/polynomial/ore_polynomial_element.pxd +48 -0
- sage/rings/polynomial/ore_polynomial_element.pyx +3145 -0
- sage/rings/polynomial/ore_polynomial_ring.py +1334 -0
- sage/rings/polynomial/polynomial_real_mpfr_dense.cpython-314-x86_64-linux-gnu.so +0 -0
- sage/rings/polynomial/polynomial_real_mpfr_dense.pyx +788 -0
- sage/rings/polynomial/q_integer_valued_polynomials.py +1264 -0
- sage/rings/polynomial/skew_polynomial_element.cpython-314-x86_64-linux-gnu.so +0 -0
- sage/rings/polynomial/skew_polynomial_element.pxd +9 -0
- sage/rings/polynomial/skew_polynomial_element.pyx +684 -0
- sage/rings/polynomial/skew_polynomial_finite_field.cpython-314-x86_64-linux-gnu.so +0 -0
- sage/rings/polynomial/skew_polynomial_finite_field.pxd +19 -0
- sage/rings/polynomial/skew_polynomial_finite_field.pyx +1093 -0
- sage/rings/polynomial/skew_polynomial_finite_order.cpython-314-x86_64-linux-gnu.so +0 -0
- sage/rings/polynomial/skew_polynomial_finite_order.pxd +10 -0
- sage/rings/polynomial/skew_polynomial_finite_order.pyx +567 -0
- sage/rings/polynomial/skew_polynomial_ring.py +908 -0
- sage/rings/real_double_element_gsl.cpython-314-x86_64-linux-gnu.so +0 -0
- sage/rings/real_double_element_gsl.pxd +8 -0
- sage/rings/real_double_element_gsl.pyx +794 -0
- sage/rings/real_field.py +58 -0
- sage/rings/real_mpfr.cpython-314-x86_64-linux-gnu.so +0 -0
- sage/rings/real_mpfr.pxd +29 -0
- sage/rings/real_mpfr.pyx +6122 -0
- sage/rings/ring_extension.cpython-314-x86_64-linux-gnu.so +0 -0
- sage/rings/ring_extension.pxd +42 -0
- sage/rings/ring_extension.pyx +2779 -0
- sage/rings/ring_extension_conversion.cpython-314-x86_64-linux-gnu.so +0 -0
- sage/rings/ring_extension_conversion.pxd +16 -0
- sage/rings/ring_extension_conversion.pyx +462 -0
- sage/rings/ring_extension_element.cpython-314-x86_64-linux-gnu.so +0 -0
- sage/rings/ring_extension_element.pxd +21 -0
- sage/rings/ring_extension_element.pyx +1635 -0
- sage/rings/ring_extension_homset.py +64 -0
- sage/rings/ring_extension_morphism.cpython-314-x86_64-linux-gnu.so +0 -0
- sage/rings/ring_extension_morphism.pxd +35 -0
- sage/rings/ring_extension_morphism.pyx +920 -0
- sage/schemes/all__sagemath_modules.py +1 -0
- sage/schemes/projective/all__sagemath_modules.py +1 -0
- sage/schemes/projective/coherent_sheaf.py +300 -0
- sage/schemes/projective/cohomology.py +510 -0
- sage/stats/all.py +15 -0
- sage/stats/basic_stats.py +489 -0
- sage/stats/distributions/all.py +7 -0
- sage/stats/distributions/catalog.py +34 -0
- sage/stats/distributions/dgs.h +50 -0
- sage/stats/distributions/dgs.pxd +111 -0
- sage/stats/distributions/dgs_bern.h +400 -0
- sage/stats/distributions/dgs_gauss.h +614 -0
- sage/stats/distributions/dgs_misc.h +104 -0
- sage/stats/distributions/discrete_gaussian_integer.cpython-314-x86_64-linux-gnu.so +0 -0
- sage/stats/distributions/discrete_gaussian_integer.pxd +14 -0
- sage/stats/distributions/discrete_gaussian_integer.pyx +498 -0
- sage/stats/distributions/discrete_gaussian_lattice.py +908 -0
- sage/stats/distributions/discrete_gaussian_polynomial.py +141 -0
- sage/stats/hmm/all.py +15 -0
- sage/stats/hmm/chmm.cpython-314-x86_64-linux-gnu.so +0 -0
- sage/stats/hmm/chmm.pyx +1595 -0
- sage/stats/hmm/distributions.cpython-314-x86_64-linux-gnu.so +0 -0
- sage/stats/hmm/distributions.pxd +29 -0
- sage/stats/hmm/distributions.pyx +531 -0
- sage/stats/hmm/hmm.cpython-314-x86_64-linux-gnu.so +0 -0
- sage/stats/hmm/hmm.pxd +17 -0
- sage/stats/hmm/hmm.pyx +1388 -0
- sage/stats/hmm/util.cpython-314-x86_64-linux-gnu.so +0 -0
- sage/stats/hmm/util.pxd +7 -0
- sage/stats/hmm/util.pyx +165 -0
- sage/stats/intlist.cpython-314-x86_64-linux-gnu.so +0 -0
- sage/stats/intlist.pxd +14 -0
- sage/stats/intlist.pyx +588 -0
- sage/stats/r.py +49 -0
- sage/stats/time_series.cpython-314-x86_64-linux-gnu.so +0 -0
- sage/stats/time_series.pxd +6 -0
- sage/stats/time_series.pyx +2546 -0
- sage/tensor/all.py +2 -0
- sage/tensor/modules/all.py +8 -0
- sage/tensor/modules/alternating_contr_tensor.py +761 -0
- sage/tensor/modules/comp.py +5598 -0
- sage/tensor/modules/ext_pow_free_module.py +824 -0
- sage/tensor/modules/finite_rank_free_module.py +3589 -0
- sage/tensor/modules/format_utilities.py +333 -0
- sage/tensor/modules/free_module_alt_form.py +858 -0
- sage/tensor/modules/free_module_automorphism.py +1207 -0
- sage/tensor/modules/free_module_basis.py +1074 -0
- sage/tensor/modules/free_module_element.py +284 -0
- sage/tensor/modules/free_module_homset.py +652 -0
- sage/tensor/modules/free_module_linear_group.py +564 -0
- sage/tensor/modules/free_module_morphism.py +1581 -0
- sage/tensor/modules/free_module_tensor.py +3289 -0
- sage/tensor/modules/reflexive_module.py +386 -0
- sage/tensor/modules/tensor_free_module.py +780 -0
- sage/tensor/modules/tensor_free_submodule.py +538 -0
- sage/tensor/modules/tensor_free_submodule_basis.py +140 -0
- sage/tensor/modules/tensor_with_indices.py +1043 -0
|
@@ -0,0 +1,569 @@
|
|
|
1
|
+
# sage_setup: distribution = sagemath-modules
|
|
2
|
+
# sage.doctest: needs sage.combinat
|
|
3
|
+
"""
|
|
4
|
+
Classical Ciphers
|
|
5
|
+
"""
|
|
6
|
+
# ****************************************************************************
|
|
7
|
+
# Copyright (C) 2007 David Kohel <kohel@maths.usyd.edu.au>
|
|
8
|
+
#
|
|
9
|
+
# Distributed under the terms of the GNU General Public License (GPL)
|
|
10
|
+
#
|
|
11
|
+
# https://www.gnu.org/licenses/
|
|
12
|
+
# ****************************************************************************
|
|
13
|
+
from sage.misc.lazy_import import lazy_import
|
|
14
|
+
from sage.monoids.string_monoid_element import StringMonoidElement
|
|
15
|
+
|
|
16
|
+
lazy_import('sage.modules.free_module', 'FreeModule')
|
|
17
|
+
|
|
18
|
+
from .cipher import SymmetricKeyCipher
|
|
19
|
+
|
|
20
|
+
|
|
21
|
+
class AffineCipher(SymmetricKeyCipher):
|
|
22
|
+
r"""
|
|
23
|
+
Affine cipher class. This is the class that does the actual work of
|
|
24
|
+
encryption and decryption. Users should not directly instantiate or
|
|
25
|
+
create objects of this class. Instead, functionalities of this class
|
|
26
|
+
should be accessed via
|
|
27
|
+
:class:`AffineCryptosystem <sage.crypto.classical.AffineCryptosystem>`
|
|
28
|
+
as the latter provides a convenient user interface.
|
|
29
|
+
"""
|
|
30
|
+
|
|
31
|
+
def __init__(self, parent, key):
|
|
32
|
+
r"""
|
|
33
|
+
Create an affine cipher.
|
|
34
|
+
|
|
35
|
+
INPUT:
|
|
36
|
+
|
|
37
|
+
- ``parent`` -- an ``AffineCryptosystem`` object
|
|
38
|
+
|
|
39
|
+
- ``key`` -- a secret key; let `N` be the size of the cipher domain.
|
|
40
|
+
A key of this affine cipher is an ordered pair
|
|
41
|
+
`(a, b) \in \ZZ_N \times \ZZ_N` such that `\gcd(a, N) = 1`.
|
|
42
|
+
|
|
43
|
+
EXAMPLES:
|
|
44
|
+
|
|
45
|
+
Testing of dumping and loading object::
|
|
46
|
+
|
|
47
|
+
sage: A = AffineCryptosystem(AlphabeticStrings())
|
|
48
|
+
sage: AC = A(3, 5)
|
|
49
|
+
sage: AC == loads(dumps(AC))
|
|
50
|
+
True
|
|
51
|
+
"""
|
|
52
|
+
SymmetricKeyCipher.__init__(self, parent, key)
|
|
53
|
+
|
|
54
|
+
def __eq__(self, other):
|
|
55
|
+
r"""
|
|
56
|
+
Comparing this ``AffineCipher`` with ``other``. Two ``AffineCipher``
|
|
57
|
+
objects are the same if they are of the same type, have the same
|
|
58
|
+
parent, and share the same secret key.
|
|
59
|
+
|
|
60
|
+
INPUT:
|
|
61
|
+
|
|
62
|
+
- ``other`` -- another object to compare with
|
|
63
|
+
|
|
64
|
+
OUTPUT: ``True`` if ``self`` and ``other`` are the same
|
|
65
|
+
``AffineCipher`` object; ``False`` otherwise
|
|
66
|
+
|
|
67
|
+
EXAMPLES::
|
|
68
|
+
|
|
69
|
+
sage: aff1 = AffineCryptosystem(AlphabeticStrings())
|
|
70
|
+
sage: aff2 = AffineCryptosystem(AlphabeticStrings())
|
|
71
|
+
sage: aff1 == aff2
|
|
72
|
+
True
|
|
73
|
+
sage: aff1(1, 2) == aff2(1, 2)
|
|
74
|
+
True
|
|
75
|
+
"""
|
|
76
|
+
return type(self) is type(other) and self.parent() == other.parent() and self.key() == other.key()
|
|
77
|
+
|
|
78
|
+
def __call__(self, M):
|
|
79
|
+
r"""
|
|
80
|
+
Return the ciphertext (respectively, plaintext) corresponding to
|
|
81
|
+
``M``. This is the main place where encryption and decryption takes
|
|
82
|
+
place.
|
|
83
|
+
|
|
84
|
+
INPUT:
|
|
85
|
+
|
|
86
|
+
- ``M`` -- a message to be encrypted or decrypted. This message must
|
|
87
|
+
be encoded using the plaintext or ciphertext alphabet. The current
|
|
88
|
+
behaviour is that the plaintext and ciphertext alphabets are the
|
|
89
|
+
same alphabet.
|
|
90
|
+
|
|
91
|
+
- ``algorithm`` -- (default: ``'encrypt'``) whether to use the
|
|
92
|
+
encryption or decryption algorithm on ``M``. The flag ``'encrypt'``
|
|
93
|
+
signifies using the encryption algorithm, while ``'decrypt'``
|
|
94
|
+
signifies using the decryption algorithm. The only acceptable
|
|
95
|
+
values for ``algorithm`` are: ``'encrypt'`` and ``'decrypt'``.
|
|
96
|
+
|
|
97
|
+
OUTPUT: the ciphertext or plaintext corresponding to ``M``
|
|
98
|
+
|
|
99
|
+
EXAMPLES::
|
|
100
|
+
|
|
101
|
+
sage: A = AffineCryptosystem(AlphabeticStrings()); A
|
|
102
|
+
Affine cryptosystem on Free alphabetic string monoid on A-Z
|
|
103
|
+
sage: P = A.encoding("The affine cryptosystem generalizes the shift cipher.")
|
|
104
|
+
sage: P
|
|
105
|
+
THEAFFINECRYPTOSYSTEMGENERALIZESTHESHIFTCIPHER
|
|
106
|
+
sage: a, b = (9, 13)
|
|
107
|
+
sage: E = A(a, b); E
|
|
108
|
+
Affine cipher on Free alphabetic string monoid on A-Z
|
|
109
|
+
sage: C = E(P); C
|
|
110
|
+
CYXNGGHAXFKVSCJTVTCXRPXAXKNIHEXTCYXTYHGCFHSYXK
|
|
111
|
+
sage: aInv, bInv = A.inverse_key(a, b)
|
|
112
|
+
sage: D = A(aInv, bInv); D
|
|
113
|
+
Affine cipher on Free alphabetic string monoid on A-Z
|
|
114
|
+
sage: D(C)
|
|
115
|
+
THEAFFINECRYPTOSYSTEMGENERALIZESTHESHIFTCIPHER
|
|
116
|
+
sage: D(C) == P
|
|
117
|
+
True
|
|
118
|
+
sage: D(C) == P == D(E(P))
|
|
119
|
+
True
|
|
120
|
+
"""
|
|
121
|
+
# sanity check
|
|
122
|
+
D = self.domain() # = plaintext_space = ciphertext_space
|
|
123
|
+
if M.parent() != D:
|
|
124
|
+
raise TypeError("Argument M must be a string in the plaintext/ciphertext space.")
|
|
125
|
+
|
|
126
|
+
from sage.rings.finite_rings.integer_mod import Mod
|
|
127
|
+
A = list(D.alphabet()) # plaintext/ciphertext alphabet as a list
|
|
128
|
+
N = self.domain().ngens() # number of elements in this alphabet
|
|
129
|
+
a, b = self.key() # encryption/decryption key (a,b)
|
|
130
|
+
# Let I be the index list of M. That is, the i-th element of M has
|
|
131
|
+
# index k in the cipher domain D. We store this cipher domain index
|
|
132
|
+
# as the i-th element of I.
|
|
133
|
+
I = [A.index(str(e)) for e in M]
|
|
134
|
+
|
|
135
|
+
# Encrypt the plaintext M. For each element i in I, the ciphertext
|
|
136
|
+
# corresponding to i is ai + b (mod N). This can also be used for
|
|
137
|
+
# decryption, in which case (a, b) is the inverse key corresponding
|
|
138
|
+
# to a secret key.
|
|
139
|
+
return D([ A.index(A[Mod(a*i + b, N).lift()]) for i in I ])
|
|
140
|
+
|
|
141
|
+
def _repr_(self):
|
|
142
|
+
r"""
|
|
143
|
+
Return the string representation of this affine cipher.
|
|
144
|
+
|
|
145
|
+
EXAMPLES::
|
|
146
|
+
|
|
147
|
+
sage: A = AffineCryptosystem(AlphabeticStrings())
|
|
148
|
+
sage: A(1, 2)
|
|
149
|
+
Affine cipher on Free alphabetic string monoid on A-Z
|
|
150
|
+
"""
|
|
151
|
+
# The affine cipher has the plaintext and ciphertext spaces defined
|
|
152
|
+
# over the same non-empty alphabet. The cipher domain is the same
|
|
153
|
+
# as the alphabet used for the plaintext and ciphertext spaces.
|
|
154
|
+
return "Affine cipher on %s" % self.parent().cipher_domain()
|
|
155
|
+
|
|
156
|
+
|
|
157
|
+
class HillCipher(SymmetricKeyCipher):
|
|
158
|
+
"""
|
|
159
|
+
Hill cipher class
|
|
160
|
+
"""
|
|
161
|
+
def __init__(self, parent, key):
|
|
162
|
+
"""
|
|
163
|
+
Create a Hill cipher.
|
|
164
|
+
|
|
165
|
+
EXAMPLES::
|
|
166
|
+
|
|
167
|
+
sage: # needs sage.modules
|
|
168
|
+
sage: S = AlphabeticStrings()
|
|
169
|
+
sage: E = HillCryptosystem(S,3); E
|
|
170
|
+
Hill cryptosystem on Free alphabetic string monoid on A-Z of block length 3
|
|
171
|
+
sage: M = E.key_space()
|
|
172
|
+
sage: A = M([[1,0,1],[0,1,1],[2,2,3]]); A
|
|
173
|
+
[1 0 1]
|
|
174
|
+
[0 1 1]
|
|
175
|
+
[2 2 3]
|
|
176
|
+
sage: e = E(A); e
|
|
177
|
+
Hill cipher on Free alphabetic string monoid on A-Z of block length 3
|
|
178
|
+
sage: e(S("LAMAISONBLANCHE"))
|
|
179
|
+
JYVKSKQPELAYKPV
|
|
180
|
+
|
|
181
|
+
TESTS::
|
|
182
|
+
|
|
183
|
+
sage: S = AlphabeticStrings()
|
|
184
|
+
sage: E = HillCryptosystem(S,3) # needs sage.modules
|
|
185
|
+
sage: E == loads(dumps(E)) # needs sage.modules
|
|
186
|
+
True
|
|
187
|
+
"""
|
|
188
|
+
# TODO: some type checking that the key is an invertible matrix?
|
|
189
|
+
SymmetricKeyCipher.__init__(self, parent, key)
|
|
190
|
+
|
|
191
|
+
def __eq__(self, right):
|
|
192
|
+
return type(self) is type(right) and self.parent() == right.parent() and self.key() == right.key()
|
|
193
|
+
|
|
194
|
+
def __call__(self, M):
|
|
195
|
+
S = self.domain() # = plaintext_space = ciphertext_space
|
|
196
|
+
if not isinstance(M, StringMonoidElement) and M.parent() == S:
|
|
197
|
+
raise TypeError("Argument M (= %s) must be a string in the plaintext space." % M)
|
|
198
|
+
m = self.parent().block_length()
|
|
199
|
+
if len(M) % m != 0:
|
|
200
|
+
raise TypeError("The length of M (= %s) must be a multiple of %s." % (M, m ))
|
|
201
|
+
Alph = list(S.alphabet())
|
|
202
|
+
A = self.key() # A is an m x m matrix
|
|
203
|
+
R = A.parent().base_ring()
|
|
204
|
+
V = FreeModule(R,m)
|
|
205
|
+
Mstr = str(M)
|
|
206
|
+
C = []
|
|
207
|
+
for i in range(len(M)//m):
|
|
208
|
+
v = V([ Alph.index(Mstr[m*i+j]) for j in range(m) ])
|
|
209
|
+
C += (v * A).list()
|
|
210
|
+
return S([ k.lift() for k in C ])
|
|
211
|
+
|
|
212
|
+
def _repr_(self):
|
|
213
|
+
r"""
|
|
214
|
+
Return the string representation of this Hill cipher.
|
|
215
|
+
|
|
216
|
+
EXAMPLES::
|
|
217
|
+
|
|
218
|
+
sage: # needs sage.modules
|
|
219
|
+
sage: H = HillCryptosystem(AlphabeticStrings(), 3)
|
|
220
|
+
sage: M = MatrixSpace(IntegerModRing(26), 3, 3)
|
|
221
|
+
sage: A = M([[1,0,1], [0,1,1], [2,2,3]])
|
|
222
|
+
sage: e = H(A); e
|
|
223
|
+
Hill cipher on Free alphabetic string monoid on A-Z of block length 3
|
|
224
|
+
"""
|
|
225
|
+
return "Hill cipher on %s of block length %s" % (
|
|
226
|
+
self.parent().cipher_domain(), self.parent().block_length() )
|
|
227
|
+
|
|
228
|
+
def inverse(self):
|
|
229
|
+
E = self.parent()
|
|
230
|
+
try:
|
|
231
|
+
B = E.inverse_key(self.key())
|
|
232
|
+
except Exception:
|
|
233
|
+
raise ValueError("Argument\n\n%s\n\nmust be an invertible cipher." % self)
|
|
234
|
+
return E(B)
|
|
235
|
+
|
|
236
|
+
|
|
237
|
+
class ShiftCipher(SymmetricKeyCipher):
|
|
238
|
+
r"""
|
|
239
|
+
Shift cipher class. This is the class that does the actual work of
|
|
240
|
+
encryption and decryption. Users should not directly instantiate or
|
|
241
|
+
create objects of this class. Instead, functionalities of this class
|
|
242
|
+
should be accessed via
|
|
243
|
+
:class:`ShiftCryptosystem <sage.crypto.classical.ShiftCryptosystem>`
|
|
244
|
+
as the latter provides a convenient user interface.
|
|
245
|
+
"""
|
|
246
|
+
|
|
247
|
+
def __init__(self, parent, key):
|
|
248
|
+
r"""
|
|
249
|
+
Create a shift cipher.
|
|
250
|
+
|
|
251
|
+
INPUT:
|
|
252
|
+
|
|
253
|
+
- ``parent`` -- a ``ShiftCryptosystem`` object
|
|
254
|
+
|
|
255
|
+
- ``key`` -- a secret key
|
|
256
|
+
|
|
257
|
+
EXAMPLES::
|
|
258
|
+
|
|
259
|
+
sage: S = ShiftCryptosystem(AlphabeticStrings()); S
|
|
260
|
+
Shift cryptosystem on Free alphabetic string monoid on A-Z
|
|
261
|
+
sage: P = S.encoding("The shift cryptosystem generalizes the Caesar cipher.")
|
|
262
|
+
sage: P
|
|
263
|
+
THESHIFTCRYPTOSYSTEMGENERALIZESTHECAESARCIPHER
|
|
264
|
+
sage: K = 7
|
|
265
|
+
sage: C = S.enciphering(K, P); C
|
|
266
|
+
AOLZOPMAJYFWAVZFZALTNLULYHSPGLZAOLJHLZHYJPWOLY
|
|
267
|
+
sage: S.deciphering(K, C)
|
|
268
|
+
THESHIFTCRYPTOSYSTEMGENERALIZESTHECAESARCIPHER
|
|
269
|
+
sage: S.deciphering(K, C) == P
|
|
270
|
+
True
|
|
271
|
+
"""
|
|
272
|
+
SymmetricKeyCipher.__init__(self, parent, key)
|
|
273
|
+
|
|
274
|
+
def __eq__(self, other):
|
|
275
|
+
r"""
|
|
276
|
+
Comparing this ``ShiftCipher`` with ``other``. Two ``ShiftCipher``
|
|
277
|
+
objects are the same if they are of the same type, have the same
|
|
278
|
+
parent, and share the same secret key.
|
|
279
|
+
|
|
280
|
+
INPUT:
|
|
281
|
+
|
|
282
|
+
- ``other`` -- another object to compare with
|
|
283
|
+
|
|
284
|
+
OUTPUT: ``True`` if ``self`` and ``other`` are the same ``ShiftCipher``
|
|
285
|
+
object; ``False`` otherwise.
|
|
286
|
+
|
|
287
|
+
EXAMPLES::
|
|
288
|
+
|
|
289
|
+
sage: shift1 = ShiftCryptosystem(AlphabeticStrings())
|
|
290
|
+
sage: shift2 = ShiftCryptosystem(AlphabeticStrings())
|
|
291
|
+
sage: shift1 == shift2
|
|
292
|
+
True
|
|
293
|
+
sage: shift1 = ShiftCryptosystem(HexadecimalStrings())
|
|
294
|
+
sage: shift2 = ShiftCryptosystem(BinaryStrings())
|
|
295
|
+
sage: shift1 == shift2
|
|
296
|
+
False
|
|
297
|
+
"""
|
|
298
|
+
return type(self) is type(other) and self.parent() == other.parent() and self.key() == other.key()
|
|
299
|
+
|
|
300
|
+
def __call__(self, M):
|
|
301
|
+
r"""
|
|
302
|
+
Return the ciphertext (respectively, plaintext) corresponding to
|
|
303
|
+
``M``. This is the main place where encryption and decryption takes
|
|
304
|
+
place.
|
|
305
|
+
|
|
306
|
+
INPUT:
|
|
307
|
+
|
|
308
|
+
- ``M`` -- a message to be encrypted or decrypted. This message must
|
|
309
|
+
be encoded using the plaintext or ciphertext alphabet. The current
|
|
310
|
+
behaviour is that the plaintext and ciphertext alphabets are the
|
|
311
|
+
same alphabet.
|
|
312
|
+
|
|
313
|
+
OUTPUT: the ciphertext or plaintext corresponding to ``M``
|
|
314
|
+
|
|
315
|
+
EXAMPLES:
|
|
316
|
+
|
|
317
|
+
These are indirect doctests. Functionalities of this class are
|
|
318
|
+
usually invoked from
|
|
319
|
+
:class:`ShiftCryptosystem <sage.crypto.classical.ShiftCryptosystem>`.
|
|
320
|
+
|
|
321
|
+
::
|
|
322
|
+
|
|
323
|
+
sage: S = ShiftCryptosystem(AlphabeticStrings())
|
|
324
|
+
sage: S.enciphering(12, S.encoding("Stop shifting me."))
|
|
325
|
+
EFABETURFUZSYQ
|
|
326
|
+
sage: S = ShiftCryptosystem(HexadecimalStrings())
|
|
327
|
+
sage: S.enciphering(7, S.encoding("Shift me now."))
|
|
328
|
+
cadfd0ddeb97d4dc97d5d6ee95
|
|
329
|
+
sage: S = ShiftCryptosystem(BinaryStrings())
|
|
330
|
+
sage: S.enciphering(1, S.encoding("OK, enough shifting."))
|
|
331
|
+
1011000010110100110100111101111110011010100100011001000010001010100110001001011111011111100011001001011110010110100110011000101110010110100100011001100011010001
|
|
332
|
+
"""
|
|
333
|
+
dom = self.domain() # = plaintext_space = ciphertext_space
|
|
334
|
+
if not isinstance(M, StringMonoidElement) and M.parent() == dom:
|
|
335
|
+
raise TypeError("Argument M (= %s) must be a string in the plaintext/ciphertext space." % M)
|
|
336
|
+
from sage.rings.finite_rings.integer_mod import Mod
|
|
337
|
+
A = list(dom.alphabet()) # plaintext/ciphertext alphabet as a list
|
|
338
|
+
N = self.domain().ngens() # number of elements in this alphabet
|
|
339
|
+
K = self.key() # encryption/decryption key
|
|
340
|
+
# Here, M is a message encoded within the ciphertext/plaintext
|
|
341
|
+
# alphabet of this shift cryptosystem. The list A above is a list of
|
|
342
|
+
# all elements of this alphabet, each element being associated with
|
|
343
|
+
# an index 0 <= i < n, where n is the size of A. Now get the index
|
|
344
|
+
# of each character in the message M, storing all these indices
|
|
345
|
+
# in the index list I.
|
|
346
|
+
# TODO: the following two lines are coded with clarity and
|
|
347
|
+
# readability in mind. It is possible to remove the overhead of
|
|
348
|
+
# doing a list comprehension to get the index associated with each
|
|
349
|
+
# element of M. For example, the next two lines can be crammed into
|
|
350
|
+
# one list comprehension as follows:
|
|
351
|
+
# return dom([ A.index(A[Mod(A.index(str(i)) + K, N).lift()]) for i in M ])
|
|
352
|
+
# But it performs badly compared to the following two lines.
|
|
353
|
+
I = [A.index(str(e)) for e in M]
|
|
354
|
+
# Perform encryption/decryption on the whole message M, returning
|
|
355
|
+
# the result as a string encoded in the alphabet A.
|
|
356
|
+
return dom([ A.index(A[Mod(i + K, N).lift()]) for i in I ])
|
|
357
|
+
|
|
358
|
+
def _repr_(self):
|
|
359
|
+
r"""
|
|
360
|
+
Return the string representation of this shift cipher.
|
|
361
|
+
|
|
362
|
+
EXAMPLES::
|
|
363
|
+
|
|
364
|
+
sage: S = ShiftCryptosystem(AlphabeticStrings())
|
|
365
|
+
sage: S(3)
|
|
366
|
+
Shift cipher on Free alphabetic string monoid on A-Z
|
|
367
|
+
sage: S = ShiftCryptosystem(HexadecimalStrings())
|
|
368
|
+
sage: S(5)
|
|
369
|
+
Shift cipher on Free hexadecimal string monoid
|
|
370
|
+
sage: S = ShiftCryptosystem(BinaryStrings())
|
|
371
|
+
sage: S(1)
|
|
372
|
+
Shift cipher on Free binary string monoid
|
|
373
|
+
"""
|
|
374
|
+
# The shift cipher has the plaintext and ciphertext spaces defined
|
|
375
|
+
# over the same non-empty alphabet. The cipher domain is the same
|
|
376
|
+
# as the alphabet used for the plaintext and ciphertext spaces.
|
|
377
|
+
return "Shift cipher on %s" % self.parent().cipher_domain()
|
|
378
|
+
|
|
379
|
+
|
|
380
|
+
class SubstitutionCipher(SymmetricKeyCipher):
|
|
381
|
+
"""
|
|
382
|
+
Substitution cipher class
|
|
383
|
+
"""
|
|
384
|
+
def __init__(self, parent, key):
|
|
385
|
+
"""
|
|
386
|
+
Create a substitution cipher.
|
|
387
|
+
|
|
388
|
+
EXAMPLES::
|
|
389
|
+
|
|
390
|
+
sage: S = AlphabeticStrings()
|
|
391
|
+
sage: E = SubstitutionCryptosystem(S)
|
|
392
|
+
sage: E
|
|
393
|
+
Substitution cryptosystem on Free alphabetic string monoid on A-Z
|
|
394
|
+
sage: K = S([ 25-i for i in range(26) ])
|
|
395
|
+
sage: K
|
|
396
|
+
ZYXWVUTSRQPONMLKJIHGFEDCBA
|
|
397
|
+
sage: e = E(K)
|
|
398
|
+
sage: m = S("THECATINTHEHAT")
|
|
399
|
+
sage: e(m)
|
|
400
|
+
GSVXZGRMGSVSZG
|
|
401
|
+
|
|
402
|
+
TESTS::
|
|
403
|
+
|
|
404
|
+
sage: S = AlphabeticStrings()
|
|
405
|
+
sage: E = SubstitutionCryptosystem(S)
|
|
406
|
+
sage: E == loads(dumps(E))
|
|
407
|
+
True
|
|
408
|
+
"""
|
|
409
|
+
SymmetricKeyCipher.__init__(self, parent, key)
|
|
410
|
+
|
|
411
|
+
def __eq__(self, right):
|
|
412
|
+
return type(self) is type(right) and self.parent() == right.parent() and self.key() == right.key()
|
|
413
|
+
|
|
414
|
+
def __call__(self, M):
|
|
415
|
+
S = self.domain() # = plaintext_space = ciphertext_space
|
|
416
|
+
if not isinstance(M, StringMonoidElement) and M.parent() == S:
|
|
417
|
+
raise TypeError("Argument M (= %s) must be a string in the plaintext space." % M)
|
|
418
|
+
A = list(S.alphabet())
|
|
419
|
+
K = str(self.key()) # K is a string, while we want the indices:
|
|
420
|
+
I = [ A.index(K[i]) for i in range(len(K)) ]
|
|
421
|
+
Mstr = str(M)
|
|
422
|
+
return S([ I[A.index(Mstr[i])] for i in range(len(Mstr)) ])
|
|
423
|
+
|
|
424
|
+
def _repr_(self):
|
|
425
|
+
r"""
|
|
426
|
+
Return the string representation of this substitution cipher.
|
|
427
|
+
|
|
428
|
+
EXAMPLES::
|
|
429
|
+
|
|
430
|
+
sage: A = HexadecimalStrings(); S = SubstitutionCryptosystem(A)
|
|
431
|
+
sage: K = A([16-i for i in range(16)]); S(K)
|
|
432
|
+
Substitution cipher on Free hexadecimal string monoid
|
|
433
|
+
sage: A = AlphabeticStrings(); S = SubstitutionCryptosystem(A)
|
|
434
|
+
sage: K = A([26-i for i in range(26)]); S(K)
|
|
435
|
+
Substitution cipher on Free alphabetic string monoid on A-Z
|
|
436
|
+
sage: A = OctalStrings(); S = SubstitutionCryptosystem(A)
|
|
437
|
+
sage: K = A([8-i for i in range(8)]); S(K)
|
|
438
|
+
Substitution cipher on Free octal string monoid
|
|
439
|
+
sage: A = BinaryStrings(); S = SubstitutionCryptosystem(A)
|
|
440
|
+
sage: K = A([2-i for i in range(2)]); S(K)
|
|
441
|
+
Substitution cipher on Free binary string monoid
|
|
442
|
+
sage: A = Radix64Strings(); S = SubstitutionCryptosystem(A)
|
|
443
|
+
sage: K = A([64-i for i in range(64)]); S(K)
|
|
444
|
+
Substitution cipher on Free radix 64 string monoid
|
|
445
|
+
"""
|
|
446
|
+
return "Substitution cipher on %s" % self.parent().cipher_domain()
|
|
447
|
+
|
|
448
|
+
def inverse(self):
|
|
449
|
+
E = self.parent()
|
|
450
|
+
K = E.inverse_key(self.key())
|
|
451
|
+
return E(K)
|
|
452
|
+
|
|
453
|
+
|
|
454
|
+
class TranspositionCipher(SymmetricKeyCipher):
|
|
455
|
+
"""
|
|
456
|
+
Transition cipher class
|
|
457
|
+
"""
|
|
458
|
+
def __init__(self, parent, key):
|
|
459
|
+
"""
|
|
460
|
+
Create a transposition cipher.
|
|
461
|
+
|
|
462
|
+
EXAMPLES::
|
|
463
|
+
|
|
464
|
+
sage: # needs sage.groups
|
|
465
|
+
sage: S = AlphabeticStrings()
|
|
466
|
+
sage: E = TranspositionCryptosystem(S,14); E
|
|
467
|
+
Transposition cryptosystem on
|
|
468
|
+
Free alphabetic string monoid on A-Z of block length 14
|
|
469
|
+
sage: K = [ 14-i for i in range(14) ]; K
|
|
470
|
+
[14, 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, 1]
|
|
471
|
+
sage: e = E(K)
|
|
472
|
+
sage: m = S("THECATINTHEHAT")
|
|
473
|
+
sage: e(m)
|
|
474
|
+
TAHEHTNITACEHT
|
|
475
|
+
|
|
476
|
+
EXAMPLES::
|
|
477
|
+
|
|
478
|
+
sage: # needs sage.groups
|
|
479
|
+
sage: S = AlphabeticStrings()
|
|
480
|
+
sage: E = TranspositionCryptosystem(S,15)
|
|
481
|
+
sage: m = S("THECATANDTHEHAT")
|
|
482
|
+
sage: G = E.key_space(); G
|
|
483
|
+
Symmetric group of order 15! as a permutation group
|
|
484
|
+
sage: g = G([ 3, 2, 1, 6, 5, 4, 9, 8, 7, 12, 11, 10, 15, 14, 13 ])
|
|
485
|
+
sage: e = E(g)
|
|
486
|
+
sage: e(m)
|
|
487
|
+
EHTTACDNAEHTTAH
|
|
488
|
+
|
|
489
|
+
TESTS::
|
|
490
|
+
|
|
491
|
+
sage: S = AlphabeticStrings()
|
|
492
|
+
sage: E = TranspositionCryptosystem(S,14) # needs sage.groups
|
|
493
|
+
sage: E == loads(dumps(E)) # needs sage.groups
|
|
494
|
+
True
|
|
495
|
+
"""
|
|
496
|
+
n = parent.block_length()
|
|
497
|
+
if isinstance(key, list) and not len(key) == n:
|
|
498
|
+
raise ValueError("key (= %s) must have block length %s" % (key, n))
|
|
499
|
+
SymmetricKeyCipher.__init__(self, parent, key)
|
|
500
|
+
|
|
501
|
+
def __call__(self, M, mode='ECB'):
|
|
502
|
+
S = self.domain() # = plaintext_space = ciphertext_space
|
|
503
|
+
if not isinstance(M, StringMonoidElement) and M.parent() == S:
|
|
504
|
+
raise TypeError("Argument M (= %s) must be a string in the plaintext space." % M)
|
|
505
|
+
if not mode == "ECB":
|
|
506
|
+
raise NotImplementedError("Enciphering not implemented for mode (= %s) other than 'ECB'." % mode)
|
|
507
|
+
g = self.key()
|
|
508
|
+
N = len(M)
|
|
509
|
+
m = self.parent().block_length()
|
|
510
|
+
if not N % m == 0:
|
|
511
|
+
raise TypeError("Argument M (= %s) must be a string of length k*%s." % (M, m))
|
|
512
|
+
Melt = M._element_list # this uses the internal structure of string monoids
|
|
513
|
+
# Caution: this is parsed as an outer loop in k and an inner loop in i:
|
|
514
|
+
# for k in range(N//m):
|
|
515
|
+
# for i in range(m):
|
|
516
|
+
# S([ Melt[g(i+1)-1+k*m]
|
|
517
|
+
return S([ Melt[g(i+1)-1+k*m] for k in range(N//m) for i in range(m) ])
|
|
518
|
+
|
|
519
|
+
def inverse(self):
|
|
520
|
+
E = self.parent()
|
|
521
|
+
K = E.inverse_key(self.key())
|
|
522
|
+
return E(K)
|
|
523
|
+
|
|
524
|
+
|
|
525
|
+
class VigenereCipher(SymmetricKeyCipher):
|
|
526
|
+
"""
|
|
527
|
+
Vigenere cipher class
|
|
528
|
+
"""
|
|
529
|
+
def __init__(self, parent, key):
|
|
530
|
+
"""
|
|
531
|
+
Create a Vigenere cipher.
|
|
532
|
+
|
|
533
|
+
EXAMPLES::
|
|
534
|
+
|
|
535
|
+
sage: S = AlphabeticStrings()
|
|
536
|
+
sage: E = VigenereCryptosystem(S,11)
|
|
537
|
+
sage: K = S("SHAKESPEARE")
|
|
538
|
+
sage: e = E(K)
|
|
539
|
+
sage: m = S("THECATINTHEHAT")
|
|
540
|
+
sage: e(m)
|
|
541
|
+
LOEMELXRTYIZHT
|
|
542
|
+
|
|
543
|
+
TESTS::
|
|
544
|
+
|
|
545
|
+
sage: S = AlphabeticStrings()
|
|
546
|
+
sage: E = VigenereCryptosystem(S,11)
|
|
547
|
+
sage: E == loads(dumps(E))
|
|
548
|
+
True
|
|
549
|
+
"""
|
|
550
|
+
SymmetricKeyCipher.__init__(self, parent, key)
|
|
551
|
+
|
|
552
|
+
def __call__(self, M, mode='ECB'):
|
|
553
|
+
S = self.domain() # = plaintext_space = ciphertext_space
|
|
554
|
+
if not isinstance(M, StringMonoidElement) and M.parent() == S:
|
|
555
|
+
raise TypeError("Argument M (= %s) must be a string in the plaintext space." % M)
|
|
556
|
+
if not mode == "ECB":
|
|
557
|
+
raise NotImplementedError("Enciphering not implemented for mode (= %s) other than 'ECB'." % mode)
|
|
558
|
+
K = self.key()
|
|
559
|
+
m = self.parent().period()
|
|
560
|
+
n = S.ngens()
|
|
561
|
+
# This uses the internal structure of string monoids
|
|
562
|
+
Melt = M._element_list
|
|
563
|
+
Kelt = K._element_list
|
|
564
|
+
return S([ (Melt[i]+Kelt[i % m]) % n for i in range(len(M)) ])
|
|
565
|
+
|
|
566
|
+
def inverse(self):
|
|
567
|
+
E = self.parent()
|
|
568
|
+
K = E.inverse_key(self.key())
|
|
569
|
+
return E(K)
|