passagemath-modules 10.6.31__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.

Files changed (807) hide show
  1. passagemath_modules-10.6.31.dist-info/METADATA +281 -0
  2. passagemath_modules-10.6.31.dist-info/RECORD +807 -0
  3. passagemath_modules-10.6.31.dist-info/WHEEL +6 -0
  4. passagemath_modules-10.6.31.dist-info/top_level.txt +2 -0
  5. passagemath_modules.libs/libgfortran-83c28eba.so.5.0.0 +0 -0
  6. passagemath_modules.libs/libgmp-6e109695.so.10.5.0 +0 -0
  7. passagemath_modules.libs/libgsl-cda90e79.so.28.0.0 +0 -0
  8. passagemath_modules.libs/libmpc-7f678fcf.so.3.3.1 +0 -0
  9. passagemath_modules.libs/libmpfr-ecd7067e.so.6.2.1 +0 -0
  10. passagemath_modules.libs/libopenblasp-r0-6dcb67f9.3.29.so +0 -0
  11. passagemath_modules.libs/libquadmath-2284e583.so.0.0.0 +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-x86_64-linux-gnu.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-x86_64-linux-gnu.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-x86_64-linux-gnu.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-x86_64-linux-gnu.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-x86_64-linux-gnu.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-x86_64-linux-gnu.so +0 -0
  74. sage/calculus/integration.pyx +698 -0
  75. sage/calculus/interpolation.cpython-314-x86_64-linux-gnu.so +0 -0
  76. sage/calculus/interpolation.pxd +13 -0
  77. sage/calculus/interpolation.pyx +387 -0
  78. sage/calculus/interpolators.cpython-314-x86_64-linux-gnu.so +0 -0
  79. sage/calculus/interpolators.pyx +326 -0
  80. sage/calculus/ode.cpython-314-x86_64-linux-gnu.so +0 -0
  81. sage/calculus/ode.pxd +5 -0
  82. sage/calculus/ode.pyx +610 -0
  83. sage/calculus/riemann.cpython-314-x86_64-linux-gnu.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-x86_64-linux-gnu.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-x86_64-linux-gnu.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-x86_64-linux-gnu.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-x86_64-linux-gnu.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-x86_64-linux-gnu.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-x86_64-linux-gnu.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-x86_64-linux-gnu.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-x86_64-linux-gnu.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-x86_64-linux-gnu.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-x86_64-linux-gnu.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-x86_64-linux-gnu.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-x86_64-linux-gnu.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-x86_64-linux-gnu.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-x86_64-linux-gnu.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-x86_64-linux-gnu.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-x86_64-linux-gnu.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-x86_64-linux-gnu.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-x86_64-linux-gnu.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-x86_64-linux-gnu.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-x86_64-linux-gnu.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-x86_64-linux-gnu.so +0 -0
  401. sage/matrix/constructor.pyx +750 -0
  402. sage/matrix/docs.py +430 -0
  403. sage/matrix/echelon_matrix.cpython-314-x86_64-linux-gnu.so +0 -0
  404. sage/matrix/echelon_matrix.pyx +155 -0
  405. sage/matrix/matrix.pxd +2 -0
  406. sage/matrix/matrix0.cpython-314-x86_64-linux-gnu.so +0 -0
  407. sage/matrix/matrix0.pxd +68 -0
  408. sage/matrix/matrix0.pyx +6324 -0
  409. sage/matrix/matrix1.cpython-314-x86_64-linux-gnu.so +0 -0
  410. sage/matrix/matrix1.pxd +8 -0
  411. sage/matrix/matrix1.pyx +2851 -0
  412. sage/matrix/matrix2.cpython-314-x86_64-linux-gnu.so +0 -0
  413. sage/matrix/matrix2.pxd +25 -0
  414. sage/matrix/matrix2.pyx +20181 -0
  415. sage/matrix/matrix_cdv.cpython-314-x86_64-linux-gnu.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-x86_64-linux-gnu.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-x86_64-linux-gnu.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-x86_64-linux-gnu.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-x86_64-linux-gnu.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-x86_64-linux-gnu.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-x86_64-linux-gnu.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-x86_64-linux-gnu.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-x86_64-linux-gnu.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-x86_64-linux-gnu.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-x86_64-linux-gnu.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-x86_64-linux-gnu.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-x86_64-linux-gnu.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-x86_64-linux-gnu.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-x86_64-linux-gnu.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-x86_64-linux-gnu.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-x86_64-linux-gnu.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-x86_64-linux-gnu.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-x86_64-linux-gnu.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-x86_64-linux-gnu.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-x86_64-linux-gnu.so +0 -0
  492. sage/matroids/extension.pxd +34 -0
  493. sage/matroids/extension.pyx +519 -0
  494. sage/matroids/flats_matroid.cpython-314-x86_64-linux-gnu.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-x86_64-linux-gnu.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-x86_64-linux-gnu.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-x86_64-linux-gnu.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-x86_64-linux-gnu.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-x86_64-linux-gnu.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-x86_64-linux-gnu.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-x86_64-linux-gnu.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-x86_64-linux-gnu.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-x86_64-linux-gnu.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-x86_64-linux-gnu.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-x86_64-linux-gnu.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-x86_64-linux-gnu.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-x86_64-linux-gnu.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-x86_64-linux-gnu.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-x86_64-linux-gnu.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-x86_64-linux-gnu.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-x86_64-linux-gnu.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-x86_64-linux-gnu.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-x86_64-linux-gnu.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-x86_64-linux-gnu.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-x86_64-linux-gnu.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-x86_64-linux-gnu.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-x86_64-linux-gnu.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-x86_64-linux-gnu.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-x86_64-linux-gnu.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-x86_64-linux-gnu.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-x86_64-linux-gnu.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-x86_64-linux-gnu.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-x86_64-linux-gnu.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-x86_64-linux-gnu.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-x86_64-linux-gnu.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-x86_64-linux-gnu.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-x86_64-linux-gnu.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-x86_64-linux-gnu.so +0 -0
  701. sage/rings/function_field/hermite_form_polynomial.pyx +188 -0
  702. sage/rings/function_field/khuri_makdisi.cpython-314-x86_64-linux-gnu.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-x86_64-linux-gnu.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-x86_64-linux-gnu.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-x86_64-linux-gnu.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-x86_64-linux-gnu.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-x86_64-linux-gnu.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-x86_64-linux-gnu.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-x86_64-linux-gnu.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-x86_64-linux-gnu.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-x86_64-linux-gnu.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-x86_64-linux-gnu.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-x86_64-linux-gnu.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-x86_64-linux-gnu.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-x86_64-linux-gnu.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-x86_64-linux-gnu.so +0 -0
  771. sage/stats/hmm/chmm.pyx +1595 -0
  772. sage/stats/hmm/distributions.cpython-314-x86_64-linux-gnu.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-x86_64-linux-gnu.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-x86_64-linux-gnu.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-x86_64-linux-gnu.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-x86_64-linux-gnu.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,706 @@
1
+ # sage_setup: distribution = sagemath-modules
2
+ """
3
+ Elements of Finite Algebras
4
+ """
5
+ # ****************************************************************************
6
+ # Copyright (C) 2011 Johan Bosman <johan.g.bosman@gmail.com>
7
+ # Copyright (C) 2011, 2013 Peter Bruin <peter.bruin@math.uzh.ch>
8
+ # Copyright (C) 2011 Michiel Kosters <kosters@gmail.com>
9
+ # Copyright (C) 2017 Simon King <simon.king@uni-jena.de>
10
+ #
11
+ # Distributed under the terms of the GNU General Public License (GPL)
12
+ # as published by the Free Software Foundation; either version 2 of
13
+ # the License, or (at your option) any later version.
14
+ # https://www.gnu.org/licenses/
15
+ # ****************************************************************************
16
+ import re
17
+
18
+ from sage.matrix.matrix_space import MatrixSpace
19
+ from sage.rings.integer import Integer
20
+
21
+ from cpython.object cimport PyObject_RichCompare as richcmp
22
+
23
+ cpdef FiniteDimensionalAlgebraElement unpickle_FiniteDimensionalAlgebraElement(A, vec, mat):
24
+ """
25
+ Helper for unpickling of finite dimensional algebra elements.
26
+
27
+ TESTS::
28
+
29
+ sage: B = FiniteDimensionalAlgebra(QQ, [Matrix([[1,0,0], [0,1,0], [0,0,0]]),
30
+ ....: Matrix([[1,1,0], [0,1,1], [0,1,1]]),
31
+ ....: Matrix([[0,0,1], [0,1,0], [1,0,0]])])
32
+ sage: x = B([1,2,3])
33
+ sage: loads(dumps(x)) == x # indirect doctest
34
+ True
35
+ """
36
+ cdef FiniteDimensionalAlgebraElement x = A.element_class.__new__(A.element_class)
37
+ AlgebraElement.__init__(x, A)
38
+ x._vector = vec
39
+ x.__matrix = mat
40
+ return x
41
+
42
+ cdef class FiniteDimensionalAlgebraElement(AlgebraElement):
43
+ r"""
44
+ Create an element of a :class:`FiniteDimensionalAlgebra` using a multiplication table.
45
+
46
+ INPUT:
47
+
48
+ - ``A`` -- a :class:`FiniteDimensionalAlgebra` which will be the parent
49
+
50
+ - ``elt`` -- vector, matrix or element of the base field
51
+ (default: ``None``)
52
+
53
+ - ``check`` -- boolean (default: ``True``); if ``False`` and ``elt`` is a
54
+ matrix, assume that it is known to be the matrix of an element
55
+
56
+ If ``elt`` is a vector or a matrix consisting of a single row, it is
57
+ interpreted as a vector of coordinates with respect to the given basis
58
+ of ``A``. If ``elt`` is a square matrix, it is interpreted as a
59
+ multiplication matrix with respect to this basis.
60
+
61
+ EXAMPLES::
62
+
63
+ sage: A = FiniteDimensionalAlgebra(GF(3), [Matrix([[1,0], [0,1]]),
64
+ ....: Matrix([[0,1], [0,0]])])
65
+ sage: A(17)
66
+ 2*e0
67
+ sage: A([1,1])
68
+ e0 + e1
69
+ """
70
+ def __init__(self, A, elt=None, check=True):
71
+ """
72
+ TESTS::
73
+
74
+ sage: A = FiniteDimensionalAlgebra(GF(3), [Matrix([[1,0], [0,1]]),
75
+ ....: Matrix([[0,1], [0,0]])])
76
+ sage: A(QQ(4))
77
+ Traceback (most recent call last):
78
+ ...
79
+ TypeError: elt should be a vector, a matrix, or an element of the base field
80
+
81
+ sage: B = FiniteDimensionalAlgebra(QQ, [Matrix([[1,0], [0,1]]),
82
+ ....: Matrix([[0,1], [-1,0]])])
83
+ sage: elt = B(Matrix([[1,1], [-1,1]])); elt
84
+ e0 + e1
85
+ sage: TestSuite(elt).run()
86
+ sage: B(Matrix([[0,1], [1,0]]))
87
+ Traceback (most recent call last):
88
+ ...
89
+ ValueError: matrix does not define an element of the algebra
90
+ """
91
+ AlgebraElement.__init__(self, A)
92
+ k = A.base_ring()
93
+ n = A.degree()
94
+ if elt is None:
95
+ self._vector = MatrixSpace(k, 1, n)()
96
+ self.__matrix = MatrixSpace(k, n)()
97
+ else:
98
+ if isinstance(elt, int):
99
+ elt = Integer(elt)
100
+ elif isinstance(elt, list):
101
+ elt = MatrixSpace(k, 1, n)(elt)
102
+ if A == elt.parent():
103
+ mat = (<FiniteDimensionalAlgebraElement> elt).__matrix
104
+ if mat is None:
105
+ self.__matrix = None
106
+ else:
107
+ self.__matrix = mat.base_extend(k)
108
+ self._vector = elt._vector.base_extend(k)
109
+ elif k.has_coerce_map_from(elt.parent()):
110
+ e = k(elt)
111
+ if e == 0:
112
+ self._vector = MatrixSpace(k, 1, n)()
113
+ self.__matrix = MatrixSpace(k, n)()
114
+ elif A.is_unitary():
115
+ self._vector = A._one * e
116
+ self.__matrix = MatrixSpace(k, n)(1) * e
117
+ else:
118
+ raise TypeError("algebra is not unitary")
119
+ elif isinstance(elt, Vector):
120
+ self._vector = MatrixSpace(k, 1, n)(list(elt))
121
+ elif isinstance(elt, Matrix):
122
+ if elt.ncols() != n:
123
+ raise ValueError("matrix does not define an element of the algebra")
124
+ if elt.nrows() == 1:
125
+ self._vector = elt.__copy__()
126
+ else:
127
+ if not A.is_unitary():
128
+ raise TypeError("algebra is not unitary")
129
+ self._vector = A._one * elt
130
+ if check and self._matrix != elt:
131
+ raise ValueError("matrix does not define an element of the algebra")
132
+ else:
133
+ raise TypeError("elt should be a vector, a matrix, " +
134
+ "or an element of the base field")
135
+ self._vector.set_immutable()
136
+
137
+ def __reduce__(self):
138
+ """
139
+ TESTS::
140
+
141
+ sage: B = FiniteDimensionalAlgebra(QQ, [Matrix([[1,0,0], [0,1,0], [0,0,0]]),
142
+ ....: Matrix([[1,1,0], [0,1,1], [0,1,1]]),
143
+ ....: Matrix([[0,0,1], [0,1,0], [1,0,0]])])
144
+ sage: x = B([1,2,3])
145
+ sage: loads(dumps(x)) == x # indirect doctest
146
+ True
147
+ sage: loads(dumps(x)) is x
148
+ False
149
+ """
150
+ return unpickle_FiniteDimensionalAlgebraElement, (self._parent, self._vector, self.__matrix)
151
+
152
+ def __setstate__(self, state):
153
+ """
154
+ This method serves at unpickling old pickles.
155
+
156
+ TESTS::
157
+
158
+ sage: A = FiniteDimensionalAlgebra(QQ, [Matrix([[1,0,0], [0,1,0], [0,0,0]]),
159
+ ....: Matrix([[0,1,0], [0,0,0], [0,0,0]]),
160
+ ....: Matrix([[0,0,0], [0,0,0], [0,0,1]])])
161
+ sage: x = A.element_class.__new__(A.element_class)
162
+ sage: x.__setstate__((A, {'_vector':vector([1,1,1]), '_matrix':matrix(QQ,3,[1,1,0, 0,1,0, 0,0,1])}))
163
+ sage: x
164
+ e0 + e1 + e2
165
+ sage: x.matrix()
166
+ [1 1 0]
167
+ [0 1 0]
168
+ [0 0 1]
169
+
170
+ Note that in old pickles, the vector actually is a vector. However,
171
+ it is converted into a single-row matrix, in the new implementation::
172
+
173
+ sage: x.vector()
174
+ (1, 1, 1)
175
+ """
176
+ self._parent, D = state
177
+ v = D.pop('_vector')
178
+ if isinstance(v, Vector):
179
+ self._vector = MatrixSpace(self._parent.base_ring(), 1, len(v))(list(v))
180
+ else:
181
+ self._vector = v
182
+ self.__matrix = D.pop('_matrix', None)
183
+ try:
184
+ self.__dict__ = D
185
+ except AttributeError:
186
+ pass
187
+
188
+ @property
189
+ def _matrix(self):
190
+ """
191
+ TESTS::
192
+
193
+ sage: B = FiniteDimensionalAlgebra(QQ, [Matrix([[1,0,0], [0,1,0], [0,0,0]]),
194
+ ....: Matrix([[1,1,0], [0,1,1], [0,1,1]]),
195
+ ....: Matrix([[0,0,1], [0,1,0], [1,0,0]])])
196
+ sage: x = B([1,2,3])
197
+ sage: x._matrix
198
+ [3 2 3]
199
+ [0 6 2]
200
+ [3 2 2]
201
+ """
202
+ cdef Py_ssize_t i
203
+ cdef tuple table
204
+ if self.__matrix is None:
205
+ A = self.parent()
206
+ table = <tuple> A.table()
207
+ ret = sum(self._vector[0, i] * table[i] for i in range(A.degree()))
208
+ self.__matrix = MatrixSpace(A.base_ring(), A.degree())(ret)
209
+ self.__matrix.set_immutable()
210
+ return self.__matrix
211
+
212
+ def vector(self):
213
+ """
214
+ Return ``self`` as a vector.
215
+
216
+ EXAMPLES::
217
+
218
+ sage: B = FiniteDimensionalAlgebra(QQ, [Matrix([[1,0,0], [0,1,0], [0,0,0]]),
219
+ ....: Matrix([[0,1,0], [0,0,0], [0,0,0]]),
220
+ ....: Matrix([[0,0,0], [0,0,0], [0,0,1]])])
221
+ sage: B(5).vector()
222
+ (5, 0, 5)
223
+ """
224
+ # By :issue:`23707`, ``self._vector`` now is a single row matrix,
225
+ # not a vector, which results in a speed-up.
226
+ # For backwards compatibility, this method still returns a vector.
227
+ return self._vector[0]
228
+
229
+ def matrix(self):
230
+ """
231
+ Return the matrix for multiplication by ``self`` from the right.
232
+
233
+ EXAMPLES::
234
+
235
+ sage: B = FiniteDimensionalAlgebra(QQ, [Matrix([[1,0,0], [0,1,0], [0,0,0]]),
236
+ ....: Matrix([[0,1,0], [0,0,0], [0,0,0]]),
237
+ ....: Matrix([[0,0,0], [0,0,0], [0,0,1]])])
238
+ sage: B(5).matrix()
239
+ [5 0 0]
240
+ [0 5 0]
241
+ [0 0 5]
242
+ """
243
+ return self._matrix
244
+
245
+ cpdef dict monomial_coefficients(self, bint copy=True):
246
+ """
247
+ Return a dictionary whose keys are indices of basis elements in
248
+ the support of ``self`` and whose values are the corresponding
249
+ coefficients.
250
+
251
+ INPUT:
252
+
253
+ - ``copy`` -- ignored
254
+
255
+ EXAMPLES::
256
+
257
+ sage: B = FiniteDimensionalAlgebra(QQ, [Matrix([[1,0], [0,1]]),
258
+ ....: Matrix([[0,1], [-1,0]])])
259
+ sage: elt = B(Matrix([[1,1], [-1,1]]))
260
+ sage: elt.monomial_coefficients()
261
+ {0: 1, 1: 1}
262
+ sage: B.one().monomial_coefficients()
263
+ {0: 1}
264
+ """
265
+ return {k[1]: c for k, c in self._vector._dict().items()}
266
+
267
+ def left_matrix(self):
268
+ """
269
+ Return the matrix for multiplication by ``self`` from the left.
270
+
271
+ EXAMPLES::
272
+
273
+ sage: C = FiniteDimensionalAlgebra(QQ, [Matrix([[1,0,0], [0,0,0], [0,0,0]]),
274
+ ....: Matrix([[0,1,0], [0,0,0], [0,0,0]]),
275
+ ....: Matrix([[0,0,0], [0,1,0], [0,0,1]])])
276
+ sage: C([1,2,0]).left_matrix()
277
+ [1 0 0]
278
+ [0 1 0]
279
+ [0 2 0]
280
+ """
281
+ A = self.parent()
282
+ if A.is_commutative():
283
+ return self._matrix
284
+ return sum([self._vector[0, i] * A.left_table()[i] for
285
+ i in range(A.degree())])
286
+
287
+ def _repr_(self):
288
+ """
289
+ Return the string representation of ``self``.
290
+
291
+ EXAMPLES::
292
+
293
+ sage: A = FiniteDimensionalAlgebra(GF(3), [Matrix([[1,0], [0,1]]),
294
+ ....: Matrix([[0,1], [0,0]])])
295
+ sage: A(1)
296
+ e0
297
+ """
298
+ s = " "
299
+ A = self.parent()
300
+ m = A.degree()
301
+ coeffs = self._vector.list()
302
+ atomic = A.base_ring()._repr_option('element_is_atomic')
303
+ non_zero = False
304
+ for n in range(m):
305
+ x = coeffs[n]
306
+ if x:
307
+ if non_zero:
308
+ s += " + "
309
+ non_zero = True
310
+ x = y = repr(x)
311
+ if y.find('-') == 0:
312
+ y = y[1:]
313
+ if not atomic and (y.find("+") != -1 or y.find("-") != -1):
314
+ x = "({})".format(x)
315
+ var = "*{}".format(A._names[n])
316
+ s += "{}{}".format(x, var)
317
+ s = s.replace(" + -", " - ")
318
+ s = re.sub(r' 1(\.0+)?\*', ' ', s)
319
+ s = re.sub(r' -1(\.0+)?\*', ' -', s)
320
+ if s == " ":
321
+ return "0"
322
+ return s[1:]
323
+
324
+ def _latex_(self):
325
+ r"""
326
+ Return the LaTeX representation of ``self``.
327
+
328
+ EXAMPLES::
329
+
330
+ sage: A = FiniteDimensionalAlgebra(GF(3), [Matrix([[1,0], [0,1]]),
331
+ ....: Matrix([[0,1], [0,0]])])
332
+ sage: latex(A(1)) # indirect doctest
333
+ \left(\begin{array}{rr}
334
+ 1 & 0 \\
335
+ 0 & 1
336
+ \end{array}\right)
337
+ """
338
+ from sage.misc.latex import latex
339
+ return latex(self.matrix())
340
+
341
+ def __hash__(self):
342
+ """
343
+ Return the hash value for ``self``.
344
+
345
+ EXAMPLES::
346
+
347
+ sage: A = FiniteDimensionalAlgebra(GF(3), [Matrix([[1,0], [0,1]]),
348
+ ....: Matrix([[0,1], [0,0]])])
349
+ sage: a = A([1,2])
350
+ sage: b = A([2,3])
351
+ sage: hash(a) == hash(A([1,2]))
352
+ True
353
+ sage: hash(a) == hash(b)
354
+ False
355
+ """
356
+ return hash(self._vector)
357
+
358
+ def __getitem__(self, m):
359
+ """
360
+ Return the `m`-th coefficient of ``self``.
361
+
362
+ EXAMPLES::
363
+
364
+ sage: A = FiniteDimensionalAlgebra(QQ, [Matrix([[1,0,0], [0,1,0], [0,0,0]]),
365
+ ....: Matrix([[0,1,0], [0,0,0], [0,0,0]]),
366
+ ....: Matrix([[0,0,0], [0,0,0], [0,0,1]])])
367
+ sage: A([2,1/4,3])[2]
368
+ 3
369
+ """
370
+ return self._vector[0, m]
371
+
372
+ def __len__(self):
373
+ """
374
+ Return the number of coefficients of ``self``,
375
+ including the zero coefficients.
376
+
377
+ EXAMPLES::
378
+
379
+ sage: A = FiniteDimensionalAlgebra(QQ, [Matrix([[1,0,0], [0,1,0], [0,0,0]]),
380
+ ....: Matrix([[0,1,0], [0,0,0], [0,0,0]]),
381
+ ....: Matrix([[0,0,0], [0,0,0], [0,0,1]])])
382
+ sage: len(A([2,1/4,3]))
383
+ 3
384
+ sage: len(A([2,0,3/4]))
385
+ 3
386
+ """
387
+ return self._vector.ncols()
388
+
389
+ # (Rich) comparison
390
+ cpdef _richcmp_(self, right, int op):
391
+ """
392
+ EXAMPLES::
393
+
394
+ sage: A = FiniteDimensionalAlgebra(GF(3), [Matrix([[1,0], [0,1]]),
395
+ ....: Matrix([[0,1], [0,0]])])
396
+ sage: A(2) == 2
397
+ True
398
+ sage: A(2) == 3
399
+ False
400
+ sage: A(2) == GF(5)(2)
401
+ False
402
+
403
+ sage: B = FiniteDimensionalAlgebra(QQ, [Matrix([[1,0,0], [0,1,0], [0,0,0]]),
404
+ ....: Matrix([[0,1,0], [0,0,0], [0,0,0]]),
405
+ ....: Matrix([[0,0,0], [0,0,0], [0,0,1]])])
406
+ sage: B(1) != 0
407
+ True
408
+
409
+ By :issue:`23707`, an ordering is defined on finite-dimensional algebras, corresponding
410
+ to the ordering of the defining vectors; this may be handy if the vector space basis of
411
+ the algebra corresponds to the standard monomials of the relation ideal, when
412
+ the algebra is considered as a quotient of a path algebra. ::
413
+
414
+ sage: A(1) > 0
415
+ True
416
+ sage: A(1) < 0
417
+ False
418
+ sage: A(1) >= 0
419
+ True
420
+ sage: A(1) <= 0
421
+ False
422
+ """
423
+ return richcmp(self._vector, <FiniteDimensionalAlgebraElement>right._vector, op)
424
+
425
+ cpdef _add_(self, other):
426
+ """
427
+ EXAMPLES::
428
+
429
+ sage: A = FiniteDimensionalAlgebra(GF(3), [Matrix([[1,0], [0,1]]),
430
+ ....: Matrix([[0,1], [0,0]])])
431
+ sage: A.basis()[0] + A.basis()[1]
432
+ e0 + e1
433
+ """
434
+ return self._parent.element_class(self._parent, self._vector + <FiniteDimensionalAlgebraElement>other._vector)
435
+
436
+ cpdef _sub_(self, other):
437
+ """
438
+ EXAMPLES::
439
+
440
+ sage: A = FiniteDimensionalAlgebra(GF(3), [Matrix([[1,0], [0,1]]),
441
+ ....: Matrix([[0,1], [0,0]])])
442
+ sage: A.basis()[0] - A.basis()[1]
443
+ e0 + 2*e1
444
+ """
445
+ return self._parent.element_class(self._parent, self._vector - <FiniteDimensionalAlgebraElement>other._vector)
446
+
447
+ cpdef _mul_(self, other):
448
+ """
449
+ EXAMPLES::
450
+
451
+ sage: C = FiniteDimensionalAlgebra(QQ, [Matrix([[1,0,0], [0,0,0], [0,0,0]]),
452
+ ....: Matrix([[0,1,0], [0,0,0], [0,0,0]]),
453
+ ....: Matrix([[0,0,0], [0,1,0], [0,0,1]])])
454
+ sage: C.basis()[1] * C.basis()[2]
455
+ e1
456
+ """
457
+ return self._parent.element_class(self._parent, self._vector * <FiniteDimensionalAlgebraElement>(other)._matrix)
458
+
459
+ cpdef _lmul_(self, Element other):
460
+ """
461
+ TESTS::
462
+
463
+ sage: C = FiniteDimensionalAlgebra(QQ, [Matrix([[1,0,0], [0,0,0], [0,0,0]]),
464
+ ....: Matrix([[0,1,0], [0,0,0], [0,0,0]]),
465
+ ....: Matrix([[0,0,0], [0,1,0], [0,0,1]])])
466
+ sage: c = C.random_element()
467
+ sage: c * 2 == c + c
468
+ True
469
+ """
470
+ if not self._parent.base_ring().has_coerce_map_from(other.parent()):
471
+ raise TypeError("unsupported operand parent(s) for *: '{}' and '{}'"
472
+ .format(self.parent(), other.parent()))
473
+ return self._parent.element_class(self._parent, self._vector * other)
474
+
475
+ cpdef _rmul_(self, Element other):
476
+ """
477
+ TESTS::
478
+
479
+ sage: C = FiniteDimensionalAlgebra(QQ, [Matrix([[1,0,0], [0,0,0], [0,0,0]]),
480
+ ....: Matrix([[0,1,0], [0,0,0], [0,0,0]]),
481
+ ....: Matrix([[0,0,0], [0,1,0], [0,0,1]])])
482
+ sage: c = C.random_element()
483
+ sage: 2 * c == c + c
484
+ True
485
+ """
486
+ if not self._parent.base_ring().has_coerce_map_from(other.parent()):
487
+ raise TypeError("unsupported operand parent(s) for *: '{}' and '{}'"
488
+ .format(self.parent(), other.parent()))
489
+ # Note the different order below
490
+ return self._parent.element_class(self._parent, other * self._vector)
491
+
492
+ def __pow__(self, n, m):
493
+ """
494
+ Return ``self`` raised to the power ``n``.
495
+
496
+ EXAMPLES::
497
+
498
+ sage: B = FiniteDimensionalAlgebra(QQ, [Matrix([[1,0,0], [0,1,0], [0,0,0]]),
499
+ ....: Matrix([[0,1,0], [0,0,0], [0,0,0]]),
500
+ ....: Matrix([[0,0,0], [0,0,0], [0,0,1]])])
501
+ sage: b = B([2,3,4])
502
+ sage: b^6
503
+ 64*e0 + 576*e1 + 4096*e2
504
+ """
505
+ A = self.parent()
506
+ if not (A._assume_associative or A.is_associative()):
507
+ raise TypeError("algebra is not associative")
508
+ if n > 0:
509
+ return A.element_class(A, self._vector * self._matrix ** (n - 1))
510
+ if not A.is_unitary():
511
+ raise TypeError("algebra is not unitary")
512
+ if n == 0:
513
+ return A.one()
514
+ cdef FiniteDimensionalAlgebraElement a = <FiniteDimensionalAlgebraElement>(~self)
515
+ return A.element_class(A, a._vector * a.__matrix ** (-n - 1))
516
+
517
+ def __invert__(self):
518
+ """
519
+ TESTS::
520
+
521
+ sage: C = FiniteDimensionalAlgebra(QQ, [Matrix([[1,0], [0,1]]),
522
+ ....: Matrix([[0,1], [-1,0]])])
523
+ sage: x = C([1,2])
524
+ sage: y = ~x; y # indirect doctest
525
+ 1/5*e0 - 2/5*e1
526
+ sage: x*y
527
+ e0
528
+ sage: C.one()
529
+ e0
530
+ """
531
+ return self.inverse()
532
+
533
+ def is_invertible(self):
534
+ """
535
+ Return ``True`` if ``self`` has a two-sided multiplicative
536
+ inverse.
537
+
538
+ This assumes that the algebra to which ``self`` belongs is
539
+ associative.
540
+
541
+ .. NOTE::
542
+
543
+ If an element of a unitary finite-dimensional algebra over a field
544
+ admits a left inverse, then this is the unique left
545
+ inverse, and it is also a right inverse.
546
+
547
+ EXAMPLES::
548
+
549
+ sage: C = FiniteDimensionalAlgebra(QQ, [Matrix([[1,0], [0,1]]),
550
+ ....: Matrix([[0,1], [-1,0]])])
551
+ sage: C([1,2]).is_invertible()
552
+ True
553
+ sage: C(0).is_invertible()
554
+ False
555
+ """
556
+ return self._inverse is not None
557
+
558
+ @property
559
+ def _inverse(self):
560
+ """
561
+ The two-sided inverse of ``self``, if it exists; otherwise this
562
+ is ``None``.
563
+
564
+ This assumes that the algebra to which ``self`` belongs is
565
+ associative.
566
+
567
+ EXAMPLES::
568
+
569
+ sage: C = FiniteDimensionalAlgebra(QQ, [Matrix([[1,0], [0,1]]),
570
+ ....: Matrix([[0,1], [-1,0]])])
571
+ sage: C([1,2])._inverse
572
+ 1/5*e0 - 2/5*e1
573
+ sage: C(0)._inverse is None
574
+ True
575
+ """
576
+ cdef FiniteDimensionalAlgebraElement y
577
+ if self.__inverse is None:
578
+ A = self.parent()
579
+ if not A.is_unitary():
580
+ self.__inverse = False
581
+ try:
582
+ a = self._matrix.inverse()
583
+ y = FiniteDimensionalAlgebraElement(A, a, check=True)
584
+ y.__inverse = self
585
+ self.__inverse = y
586
+ except (ZeroDivisionError, ValueError):
587
+ self.__inverse = False
588
+ if self.__inverse is False:
589
+ return None
590
+ return self.__inverse
591
+
592
+ def inverse(self):
593
+ """
594
+ Return the two-sided multiplicative inverse of ``self``, if it
595
+ exists.
596
+
597
+ This assumes that the algebra to which ``self`` belongs is
598
+ associative.
599
+
600
+ .. NOTE::
601
+
602
+ If an element of a finite-dimensional unitary associative
603
+ algebra over a field admits a left inverse, then this is the
604
+ unique left inverse, and it is also a right inverse.
605
+
606
+ EXAMPLES::
607
+
608
+ sage: C = FiniteDimensionalAlgebra(QQ, [Matrix([[1,0], [0,1]]),
609
+ ....: Matrix([[0,1], [-1,0]])])
610
+ sage: C([1,2]).inverse()
611
+ 1/5*e0 - 2/5*e1
612
+ """
613
+ A = self.parent()
614
+ if not A.is_unitary():
615
+ raise TypeError("algebra is not unitary")
616
+
617
+ if self._inverse is None:
618
+ raise ZeroDivisionError("element is not invertible")
619
+ return self._inverse
620
+
621
+ def is_zerodivisor(self):
622
+ """
623
+ Return ``True`` if ``self`` is a left or right zero-divisor.
624
+
625
+ EXAMPLES::
626
+
627
+ sage: C = FiniteDimensionalAlgebra(QQ, [Matrix([[1,0], [0,1]]),
628
+ ....: Matrix([[0,1], [0,0]])])
629
+ sage: C([1,0]).is_zerodivisor()
630
+ False
631
+ sage: C([0,1]).is_zerodivisor()
632
+ True
633
+ """
634
+ return self.matrix().det() == 0 or self.left_matrix().det() == 0
635
+
636
+ def is_nilpotent(self):
637
+ """
638
+ Return ``True`` if ``self`` is nilpotent.
639
+
640
+ EXAMPLES::
641
+
642
+ sage: C = FiniteDimensionalAlgebra(QQ, [Matrix([[1,0], [0,1]]),
643
+ ....: Matrix([[0,1], [0,0]])])
644
+ sage: C([1,0]).is_nilpotent()
645
+ False
646
+ sage: C([0,1]).is_nilpotent()
647
+ True
648
+
649
+ sage: A = FiniteDimensionalAlgebra(QQ, [Matrix([0])])
650
+ sage: A([1]).is_nilpotent()
651
+ True
652
+ """
653
+ A = self.parent()
654
+ if not (A._assume_associative or A.is_associative()):
655
+ raise TypeError("algebra is not associative")
656
+ return self.matrix() ** A.degree() == 0
657
+
658
+ def minimal_polynomial(self):
659
+ """
660
+ Return the minimal polynomial of ``self``.
661
+
662
+ EXAMPLES::
663
+
664
+ sage: B = FiniteDimensionalAlgebra(QQ, [Matrix([[1,0,0], [0,1,0], [0,0,0]]),
665
+ ....: Matrix([[0,1,0], [0,0,0], [0,0,0]]),
666
+ ....: Matrix([[0,0,0], [0,0,0], [0,0,1]])])
667
+ sage: B(0).minimal_polynomial() # needs sage.libs.pari
668
+ x
669
+ sage: b = B.random_element()
670
+ sage: f = b.minimal_polynomial(); f # random # needs sage.libs.pari
671
+ x^3 + 1/2*x^2 - 7/16*x + 1/16
672
+ sage: f(b) == 0 # needs sage.libs.pari
673
+ True
674
+ """
675
+ A = self.parent()
676
+ if not A.is_unitary():
677
+ raise TypeError("algebra is not unitary")
678
+ if not (A._assume_associative or A.is_associative()):
679
+ raise TypeError("algebra is not associative")
680
+ return self.matrix().minimal_polynomial()
681
+
682
+ def characteristic_polynomial(self):
683
+ """
684
+ Return the characteristic polynomial of ``self``.
685
+
686
+ .. NOTE::
687
+
688
+ This function just returns the characteristic polynomial
689
+ of the matrix of right multiplication by ``self``. This
690
+ may not be a very meaningful invariant if the algebra is
691
+ not unitary and associative.
692
+
693
+ EXAMPLES::
694
+
695
+ sage: B = FiniteDimensionalAlgebra(QQ, [Matrix([[1,0,0], [0,1,0], [0,0,0]]),
696
+ ....: Matrix([[0,1,0], [0,0,0], [0,0,0]]),
697
+ ....: Matrix([[0,0,0], [0,0,0], [0,0,1]])])
698
+ sage: B(0).characteristic_polynomial() # needs sage.libs.pari
699
+ x^3
700
+ sage: b = B.random_element()
701
+ sage: f = b.characteristic_polynomial(); f # random # needs sage.libs.pari
702
+ x^3 - 8*x^2 + 16*x
703
+ sage: f(b) == 0 # needs sage.libs.pari
704
+ True
705
+ """
706
+ return self.matrix().characteristic_polynomial()