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,910 @@
1
+ # sage_setup: distribution = sagemath-modules
2
+ # sage.doctest: optional - scipy
3
+ """
4
+ Numerical Root Finding and Optimization
5
+
6
+ AUTHOR:
7
+
8
+ - William Stein (2007): initial version
9
+ - Nathann Cohen (2008): Bin Packing
10
+
11
+
12
+ Functions and Methods
13
+ ----------------------
14
+ """
15
+
16
+ from sage.modules.free_module_element import vector
17
+ from sage.rings.real_double import RDF
18
+
19
+
20
+ def find_root(f, a, b, xtol=10e-13, rtol=2.0**-50, maxiter=100, full_output=False):
21
+ r"""
22
+ Numerically find a root of ``f`` on the closed interval `[a,b]`
23
+ (or `[b,a]`) if possible, where ``f`` is a function in the one variable.
24
+ Note: this function only works in fixed (machine) precision, it is not
25
+ possible to get arbitrary precision approximations with it.
26
+
27
+ INPUT:
28
+
29
+ - ``f`` -- a function of one variable or symbolic equality
30
+
31
+ - ``a``, ``b`` -- endpoints of the interval
32
+
33
+ - ``xtol``, ``rtol`` -- the routine converges when a root is known
34
+ to lie within ``xtol`` of the value return. Should be `\geq 0`.
35
+ The routine modifies this to take into account the relative precision
36
+ of doubles. By default, rtol is ``4*numpy.finfo(float).eps``, the
37
+ minimum allowed value for :func:`scipy:scipy.optimize.brentq`, which is
38
+ what this method uses underneath. This value is equal to ``2.0**-50`` for
39
+ IEEE-754 double precision floats as used by Python.
40
+
41
+ - ``maxiter`` -- integer; if convergence is not achieved in
42
+ ``maxiter`` iterations, an error is raised. Must be `\geq 0`.
43
+
44
+ - ``full_output`` -- boolean (default: ``False``); if ``True``, also return
45
+ object that contains information about convergence
46
+
47
+ EXAMPLES:
48
+
49
+ An example involving an algebraic polynomial function::
50
+
51
+ sage: R.<x> = QQ[]
52
+ sage: f = (x+17)*(x-3)*(x-1/8)^3
53
+ sage: find_root(f, 0,4)
54
+ 2.999999999999995
55
+ sage: find_root(f, 0,1) # abs tol 1e-6 (note -- precision of answer isn't very good on some machines)
56
+ 0.124999
57
+ sage: find_root(f, -20,-10)
58
+ -17.0
59
+
60
+ In Pomerance's book on primes he asserts that the famous Riemann
61
+ Hypothesis is equivalent to the statement that the function `f(x)`
62
+ defined below is positive for all `x \geq 2.01`::
63
+
64
+ sage: def f(x):
65
+ ....: return sqrt(x) * log(x) - abs(Li(x) - prime_pi(x))
66
+
67
+ We find where `f` equals, i.e., what value that is slightly smaller
68
+ than `2.01` that could have been used in the formulation of the Riemann
69
+ Hypothesis::
70
+
71
+ sage: find_root(f, 2, 4, rtol=0.0001) # needs sage.symbolic
72
+ 2.0082...
73
+
74
+ This agrees with the plot::
75
+
76
+ sage: plot(f, 2, 2.01) # needs sage.symbolic
77
+ Graphics object consisting of 1 graphics primitive
78
+
79
+ The following example was added due to :issue:`4942` and demonstrates that
80
+ the function need not be defined at the endpoints::
81
+
82
+ sage: find_root(x^2*log(x,2)-1,0, 2) # abs tol 1e-6
83
+ 1.41421356237
84
+
85
+ The following is an example, again from :issue:`4942` where Brent's method
86
+ fails. Currently no other method is implemented, but at least we
87
+ acknowledge the fact that the algorithm fails::
88
+
89
+ sage: find_root(1/(x-1)+1,0, 2)
90
+ 0.0
91
+ sage: find_root(1/(x-1)+1,0.00001, 2)
92
+ Traceback (most recent call last):
93
+ ...
94
+ NotImplementedError: Brent's method failed to find a zero for f on the interval
95
+
96
+ An example of a function which evaluates to NaN on the entire interval::
97
+
98
+ sage: f(x) = 0.0 / max(0, x)
99
+ sage: find_root(f, -1, 0)
100
+ Traceback (most recent call last):
101
+ ...
102
+ RuntimeError: f appears to have no zero on the interval
103
+ """
104
+ try:
105
+ return f.find_root(a=a,b=b,xtol=xtol,rtol=rtol,maxiter=maxiter,full_output=full_output)
106
+ except AttributeError:
107
+ pass
108
+ a = float(a)
109
+ b = float(b)
110
+ if a > b:
111
+ a, b = b, a
112
+ left = f(a)
113
+ right = f(b)
114
+
115
+ if left > 0 and right > 0:
116
+ # Refine further -- try to find a point where this
117
+ # function is negative in the interval
118
+ val, s = find_local_minimum(f, a, b)
119
+ if val > 0:
120
+ if val < rtol:
121
+ if full_output:
122
+ return s, "No extra data"
123
+ else:
124
+ return s
125
+ raise RuntimeError("f appears to have no zero on the interval")
126
+ # If we found such an s, then we just instead find
127
+ # a root between left and s or s and right.
128
+ a = s # arbitrary choice -- maybe should try both and take one that works?
129
+
130
+ elif left < 0 and right < 0:
131
+ # Refine further
132
+ val, s = find_local_maximum(f, a, b)
133
+ if val < 0:
134
+ if abs(val) < rtol:
135
+ if full_output:
136
+ return s, "No extra data"
137
+ else:
138
+ return s
139
+ raise RuntimeError("f appears to have no zero on the interval")
140
+ a = s
141
+
142
+ # Fixing :issue:`4942` - if the answer on any of the endpoints is NaN,
143
+ # we restrict to looking between minimum and maximum values in the segment
144
+ # Note - this could be used in all cases, but it requires some more
145
+ # computation
146
+
147
+ if (left != left) or (right != right):
148
+ minval, s_1 = find_local_minimum(f, a, b)
149
+ maxval, s_2 = find_local_maximum(f, a, b)
150
+ if ((minval > 0) or (maxval < 0) or
151
+ (minval != minval) or (maxval != maxval)):
152
+ raise RuntimeError("f appears to have no zero on the interval")
153
+ a = min(s_1, s_2)
154
+ b = max(s_1, s_2)
155
+
156
+ import scipy.optimize
157
+ import numpy
158
+ if int(numpy.version.short_version[0]) > 1:
159
+ numpy.set_printoptions(legacy="1.25")
160
+
161
+ g = lambda x: float(f(x))
162
+ brentqRes = scipy.optimize.brentq(g, a, b,
163
+ full_output=full_output, xtol=xtol, rtol=rtol, maxiter=maxiter)
164
+ # A check following :issue:`4942`, to ensure we actually found a root
165
+ # Maybe should use a different tolerance here?
166
+ # The idea is to take roughly the derivative and multiply by estimated
167
+ # value of the root
168
+ root = 0
169
+ if full_output:
170
+ root = brentqRes[0]
171
+ else:
172
+ root = brentqRes
173
+ if abs(f(root)) > max(abs(root * rtol * (right - left) / (b - a)), 1e-6):
174
+ raise NotImplementedError("Brent's method failed to find a zero for f on the interval")
175
+ return brentqRes
176
+
177
+
178
+ def find_local_maximum(f, a, b, tol=1.48e-08, maxfun=500):
179
+ """
180
+ Numerically find a local maximum of the expression `f` on the interval
181
+ `[a,b]` (or `[b,a]`) along with the point at which the maximum is attained.
182
+
183
+ Note that this function only finds a *local* maximum, and not the
184
+ global maximum on that interval -- see the examples with
185
+ :func:`find_local_maximum`.
186
+
187
+ See the documentation for :func:`find_local_maximum` for more
188
+ details and possible workarounds for finding the global minimum on
189
+ an interval.
190
+
191
+ EXAMPLES::
192
+
193
+ sage: f = lambda x: x*cos(x)
194
+ sage: find_local_maximum(f, 0, 5)
195
+ (0.561096338191..., 0.8603335890...)
196
+ sage: find_local_maximum(f, 0, 5, tol=0.1, maxfun=10)
197
+ (0.561090323458..., 0.857926501456...)
198
+ sage: find_local_maximum(8*e^(-x)*sin(x) - 1, 0, 7) # needs sage.symbolic
199
+ (1.579175535558..., 0.7853981...)
200
+ """
201
+ try:
202
+ return f.find_local_maximum(a=a, b=b, tol=tol, maxfun=maxfun)
203
+ except AttributeError:
204
+ pass
205
+ minval, x = find_local_minimum(lambda z: -f(z), a=a, b=b, tol=tol, maxfun=maxfun)
206
+ return -minval, x
207
+
208
+
209
+ def find_local_minimum(f, a, b, tol=1.48e-08, maxfun=500):
210
+ """
211
+ Numerically find a local minimum of the expression ``f`` on the
212
+ interval `[a,b]` (or `[b,a]`) and the point at which it attains that
213
+ minimum. Note that ``f`` must be a function of (at most) one
214
+ variable.
215
+
216
+ Note that this function only finds a *local* minimum, and not the
217
+ global minimum on that interval -- see the examples below.
218
+
219
+ INPUT:
220
+
221
+ - ``f`` -- a function of at most one variable
222
+
223
+ - ``a``, ``b`` -- endpoints of interval on which to minimize `f`
224
+
225
+ - ``tol`` -- the convergence tolerance
226
+
227
+ - ``maxfun`` -- maximum function evaluations
228
+
229
+ OUTPUT:
230
+
231
+ - ``minval`` -- (float) the minimum value that `f` takes on in the
232
+ interval `[a,b]`
233
+
234
+ - ``x`` -- (float) the point at which `f` takes on the minimum value
235
+
236
+ EXAMPLES::
237
+
238
+ sage: f = lambda x: x*cos(x)
239
+ sage: find_local_minimum(f, 1, 5)
240
+ (-3.28837139559..., 3.4256184695...)
241
+ sage: find_local_minimum(f, 1, 5, tol=1e-3)
242
+ (-3.28837136189098..., 3.42575079030572...)
243
+ sage: find_local_minimum(f, 1, 5, tol=1e-2, maxfun=10)
244
+ (-3.28837084598..., 3.4250840220...)
245
+ sage: show(plot(f, 0, 20)) # needs sage.plot
246
+ sage: find_local_minimum(f, 1, 15)
247
+ (-9.4772942594..., 9.5293344109...)
248
+
249
+ Only local minima are found; if you enlarge the interval, the
250
+ returned minimum may be *larger*! See :issue:`2607`.
251
+
252
+ ::
253
+
254
+ sage: # needs sage.symbolic
255
+ sage: f(x) = -x*sin(x^2)
256
+ sage: find_local_minimum(f, -2.5, -1)
257
+ (-2.182769784677722, -2.1945027498534686)
258
+
259
+ Enlarging the interval returns a larger minimum::
260
+
261
+ sage: # needs sage.symbolic
262
+ sage: find_local_minimum(f, -2.5, 2)
263
+ (-1.3076194129914434, 1.3552111405712108)
264
+
265
+ One work-around is to plot the function and grab the minimum from
266
+ that, although the plotting code does not necessarily do careful
267
+ numerics (observe the small number of decimal places that we
268
+ actually test)::
269
+
270
+ sage: # needs sage.plot sage.symbolic
271
+ sage: plot(f, (x, -2.5, -1)).ymin()
272
+ -2.182...
273
+ sage: plot(f, (x, -2.5, 2)).ymin()
274
+ -2.182...
275
+
276
+ ALGORITHM:
277
+
278
+ Uses :func:`scipy:scipy.optimize.fminbound` which uses Brent's method.
279
+
280
+
281
+ AUTHOR:
282
+
283
+ - William Stein (2007-12-07)
284
+ """
285
+ try:
286
+ return f.find_local_minimum(a=a, b=b, tol=tol, maxfun=maxfun)
287
+ except AttributeError:
288
+ pass
289
+ a = float(a)
290
+ b = float(b)
291
+ import scipy.optimize
292
+ import numpy
293
+ if int(numpy.version.short_version[0]) > 1:
294
+ numpy.set_printoptions(legacy="1.25")
295
+
296
+ xmin, fval, iter, funcalls = scipy.optimize.fminbound(f, a, b, full_output=1, xtol=tol, maxfun=maxfun)
297
+ return fval, xmin
298
+
299
+
300
+ def minimize(func, x0, gradient=None, hessian=None, algorithm='default',
301
+ verbose=False, **args):
302
+ r"""
303
+ This function is an interface to a variety of algorithms for computing
304
+ the minimum of a function of several variables.
305
+
306
+ INPUT:
307
+
308
+ - ``func`` -- either a symbolic function or a Python function whose
309
+ argument is a tuple with `n` components
310
+
311
+ - ``x0`` -- initial point for finding minimum
312
+
313
+ - ``gradient`` -- (optional) gradient function. This will be computed
314
+ automatically for symbolic functions. For Python functions, it allows
315
+ the use of algorithms requiring derivatives. It should accept a
316
+ tuple of arguments and return a NumPy array containing the partial
317
+ derivatives at that point.
318
+
319
+ - ``hessian`` -- (optional) hessian function. This will be computed
320
+ automatically for symbolic functions. For Python functions, it allows
321
+ the use of algorithms requiring derivatives. It should accept a tuple
322
+ of arguments and return a NumPy array containing the second partial
323
+ derivatives of the function.
324
+
325
+ - ``algorithm`` -- string specifying algorithm to use. Options are
326
+ ``'default'`` (for Python functions, the simplex method is the default)
327
+ (for symbolic functions bfgs is the default):
328
+
329
+ - ``'simplex'`` -- using the downhill simplex algorithm
330
+
331
+ - ``'powell'`` -- use the modified Powell algorithm
332
+
333
+ - ``'bfgs'`` -- (Broyden-Fletcher-Goldfarb-Shanno) requires gradient
334
+
335
+ - ``'cg'`` -- (conjugate-gradient) requires gradient
336
+
337
+ - ``'ncg'`` -- (newton-conjugate gradient) requires gradient and hessian
338
+
339
+ - ``verbose`` -- boolean (default: ``False``); print convergence message
340
+
341
+ .. NOTE::
342
+
343
+ For additional information on the algorithms implemented in this function,
344
+ consult SciPy's :mod:`documentation on optimization and root
345
+ finding <scipy:scipy.optimize>`.
346
+
347
+ EXAMPLES:
348
+
349
+ Minimize a fourth order polynomial in three variables (see the
350
+ :wikipedia:`Rosenbrock_function`)::
351
+
352
+ sage: vars = var('x y z') # needs sage.symbolic
353
+ sage: f = 100*(y-x^2)^2 + (1-x)^2 + 100*(z-y^2)^2 + (1-y)^2 # needs sage.symbolic
354
+ sage: minimize(f, [.1,.3,.4]) # abs tol 1e-6 # needs sage.symbolic
355
+ (1.0, 1.0, 1.0)
356
+
357
+ Try the newton-conjugate gradient method; the gradient and hessian are
358
+ computed automatically::
359
+
360
+ sage: minimize(f, [.1, .3, .4], algorithm='ncg') # abs tol 1e-6 # needs sage.symbolic
361
+ (1.0, 1.0, 1.0)
362
+
363
+ We get additional convergence information with the `verbose` option::
364
+
365
+ sage: minimize(f, [.1, .3, .4], algorithm='ncg', verbose=True) # needs sage.symbolic
366
+ Optimization terminated successfully.
367
+ ...
368
+ (0.9999999..., 0.999999..., 0.999999...)
369
+
370
+ Same example with just Python functions::
371
+
372
+ sage: def rosen(x): # The Rosenbrock function
373
+ ....: return sum(100.0r*(x[1r:]-x[:-1r]**2.0r)**2.0r + (1r-x[:-1r])**2.0r)
374
+ sage: minimize(rosen, [.1,.3,.4]) # abs tol 3e-5
375
+ (1.0, 1.0, 1.0)
376
+
377
+ Same example with a pure Python function and a Python function to
378
+ compute the gradient::
379
+
380
+ sage: # needs numpy
381
+ sage: def rosen(x): # The Rosenbrock function
382
+ ....: return sum(100.0r*(x[1r:]-x[:-1r]**2.0r)**2.0r + (1r-x[:-1r])**2.0r)
383
+ sage: import numpy
384
+ sage: if int(numpy.version.short_version[0]) > 1:
385
+ ....: _ = numpy.set_printoptions(legacy="1.25")
386
+ sage: from numpy import zeros
387
+ sage: def rosen_der(x):
388
+ ....: xm = x[1r:-1r]
389
+ ....: xm_m1 = x[:-2r]
390
+ ....: xm_p1 = x[2r:]
391
+ ....: der = zeros(x.shape, dtype=float)
392
+ ....: der[1r:-1r] = 200r*(xm-xm_m1**2r) - 400r*(xm_p1 - xm**2r)*xm - 2r*(1r-xm)
393
+ ....: der[0] = -400r*x[0r]*(x[1r]-x[0r]**2r) - 2r*(1r-x[0])
394
+ ....: der[-1] = 200r*(x[-1r]-x[-2r]**2r)
395
+ ....: return der
396
+ sage: minimize(rosen, [.1,.3,.4], gradient=rosen_der, # abs tol 1e-6
397
+ ....: algorithm='bfgs')
398
+ (1.0, 1.0, 1.0)
399
+ """
400
+ from sage.structure.element import Expression
401
+ from sage.ext.fast_callable import fast_callable
402
+ import numpy
403
+ if int(numpy.version.short_version[0]) > 1:
404
+ numpy.set_printoptions(legacy="1.25")
405
+
406
+ from scipy import optimize
407
+ if isinstance(func, Expression):
408
+ var_list = func.variables()
409
+ var_names = [str(_) for _ in var_list]
410
+ fast_f = fast_callable(func, vars=var_names, domain=float)
411
+ f = lambda p: fast_f(*p)
412
+ gradient_list = func.gradient()
413
+ fast_gradient_functions = [fast_callable(gradient_list[i],
414
+ vars=var_names, domain=float)
415
+ for i in range(len(gradient_list))]
416
+ gradient = lambda p: numpy.array([ a(*p) for a in fast_gradient_functions])
417
+ else:
418
+ f = func
419
+
420
+ if algorithm == "default":
421
+ if gradient is None:
422
+ min = optimize.fmin(f, [float(_) for _ in x0], disp=verbose, **args)
423
+ else:
424
+ min = optimize.fmin_bfgs(f, [float(_) for _ in x0],fprime=gradient, disp=verbose, **args)
425
+ else:
426
+ if algorithm == "simplex":
427
+ min = optimize.fmin(f, [float(_) for _ in x0], disp=verbose, **args)
428
+ elif algorithm == "bfgs":
429
+ min = optimize.fmin_bfgs(f, [float(_) for _ in x0], fprime=gradient, disp=verbose, **args)
430
+ elif algorithm == "cg":
431
+ min = optimize.fmin_cg(f, [float(_) for _ in x0], fprime=gradient, disp=verbose, **args)
432
+ elif algorithm == "powell":
433
+ min = optimize.fmin_powell(f, [float(_) for _ in x0], disp=verbose, **args)
434
+ elif algorithm == "ncg":
435
+ if isinstance(func, Expression):
436
+ hess = func.hessian()
437
+ hess_fast = [ [fast_callable(a, vars=var_names, domain=float) for a in row] for row in hess]
438
+ hessian = lambda p: [[a(*p) for a in row] for row in hess_fast]
439
+ from numpy import dot
440
+ hessian_p = lambda p,v: dot(numpy.array(hessian(p)),v)
441
+ min = optimize.fmin_ncg(f, [float(_) for _ in x0], fprime=gradient,
442
+ fhess=hessian, fhess_p=hessian_p, disp=verbose, **args)
443
+ return vector(RDF, min)
444
+
445
+
446
+ def minimize_constrained(func, cons, x0, gradient=None, algorithm='default', **args):
447
+ r"""
448
+ Minimize a function with constraints.
449
+
450
+ INPUT:
451
+
452
+ - ``func`` -- either a symbolic function, or a Python function whose
453
+ argument is a tuple with `n` components
454
+
455
+ - ``cons`` -- constraints. This should be either a function or list of
456
+ functions that must be positive. Alternatively, the constraints can
457
+ be specified as a list of intervals that define the region we are
458
+ minimizing in. If the constraints are specified as functions, the
459
+ functions should be functions of a tuple with `n` components
460
+ (assuming `n` variables). If the constraints are specified as a list
461
+ of intervals and there are no constraints for a given variable, that
462
+ component can be (``None``, ``None``).
463
+
464
+ - ``x0`` -- initial point for finding minimum
465
+
466
+ - ``algorithm`` -- (optional) specify the algorithm to use:
467
+
468
+ - ``'default'`` -- default choices
469
+
470
+ - ``'l-bfgs-b'`` -- only effective if you specify bound constraints;
471
+ see [ZBN1997]_
472
+
473
+ - ``gradient`` -- (optional) gradient function. This will be computed
474
+ automatically for symbolic functions. This is only used when the
475
+ constraints are specified as a list of intervals.
476
+
477
+ EXAMPLES:
478
+
479
+ Let us maximize `x + y - 50` subject to the following constraints:
480
+ `50x + 24y \leq 2400`, `30x + 33y \leq 2100`, `x \geq 45`,
481
+ and `y \geq 5`::
482
+
483
+ sage: f = lambda p: -p[0]-p[1]+50
484
+ sage: c_1 = lambda p: p[0]-45
485
+ sage: c_2 = lambda p: p[1]-5
486
+ sage: c_3 = lambda p: -50*p[0]-24*p[1]+2400
487
+ sage: c_4 = lambda p: -30*p[0]-33*p[1]+2100
488
+ sage: a = minimize_constrained(f,[c_1,c_2,c_3,c_4],[2,3])
489
+ sage: a
490
+ (45.0, 6.25...)
491
+
492
+ Let's find a minimum of `\sin(xy)`::
493
+
494
+ sage: x,y = var('x y') # needs sage.symbolic
495
+ sage: f(x,y) = sin(x*y) # needs sage.symbolic
496
+ sage: minimize_constrained(f, [(None,None),(4,10)],[5,5]) # needs sage.symbolic
497
+ (4.8..., 4.8...)
498
+
499
+ Check if L-BFGS-B finds the same minimum::
500
+
501
+ sage: minimize_constrained(f, [(None,None),(4,10)],[5,5], # needs sage.symbolic
502
+ ....: algorithm='l-bfgs-b')
503
+ (4.7..., 4.9...)
504
+
505
+ Rosenbrock function (see the :wikipedia:`Rosenbrock_function`)::
506
+
507
+ sage: from scipy.optimize import rosen, rosen_der
508
+ sage: minimize_constrained(rosen, [(-50,-10),(5,10)],[1,1],
509
+ ....: gradient=rosen_der, algorithm='l-bfgs-b')
510
+ (-10.0, 10.0)
511
+ sage: minimize_constrained(rosen, [(-50,-10),(5,10)],[1,1],
512
+ ....: algorithm='l-bfgs-b')
513
+ (-10.0, 10.0)
514
+
515
+ TESTS:
516
+
517
+ Check if :issue:`6592` is fixed::
518
+
519
+ sage: # needs sage.symbolic
520
+ sage: x, y = var('x y')
521
+ sage: f(x,y) = (100 - x) + (1000 - y)
522
+ sage: c(x,y) = x + y - 479 # > 0
523
+ sage: minimize_constrained(f, [c], [100, 300])
524
+ (805.985..., 1005.985...)
525
+ sage: minimize_constrained(f, c, [100, 300])
526
+ (805.985..., 1005.985...)
527
+
528
+ If ``func`` is symbolic, its minimizer should be in the same order
529
+ as its arguments (:issue:`32511`)::
530
+
531
+ sage: # needs sage.symbolic
532
+ sage: x,y = SR.var('x,y')
533
+ sage: f(y,x) = x - y
534
+ sage: c1(y,x) = x
535
+ sage: c2(y,x) = 1-y
536
+ sage: minimize_constrained(f, [c1, c2], (0,0))
537
+ (1.0, 0.0)
538
+ """
539
+ from sage.structure.element import Expression
540
+ from sage.ext.fast_callable import fast_callable
541
+ import numpy
542
+ if int(numpy.version.short_version[0]) > 1:
543
+ numpy.set_printoptions(legacy="1.25")
544
+ from scipy import optimize
545
+ function_type = type(lambda x,y: x+y)
546
+
547
+ if isinstance(func, Expression):
548
+ var_list = func.arguments()
549
+ fast_f = fast_callable(func, vars=var_list, domain=float)
550
+ f = lambda p: fast_f(*p)
551
+ gradient_list = func.gradient()
552
+ fast_gradient_functions = [ fast_callable(gi,
553
+ vars=var_list,
554
+ domain=float)
555
+ for gi in gradient_list ]
556
+ gradient = lambda p: numpy.array([ a(*p) for a in fast_gradient_functions])
557
+ if isinstance(cons, Expression):
558
+ fast_cons = fast_callable(cons, vars=var_list, domain=float)
559
+ cons = lambda p: numpy.array([fast_cons(*p)])
560
+ elif isinstance(cons, list) and isinstance(cons[0], Expression):
561
+ fast_cons = [ fast_callable(ci, vars=var_list, domain=float)
562
+ for ci in cons ]
563
+ cons = lambda p: numpy.array([a(*p) for a in fast_cons])
564
+ else:
565
+ f = func
566
+
567
+ if isinstance(cons, list):
568
+ if isinstance(cons[0], (tuple, list)) or cons[0] is None:
569
+ if gradient is not None:
570
+ if algorithm == 'l-bfgs-b':
571
+ min = optimize.fmin_l_bfgs_b(f, x0, gradient, bounds=cons, iprint=-1, **args)[0]
572
+ else:
573
+ min = optimize.fmin_tnc(f, x0, gradient, bounds=cons, messages=0, **args)[0]
574
+ else:
575
+ if algorithm == 'l-bfgs-b':
576
+ min = optimize.fmin_l_bfgs_b(f, x0, approx_grad=True, bounds=cons, iprint=-1, **args)[0]
577
+ else:
578
+ min = optimize.fmin_tnc(f, x0, approx_grad=True, bounds=cons, messages=0, **args)[0]
579
+ elif isinstance(cons[0], (function_type, Expression)):
580
+ min = optimize.fmin_cobyla(f, x0, cons, **args)
581
+ elif isinstance(cons, (function_type, Expression)):
582
+ min = optimize.fmin_cobyla(f, x0, cons, **args)
583
+ return vector(RDF, min)
584
+
585
+
586
+ def find_fit(data, model, initial_guess=None, parameters=None, variables=None, solution_dict=False):
587
+ r"""
588
+ Finds numerical estimates for the parameters of the function model to
589
+ give a best fit to data.
590
+
591
+
592
+ INPUT:
593
+
594
+ - ``data`` -- a two dimensional table of floating point numbers of the
595
+ form `[[x_{1,1}, x_{1,2}, \ldots, x_{1,k}, f_1],
596
+ [x_{2,1}, x_{2,2}, \ldots, x_{2,k}, f_2],
597
+ \ldots,
598
+ [x_{n,1}, x_{n,2}, \ldots, x_{n,k}, f_n]]` given as either a list of
599
+ lists, matrix, or numpy array.
600
+
601
+ - ``model`` -- either a symbolic expression, symbolic function, or a
602
+ Python function. ``model`` has to be a function of the variables
603
+ `(x_1, x_2, \ldots, x_k)` and free parameters
604
+ `(a_1, a_2, \ldots, a_l)`.
605
+
606
+ - ``initial_guess`` -- (default: ``None``) initial estimate for the
607
+ parameters `(a_1, a_2, \ldots, a_l)`, given as either a list, tuple,
608
+ vector or numpy array. If ``None``, the default estimate for each
609
+ parameter is `1`.
610
+
611
+ - ``parameters`` -- (default: ``None``) a list of the parameters
612
+ `(a_1, a_2, \ldots, a_l)`. If model is a symbolic function it is
613
+ ignored, and the free parameters of the symbolic function are used.
614
+
615
+ - ``variables`` -- (default: ``None``) a list of the variables
616
+ `(x_1, x_2, \ldots, x_k)`. If model is a symbolic function it is
617
+ ignored, and the variables of the symbolic function are used.
618
+
619
+ - ``solution_dict`` -- boolean (default: ``False``); if ``True``, return the
620
+ solution as a dictionary rather than an equation
621
+
622
+ EXAMPLES:
623
+
624
+ First we create some data points of a sine function with some "random"
625
+ perturbations::
626
+
627
+ sage: set_random_seed(0)
628
+ sage: data = [(i, 1.2 * sin(0.5*i-0.2) + 0.1 * normalvariate(0, 1)) # needs sage.symbolic
629
+ ....: for i in xsrange(0, 4*pi, 0.2)]
630
+ sage: var('a, b, c, x') # needs sage.symbolic
631
+ (a, b, c, x)
632
+
633
+ We define a function with free parameters `a`, `b` and `c`::
634
+
635
+ sage: model(x) = a * sin(b * x - c) # needs sage.symbolic
636
+
637
+ We search for the parameters that give the best fit to the data::
638
+
639
+ sage: find_fit(data, model) # needs sage.symbolic
640
+ [a == 1.21..., b == 0.49..., c == 0.19...]
641
+
642
+ We can also use a Python function for the model::
643
+
644
+ sage: def f(x, a, b, c): return a * sin(b * x - c)
645
+ sage: fit = find_fit(data, f, parameters=[a, b, c], variables=[x], # needs sage.symbolic
646
+ ....: solution_dict = True)
647
+ sage: fit[a], fit[b], fit[c] # needs sage.symbolic
648
+ (1.21..., 0.49..., 0.19...)
649
+
650
+ We search for a formula for the `n`-th prime number::
651
+
652
+ sage: # needs sage.libs.pari
653
+ sage: dataprime = [(i, nth_prime(i)) for i in range(1, 5000, 100)]
654
+ sage: find_fit(dataprime, a * x * log(b * x), # needs sage.symbolic
655
+ ....: parameters=[a, b], variables=[x])
656
+ [a == 1.11..., b == 1.24...]
657
+
658
+
659
+ ALGORITHM:
660
+
661
+ Uses :func:`scipy:scipy.optimize.leastsq` which in turn uses MINPACK's
662
+ ``lmdif`` and ``lmder`` algorithms.
663
+ """
664
+ import numpy
665
+ if int(numpy.version.short_version[0]) > 1:
666
+ numpy.set_printoptions(legacy="1.25")
667
+
668
+ if not isinstance(data, numpy.ndarray):
669
+ try:
670
+ data = numpy.array(data, dtype=float)
671
+ except (ValueError, TypeError):
672
+ raise TypeError("data has to be a list of lists, a matrix, or a numpy array")
673
+ elif data.dtype == object:
674
+ raise ValueError("the entries of data have to be of type float")
675
+
676
+ if data.ndim != 2:
677
+ raise ValueError("data has to be a two dimensional table of floating point numbers")
678
+
679
+ from sage.structure.element import Expression
680
+
681
+ if isinstance(model, Expression):
682
+ if variables is None:
683
+ variables = list(model.arguments())
684
+ if parameters is None:
685
+ parameters = list(model.variables())
686
+ for v in variables:
687
+ parameters.remove(v)
688
+
689
+ if data.shape[1] != len(variables) + 1:
690
+ raise ValueError("each row of data needs %d entries, only %d entries given" % (len(variables) + 1, data.shape[1]))
691
+
692
+ if parameters is None or len(parameters) == 0 or \
693
+ variables is None or len(variables) == 0:
694
+ raise ValueError("no variables given")
695
+
696
+ if initial_guess is None:
697
+ initial_guess = len(parameters) * [1]
698
+
699
+ if not isinstance(initial_guess, numpy.ndarray):
700
+ try:
701
+ initial_guess = numpy.array(initial_guess, dtype=float)
702
+ except (ValueError, TypeError):
703
+ raise TypeError("initial_guess has to be a list, tuple, or numpy array")
704
+ elif initial_guess.dtype == object:
705
+ raise ValueError("the entries of initial_guess have to be of type float")
706
+
707
+ if len(initial_guess) != len(parameters):
708
+ raise ValueError("length of initial_guess does not coincide with the number of parameters")
709
+
710
+ if isinstance(model, Expression):
711
+ from sage.ext.fast_callable import fast_callable
712
+ var_list = variables + parameters
713
+ func = fast_callable(model, vars=var_list, domain=float)
714
+ else:
715
+ func = model
716
+
717
+ def function(x_data, params):
718
+ result = numpy.zeros(len(x_data))
719
+ for row in range(len(x_data)):
720
+ fparams = numpy.hstack((x_data[row], params)).tolist()
721
+ result[row] = func(*fparams)
722
+ return result
723
+
724
+ def error_function(params, x_data, y_data):
725
+ result = numpy.zeros(len(x_data))
726
+ for row in range(len(x_data)):
727
+ fparams = x_data[row].tolist() + params.tolist()
728
+ result[row] = func(*fparams)
729
+ return result - y_data
730
+
731
+ x_data = data[:, 0:len(variables)]
732
+ y_data = data[:, -1]
733
+
734
+ from scipy.optimize import leastsq
735
+ estimated_params, d = leastsq(error_function, initial_guess,
736
+ args=(x_data, y_data))
737
+
738
+ if isinstance(estimated_params, float):
739
+ estimated_params = [estimated_params]
740
+ else:
741
+ estimated_params = estimated_params.tolist()
742
+
743
+ if solution_dict:
744
+ return dict(zip(parameters, estimated_params))
745
+
746
+ return [item[0] == item[1] for item in zip(parameters, estimated_params)]
747
+
748
+
749
+ def binpacking(items, maximum=1, k=None, solver=None, verbose=0,
750
+ *, integrality_tolerance=1e-3):
751
+ r"""
752
+ Solve the bin packing problem.
753
+
754
+ The Bin Packing problem is the following :
755
+
756
+ Given a list of items of weights `p_i` and a real value `k`, what is the
757
+ least number of bins such that all the items can be packed in the bins,
758
+ while ensuring that the sum of the weights of the items packed in each bin
759
+ is at most `k` ?
760
+
761
+ For more informations, see :wikipedia:`Bin_packing_problem`.
762
+
763
+ Two versions of this problem are solved by this algorithm :
764
+
765
+ - Is it possible to put the given items in `k` bins ?
766
+ - What is the assignment of items using the least number of bins with
767
+ the given list of items ?
768
+
769
+ INPUT:
770
+
771
+ - ``items`` -- list or dict; either a list of real values (the items'
772
+ weight), or a dictionary associating to each item its weight
773
+
774
+ - ``maximum`` -- (default: 1) the maximal size of a bin
775
+
776
+ - ``k`` -- integer (default: ``None``); number of bins:
777
+
778
+ - When set to an integer value, the function returns a partition of the
779
+ items into `k` bins if possible, and raises an exception otherwise.
780
+
781
+ - When set to ``None``, the function returns a partition of the items
782
+ using the least possible number of bins.
783
+
784
+ - ``solver`` -- (default: ``None``) specify a Mixed Integer Linear Programming
785
+ (MILP) solver to be used. If set to ``None``, the default one is used. For
786
+ more information on MILP solvers and which default solver is used, see
787
+ the method
788
+ :meth:`solve <sage.numerical.mip.MixedIntegerLinearProgram.solve>`
789
+ of the class
790
+ :class:`MixedIntegerLinearProgram <sage.numerical.mip.MixedIntegerLinearProgram>`.
791
+
792
+ - ``verbose`` -- integer (default: 0); sets the level of verbosity. Set
793
+ to 0 by default, which means quiet.
794
+
795
+ - ``integrality_tolerance`` -- parameter for use with MILP solvers over an
796
+ inexact base ring; see :meth:`MixedIntegerLinearProgram.get_values`
797
+
798
+ OUTPUT:
799
+
800
+ A list of lists, each member corresponding to a bin and containing either
801
+ the list of the weights inside it when ``items`` is a list of items' weight,
802
+ or the list of items inside it when ``items`` is a dictionary. If there is
803
+ no solution, an exception is raised (this can only happen when ``k`` is
804
+ specified or if ``maximum`` is less than the weight of one item).
805
+
806
+ EXAMPLES:
807
+
808
+ Trying to find the minimum amount of boxes for 5 items of weights
809
+ `1/5, 1/4, 2/3, 3/4, 5/7`::
810
+
811
+ sage: from sage.numerical.optimize import binpacking
812
+ sage: values = [1/5, 1/3, 2/3, 3/4, 5/7]
813
+ sage: bins = binpacking(values) # needs sage.numerical.mip
814
+ sage: len(bins) # needs sage.numerical.mip
815
+ 3
816
+
817
+ Checking the bins are of correct size ::
818
+
819
+ sage: all(sum(b) <= 1 for b in bins) # needs sage.numerical.mip
820
+ True
821
+
822
+ Checking every item is in a bin ::
823
+
824
+ sage: b1, b2, b3 = bins # needs sage.numerical.mip
825
+ sage: all((v in b1 or v in b2 or v in b3) for v in values) # needs sage.numerical.mip
826
+ True
827
+
828
+ And only in one bin ::
829
+
830
+ sage: sum(len(b) for b in bins) == len(values) # needs sage.numerical.mip
831
+ True
832
+
833
+ One way to use only three boxes (which is best possible) is to put
834
+ `1/5 + 3/4` together in a box, `1/3+2/3` in another, and `5/7`
835
+ by itself in the third one.
836
+
837
+ Of course, we can also check that there is no solution using only two boxes ::
838
+
839
+ sage: from sage.numerical.optimize import binpacking
840
+ sage: binpacking([0.2,0.3,0.8,0.9], k=2) # needs sage.numerical.mip
841
+ Traceback (most recent call last):
842
+ ...
843
+ ValueError: this problem has no solution
844
+
845
+ We can also provide a dictionary keyed by items and associating to each item
846
+ its weight. Then, the bins contain the name of the items inside it ::
847
+
848
+ sage: values = {'a':1/5, 'b':1/3, 'c':2/3, 'd':3/4, 'e':5/7}
849
+ sage: bins = binpacking(values) # needs sage.numerical.mip
850
+ sage: set(flatten(bins)) == set(values.keys()) # needs sage.numerical.mip
851
+ True
852
+
853
+ TESTS:
854
+
855
+ Wrong type for parameter items::
856
+
857
+ sage: binpacking(set())
858
+ Traceback (most recent call last):
859
+ ...
860
+ TypeError: parameter items must be a list or a dictionary.
861
+ """
862
+ if isinstance(items, list):
863
+ weight = dict(enumerate(items))
864
+ elif isinstance(items, dict):
865
+ weight = items
866
+ else:
867
+ raise TypeError("parameter items must be a list or a dictionary.")
868
+
869
+ if max(weight.values()) > maximum:
870
+ raise ValueError("this problem has no solution")
871
+
872
+ if k is None:
873
+ from sage.functions.other import ceil
874
+ k = ceil(sum(weight.values())/maximum)
875
+ while True:
876
+ from sage.numerical.mip import MIPSolverException
877
+ try:
878
+ return binpacking(items, k=k, maximum=maximum, solver=solver, verbose=verbose,
879
+ integrality_tolerance=integrality_tolerance)
880
+ except MIPSolverException:
881
+ k = k + 1
882
+
883
+ from sage.numerical.mip import MixedIntegerLinearProgram, MIPSolverException
884
+ p = MixedIntegerLinearProgram(solver=solver)
885
+
886
+ # Boolean variable indicating whether the ith element belongs to box b
887
+ box = p.new_variable(binary=True)
888
+
889
+ # Capacity constraint of each bin
890
+ for b in range(k):
891
+ p.add_constraint(p.sum(weight[i]*box[i,b] for i in weight) <= maximum)
892
+
893
+ # Each item is assigned exactly one bin
894
+ for i in weight:
895
+ p.add_constraint(p.sum(box[i,b] for b in range(k)) == 1)
896
+
897
+ try:
898
+ p.solve(log=verbose)
899
+ except MIPSolverException:
900
+ raise ValueError("this problem has no solution")
901
+
902
+ box = p.get_values(box, convert=bool, tolerance=integrality_tolerance)
903
+
904
+ boxes = [[] for i in range(k)]
905
+
906
+ for i,b in box:
907
+ if box[i,b]:
908
+ boxes[b].append(weight[i] if isinstance(items, list) else i)
909
+
910
+ return boxes