passagemath-modules 10.6.31rc3__cp314-cp314-musllinux_1_2_aarch64.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.

Files changed (807) hide show
  1. passagemath_modules-10.6.31rc3.dist-info/METADATA +281 -0
  2. passagemath_modules-10.6.31rc3.dist-info/RECORD +807 -0
  3. passagemath_modules-10.6.31rc3.dist-info/WHEEL +5 -0
  4. passagemath_modules-10.6.31rc3.dist-info/top_level.txt +2 -0
  5. passagemath_modules.libs/libgcc_s-2d945d6c.so.1 +0 -0
  6. passagemath_modules.libs/libgfortran-67378ab2.so.5.0.0 +0 -0
  7. passagemath_modules.libs/libgmp-28992bcb.so.10.5.0 +0 -0
  8. passagemath_modules.libs/libgsl-23768756.so.28.0.0 +0 -0
  9. passagemath_modules.libs/libmpc-7897025b.so.3.3.1 +0 -0
  10. passagemath_modules.libs/libmpfr-e34bb864.so.6.2.1 +0 -0
  11. passagemath_modules.libs/libopenblasp-r0-503f0c35.3.29.so +0 -0
  12. sage/algebras/all__sagemath_modules.py +20 -0
  13. sage/algebras/catalog.py +148 -0
  14. sage/algebras/clifford_algebra.py +3107 -0
  15. sage/algebras/clifford_algebra_element.cpython-314-aarch64-linux-musl.so +0 -0
  16. sage/algebras/clifford_algebra_element.pxd +16 -0
  17. sage/algebras/clifford_algebra_element.pyx +997 -0
  18. sage/algebras/commutative_dga.py +4252 -0
  19. sage/algebras/exterior_algebra_groebner.cpython-314-aarch64-linux-musl.so +0 -0
  20. sage/algebras/exterior_algebra_groebner.pxd +55 -0
  21. sage/algebras/exterior_algebra_groebner.pyx +727 -0
  22. sage/algebras/finite_dimensional_algebras/all.py +2 -0
  23. sage/algebras/finite_dimensional_algebras/finite_dimensional_algebra.py +1029 -0
  24. sage/algebras/finite_dimensional_algebras/finite_dimensional_algebra_element.cpython-314-aarch64-linux-musl.so +0 -0
  25. sage/algebras/finite_dimensional_algebras/finite_dimensional_algebra_element.pxd +12 -0
  26. sage/algebras/finite_dimensional_algebras/finite_dimensional_algebra_element.pyx +706 -0
  27. sage/algebras/finite_dimensional_algebras/finite_dimensional_algebra_ideal.py +196 -0
  28. sage/algebras/finite_dimensional_algebras/finite_dimensional_algebra_morphism.py +255 -0
  29. sage/algebras/finite_gca.py +528 -0
  30. sage/algebras/group_algebra.py +232 -0
  31. sage/algebras/lie_algebras/abelian.py +197 -0
  32. sage/algebras/lie_algebras/affine_lie_algebra.py +1213 -0
  33. sage/algebras/lie_algebras/all.py +25 -0
  34. sage/algebras/lie_algebras/all__sagemath_modules.py +1 -0
  35. sage/algebras/lie_algebras/bch.py +177 -0
  36. sage/algebras/lie_algebras/bgg_dual_module.py +1184 -0
  37. sage/algebras/lie_algebras/bgg_resolution.py +232 -0
  38. sage/algebras/lie_algebras/center_uea.py +767 -0
  39. sage/algebras/lie_algebras/classical_lie_algebra.py +2516 -0
  40. sage/algebras/lie_algebras/examples.py +683 -0
  41. sage/algebras/lie_algebras/free_lie_algebra.py +973 -0
  42. sage/algebras/lie_algebras/heisenberg.py +820 -0
  43. sage/algebras/lie_algebras/lie_algebra.py +1562 -0
  44. sage/algebras/lie_algebras/lie_algebra_element.cpython-314-aarch64-linux-musl.so +0 -0
  45. sage/algebras/lie_algebras/lie_algebra_element.pxd +68 -0
  46. sage/algebras/lie_algebras/lie_algebra_element.pyx +2122 -0
  47. sage/algebras/lie_algebras/morphism.py +661 -0
  48. sage/algebras/lie_algebras/nilpotent_lie_algebra.py +457 -0
  49. sage/algebras/lie_algebras/onsager.py +1324 -0
  50. sage/algebras/lie_algebras/poincare_birkhoff_witt.py +816 -0
  51. sage/algebras/lie_algebras/quotient.py +462 -0
  52. sage/algebras/lie_algebras/rank_two_heisenberg_virasoro.py +355 -0
  53. sage/algebras/lie_algebras/representation.py +1040 -0
  54. sage/algebras/lie_algebras/structure_coefficients.py +459 -0
  55. sage/algebras/lie_algebras/subalgebra.py +967 -0
  56. sage/algebras/lie_algebras/symplectic_derivation.py +289 -0
  57. sage/algebras/lie_algebras/verma_module.py +1630 -0
  58. sage/algebras/lie_algebras/virasoro.py +1186 -0
  59. sage/algebras/octonion_algebra.cpython-314-aarch64-linux-musl.so +0 -0
  60. sage/algebras/octonion_algebra.pxd +20 -0
  61. sage/algebras/octonion_algebra.pyx +987 -0
  62. sage/algebras/orlik_solomon.py +907 -0
  63. sage/algebras/orlik_terao.py +779 -0
  64. sage/algebras/steenrod/all.py +7 -0
  65. sage/algebras/steenrod/steenrod_algebra.py +4258 -0
  66. sage/algebras/steenrod/steenrod_algebra_bases.py +1179 -0
  67. sage/algebras/steenrod/steenrod_algebra_misc.py +1167 -0
  68. sage/algebras/steenrod/steenrod_algebra_mult.py +954 -0
  69. sage/algebras/weyl_algebra.py +1126 -0
  70. sage/all__sagemath_modules.py +62 -0
  71. sage/calculus/all__sagemath_modules.py +19 -0
  72. sage/calculus/expr.py +205 -0
  73. sage/calculus/integration.cpython-314-aarch64-linux-musl.so +0 -0
  74. sage/calculus/integration.pyx +698 -0
  75. sage/calculus/interpolation.cpython-314-aarch64-linux-musl.so +0 -0
  76. sage/calculus/interpolation.pxd +13 -0
  77. sage/calculus/interpolation.pyx +387 -0
  78. sage/calculus/interpolators.cpython-314-aarch64-linux-musl.so +0 -0
  79. sage/calculus/interpolators.pyx +326 -0
  80. sage/calculus/ode.cpython-314-aarch64-linux-musl.so +0 -0
  81. sage/calculus/ode.pxd +5 -0
  82. sage/calculus/ode.pyx +610 -0
  83. sage/calculus/riemann.cpython-314-aarch64-linux-musl.so +0 -0
  84. sage/calculus/riemann.pyx +1521 -0
  85. sage/calculus/test_sympy.py +201 -0
  86. sage/calculus/transforms/all.py +7 -0
  87. sage/calculus/transforms/dft.py +844 -0
  88. sage/calculus/transforms/dwt.cpython-314-aarch64-linux-musl.so +0 -0
  89. sage/calculus/transforms/dwt.pxd +7 -0
  90. sage/calculus/transforms/dwt.pyx +160 -0
  91. sage/calculus/transforms/fft.cpython-314-aarch64-linux-musl.so +0 -0
  92. sage/calculus/transforms/fft.pxd +12 -0
  93. sage/calculus/transforms/fft.pyx +487 -0
  94. sage/calculus/wester.py +662 -0
  95. sage/coding/abstract_code.py +1108 -0
  96. sage/coding/ag_code.py +868 -0
  97. sage/coding/ag_code_decoders.cpython-314-aarch64-linux-musl.so +0 -0
  98. sage/coding/ag_code_decoders.pyx +2639 -0
  99. sage/coding/all.py +15 -0
  100. sage/coding/bch_code.py +494 -0
  101. sage/coding/binary_code.cpython-314-aarch64-linux-musl.so +0 -0
  102. sage/coding/binary_code.pxd +124 -0
  103. sage/coding/binary_code.pyx +4139 -0
  104. sage/coding/bounds_catalog.py +43 -0
  105. sage/coding/channel.py +819 -0
  106. sage/coding/channels_catalog.py +29 -0
  107. sage/coding/code_bounds.py +755 -0
  108. sage/coding/code_constructions.py +804 -0
  109. sage/coding/codes_catalog.py +111 -0
  110. sage/coding/cyclic_code.py +1329 -0
  111. sage/coding/databases.py +316 -0
  112. sage/coding/decoder.py +373 -0
  113. sage/coding/decoders_catalog.py +88 -0
  114. sage/coding/delsarte_bounds.py +709 -0
  115. sage/coding/encoder.py +390 -0
  116. sage/coding/encoders_catalog.py +64 -0
  117. sage/coding/extended_code.py +468 -0
  118. sage/coding/gabidulin_code.py +1058 -0
  119. sage/coding/golay_code.py +404 -0
  120. sage/coding/goppa_code.py +441 -0
  121. sage/coding/grs_code.py +2371 -0
  122. sage/coding/guava.py +107 -0
  123. sage/coding/guruswami_sudan/all.py +1 -0
  124. sage/coding/guruswami_sudan/gs_decoder.py +897 -0
  125. sage/coding/guruswami_sudan/interpolation.py +409 -0
  126. sage/coding/guruswami_sudan/utils.py +176 -0
  127. sage/coding/hamming_code.py +176 -0
  128. sage/coding/information_set_decoder.py +1032 -0
  129. sage/coding/kasami_codes.cpython-314-aarch64-linux-musl.so +0 -0
  130. sage/coding/kasami_codes.pyx +351 -0
  131. sage/coding/linear_code.py +3067 -0
  132. sage/coding/linear_code_no_metric.py +1354 -0
  133. sage/coding/linear_rank_metric.py +961 -0
  134. sage/coding/parity_check_code.py +353 -0
  135. sage/coding/punctured_code.py +719 -0
  136. sage/coding/reed_muller_code.py +999 -0
  137. sage/coding/self_dual_codes.py +942 -0
  138. sage/coding/source_coding/all.py +2 -0
  139. sage/coding/source_coding/huffman.py +553 -0
  140. sage/coding/subfield_subcode.py +423 -0
  141. sage/coding/two_weight_db.py +399 -0
  142. sage/combinat/all__sagemath_modules.py +7 -0
  143. sage/combinat/cartesian_product.py +347 -0
  144. sage/combinat/family.py +11 -0
  145. sage/combinat/free_module.py +1977 -0
  146. sage/combinat/root_system/all.py +147 -0
  147. sage/combinat/root_system/ambient_space.py +527 -0
  148. sage/combinat/root_system/associahedron.py +471 -0
  149. sage/combinat/root_system/braid_move_calculator.py +143 -0
  150. sage/combinat/root_system/braid_orbit.cpython-314-aarch64-linux-musl.so +0 -0
  151. sage/combinat/root_system/braid_orbit.pyx +144 -0
  152. sage/combinat/root_system/branching_rules.py +2301 -0
  153. sage/combinat/root_system/cartan_matrix.py +1245 -0
  154. sage/combinat/root_system/cartan_type.py +3069 -0
  155. sage/combinat/root_system/coxeter_group.py +162 -0
  156. sage/combinat/root_system/coxeter_matrix.py +1261 -0
  157. sage/combinat/root_system/coxeter_type.py +681 -0
  158. sage/combinat/root_system/dynkin_diagram.py +900 -0
  159. sage/combinat/root_system/extended_affine_weyl_group.py +2993 -0
  160. sage/combinat/root_system/fundamental_group.py +795 -0
  161. sage/combinat/root_system/hecke_algebra_representation.py +1203 -0
  162. sage/combinat/root_system/integrable_representations.py +1227 -0
  163. sage/combinat/root_system/non_symmetric_macdonald_polynomials.py +1965 -0
  164. sage/combinat/root_system/pieri_factors.py +1147 -0
  165. sage/combinat/root_system/plot.py +1615 -0
  166. sage/combinat/root_system/root_lattice_realization_algebras.py +1214 -0
  167. sage/combinat/root_system/root_lattice_realizations.py +4628 -0
  168. sage/combinat/root_system/root_space.py +487 -0
  169. sage/combinat/root_system/root_system.py +882 -0
  170. sage/combinat/root_system/type_A.py +348 -0
  171. sage/combinat/root_system/type_A_affine.py +227 -0
  172. sage/combinat/root_system/type_A_infinity.py +241 -0
  173. sage/combinat/root_system/type_B.py +347 -0
  174. sage/combinat/root_system/type_BC_affine.py +287 -0
  175. sage/combinat/root_system/type_B_affine.py +216 -0
  176. sage/combinat/root_system/type_C.py +317 -0
  177. sage/combinat/root_system/type_C_affine.py +188 -0
  178. sage/combinat/root_system/type_D.py +357 -0
  179. sage/combinat/root_system/type_D_affine.py +208 -0
  180. sage/combinat/root_system/type_E.py +641 -0
  181. sage/combinat/root_system/type_E_affine.py +231 -0
  182. sage/combinat/root_system/type_F.py +387 -0
  183. sage/combinat/root_system/type_F_affine.py +137 -0
  184. sage/combinat/root_system/type_G.py +293 -0
  185. sage/combinat/root_system/type_G_affine.py +132 -0
  186. sage/combinat/root_system/type_H.py +105 -0
  187. sage/combinat/root_system/type_I.py +110 -0
  188. sage/combinat/root_system/type_Q.py +150 -0
  189. sage/combinat/root_system/type_affine.py +509 -0
  190. sage/combinat/root_system/type_dual.py +704 -0
  191. sage/combinat/root_system/type_folded.py +301 -0
  192. sage/combinat/root_system/type_marked.py +748 -0
  193. sage/combinat/root_system/type_reducible.py +601 -0
  194. sage/combinat/root_system/type_relabel.py +730 -0
  195. sage/combinat/root_system/type_super_A.py +837 -0
  196. sage/combinat/root_system/weight_lattice_realizations.py +1188 -0
  197. sage/combinat/root_system/weight_space.py +639 -0
  198. sage/combinat/root_system/weyl_characters.py +2238 -0
  199. sage/crypto/__init__.py +4 -0
  200. sage/crypto/all.py +28 -0
  201. sage/crypto/block_cipher/all.py +7 -0
  202. sage/crypto/block_cipher/des.py +1065 -0
  203. sage/crypto/block_cipher/miniaes.py +2171 -0
  204. sage/crypto/block_cipher/present.py +909 -0
  205. sage/crypto/block_cipher/sdes.py +1527 -0
  206. sage/crypto/boolean_function.cpython-314-aarch64-linux-musl.so +0 -0
  207. sage/crypto/boolean_function.pxd +10 -0
  208. sage/crypto/boolean_function.pyx +1487 -0
  209. sage/crypto/cipher.py +78 -0
  210. sage/crypto/classical.py +3668 -0
  211. sage/crypto/classical_cipher.py +569 -0
  212. sage/crypto/cryptosystem.py +387 -0
  213. sage/crypto/key_exchange/all.py +7 -0
  214. sage/crypto/key_exchange/catalog.py +24 -0
  215. sage/crypto/key_exchange/diffie_hellman.py +323 -0
  216. sage/crypto/key_exchange/key_exchange_scheme.py +107 -0
  217. sage/crypto/lattice.py +312 -0
  218. sage/crypto/lfsr.py +295 -0
  219. sage/crypto/lwe.py +840 -0
  220. sage/crypto/mq/__init__.py +4 -0
  221. sage/crypto/mq/mpolynomialsystemgenerator.py +204 -0
  222. sage/crypto/mq/rijndael_gf.py +2345 -0
  223. sage/crypto/mq/sbox.py +7 -0
  224. sage/crypto/mq/sr.py +3344 -0
  225. sage/crypto/public_key/all.py +5 -0
  226. sage/crypto/public_key/blum_goldwasser.py +776 -0
  227. sage/crypto/sbox.cpython-314-aarch64-linux-musl.so +0 -0
  228. sage/crypto/sbox.pyx +2090 -0
  229. sage/crypto/sboxes.py +2090 -0
  230. sage/crypto/stream.py +390 -0
  231. sage/crypto/stream_cipher.py +297 -0
  232. sage/crypto/util.py +519 -0
  233. sage/ext/all__sagemath_modules.py +1 -0
  234. sage/ext/interpreters/__init__.py +1 -0
  235. sage/ext/interpreters/all__sagemath_modules.py +2 -0
  236. sage/ext/interpreters/wrapper_cc.cpython-314-aarch64-linux-musl.so +0 -0
  237. sage/ext/interpreters/wrapper_cc.pxd +30 -0
  238. sage/ext/interpreters/wrapper_cc.pyx +252 -0
  239. sage/ext/interpreters/wrapper_cdf.cpython-314-aarch64-linux-musl.so +0 -0
  240. sage/ext/interpreters/wrapper_cdf.pxd +26 -0
  241. sage/ext/interpreters/wrapper_cdf.pyx +245 -0
  242. sage/ext/interpreters/wrapper_rdf.cpython-314-aarch64-linux-musl.so +0 -0
  243. sage/ext/interpreters/wrapper_rdf.pxd +23 -0
  244. sage/ext/interpreters/wrapper_rdf.pyx +221 -0
  245. sage/ext/interpreters/wrapper_rr.cpython-314-aarch64-linux-musl.so +0 -0
  246. sage/ext/interpreters/wrapper_rr.pxd +28 -0
  247. sage/ext/interpreters/wrapper_rr.pyx +335 -0
  248. sage/geometry/all__sagemath_modules.py +5 -0
  249. sage/geometry/toric_lattice.py +1745 -0
  250. sage/geometry/toric_lattice_element.cpython-314-aarch64-linux-musl.so +0 -0
  251. sage/geometry/toric_lattice_element.pyx +432 -0
  252. sage/groups/abelian_gps/abelian_group.py +1925 -0
  253. sage/groups/abelian_gps/abelian_group_element.py +164 -0
  254. sage/groups/abelian_gps/all__sagemath_modules.py +5 -0
  255. sage/groups/abelian_gps/dual_abelian_group.py +421 -0
  256. sage/groups/abelian_gps/dual_abelian_group_element.py +179 -0
  257. sage/groups/abelian_gps/element_base.py +341 -0
  258. sage/groups/abelian_gps/values.py +488 -0
  259. sage/groups/additive_abelian/additive_abelian_group.py +476 -0
  260. sage/groups/additive_abelian/additive_abelian_wrapper.py +857 -0
  261. sage/groups/additive_abelian/all.py +4 -0
  262. sage/groups/additive_abelian/qmodnz.py +231 -0
  263. sage/groups/additive_abelian/qmodnz_element.py +349 -0
  264. sage/groups/affine_gps/affine_group.py +535 -0
  265. sage/groups/affine_gps/all.py +1 -0
  266. sage/groups/affine_gps/catalog.py +17 -0
  267. sage/groups/affine_gps/euclidean_group.py +246 -0
  268. sage/groups/affine_gps/group_element.py +562 -0
  269. sage/groups/all__sagemath_modules.py +12 -0
  270. sage/groups/galois_group.py +479 -0
  271. sage/groups/matrix_gps/all.py +4 -0
  272. sage/groups/matrix_gps/all__sagemath_modules.py +13 -0
  273. sage/groups/matrix_gps/catalog.py +26 -0
  274. sage/groups/matrix_gps/coxeter_group.py +927 -0
  275. sage/groups/matrix_gps/finitely_generated.py +487 -0
  276. sage/groups/matrix_gps/group_element.cpython-314-aarch64-linux-musl.so +0 -0
  277. sage/groups/matrix_gps/group_element.pxd +11 -0
  278. sage/groups/matrix_gps/group_element.pyx +431 -0
  279. sage/groups/matrix_gps/linear.py +440 -0
  280. sage/groups/matrix_gps/matrix_group.py +617 -0
  281. sage/groups/matrix_gps/named_group.py +296 -0
  282. sage/groups/matrix_gps/orthogonal.py +544 -0
  283. sage/groups/matrix_gps/symplectic.py +251 -0
  284. sage/groups/matrix_gps/unitary.py +436 -0
  285. sage/groups/misc_gps/all__sagemath_modules.py +1 -0
  286. sage/groups/misc_gps/argument_groups.py +1905 -0
  287. sage/groups/misc_gps/imaginary_groups.py +479 -0
  288. sage/groups/perm_gps/all__sagemath_modules.py +1 -0
  289. sage/groups/perm_gps/partn_ref/all__sagemath_modules.py +1 -0
  290. sage/groups/perm_gps/partn_ref/refinement_binary.cpython-314-aarch64-linux-musl.so +0 -0
  291. sage/groups/perm_gps/partn_ref/refinement_binary.pxd +41 -0
  292. sage/groups/perm_gps/partn_ref/refinement_binary.pyx +1167 -0
  293. sage/groups/perm_gps/partn_ref/refinement_matrices.cpython-314-aarch64-linux-musl.so +0 -0
  294. sage/groups/perm_gps/partn_ref/refinement_matrices.pxd +31 -0
  295. sage/groups/perm_gps/partn_ref/refinement_matrices.pyx +385 -0
  296. sage/homology/algebraic_topological_model.py +595 -0
  297. sage/homology/all.py +2 -0
  298. sage/homology/all__sagemath_modules.py +8 -0
  299. sage/homology/chain_complex.py +2148 -0
  300. sage/homology/chain_complex_homspace.py +165 -0
  301. sage/homology/chain_complex_morphism.py +629 -0
  302. sage/homology/chain_homotopy.py +604 -0
  303. sage/homology/chains.py +653 -0
  304. sage/homology/free_resolution.py +923 -0
  305. sage/homology/graded_resolution.py +567 -0
  306. sage/homology/hochschild_complex.py +756 -0
  307. sage/homology/homology_group.py +188 -0
  308. sage/homology/homology_morphism.py +422 -0
  309. sage/homology/homology_vector_space_with_basis.py +1454 -0
  310. sage/homology/koszul_complex.py +169 -0
  311. sage/homology/matrix_utils.py +205 -0
  312. sage/libs/all__sagemath_modules.py +1 -0
  313. sage/libs/gsl/__init__.py +1 -0
  314. sage/libs/gsl/airy.pxd +56 -0
  315. sage/libs/gsl/all.pxd +66 -0
  316. sage/libs/gsl/array.cpython-314-aarch64-linux-musl.so +0 -0
  317. sage/libs/gsl/array.pxd +5 -0
  318. sage/libs/gsl/array.pyx +102 -0
  319. sage/libs/gsl/bessel.pxd +208 -0
  320. sage/libs/gsl/blas.pxd +116 -0
  321. sage/libs/gsl/blas_types.pxd +34 -0
  322. sage/libs/gsl/block.pxd +52 -0
  323. sage/libs/gsl/chebyshev.pxd +37 -0
  324. sage/libs/gsl/clausen.pxd +12 -0
  325. sage/libs/gsl/combination.pxd +47 -0
  326. sage/libs/gsl/complex.pxd +151 -0
  327. sage/libs/gsl/coulomb.pxd +30 -0
  328. sage/libs/gsl/coupling.pxd +21 -0
  329. sage/libs/gsl/dawson.pxd +12 -0
  330. sage/libs/gsl/debye.pxd +24 -0
  331. sage/libs/gsl/dilog.pxd +14 -0
  332. sage/libs/gsl/eigen.pxd +46 -0
  333. sage/libs/gsl/elementary.pxd +12 -0
  334. sage/libs/gsl/ellint.pxd +48 -0
  335. sage/libs/gsl/elljac.pxd +8 -0
  336. sage/libs/gsl/erf.pxd +32 -0
  337. sage/libs/gsl/errno.pxd +26 -0
  338. sage/libs/gsl/exp.pxd +44 -0
  339. sage/libs/gsl/expint.pxd +44 -0
  340. sage/libs/gsl/fermi_dirac.pxd +44 -0
  341. sage/libs/gsl/fft.pxd +121 -0
  342. sage/libs/gsl/fit.pxd +50 -0
  343. sage/libs/gsl/gamma.pxd +94 -0
  344. sage/libs/gsl/gegenbauer.pxd +26 -0
  345. sage/libs/gsl/histogram.pxd +176 -0
  346. sage/libs/gsl/hyperg.pxd +52 -0
  347. sage/libs/gsl/integration.pxd +69 -0
  348. sage/libs/gsl/interp.pxd +109 -0
  349. sage/libs/gsl/laguerre.pxd +24 -0
  350. sage/libs/gsl/lambert.pxd +16 -0
  351. sage/libs/gsl/legendre.pxd +90 -0
  352. sage/libs/gsl/linalg.pxd +185 -0
  353. sage/libs/gsl/log.pxd +26 -0
  354. sage/libs/gsl/math.pxd +43 -0
  355. sage/libs/gsl/matrix.pxd +143 -0
  356. sage/libs/gsl/matrix_complex.pxd +130 -0
  357. sage/libs/gsl/min.pxd +67 -0
  358. sage/libs/gsl/monte.pxd +56 -0
  359. sage/libs/gsl/ntuple.pxd +32 -0
  360. sage/libs/gsl/odeiv.pxd +70 -0
  361. sage/libs/gsl/permutation.pxd +78 -0
  362. sage/libs/gsl/poly.pxd +40 -0
  363. sage/libs/gsl/pow_int.pxd +12 -0
  364. sage/libs/gsl/psi.pxd +28 -0
  365. sage/libs/gsl/qrng.pxd +29 -0
  366. sage/libs/gsl/random.pxd +257 -0
  367. sage/libs/gsl/rng.pxd +100 -0
  368. sage/libs/gsl/roots.pxd +72 -0
  369. sage/libs/gsl/sort.pxd +36 -0
  370. sage/libs/gsl/statistics.pxd +59 -0
  371. sage/libs/gsl/sum.pxd +55 -0
  372. sage/libs/gsl/synchrotron.pxd +16 -0
  373. sage/libs/gsl/transport.pxd +24 -0
  374. sage/libs/gsl/trig.pxd +58 -0
  375. sage/libs/gsl/types.pxd +137 -0
  376. sage/libs/gsl/vector.pxd +101 -0
  377. sage/libs/gsl/vector_complex.pxd +83 -0
  378. sage/libs/gsl/wavelet.pxd +49 -0
  379. sage/libs/gsl/zeta.pxd +28 -0
  380. sage/libs/mpc/__init__.pxd +114 -0
  381. sage/libs/mpc/types.pxd +28 -0
  382. sage/libs/mpfr/__init__.pxd +299 -0
  383. sage/libs/mpfr/types.pxd +26 -0
  384. sage/libs/mpmath/__init__.py +1 -0
  385. sage/libs/mpmath/all.py +27 -0
  386. sage/libs/mpmath/all__sagemath_modules.py +1 -0
  387. sage/libs/mpmath/utils.cpython-314-aarch64-linux-musl.so +0 -0
  388. sage/libs/mpmath/utils.pxd +4 -0
  389. sage/libs/mpmath/utils.pyx +319 -0
  390. sage/matrix/action.cpython-314-aarch64-linux-musl.so +0 -0
  391. sage/matrix/action.pxd +26 -0
  392. sage/matrix/action.pyx +596 -0
  393. sage/matrix/all.py +9 -0
  394. sage/matrix/args.cpython-314-aarch64-linux-musl.so +0 -0
  395. sage/matrix/args.pxd +144 -0
  396. sage/matrix/args.pyx +1668 -0
  397. sage/matrix/benchmark.py +1258 -0
  398. sage/matrix/berlekamp_massey.py +95 -0
  399. sage/matrix/compute_J_ideal.py +926 -0
  400. sage/matrix/constructor.cpython-314-aarch64-linux-musl.so +0 -0
  401. sage/matrix/constructor.pyx +750 -0
  402. sage/matrix/docs.py +430 -0
  403. sage/matrix/echelon_matrix.cpython-314-aarch64-linux-musl.so +0 -0
  404. sage/matrix/echelon_matrix.pyx +155 -0
  405. sage/matrix/matrix.pxd +2 -0
  406. sage/matrix/matrix0.cpython-314-aarch64-linux-musl.so +0 -0
  407. sage/matrix/matrix0.pxd +68 -0
  408. sage/matrix/matrix0.pyx +6324 -0
  409. sage/matrix/matrix1.cpython-314-aarch64-linux-musl.so +0 -0
  410. sage/matrix/matrix1.pxd +8 -0
  411. sage/matrix/matrix1.pyx +2851 -0
  412. sage/matrix/matrix2.cpython-314-aarch64-linux-musl.so +0 -0
  413. sage/matrix/matrix2.pxd +25 -0
  414. sage/matrix/matrix2.pyx +20181 -0
  415. sage/matrix/matrix_cdv.cpython-314-aarch64-linux-musl.so +0 -0
  416. sage/matrix/matrix_cdv.pxd +4 -0
  417. sage/matrix/matrix_cdv.pyx +93 -0
  418. sage/matrix/matrix_complex_double_dense.cpython-314-aarch64-linux-musl.so +0 -0
  419. sage/matrix/matrix_complex_double_dense.pxd +5 -0
  420. sage/matrix/matrix_complex_double_dense.pyx +98 -0
  421. sage/matrix/matrix_dense.cpython-314-aarch64-linux-musl.so +0 -0
  422. sage/matrix/matrix_dense.pxd +5 -0
  423. sage/matrix/matrix_dense.pyx +343 -0
  424. sage/matrix/matrix_domain_dense.pxd +5 -0
  425. sage/matrix/matrix_domain_sparse.pxd +5 -0
  426. sage/matrix/matrix_double_dense.cpython-314-aarch64-linux-musl.so +0 -0
  427. sage/matrix/matrix_double_dense.pxd +7 -0
  428. sage/matrix/matrix_double_dense.pyx +3906 -0
  429. sage/matrix/matrix_double_sparse.cpython-314-aarch64-linux-musl.so +0 -0
  430. sage/matrix/matrix_double_sparse.pxd +6 -0
  431. sage/matrix/matrix_double_sparse.pyx +248 -0
  432. sage/matrix/matrix_generic_dense.cpython-314-aarch64-linux-musl.so +0 -0
  433. sage/matrix/matrix_generic_dense.pxd +7 -0
  434. sage/matrix/matrix_generic_dense.pyx +354 -0
  435. sage/matrix/matrix_generic_sparse.cpython-314-aarch64-linux-musl.so +0 -0
  436. sage/matrix/matrix_generic_sparse.pxd +7 -0
  437. sage/matrix/matrix_generic_sparse.pyx +461 -0
  438. sage/matrix/matrix_laurent_mpolynomial_dense.cpython-314-aarch64-linux-musl.so +0 -0
  439. sage/matrix/matrix_laurent_mpolynomial_dense.pxd +5 -0
  440. sage/matrix/matrix_laurent_mpolynomial_dense.pyx +115 -0
  441. sage/matrix/matrix_misc.py +313 -0
  442. sage/matrix/matrix_numpy_dense.cpython-314-aarch64-linux-musl.so +0 -0
  443. sage/matrix/matrix_numpy_dense.pxd +14 -0
  444. sage/matrix/matrix_numpy_dense.pyx +450 -0
  445. sage/matrix/matrix_numpy_integer_dense.cpython-314-aarch64-linux-musl.so +0 -0
  446. sage/matrix/matrix_numpy_integer_dense.pxd +7 -0
  447. sage/matrix/matrix_numpy_integer_dense.pyx +59 -0
  448. sage/matrix/matrix_polynomial_dense.cpython-314-aarch64-linux-musl.so +0 -0
  449. sage/matrix/matrix_polynomial_dense.pxd +5 -0
  450. sage/matrix/matrix_polynomial_dense.pyx +5341 -0
  451. sage/matrix/matrix_real_double_dense.cpython-314-aarch64-linux-musl.so +0 -0
  452. sage/matrix/matrix_real_double_dense.pxd +7 -0
  453. sage/matrix/matrix_real_double_dense.pyx +122 -0
  454. sage/matrix/matrix_space.py +2848 -0
  455. sage/matrix/matrix_sparse.cpython-314-aarch64-linux-musl.so +0 -0
  456. sage/matrix/matrix_sparse.pxd +5 -0
  457. sage/matrix/matrix_sparse.pyx +1222 -0
  458. sage/matrix/matrix_window.cpython-314-aarch64-linux-musl.so +0 -0
  459. sage/matrix/matrix_window.pxd +37 -0
  460. sage/matrix/matrix_window.pyx +242 -0
  461. sage/matrix/misc_mpfr.cpython-314-aarch64-linux-musl.so +0 -0
  462. sage/matrix/misc_mpfr.pyx +80 -0
  463. sage/matrix/operation_table.py +1182 -0
  464. sage/matrix/special.py +3666 -0
  465. sage/matrix/strassen.cpython-314-aarch64-linux-musl.so +0 -0
  466. sage/matrix/strassen.pyx +851 -0
  467. sage/matrix/symplectic_basis.py +541 -0
  468. sage/matrix/template.pxd +6 -0
  469. sage/matrix/tests.py +71 -0
  470. sage/matroids/advanced.py +77 -0
  471. sage/matroids/all.py +13 -0
  472. sage/matroids/basis_exchange_matroid.cpython-314-aarch64-linux-musl.so +0 -0
  473. sage/matroids/basis_exchange_matroid.pxd +96 -0
  474. sage/matroids/basis_exchange_matroid.pyx +2344 -0
  475. sage/matroids/basis_matroid.cpython-314-aarch64-linux-musl.so +0 -0
  476. sage/matroids/basis_matroid.pxd +45 -0
  477. sage/matroids/basis_matroid.pyx +1217 -0
  478. sage/matroids/catalog.py +44 -0
  479. sage/matroids/chow_ring.py +473 -0
  480. sage/matroids/chow_ring_ideal.py +849 -0
  481. sage/matroids/circuit_closures_matroid.cpython-314-aarch64-linux-musl.so +0 -0
  482. sage/matroids/circuit_closures_matroid.pxd +16 -0
  483. sage/matroids/circuit_closures_matroid.pyx +559 -0
  484. sage/matroids/circuits_matroid.cpython-314-aarch64-linux-musl.so +0 -0
  485. sage/matroids/circuits_matroid.pxd +38 -0
  486. sage/matroids/circuits_matroid.pyx +947 -0
  487. sage/matroids/constructor.py +1086 -0
  488. sage/matroids/database_collections.py +365 -0
  489. sage/matroids/database_matroids.py +5338 -0
  490. sage/matroids/dual_matroid.py +583 -0
  491. sage/matroids/extension.cpython-314-aarch64-linux-musl.so +0 -0
  492. sage/matroids/extension.pxd +34 -0
  493. sage/matroids/extension.pyx +519 -0
  494. sage/matroids/flats_matroid.cpython-314-aarch64-linux-musl.so +0 -0
  495. sage/matroids/flats_matroid.pxd +28 -0
  496. sage/matroids/flats_matroid.pyx +715 -0
  497. sage/matroids/gammoid.py +600 -0
  498. sage/matroids/graphic_matroid.cpython-314-aarch64-linux-musl.so +0 -0
  499. sage/matroids/graphic_matroid.pxd +39 -0
  500. sage/matroids/graphic_matroid.pyx +2024 -0
  501. sage/matroids/lean_matrix.cpython-314-aarch64-linux-musl.so +0 -0
  502. sage/matroids/lean_matrix.pxd +126 -0
  503. sage/matroids/lean_matrix.pyx +3667 -0
  504. sage/matroids/linear_matroid.cpython-314-aarch64-linux-musl.so +0 -0
  505. sage/matroids/linear_matroid.pxd +180 -0
  506. sage/matroids/linear_matroid.pyx +6649 -0
  507. sage/matroids/matroid.cpython-314-aarch64-linux-musl.so +0 -0
  508. sage/matroids/matroid.pxd +243 -0
  509. sage/matroids/matroid.pyx +8759 -0
  510. sage/matroids/matroids_catalog.py +190 -0
  511. sage/matroids/matroids_plot_helpers.py +890 -0
  512. sage/matroids/minor_matroid.py +480 -0
  513. sage/matroids/minorfix.h +9 -0
  514. sage/matroids/named_matroids.py +5 -0
  515. sage/matroids/rank_matroid.py +268 -0
  516. sage/matroids/set_system.cpython-314-aarch64-linux-musl.so +0 -0
  517. sage/matroids/set_system.pxd +38 -0
  518. sage/matroids/set_system.pyx +800 -0
  519. sage/matroids/transversal_matroid.cpython-314-aarch64-linux-musl.so +0 -0
  520. sage/matroids/transversal_matroid.pxd +14 -0
  521. sage/matroids/transversal_matroid.pyx +893 -0
  522. sage/matroids/union_matroid.cpython-314-aarch64-linux-musl.so +0 -0
  523. sage/matroids/union_matroid.pxd +20 -0
  524. sage/matroids/union_matroid.pyx +331 -0
  525. sage/matroids/unpickling.cpython-314-aarch64-linux-musl.so +0 -0
  526. sage/matroids/unpickling.pyx +843 -0
  527. sage/matroids/utilities.py +809 -0
  528. sage/misc/all__sagemath_modules.py +20 -0
  529. sage/misc/c3.cpython-314-aarch64-linux-musl.so +0 -0
  530. sage/misc/c3.pyx +238 -0
  531. sage/misc/compat.py +87 -0
  532. sage/misc/element_with_label.py +173 -0
  533. sage/misc/func_persist.py +79 -0
  534. sage/misc/pickle_old.cpython-314-aarch64-linux-musl.so +0 -0
  535. sage/misc/pickle_old.pyx +19 -0
  536. sage/misc/proof.py +7 -0
  537. sage/misc/replace_dot_all.py +472 -0
  538. sage/misc/sagedoc_conf.py +168 -0
  539. sage/misc/sphinxify.py +167 -0
  540. sage/misc/test_class_pickling.py +85 -0
  541. sage/modules/all.py +42 -0
  542. sage/modules/complex_double_vector.py +25 -0
  543. sage/modules/diamond_cutting.py +380 -0
  544. sage/modules/fg_pid/all.py +1 -0
  545. sage/modules/fg_pid/fgp_element.py +456 -0
  546. sage/modules/fg_pid/fgp_module.py +2091 -0
  547. sage/modules/fg_pid/fgp_morphism.py +550 -0
  548. sage/modules/filtered_vector_space.py +1271 -0
  549. sage/modules/finite_submodule_iter.cpython-314-aarch64-linux-musl.so +0 -0
  550. sage/modules/finite_submodule_iter.pxd +27 -0
  551. sage/modules/finite_submodule_iter.pyx +452 -0
  552. sage/modules/fp_graded/all.py +1 -0
  553. sage/modules/fp_graded/element.py +346 -0
  554. sage/modules/fp_graded/free_element.py +298 -0
  555. sage/modules/fp_graded/free_homspace.py +53 -0
  556. sage/modules/fp_graded/free_module.py +1060 -0
  557. sage/modules/fp_graded/free_morphism.py +217 -0
  558. sage/modules/fp_graded/homspace.py +563 -0
  559. sage/modules/fp_graded/module.py +1340 -0
  560. sage/modules/fp_graded/morphism.py +1990 -0
  561. sage/modules/fp_graded/steenrod/all.py +1 -0
  562. sage/modules/fp_graded/steenrod/homspace.py +65 -0
  563. sage/modules/fp_graded/steenrod/module.py +477 -0
  564. sage/modules/fp_graded/steenrod/morphism.py +404 -0
  565. sage/modules/fp_graded/steenrod/profile.py +241 -0
  566. sage/modules/free_module.py +8447 -0
  567. sage/modules/free_module_element.cpython-314-aarch64-linux-musl.so +0 -0
  568. sage/modules/free_module_element.pxd +22 -0
  569. sage/modules/free_module_element.pyx +5445 -0
  570. sage/modules/free_module_homspace.py +369 -0
  571. sage/modules/free_module_integer.py +896 -0
  572. sage/modules/free_module_morphism.py +823 -0
  573. sage/modules/free_module_pseudohomspace.py +352 -0
  574. sage/modules/free_module_pseudomorphism.py +578 -0
  575. sage/modules/free_quadratic_module.py +1706 -0
  576. sage/modules/free_quadratic_module_integer_symmetric.py +1790 -0
  577. sage/modules/matrix_morphism.py +1745 -0
  578. sage/modules/misc.py +103 -0
  579. sage/modules/module_functors.py +192 -0
  580. sage/modules/multi_filtered_vector_space.py +719 -0
  581. sage/modules/ore_module.py +2208 -0
  582. sage/modules/ore_module_element.py +178 -0
  583. sage/modules/ore_module_homspace.py +147 -0
  584. sage/modules/ore_module_morphism.py +968 -0
  585. sage/modules/quotient_module.py +699 -0
  586. sage/modules/real_double_vector.py +22 -0
  587. sage/modules/submodule.py +255 -0
  588. sage/modules/tensor_operations.py +567 -0
  589. sage/modules/torsion_quadratic_module.py +1352 -0
  590. sage/modules/tutorial_free_modules.py +248 -0
  591. sage/modules/vector_complex_double_dense.cpython-314-aarch64-linux-musl.so +0 -0
  592. sage/modules/vector_complex_double_dense.pxd +6 -0
  593. sage/modules/vector_complex_double_dense.pyx +117 -0
  594. sage/modules/vector_double_dense.cpython-314-aarch64-linux-musl.so +0 -0
  595. sage/modules/vector_double_dense.pxd +6 -0
  596. sage/modules/vector_double_dense.pyx +604 -0
  597. sage/modules/vector_integer_dense.cpython-314-aarch64-linux-musl.so +0 -0
  598. sage/modules/vector_integer_dense.pxd +15 -0
  599. sage/modules/vector_integer_dense.pyx +361 -0
  600. sage/modules/vector_integer_sparse.cpython-314-aarch64-linux-musl.so +0 -0
  601. sage/modules/vector_integer_sparse.pxd +29 -0
  602. sage/modules/vector_integer_sparse.pyx +406 -0
  603. sage/modules/vector_modn_dense.cpython-314-aarch64-linux-musl.so +0 -0
  604. sage/modules/vector_modn_dense.pxd +12 -0
  605. sage/modules/vector_modn_dense.pyx +394 -0
  606. sage/modules/vector_modn_sparse.cpython-314-aarch64-linux-musl.so +0 -0
  607. sage/modules/vector_modn_sparse.pxd +21 -0
  608. sage/modules/vector_modn_sparse.pyx +298 -0
  609. sage/modules/vector_numpy_dense.cpython-314-aarch64-linux-musl.so +0 -0
  610. sage/modules/vector_numpy_dense.pxd +15 -0
  611. sage/modules/vector_numpy_dense.pyx +304 -0
  612. sage/modules/vector_numpy_integer_dense.cpython-314-aarch64-linux-musl.so +0 -0
  613. sage/modules/vector_numpy_integer_dense.pxd +7 -0
  614. sage/modules/vector_numpy_integer_dense.pyx +54 -0
  615. sage/modules/vector_rational_dense.cpython-314-aarch64-linux-musl.so +0 -0
  616. sage/modules/vector_rational_dense.pxd +15 -0
  617. sage/modules/vector_rational_dense.pyx +387 -0
  618. sage/modules/vector_rational_sparse.cpython-314-aarch64-linux-musl.so +0 -0
  619. sage/modules/vector_rational_sparse.pxd +30 -0
  620. sage/modules/vector_rational_sparse.pyx +413 -0
  621. sage/modules/vector_real_double_dense.cpython-314-aarch64-linux-musl.so +0 -0
  622. sage/modules/vector_real_double_dense.pxd +6 -0
  623. sage/modules/vector_real_double_dense.pyx +126 -0
  624. sage/modules/vector_space_homspace.py +430 -0
  625. sage/modules/vector_space_morphism.py +989 -0
  626. sage/modules/with_basis/all.py +15 -0
  627. sage/modules/with_basis/cell_module.py +494 -0
  628. sage/modules/with_basis/indexed_element.cpython-314-aarch64-linux-musl.so +0 -0
  629. sage/modules/with_basis/indexed_element.pxd +13 -0
  630. sage/modules/with_basis/indexed_element.pyx +1058 -0
  631. sage/modules/with_basis/invariant.py +1075 -0
  632. sage/modules/with_basis/morphism.py +1636 -0
  633. sage/modules/with_basis/representation.py +2939 -0
  634. sage/modules/with_basis/subquotient.py +685 -0
  635. sage/numerical/all__sagemath_modules.py +6 -0
  636. sage/numerical/gauss_legendre.cpython-314-aarch64-linux-musl.so +0 -0
  637. sage/numerical/gauss_legendre.pyx +381 -0
  638. sage/numerical/optimize.py +910 -0
  639. sage/probability/all.py +10 -0
  640. sage/probability/probability_distribution.cpython-314-aarch64-linux-musl.so +0 -0
  641. sage/probability/probability_distribution.pyx +1242 -0
  642. sage/probability/random_variable.py +411 -0
  643. sage/quadratic_forms/all.py +4 -0
  644. sage/quadratic_forms/all__sagemath_modules.py +15 -0
  645. sage/quadratic_forms/binary_qf.py +2042 -0
  646. sage/quadratic_forms/bqf_class_group.py +748 -0
  647. sage/quadratic_forms/constructions.py +93 -0
  648. sage/quadratic_forms/count_local_2.cpython-314-aarch64-linux-musl.so +0 -0
  649. sage/quadratic_forms/count_local_2.pyx +365 -0
  650. sage/quadratic_forms/extras.py +195 -0
  651. sage/quadratic_forms/quadratic_form.py +1753 -0
  652. sage/quadratic_forms/quadratic_form__count_local_2.py +221 -0
  653. sage/quadratic_forms/quadratic_form__equivalence_testing.py +708 -0
  654. sage/quadratic_forms/quadratic_form__evaluate.cpython-314-aarch64-linux-musl.so +0 -0
  655. sage/quadratic_forms/quadratic_form__evaluate.pyx +139 -0
  656. sage/quadratic_forms/quadratic_form__local_density_congruence.py +977 -0
  657. sage/quadratic_forms/quadratic_form__local_field_invariants.py +1072 -0
  658. sage/quadratic_forms/quadratic_form__neighbors.py +424 -0
  659. sage/quadratic_forms/quadratic_form__reduction_theory.py +488 -0
  660. sage/quadratic_forms/quadratic_form__split_local_covering.py +416 -0
  661. sage/quadratic_forms/quadratic_form__ternary_Tornaria.py +657 -0
  662. sage/quadratic_forms/quadratic_form__theta.py +352 -0
  663. sage/quadratic_forms/quadratic_form__variable_substitutions.py +370 -0
  664. sage/quadratic_forms/random_quadraticform.py +209 -0
  665. sage/quadratic_forms/ternary.cpython-314-aarch64-linux-musl.so +0 -0
  666. sage/quadratic_forms/ternary.pyx +1154 -0
  667. sage/quadratic_forms/ternary_qf.py +2027 -0
  668. sage/rings/all__sagemath_modules.py +28 -0
  669. sage/rings/asymptotic/all__sagemath_modules.py +1 -0
  670. sage/rings/asymptotic/misc.py +1252 -0
  671. sage/rings/cc.py +4 -0
  672. sage/rings/cfinite_sequence.py +1306 -0
  673. sage/rings/complex_conversion.cpython-314-aarch64-linux-musl.so +0 -0
  674. sage/rings/complex_conversion.pxd +8 -0
  675. sage/rings/complex_conversion.pyx +23 -0
  676. sage/rings/complex_double.cpython-314-aarch64-linux-musl.so +0 -0
  677. sage/rings/complex_double.pxd +21 -0
  678. sage/rings/complex_double.pyx +2654 -0
  679. sage/rings/complex_mpc.cpython-314-aarch64-linux-musl.so +0 -0
  680. sage/rings/complex_mpc.pxd +21 -0
  681. sage/rings/complex_mpc.pyx +2576 -0
  682. sage/rings/complex_mpfr.cpython-314-aarch64-linux-musl.so +0 -0
  683. sage/rings/complex_mpfr.pxd +18 -0
  684. sage/rings/complex_mpfr.pyx +3602 -0
  685. sage/rings/derivation.py +2334 -0
  686. sage/rings/finite_rings/all__sagemath_modules.py +1 -0
  687. sage/rings/finite_rings/maps_finite_field.py +191 -0
  688. sage/rings/function_field/all__sagemath_modules.py +8 -0
  689. sage/rings/function_field/derivations.py +102 -0
  690. sage/rings/function_field/derivations_rational.py +132 -0
  691. sage/rings/function_field/differential.py +853 -0
  692. sage/rings/function_field/divisor.py +1107 -0
  693. sage/rings/function_field/drinfeld_modules/action.py +199 -0
  694. sage/rings/function_field/drinfeld_modules/all.py +1 -0
  695. sage/rings/function_field/drinfeld_modules/charzero_drinfeld_module.py +673 -0
  696. sage/rings/function_field/drinfeld_modules/drinfeld_module.py +2087 -0
  697. sage/rings/function_field/drinfeld_modules/finite_drinfeld_module.py +1131 -0
  698. sage/rings/function_field/drinfeld_modules/homset.py +420 -0
  699. sage/rings/function_field/drinfeld_modules/morphism.py +820 -0
  700. sage/rings/function_field/hermite_form_polynomial.cpython-314-aarch64-linux-musl.so +0 -0
  701. sage/rings/function_field/hermite_form_polynomial.pyx +188 -0
  702. sage/rings/function_field/khuri_makdisi.cpython-314-aarch64-linux-musl.so +0 -0
  703. sage/rings/function_field/khuri_makdisi.pyx +935 -0
  704. sage/rings/invariants/all.py +4 -0
  705. sage/rings/invariants/invariant_theory.py +4597 -0
  706. sage/rings/invariants/reconstruction.py +395 -0
  707. sage/rings/polynomial/all__sagemath_modules.py +17 -0
  708. sage/rings/polynomial/integer_valued_polynomials.py +1230 -0
  709. sage/rings/polynomial/laurent_polynomial_mpair.cpython-314-aarch64-linux-musl.so +0 -0
  710. sage/rings/polynomial/laurent_polynomial_mpair.pxd +15 -0
  711. sage/rings/polynomial/laurent_polynomial_mpair.pyx +2023 -0
  712. sage/rings/polynomial/ore_function_element.py +952 -0
  713. sage/rings/polynomial/ore_function_field.py +1028 -0
  714. sage/rings/polynomial/ore_polynomial_element.cpython-314-aarch64-linux-musl.so +0 -0
  715. sage/rings/polynomial/ore_polynomial_element.pxd +48 -0
  716. sage/rings/polynomial/ore_polynomial_element.pyx +3145 -0
  717. sage/rings/polynomial/ore_polynomial_ring.py +1334 -0
  718. sage/rings/polynomial/polynomial_real_mpfr_dense.cpython-314-aarch64-linux-musl.so +0 -0
  719. sage/rings/polynomial/polynomial_real_mpfr_dense.pyx +788 -0
  720. sage/rings/polynomial/q_integer_valued_polynomials.py +1264 -0
  721. sage/rings/polynomial/skew_polynomial_element.cpython-314-aarch64-linux-musl.so +0 -0
  722. sage/rings/polynomial/skew_polynomial_element.pxd +9 -0
  723. sage/rings/polynomial/skew_polynomial_element.pyx +684 -0
  724. sage/rings/polynomial/skew_polynomial_finite_field.cpython-314-aarch64-linux-musl.so +0 -0
  725. sage/rings/polynomial/skew_polynomial_finite_field.pxd +19 -0
  726. sage/rings/polynomial/skew_polynomial_finite_field.pyx +1093 -0
  727. sage/rings/polynomial/skew_polynomial_finite_order.cpython-314-aarch64-linux-musl.so +0 -0
  728. sage/rings/polynomial/skew_polynomial_finite_order.pxd +10 -0
  729. sage/rings/polynomial/skew_polynomial_finite_order.pyx +567 -0
  730. sage/rings/polynomial/skew_polynomial_ring.py +908 -0
  731. sage/rings/real_double_element_gsl.cpython-314-aarch64-linux-musl.so +0 -0
  732. sage/rings/real_double_element_gsl.pxd +8 -0
  733. sage/rings/real_double_element_gsl.pyx +794 -0
  734. sage/rings/real_field.py +58 -0
  735. sage/rings/real_mpfr.cpython-314-aarch64-linux-musl.so +0 -0
  736. sage/rings/real_mpfr.pxd +29 -0
  737. sage/rings/real_mpfr.pyx +6122 -0
  738. sage/rings/ring_extension.cpython-314-aarch64-linux-musl.so +0 -0
  739. sage/rings/ring_extension.pxd +42 -0
  740. sage/rings/ring_extension.pyx +2779 -0
  741. sage/rings/ring_extension_conversion.cpython-314-aarch64-linux-musl.so +0 -0
  742. sage/rings/ring_extension_conversion.pxd +16 -0
  743. sage/rings/ring_extension_conversion.pyx +462 -0
  744. sage/rings/ring_extension_element.cpython-314-aarch64-linux-musl.so +0 -0
  745. sage/rings/ring_extension_element.pxd +21 -0
  746. sage/rings/ring_extension_element.pyx +1635 -0
  747. sage/rings/ring_extension_homset.py +64 -0
  748. sage/rings/ring_extension_morphism.cpython-314-aarch64-linux-musl.so +0 -0
  749. sage/rings/ring_extension_morphism.pxd +35 -0
  750. sage/rings/ring_extension_morphism.pyx +920 -0
  751. sage/schemes/all__sagemath_modules.py +1 -0
  752. sage/schemes/projective/all__sagemath_modules.py +1 -0
  753. sage/schemes/projective/coherent_sheaf.py +300 -0
  754. sage/schemes/projective/cohomology.py +510 -0
  755. sage/stats/all.py +15 -0
  756. sage/stats/basic_stats.py +489 -0
  757. sage/stats/distributions/all.py +7 -0
  758. sage/stats/distributions/catalog.py +34 -0
  759. sage/stats/distributions/dgs.h +50 -0
  760. sage/stats/distributions/dgs.pxd +111 -0
  761. sage/stats/distributions/dgs_bern.h +400 -0
  762. sage/stats/distributions/dgs_gauss.h +614 -0
  763. sage/stats/distributions/dgs_misc.h +104 -0
  764. sage/stats/distributions/discrete_gaussian_integer.cpython-314-aarch64-linux-musl.so +0 -0
  765. sage/stats/distributions/discrete_gaussian_integer.pxd +14 -0
  766. sage/stats/distributions/discrete_gaussian_integer.pyx +498 -0
  767. sage/stats/distributions/discrete_gaussian_lattice.py +908 -0
  768. sage/stats/distributions/discrete_gaussian_polynomial.py +141 -0
  769. sage/stats/hmm/all.py +15 -0
  770. sage/stats/hmm/chmm.cpython-314-aarch64-linux-musl.so +0 -0
  771. sage/stats/hmm/chmm.pyx +1595 -0
  772. sage/stats/hmm/distributions.cpython-314-aarch64-linux-musl.so +0 -0
  773. sage/stats/hmm/distributions.pxd +29 -0
  774. sage/stats/hmm/distributions.pyx +531 -0
  775. sage/stats/hmm/hmm.cpython-314-aarch64-linux-musl.so +0 -0
  776. sage/stats/hmm/hmm.pxd +17 -0
  777. sage/stats/hmm/hmm.pyx +1388 -0
  778. sage/stats/hmm/util.cpython-314-aarch64-linux-musl.so +0 -0
  779. sage/stats/hmm/util.pxd +7 -0
  780. sage/stats/hmm/util.pyx +165 -0
  781. sage/stats/intlist.cpython-314-aarch64-linux-musl.so +0 -0
  782. sage/stats/intlist.pxd +14 -0
  783. sage/stats/intlist.pyx +588 -0
  784. sage/stats/r.py +49 -0
  785. sage/stats/time_series.cpython-314-aarch64-linux-musl.so +0 -0
  786. sage/stats/time_series.pxd +6 -0
  787. sage/stats/time_series.pyx +2546 -0
  788. sage/tensor/all.py +2 -0
  789. sage/tensor/modules/all.py +8 -0
  790. sage/tensor/modules/alternating_contr_tensor.py +761 -0
  791. sage/tensor/modules/comp.py +5598 -0
  792. sage/tensor/modules/ext_pow_free_module.py +824 -0
  793. sage/tensor/modules/finite_rank_free_module.py +3589 -0
  794. sage/tensor/modules/format_utilities.py +333 -0
  795. sage/tensor/modules/free_module_alt_form.py +858 -0
  796. sage/tensor/modules/free_module_automorphism.py +1207 -0
  797. sage/tensor/modules/free_module_basis.py +1074 -0
  798. sage/tensor/modules/free_module_element.py +284 -0
  799. sage/tensor/modules/free_module_homset.py +652 -0
  800. sage/tensor/modules/free_module_linear_group.py +564 -0
  801. sage/tensor/modules/free_module_morphism.py +1581 -0
  802. sage/tensor/modules/free_module_tensor.py +3289 -0
  803. sage/tensor/modules/reflexive_module.py +386 -0
  804. sage/tensor/modules/tensor_free_module.py +780 -0
  805. sage/tensor/modules/tensor_free_submodule.py +538 -0
  806. sage/tensor/modules/tensor_free_submodule_basis.py +140 -0
  807. sage/tensor/modules/tensor_with_indices.py +1043 -0
@@ -0,0 +1,961 @@
1
+ # sage_setup: distribution = sagemath-modules
2
+ # sage.doctest: needs sage.modules sage.rings.finite_rings
3
+ r"""
4
+ Generic structures for linear codes over the rank metric
5
+
6
+ Rank Metric
7
+ ===========
8
+
9
+ In coding theory, the most common metric is the Hamming metric, where distance
10
+ between two codewords is given by the number of positions in which they differ.
11
+ An alternative to this is the rank metric. Take two fields, `\GF{q}` and `\GF{q^m}`,
12
+ and define a code `C` to be a set of vectors of length `n` with entries from
13
+ `\GF{q^m}`. Let `c` be a codeword. We can represent it as an `m \times n` matrix
14
+ `M` over `\GF{q}`.
15
+
16
+ A detailed description on the relationship between the two representations can
17
+ be found in :meth:`sage.coding.linear_rank_metric.to_matrix_representation`
18
+ and :meth:`sage.coding.linear_rank_metric.from_matrix_representation`.
19
+
20
+ We can define a metric using the rank of the matrix representation of the
21
+ codewords. A distance between two codewords `a, b` is the rank of the matrix
22
+ representation of `a - b`. A weight of a codeword `c` is the rank of the matrix
23
+ representation of `c`.
24
+
25
+ This module allows representing rank metric codes which are linear over the
26
+ big field `\GF{q^m}`, i.e. the usual linearity condition when the codewords are
27
+ considered in vector form. One can also consider rank metric codes which are
28
+ only linear over `\GF{q}`, but these are not currently supported in SageMath.
29
+
30
+ Note that linear rank metric codes per the definition of this file are
31
+ mathematically just linear block codes, and so could be considered as a
32
+ :class:`sage.coding.linear_code.LinearCode`. However, since most of the
33
+ functionality of that class is specific to the Hamming metric, the two notions
34
+ are implemented as entirely different in SageMath. If you wish to investigate
35
+ Hamming-metric properties of a linear rank metric code ``C``, you can easily
36
+ convert it by calling ``C_hamm = LinearCode(C)``.
37
+
38
+ Linear Rank Metric Code and Gabidulin Codes
39
+ ===========================================
40
+
41
+ The class :class:`sage.coding.linear_rank_metric.LinearRankMetricCode` is the
42
+ analog of :class:`sage.coding.linear_code.LinearCode`, i.e. it is a generator
43
+ matrix-based representation of a linear rank metric code without specific
44
+ knowledge on the structure of the code.
45
+
46
+ Gabidulin codes are the main family of structured linear rank metric codes.
47
+ These codes are the rank-metric analog of Reed-Solomon codes.
48
+
49
+ ``AbstractLinearRankMetricCode``
50
+ --------------------------------
51
+
52
+ This is a base class designed to contain methods, features and parameters
53
+ shared by every linear rank metric code. For instance, generic algorithms for
54
+ computing the minimum distance, etc. Many of these algorithms are slow,
55
+ e.g. exponential in the code length. It also contains methods for swapping
56
+ between vector and matrix representation of elements.
57
+
58
+ ``AbstractLinearCodeNoMetric`` is an abstract class for linear rank metric codes,
59
+ so any linear rank metric code class should inherit from this class.
60
+ Also ``AbstractLinearCodeNoMetric`` should never itself be instantiated.
61
+
62
+ See :class:`sage.coding.linear_rank_metric.AbstractLinearRankMetricCode`
63
+ for details and examples.
64
+
65
+ ``LinearRankMetricCode``
66
+ ------------------------
67
+
68
+ This class is used to represent arbitrary and unstructured linear rank metric
69
+ codes. It mostly relies directly on generic methods provided by
70
+ ``AbstractLinearRankMetricCode``, which means that basic operations on the code
71
+ (e.g. computation of the minimum distance) will use slow algorithms.
72
+
73
+ A ``LinearRankMetricCode`` is instantiated by providing a generator::
74
+
75
+ sage: G = Matrix(GF(64), [[1,1,0], [0,0,1]])
76
+ sage: C = codes.LinearRankMetricCode(G, GF(4))
77
+ sage: C
78
+ [3, 2] linear rank metric code over GF(64)/GF(4)
79
+ sage: C.generator_matrix()
80
+ [1 1 0]
81
+ [0 0 1]
82
+ sage: c = vector(GF(64), (1, 1, 1))
83
+ sage: c in C
84
+ True
85
+
86
+ Further references
87
+ ------------------
88
+
89
+ Read more about
90
+ :wikipedia:`rank metric and Gabidulin codes <Rank_error-correcting_code>`
91
+
92
+ AUTHORS:
93
+
94
+ - Marketa Slukova (2019-08-16): initial version
95
+ - Camille Garnier and Rubén Muñoz-\-Bertrand (2024-02-13): added rank_support_of_vector, and corrected the documentation
96
+
97
+ TESTS::
98
+
99
+ sage: MS = MatrixSpace(GF(2),4,7)
100
+ sage: G = MS([[1,1,1,0,0,0,0], [1,0,0,1,1,0,0], [0,1,0,1,0,1,0], [1,1,0,1,0,0,1]])
101
+ sage: C = LinearCode(G)
102
+ sage: C == loads(dumps(C))
103
+ True
104
+ """
105
+
106
+ # ****************************************************************************
107
+ # Copyright (C) 2019 MARKETA SLUKOVA <em.slukova@gmail.com>
108
+ #
109
+ # This program is free software: you can redistribute it and/or modify
110
+ # it under the terms of the GNU General Public License as published by
111
+ # the Free Software Foundation, either version 2 of the License, or
112
+ # (at your option) any later version.
113
+ # https://www.gnu.org/licenses/
114
+ # ****************************************************************************
115
+
116
+ from sage.categories.fields import Fields
117
+ from sage.matrix.constructor import matrix
118
+ from sage.structure.element import Matrix, Vector
119
+ from sage.modules.free_module_element import vector
120
+ from sage.rings.infinity import Infinity
121
+
122
+ from .linear_code_no_metric import AbstractLinearCodeNoMetric
123
+ from .linear_code import LinearCodeGeneratorMatrixEncoder
124
+ from .decoder import Decoder
125
+
126
+
127
+ def to_matrix_representation(v, sub_field=None, basis=None):
128
+ r"""
129
+ Return a matrix representation of ``v`` over ``sub_field`` in terms of
130
+ ``basis``.
131
+
132
+ Let `(b_1, b_2, \ldots, b_m)`, `b_i \in GF(q^m)`, be a basis of `\GF{q^m}` as
133
+ a vector space over `\GF{q}`. Take an element `x \in \GF{q^m}`. We can write
134
+ `x` as `x = u_1 b_1 + u_2 b_2 + \ldots u_m b_m`, where `u_i \in GF(q)`. This
135
+ way we can represent an element from `\GF{q^m}` as a vector of length `m`
136
+ over `\GF{q}`.
137
+
138
+ Given a vector ``v`` of length `n` over some field `\GF{q^m}`, we can
139
+ represent each entry as a vector of length `m`, yielding an `m \times n`
140
+ matrix over ``sub_field``. In case ``sub_field`` is not given, we take the
141
+ prime subfield `\GF{p}` of `\GF{q^m}`.
142
+
143
+ INPUT:
144
+
145
+ - ``v`` -- a vector over some field `\GF{q^m}`
146
+
147
+ - ``sub_field`` -- (default: ``None``) a sub field of `\GF{q^m}`; if not
148
+ specified, it is the prime subfield `\GF{p}` of `\GF{q^m}`
149
+
150
+ - ``basis`` -- (default: ``None``) a basis of `\GF{q^m}` as a vector space over
151
+ ``sub_field``. If not specified, the default basis is
152
+ `1,\beta,\ldots,\beta^{m-1}` where `\beta` is the generator of `\GF{q^m}`
153
+ given by SageMath.
154
+
155
+ EXAMPLES::
156
+
157
+ sage: from sage.coding.linear_rank_metric import to_matrix_representation
158
+ sage: x = GF(64).gen()
159
+ sage: a = vector(GF(64), (x + 1, x + 1, 1))
160
+ sage: to_matrix_representation(a, GF(4))
161
+ [1 1 1]
162
+ [1 1 0]
163
+ [0 0 0]
164
+
165
+ sage: m = Matrix(GF(4), [[1, 1, 1], [1, 1, 0], [0, 0, 0]])
166
+ sage: to_matrix_representation(m)
167
+ Traceback (most recent call last):
168
+ ...
169
+ TypeError: Input must be a vector
170
+ """
171
+ if not isinstance(v, Vector):
172
+ raise TypeError("Input must be a vector")
173
+ base_field = v.base_ring()
174
+ if not sub_field:
175
+ sub_field = base_field.prime_subfield()
176
+ n = v.length()
177
+ m = base_field.degree()//sub_field.degree()
178
+ extension, to_big_field, from_big_field = base_field.vector_space(sub_field, basis, map=True)
179
+ return matrix(sub_field, m, n, lambda i, j: from_big_field(v[j])[i])
180
+
181
+
182
+ def from_matrix_representation(w, base_field=None, basis=None):
183
+ r"""
184
+ Return a vector representation of a matrix ``w`` over ``base_field`` in terms
185
+ of ``basis``.
186
+
187
+ Given an `m \times n` matrix over `\GF{q}` and some ``basis`` of `\GF{q^m}`
188
+ over `\GF{q}`, we can represent each of its columns as an element of `\GF{q^m}`,
189
+ yielding a vector of length `n` over `\GF{q}`.
190
+
191
+ In case ``base_field`` is not given, we take `\GF{q^m}`, the field extension of
192
+ `\GF{q}` of degree `m`, the number of rows of ``w``.
193
+
194
+ INPUT:
195
+
196
+ - ``w`` -- a matrix over some field `\GF{q}`
197
+
198
+ - ``base_field`` -- (default: ``None``) an extension field of `\GF{q}`. If not
199
+ specified, it is the field `\GF{q^m}`, where `m` is the number of rows of
200
+ ``w``.
201
+
202
+ - ``basis`` -- (default: ``None``) a basis of `\GF{q^m}` as a vector space over
203
+ `\GF{q}`. If not specified, the default basis is
204
+ `1,\beta,\ldots,\beta^{m-1}` where `\beta` is the generator
205
+ of `\GF{q^m}` given by SageMath.
206
+
207
+ EXAMPLES::
208
+
209
+ sage: from sage.coding.linear_rank_metric import from_matrix_representation
210
+ sage: m = Matrix(GF(4), [[1, 1, 1], [1, 1, 0], [0, 0, 0]])
211
+ sage: from_matrix_representation(m)
212
+ (z6 + 1, z6 + 1, 1)
213
+
214
+ sage: v = vector(GF(4), (1, 0, 0))
215
+ sage: from_matrix_representation(v)
216
+ Traceback (most recent call last):
217
+ ...
218
+ TypeError: Input must be a matrix
219
+ """
220
+ if not isinstance(w, Matrix):
221
+ raise TypeError("Input must be a matrix")
222
+ sub_field = w.base_ring()
223
+ if not base_field:
224
+ base_field = sub_field.extension(w.nrows())
225
+ extension, to_big_field, from_big_field = base_field.vector_space(sub_field, basis, map=True)
226
+ v = [to_big_field(w.column(i)) for i in range(w.ncols())]
227
+ return vector(v)
228
+
229
+
230
+ def rank_weight(c, sub_field=None, basis=None):
231
+ r"""
232
+ Return the rank of ``c`` as a matrix over ``sub_field``.
233
+
234
+ If ``c`` is a vector over some field `\GF{q^m}`, the function converts it
235
+ into a matrix over ``sub_field```.
236
+
237
+ INPUT:
238
+
239
+ - ``c`` -- a vector over some field `\GF{q^m}`; or a matrix over `\GF{q}`
240
+
241
+ - ``sub_field`` -- (default: ``None``) a sub field of `\GF{q^m}`; if not
242
+ specified, it is the prime subfield `\GF{p}` of `\GF{q^m}`
243
+
244
+ - ``basis`` -- (default: ``None``) a basis of `\GF{q^m}` as a vector space over
245
+ ``sub_field``. If not specified, the default basis is
246
+ `1,\beta,\ldots,\beta^{m-1}` where `\beta` is the generator
247
+ of `\GF{q^m}` given by SageMath.
248
+
249
+ EXAMPLES::
250
+
251
+ sage: from sage.coding.linear_rank_metric import rank_weight
252
+ sage: x = GF(64).gen()
253
+ sage: a = vector(GF(64), (x + 1, x + 1, 1))
254
+ sage: rank_weight(a, GF(4))
255
+ 2
256
+ """
257
+ if isinstance(c, Vector):
258
+ c = to_matrix_representation(c, sub_field, basis)
259
+ return c.rank()
260
+
261
+
262
+ def rank_distance(a, b, sub_field=None, basis=None):
263
+ r"""
264
+ Return the rank of ``a`` - ``b`` as a matrix over ``sub_field``.
265
+
266
+ Take two vectors ``a``, ``b`` over some field `\GF{q^m}`. This function
267
+ converts them to matrices over `\GF{q}` and calculates the rank of their
268
+ difference.
269
+
270
+ If ``sub_field`` is not specified, we take the prime subfield `\GF{q}` of
271
+ `\GF{q^m}`.
272
+
273
+ INPUT:
274
+
275
+ - ``a`` -- a vector over some field `\GF{q^m}`
276
+
277
+ - ``b`` -- a vector over some field `\GF{q^m}`
278
+
279
+ - ``sub_field`` -- (default: ``None``) a sub field of `\GF{q^m}`; if not
280
+ specified, it is the prime subfield `\GF{p}` of `\GF{q^m}`
281
+
282
+ - ``basis`` -- (default: ``None``) a basis of `\GF{q^m}` as a vector space over
283
+ ``sub_field``. If not specified, the default basis is
284
+ `1,\beta,\ldots,\beta^{m-1}` where `\beta` is the generator
285
+ of `\GF{q^m}` given by SageMath.
286
+
287
+ EXAMPLES::
288
+
289
+ sage: from sage.coding.linear_rank_metric import rank_distance
290
+ sage: x = GF(64).gen()
291
+ sage: a = vector(GF(64), (x + 1, x + 1, 1))
292
+ sage: b = vector(GF(64), (1, 0, 0))
293
+ sage: rank_distance(a, b, GF(4))
294
+ 2
295
+
296
+ sage: c = vector(GF(4), (1, 0, 0))
297
+ sage: rank_distance(a, c, GF(4))
298
+ Traceback (most recent call last):
299
+ ...
300
+ ValueError: The base field of (z6 + 1, z6 + 1, 1) and (1, 0, 0) has to be the same
301
+
302
+ sage: d = Matrix(GF(64), (1, 0, 0))
303
+ sage: rank_distance(a, d, GF(64))
304
+ Traceback (most recent call last):
305
+ ...
306
+ TypeError: Both inputs have to be vectors
307
+
308
+ sage: e = vector(GF(64), (1, 0))
309
+ sage: rank_distance(a, e, GF(64))
310
+ Traceback (most recent call last):
311
+ ...
312
+ ValueError: The length of (z6 + 1, z6 + 1, 1) and (1, 0) has to be the same
313
+ """
314
+ if not (a.base_ring() == b.base_ring()):
315
+ raise ValueError("The base field of {} and {} has to be the same".format(a, b))
316
+ if not (isinstance(a, Vector) and isinstance(b, Vector)):
317
+ raise TypeError("Both inputs have to be vectors")
318
+ if not len(a) == len(b):
319
+ raise ValueError("The length of {} and {} has to be the same".format(a, b))
320
+
321
+ a = to_matrix_representation(a, sub_field, basis)
322
+ b = to_matrix_representation(b, sub_field, basis)
323
+ return (a - b).rank()
324
+
325
+
326
+ class AbstractLinearRankMetricCode(AbstractLinearCodeNoMetric):
327
+ r"""
328
+ Abstract class for linear rank metric codes.
329
+
330
+ This class contains methods that can be used on families of linear rank
331
+ metric codes. Every linear rank metric code class should inherit from this
332
+ abstract class.
333
+
334
+ This class is intended for codes which are linear over the ``base_field``.
335
+
336
+ Codewords of rank metric codes have two representations. They can either be
337
+ written as a vector of length `n` over `\GF{q^m}`, or an `m \times n` matrix
338
+ over `\GF{q}`. This implementation principally uses the vector representation.
339
+ However, one can always get the matrix representation using the
340
+ :meth:`sage.coding.linear_rank_metric.AbstractLinearRankMetricCode.to_matrix`
341
+ method. To go back to a vector, use the
342
+ :meth:`sage.coding.linear_rank_metric.AbstractLinearRankMetricCode.from_matrix`
343
+ method.
344
+
345
+ Instructions on how to make a new family of rank metric codes is analogous
346
+ to making a new family of linear codes over the Hamming metric, instructions
347
+ for which are in :class:`sage.coding.linear_code.AbstractLinearCode`. For an
348
+ example on, see
349
+ :meth:`sage.coding.linear_rank_metric.AbstractLinearRankMetricCode.__init__`
350
+
351
+ .. WARNING::
352
+
353
+ A lot of methods of the abstract class rely on the knowledge of a generator matrix.
354
+ It is thus strongly recommended to set an encoder with a generator matrix implemented
355
+ as a default encoder.
356
+ """
357
+ _registered_encoders = {}
358
+ _registered_decoders = {}
359
+
360
+ def __init__(self, base_field, sub_field, length, default_encoder_name,
361
+ default_decoder_name, basis=None):
362
+ r"""
363
+ Initialize mandatory parameters that every linear rank metric code has.
364
+
365
+ This method only exists for inheritance purposes as it initializes
366
+ parameters that need to be known by every linear rank metric code.
367
+ The class :class:`sage.coding.linear_rank_metric.AbstractLinearRankMetricCode`
368
+ should never be directly instantiated.
369
+
370
+ INPUT:
371
+
372
+ - ``base_field`` -- the base field of ``self``
373
+
374
+ - ``sub_field`` -- the sub field of ``self``
375
+
376
+ - ``length`` -- the length of ``self`` (a Python int or a Sage Integer),
377
+ must be > 0 and at most the degree of the field extension
378
+
379
+ - ``default_encoder_name`` -- the name of the default encoder of ``self``
380
+
381
+ - ``default_decoder_name`` -- the name of the default decoder of ``self``
382
+
383
+ - ``basis`` -- (default: ``None``) a basis of `\GF{q^m}` as a vector space over
384
+ ``sub_field``. If not specified, the default basis is
385
+ `1,\beta,\ldots,\beta^{m-1}` where `\beta` is the generator
386
+ of `\GF{q^m}` given by SageMath.
387
+
388
+ EXAMPLES:
389
+
390
+ The following example demonstrates how to use subclass
391
+ `AbstractLinearRankMetricCode` for representing a new family of rank
392
+ metric codes. The example is a rank repetition code::
393
+
394
+ sage: from sage.coding.linear_rank_metric import AbstractLinearRankMetricCode
395
+ sage: class RankRepetitionCode(AbstractLinearRankMetricCode):
396
+ ....: def __init__(self, base_field, sub_field, length):
397
+ ....: super().__init__(base_field, sub_field, length,
398
+ ....: "GeneratorMatrix", "NearestNeighbor")
399
+ ....: beta = base_field.gen()
400
+ ....: self._generator_matrix = matrix(base_field,
401
+ ....: [[beta^i for i in range(length)]])
402
+ ....: def generator_matrix(self):
403
+ ....: return self._generator_matrix
404
+ ....: def _repr_(self):
405
+ ....: return "[%d, %d] rank-metric repetition code over GF(%s)" % (self.length(), self.dimension(), self.base_field().cardinality())
406
+
407
+ We now instantiate a member of our newly made code family::
408
+
409
+ sage: C = RankRepetitionCode(GF(8), GF(2), 3)
410
+
411
+ We can check its existence and parameters::
412
+
413
+ sage: C
414
+ [3, 1] rank-metric repetition code over GF(8)
415
+
416
+ We can encode a vector::
417
+
418
+ sage: word = vector(C.base_field(), [1])
419
+ sage: E = codes.encoders.LinearCodeSystematicEncoder(C)
420
+ sage: codeword = E(word)
421
+ sage: codeword
422
+ (1, z3, z3^2)
423
+
424
+ We can get the matrix representation of the codeword::
425
+
426
+ sage: C.matrix_form_of_vector(codeword)
427
+ [1 0 0]
428
+ [0 1 0]
429
+ [0 0 1]
430
+
431
+ We can decode the vector representation of the codeword::
432
+
433
+ sage: D = codes.decoders.LinearRankMetricCodeNearestNeighborDecoder(C)
434
+ sage: D.decode_to_code(codeword)
435
+ (1, z3, z3^2)
436
+ sage: D.decode_to_message(codeword)
437
+ (1)
438
+
439
+ We can check that it is truly a part of the framework category::
440
+
441
+ sage: C.parent()
442
+ <class '__main__.RankRepetitionCode_with_category'>
443
+ sage: C.category()
444
+ Category of facade finite dimensional vector spaces with basis
445
+ over Finite Field in z3 of size 2^3
446
+
447
+ And any method that works on rank metric linear codes works for our new dummy code::
448
+
449
+ sage: C.minimum_distance()
450
+ 3
451
+ sage: C.metric()
452
+ 'rank'
453
+
454
+ TESTS:
455
+
456
+ If ``sub_field`` is not a field, an error is raised::
457
+
458
+ sage: C = RankRepetitionCode(GF(8), ZZ, 3)
459
+ Traceback (most recent call last):
460
+ ...
461
+ ValueError: 'sub_field' must be a field (and Integer Ring is not one)
462
+
463
+ If ``sub_field`` is not a subfield of ``base_field``, an error is raised::
464
+
465
+ sage: C = RankRepetitionCode(GF(8), GF(3), 2)
466
+ Traceback (most recent call last):
467
+ ...
468
+ ValueError: 'sub_field' has to be a subfield of 'base_field'
469
+ """
470
+ self._registered_decoders["NearestNeighbor"] = LinearRankMetricCodeNearestNeighborDecoder
471
+
472
+ if not sub_field.is_field():
473
+ raise ValueError("'sub_field' must be a field (and {} is not one)".format(sub_field))
474
+ if not (sub_field.degree().divides(base_field.degree()) and (sub_field.prime_subfield() == base_field.prime_subfield())):
475
+ raise ValueError("'sub_field' has to be a subfield of 'base_field'")
476
+ m = base_field.degree() // sub_field.degree()
477
+ self._extension_degree = m
478
+ self._sub_field = sub_field
479
+
480
+ self._generic_constructor = LinearRankMetricCode
481
+ super().__init__(base_field, length, default_encoder_name,
482
+ default_decoder_name, "rank")
483
+
484
+ def sub_field(self):
485
+ r"""
486
+ Return the sub field of ``self``.
487
+
488
+ EXAMPLES::
489
+
490
+ sage: G = Matrix(GF(64), [[1,1,0], [0,0,1]])
491
+ sage: C = codes.LinearRankMetricCode(G, GF(4))
492
+ sage: C.sub_field()
493
+ Finite Field in z2 of size 2^2
494
+ """
495
+ return self._sub_field
496
+
497
+ def extension_degree(self):
498
+ r"""
499
+ Return `m`, the degree of the field extension of ``self``.
500
+
501
+ Let ``base_field`` be `\GF{q^m}` and ``sub_field`` be `\GF{q}`. Then this
502
+ function returns `m`.
503
+
504
+ EXAMPLES::
505
+
506
+ sage: G = Matrix(GF(64), [[1,1,0], [0,0,1]])
507
+ sage: C = codes.LinearRankMetricCode(G, GF(4))
508
+ sage: C.extension_degree()
509
+ 3
510
+ """
511
+
512
+ return self._extension_degree
513
+
514
+ def field_extension(self):
515
+ r"""
516
+ Return the field extension of ``self``.
517
+
518
+ Let ``base_field`` be some field `\GF{q^m}` and ``sub_field`` `\GF{q}`.
519
+ This function returns the vector space of dimension `m` over `\GF{q}`.
520
+
521
+ EXAMPLES::
522
+
523
+ sage: G = Matrix(GF(64), [[1,1,0], [0,0,1]])
524
+ sage: C = codes.LinearRankMetricCode(G, GF(4))
525
+ sage: C.field_extension()
526
+ Vector space of dimension 3 over Finite Field in z2 of size 2^2
527
+ """
528
+ return self.base_field().vector_space(self.sub_field(), map=False)
529
+
530
+ def rank_distance_between_vectors(self, left, right):
531
+ r"""
532
+ Return the rank of the matrix of ``left`` - ``right``.
533
+
534
+ INPUT:
535
+
536
+ - ``left`` -- a vector over the ``base_field`` of ``self``
537
+
538
+ - ``right`` -- a vector over the ``base_field`` of ``self``
539
+
540
+ EXAMPLES::
541
+
542
+ sage: G = Matrix(GF(64), [[1,1,0], [0,0,1]])
543
+ sage: C = codes.LinearRankMetricCode(G, GF(4))
544
+ sage: x = GF(64).gen()
545
+ sage: a = vector(GF(64), (x + 1, x + 1, 1))
546
+ sage: b = vector(GF(64), (1, 0, 0))
547
+ sage: C.rank_distance_between_vectors(a, b)
548
+ 2
549
+ """
550
+ return rank_distance(left, right, self.sub_field())
551
+
552
+ def minimum_distance(self):
553
+ r"""
554
+ Return the minimum distance of ``self``.
555
+
556
+ This algorithm simply iterates over all the elements of the code and
557
+ returns the minimum weight.
558
+
559
+ EXAMPLES::
560
+
561
+ sage: F.<a> = GF(8)
562
+ sage: G = Matrix(F, [[1,a,a^2,0]])
563
+ sage: C = codes.LinearRankMetricCode(G, GF(2))
564
+ sage: C.minimum_distance()
565
+ 3
566
+ """
567
+ d = Infinity
568
+ for c in self:
569
+ if c == self.zero():
570
+ continue
571
+ d = min(self.rank_weight_of_vector(c), d)
572
+ return d
573
+
574
+ def rank_weight_of_vector(self, word):
575
+ r"""
576
+ Return the weight of the word, i.e. its rank.
577
+
578
+ INPUT:
579
+
580
+ - ``word`` -- a vector over the ``base_field`` of ``self``
581
+
582
+ EXAMPLES::
583
+
584
+ sage: G = Matrix(GF(64), [[1,1,0], [0,0,1]])
585
+ sage: C = codes.LinearRankMetricCode(G, GF(4))
586
+ sage: x = GF(64).gen()
587
+ sage: a = vector(GF(64), (x + 1, x + 1, 1))
588
+ sage: C.rank_weight_of_vector(a)
589
+ 2
590
+ """
591
+ return rank_weight(word, self.sub_field())
592
+
593
+ def rank_support_of_vector(self, word, sub_field=None, basis=None):
594
+ r"""
595
+ Return the rank support of ``word`` over ``sub_field``, i.e. the vector space over
596
+ ``sub_field`` generated by its coefficients.
597
+
598
+ If ``word`` is a vector over some field `\GF{q^m}`, and ``sub_field`` is a subfield of
599
+ `\GF{q^m}`, the function converts it into a matrix over ``sub_field``, with
600
+ respect to the basis ``basis``.
601
+
602
+ INPUT:
603
+
604
+ - ``word`` -- a vector over the ``base_field`` of ``self``.
605
+
606
+ - ``sub_field`` -- (default: ``None``) a sub field of the
607
+ ``base_field`` of ``self``; if not specified, it is the prime
608
+ subfield of `\GF{p}` the ``base_field`` of ``self``.
609
+
610
+ - ``basis`` -- (default: ``None``) a basis of ``base_field`` of
611
+ ``self`` as a vector space over ``sub_field``. If not specified,
612
+ the default basis is `1,\beta,\ldots,\beta^{m-1}`, where `\beta` is
613
+ the generator of `\GF{q^m}` given by SageMath.
614
+
615
+ EXAMPLES::
616
+
617
+ sage: G = Matrix(GF(64), [[1,1,0], [0,0,1]])
618
+ sage: C = codes.LinearRankMetricCode(G, GF(4))
619
+ sage: a = GF(64).gen()
620
+ sage: c = vector([a^4 + a^3 + 1, a^4 + a^3 + 1, a^4 + a^3 + a^2 + 1])
621
+ sage: c in C
622
+ True
623
+ sage: C.rank_support_of_vector(c)
624
+ Vector space of degree 6 and dimension 2 over Finite Field of size 2
625
+ Basis matrix:
626
+ [1 0 0 1 1 0]
627
+ [0 0 1 0 0 0]
628
+
629
+ An example with a non canonical basis::
630
+
631
+ sage: K.<a> = GF(2^3)
632
+ sage: G = Matrix(K, [[1,1,0], [0,0,1]])
633
+ sage: C = codes.LinearRankMetricCode(G)
634
+ sage: c = vector([a^2, a^2, 0])
635
+ sage: basis = [a, a+1, a^2]
636
+ sage: C.rank_support_of_vector(c, basis=basis)
637
+ Vector space of degree 3 and dimension 1 over Finite Field of size 2
638
+ Basis matrix:
639
+ [0 0 1]
640
+
641
+ TESTS::
642
+
643
+ sage: C.rank_support_of_vector(c, GF(2^4))
644
+ Traceback (most recent call last):
645
+ ...
646
+ TypeError: the input subfield Finite Field in z4 of size 2^4 is not a subfield of Finite Field in a of size 2^3
647
+ """
648
+ word = self.ambient_space()(word)
649
+ if sub_field is not None:
650
+ if self.base_field().degree() % sub_field.degree() != 0:
651
+ raise TypeError(f"the input subfield {sub_field} is not a subfield of {self.base_field()}")
652
+ return to_matrix_representation(word, sub_field, basis).column_module()
653
+
654
+ def matrix_form_of_vector(self, word):
655
+ r"""
656
+ Return the matrix representation of a word.
657
+
658
+ INPUT:
659
+
660
+ - ``word`` -- a vector over the ``base_field`` of ``self``
661
+
662
+ EXAMPLES::
663
+
664
+ sage: G = Matrix(GF(64), [[1,1,0], [0,0,1]])
665
+ sage: C = codes.LinearRankMetricCode(G, GF(4))
666
+ sage: x = GF(64).gen()
667
+ sage: a = vector(GF(64), (x + 1, x + 1, 1))
668
+ sage: C.matrix_form_of_vector(a)
669
+ [1 1 1]
670
+ [1 1 0]
671
+ [0 0 0]
672
+ """
673
+ return to_matrix_representation(word, self.sub_field())
674
+
675
+ def vector_form_of_matrix(self, word):
676
+ r"""
677
+ Return the vector representation of a word.
678
+
679
+ INPUT:
680
+
681
+ - ``word`` -- a matrix over the ``sub_field`` of ``self``
682
+
683
+ EXAMPLES::
684
+
685
+ sage: G = Matrix(GF(64), [[1,1,0], [0,0,1]])
686
+ sage: C = codes.LinearRankMetricCode(G, GF(4))
687
+ sage: x = GF(64).gen()
688
+ sage: m = Matrix(GF(4), [[1, 1, 1], [1, 1, 0], [0, 0, 0]])
689
+ sage: C.vector_form_of_matrix(m)
690
+ (z6 + 1, z6 + 1, 1)
691
+ """
692
+ return from_matrix_representation(word, self.base_field())
693
+
694
+
695
+ class LinearRankMetricCode(AbstractLinearRankMetricCode):
696
+ r"""
697
+ Linear rank metric codes over a finite field, represented using a
698
+ generator matrix.
699
+
700
+ This class should be used for arbitrary and unstructured linear rank metric
701
+ codes. This means that basic operations on the code, such as the computation
702
+ of the minimum distance, will use generic, slow algorithms.
703
+
704
+ If you are looking for constructing a code from a more specific family, see
705
+ if the family has been implemented by investigating ``codes.<tab>``. These
706
+ more specific classes use properties particular to that family to allow
707
+ faster algorithms, and could also have family-specific methods.
708
+
709
+ EXAMPLES::
710
+
711
+ sage: G = Matrix(GF(64), [[1,1,0], [0,0,1]])
712
+ sage: C = codes.LinearRankMetricCode(G, GF(4))
713
+ sage: C
714
+ [3, 2] linear rank metric code over GF(64)/GF(4)
715
+ sage: C.base_field()
716
+ Finite Field in z6 of size 2^6
717
+ sage: C.sub_field()
718
+ Finite Field in z2 of size 2^2
719
+ sage: C.length()
720
+ 3
721
+ sage: C.dimension()
722
+ 2
723
+ sage: C[2]
724
+ (z6, z6, 0)
725
+ sage: E = codes.encoders.LinearCodeGeneratorMatrixEncoder(C)
726
+ sage: word = vector(C.base_field(), [1, 0])
727
+ sage: E(word)
728
+ (1, 1, 0)
729
+ """
730
+
731
+ def __init__(self, generator, sub_field=None, basis=None):
732
+ r"""
733
+ See the docstring for :meth:`LinearRankMetricCode`.
734
+
735
+ INPUT:
736
+
737
+ - ``generator`` -- a generator matrix over the ``base_field`` with
738
+ dimension `k \times n`, where `k` is the dimension of the code and
739
+ `n` its length; or a code over a finite field
740
+
741
+ - ``sub_field`` -- (default: ``None``) the sub field of ``self``, if not
742
+ specified, it is the prime field of ``base_field``
743
+
744
+ - ``basis`` -- (default: ``None``) a basis of `\GF{q^m}` as a vector space over
745
+ ``sub_field``. If not specified, the default basis is
746
+ `1,\beta,\ldots,\beta^{m-1}` where `\beta` is the generator `\GF{q^m}`
747
+ given by SageMath.
748
+
749
+ EXAMPLES::
750
+
751
+ sage: G = Matrix(GF(64), [[1,1,0], [0,0,1]])
752
+ sage: C = codes.LinearRankMetricCode(G, GF(4)) # indirect doctest
753
+ sage: C
754
+ [3, 2] linear rank metric code over GF(64)/GF(4)
755
+ """
756
+ base_field = generator.base_ring()
757
+ if not base_field.is_field():
758
+ raise ValueError("'generator' must be defined on a field (not a ring)")
759
+
760
+ if not sub_field:
761
+ sub_field = base_field.prime_subfield()
762
+
763
+ try:
764
+ gen_basis = None
765
+ if hasattr(generator, "nrows"): # generator matrix case
766
+ if generator.rank() < generator.nrows():
767
+ gen_basis = generator.row_space().basis()
768
+ else:
769
+ gen_basis = generator.basis() # vector space etc. case
770
+ if gen_basis is not None:
771
+ from sage.matrix.constructor import matrix
772
+ generator = matrix(base_field, gen_basis)
773
+ if generator.nrows() == 0:
774
+ raise ValueError("this linear code contains no nonzero vector")
775
+ except AttributeError:
776
+ # Assume input is an AbstractLinearRankMetricCode, extract its generator matrix
777
+ generator = generator.generator_matrix()
778
+
779
+ self._generator_matrix = generator
780
+ self._length = generator.ncols()
781
+ super().__init__(base_field, sub_field, self._length,
782
+ "GeneratorMatrix", "NearestNeighbor", basis)
783
+
784
+ def _repr_(self):
785
+ r"""
786
+ Return a string representation of ``self``.
787
+
788
+ EXAMPLES::
789
+
790
+ sage: G = Matrix(GF(64), [[1,1,0], [0,0,1]])
791
+ sage: C = codes.LinearRankMetricCode(G, GF(4))
792
+ sage: C
793
+ [3, 2] linear rank metric code over GF(64)/GF(4)
794
+ """
795
+ R = self.base_field()
796
+ S = self.sub_field()
797
+ if R and S in Fields():
798
+ return "[%s, %s] linear rank metric code over GF(%s)/GF(%s)" % (self.length(), self.dimension(), R.cardinality(), S.cardinality())
799
+ else:
800
+ return "[%s, %s] linear rank metric code over %s/%s" % (self.length(), self.dimension(), R, S)
801
+
802
+ def _latex_(self):
803
+ r"""
804
+ Return a latex representation of ``self``.
805
+
806
+ EXAMPLES::
807
+
808
+ sage: G = Matrix(GF(64), [[1,1,0], [0,0,1]])
809
+ sage: C = codes.LinearRankMetricCode(G, GF(4))
810
+ sage: latex(C)
811
+ [3, 2]\textnormal{ Linear rank metric code over }\Bold{F}_{2^{6}}/\Bold{F}_{2^{2}}
812
+ """
813
+ return "[%s, %s]\\textnormal{ Linear rank metric code over }%s/%s"\
814
+ % (self.length(), self.dimension(), self.base_field()._latex_(), self.sub_field()._latex_())
815
+
816
+ def generator_matrix(self, encoder_name=None, **kwargs):
817
+ r"""
818
+ Return a generator matrix of ``self``.
819
+
820
+ INPUT:
821
+
822
+ - ``encoder_name`` -- (default: ``None``) name of the encoder which will be
823
+ used to compute the generator matrix. ``self._generator_matrix``
824
+ will be returned if default value is kept.
825
+
826
+ - ``kwargs`` -- all additional arguments are forwarded to the construction of the
827
+ encoder that is used
828
+
829
+ EXAMPLES::
830
+
831
+ sage: G = Matrix(GF(64), [[1,1,0], [0,0,1]])
832
+ sage: C = codes.LinearRankMetricCode(G, GF(4))
833
+ sage: C.generator_matrix()
834
+ [1 1 0]
835
+ [0 0 1]
836
+ """
837
+ if encoder_name is None or encoder_name == 'GeneratorMatrix':
838
+ g = self._generator_matrix
839
+ else:
840
+ g = super().generator_matrix(encoder_name, **kwargs)
841
+ g.set_immutable()
842
+ return g
843
+
844
+
845
+ ####################### decoders ###############################
846
+ class LinearRankMetricCodeNearestNeighborDecoder(Decoder):
847
+ r"""
848
+ Construct a decoder for Linear Rank Metric Codes.
849
+
850
+ This decoder will decode to the nearest codeword found.
851
+ """
852
+
853
+ def __init__(self, code):
854
+ r"""
855
+
856
+ INPUT:
857
+
858
+ - ``code`` -- a code associated to this decoder
859
+
860
+ EXAMPLES::
861
+
862
+ sage: G = Matrix(GF(64), [[1,1,0], [0,0,1]])
863
+ sage: C = codes.LinearRankMetricCode(G, GF(4))
864
+ sage: D = codes.decoders.LinearRankMetricCodeNearestNeighborDecoder(C)
865
+ sage: D
866
+ Nearest neighbor decoder for [3, 2] linear rank metric code over GF(64)/GF(4)
867
+ """
868
+ super().__init__(code, code.ambient_space(), code._default_encoder_name)
869
+
870
+ def __eq__(self, other):
871
+ r"""
872
+ Test equality between LinearRankMetricCodeNearestNeighborDecoder objects.
873
+
874
+ EXAMPLES::
875
+
876
+ sage: G = Matrix(GF(64), [[1,1,0], [0,0,1]])
877
+ sage: C = codes.LinearRankMetricCode(G, GF(4))
878
+ sage: D1 = codes.decoders.LinearRankMetricCodeNearestNeighborDecoder(C)
879
+ sage: D2 = codes.decoders.LinearRankMetricCodeNearestNeighborDecoder(C)
880
+ sage: D1 == D2
881
+ True
882
+ """
883
+ return isinstance(other, LinearRankMetricCodeNearestNeighborDecoder)\
884
+ and self.code() == other.code()
885
+
886
+ def _repr_(self):
887
+ r"""
888
+ Return a string representation of ``self``.
889
+
890
+ EXAMPLES::
891
+
892
+ sage: G = Matrix(GF(64), [[1,1,0], [0,0,1]])
893
+ sage: C = codes.LinearRankMetricCode(G, GF(4))
894
+ sage: D = codes.decoders.LinearRankMetricCodeNearestNeighborDecoder(C)
895
+ sage: D
896
+ Nearest neighbor decoder for [3, 2] linear rank metric code over GF(64)/GF(4)
897
+ """
898
+ return "Nearest neighbor decoder for %s" % self.code()
899
+
900
+ def _latex_(self):
901
+ r"""
902
+ Return a latex representation of ``self``.
903
+
904
+ EXAMPLES::
905
+
906
+ sage: G = Matrix(GF(64), [[1,1,0], [0,0,1]])
907
+ sage: C = codes.LinearRankMetricCode(G, GF(4))
908
+ sage: D = codes.decoders.LinearRankMetricCodeNearestNeighborDecoder(C)
909
+ sage: latex(D)
910
+ \textnormal{Nearest neighbor decoder for }[3, 2]\textnormal{ Linear rank metric code over }\Bold{F}_{2^{6}}/\Bold{F}_{2^{2}}
911
+ """
912
+ return "\\textnormal{Nearest neighbor decoder for }%s" % self.code()._latex_()
913
+
914
+ def decode_to_code(self, r):
915
+ r"""
916
+ Corrects the errors in ``word`` and returns a codeword.
917
+
918
+ INPUT:
919
+
920
+ - ``r`` -- a codeword of ``self``
921
+
922
+ OUTPUT: a vector of ``self``'s message space
923
+
924
+ EXAMPLES::
925
+
926
+ sage: F.<a> = GF(4)
927
+ sage: G = Matrix(F, [[1,1,0]])
928
+ sage: C = codes.LinearRankMetricCode(G, GF(2))
929
+ sage: D = codes.decoders.LinearRankMetricCodeNearestNeighborDecoder(C)
930
+ sage: D.decode_to_code(vector(F, [a, a, 1]))
931
+ (a, a, 0)
932
+ """
933
+ C = self.code()
934
+ c_min = C.zero()
935
+ h_min = C.rank_weight_of_vector(r)
936
+ for c in C:
937
+ if C.rank_weight_of_vector(c-r) < h_min:
938
+ h_min = C.rank_weight_of_vector(c-r)
939
+ c_min = c
940
+ c_min.set_immutable()
941
+ return c_min
942
+
943
+ def decoding_radius(self):
944
+ r"""
945
+ Return maximal number of errors ``self`` can decode.
946
+
947
+ EXAMPLES::
948
+
949
+ sage: F.<a> = GF(8)
950
+ sage: G = Matrix(F, [[1,a,a^2,0]])
951
+ sage: C = codes.LinearRankMetricCode(G, GF(2))
952
+ sage: D = codes.decoders.LinearRankMetricCodeNearestNeighborDecoder(C)
953
+ sage: D.decoding_radius()
954
+ 1
955
+ """
956
+ return (self.code().minimum_distance() - 1) // 2
957
+
958
+
959
+ ####################### registration ###############################
960
+
961
+ LinearRankMetricCode._registered_encoders["GeneratorMatrix"] = LinearCodeGeneratorMatrixEncoder