passagemath-modules 10.6.31__cp314-cp314-musllinux_1_2_x86_64.whl
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Potentially problematic release.
This version of passagemath-modules might be problematic. Click here for more details.
- passagemath_modules-10.6.31.dist-info/METADATA +281 -0
- passagemath_modules-10.6.31.dist-info/RECORD +808 -0
- passagemath_modules-10.6.31.dist-info/WHEEL +5 -0
- passagemath_modules-10.6.31.dist-info/top_level.txt +2 -0
- passagemath_modules.libs/libgcc_s-0cd532bd.so.1 +0 -0
- passagemath_modules.libs/libgfortran-2c33b284.so.5.0.0 +0 -0
- passagemath_modules.libs/libgmp-0e7fc84e.so.10.5.0 +0 -0
- passagemath_modules.libs/libgsl-42cda06f.so.28.0.0 +0 -0
- passagemath_modules.libs/libmpc-d8ebe4b5.so.3.3.1 +0 -0
- passagemath_modules.libs/libmpfr-aaecbfc0.so.6.2.1 +0 -0
- passagemath_modules.libs/libopenblasp-r0-905cb27d.3.29.so +0 -0
- passagemath_modules.libs/libquadmath-bb76a5fc.so.0.0.0 +0 -0
- sage/algebras/all__sagemath_modules.py +20 -0
- sage/algebras/catalog.py +148 -0
- sage/algebras/clifford_algebra.py +3107 -0
- sage/algebras/clifford_algebra_element.cpython-314-x86_64-linux-musl.so +0 -0
- sage/algebras/clifford_algebra_element.pxd +16 -0
- sage/algebras/clifford_algebra_element.pyx +997 -0
- sage/algebras/commutative_dga.py +4252 -0
- sage/algebras/exterior_algebra_groebner.cpython-314-x86_64-linux-musl.so +0 -0
- sage/algebras/exterior_algebra_groebner.pxd +55 -0
- sage/algebras/exterior_algebra_groebner.pyx +727 -0
- sage/algebras/finite_dimensional_algebras/all.py +2 -0
- sage/algebras/finite_dimensional_algebras/finite_dimensional_algebra.py +1029 -0
- sage/algebras/finite_dimensional_algebras/finite_dimensional_algebra_element.cpython-314-x86_64-linux-musl.so +0 -0
- sage/algebras/finite_dimensional_algebras/finite_dimensional_algebra_element.pxd +12 -0
- sage/algebras/finite_dimensional_algebras/finite_dimensional_algebra_element.pyx +706 -0
- sage/algebras/finite_dimensional_algebras/finite_dimensional_algebra_ideal.py +196 -0
- sage/algebras/finite_dimensional_algebras/finite_dimensional_algebra_morphism.py +255 -0
- sage/algebras/finite_gca.py +528 -0
- sage/algebras/group_algebra.py +232 -0
- sage/algebras/lie_algebras/abelian.py +197 -0
- sage/algebras/lie_algebras/affine_lie_algebra.py +1213 -0
- sage/algebras/lie_algebras/all.py +25 -0
- sage/algebras/lie_algebras/all__sagemath_modules.py +1 -0
- sage/algebras/lie_algebras/bch.py +177 -0
- sage/algebras/lie_algebras/bgg_dual_module.py +1184 -0
- sage/algebras/lie_algebras/bgg_resolution.py +232 -0
- sage/algebras/lie_algebras/center_uea.py +767 -0
- sage/algebras/lie_algebras/classical_lie_algebra.py +2516 -0
- sage/algebras/lie_algebras/examples.py +683 -0
- sage/algebras/lie_algebras/free_lie_algebra.py +973 -0
- sage/algebras/lie_algebras/heisenberg.py +820 -0
- sage/algebras/lie_algebras/lie_algebra.py +1562 -0
- sage/algebras/lie_algebras/lie_algebra_element.cpython-314-x86_64-linux-musl.so +0 -0
- sage/algebras/lie_algebras/lie_algebra_element.pxd +68 -0
- sage/algebras/lie_algebras/lie_algebra_element.pyx +2122 -0
- sage/algebras/lie_algebras/morphism.py +661 -0
- sage/algebras/lie_algebras/nilpotent_lie_algebra.py +457 -0
- sage/algebras/lie_algebras/onsager.py +1324 -0
- sage/algebras/lie_algebras/poincare_birkhoff_witt.py +816 -0
- sage/algebras/lie_algebras/quotient.py +462 -0
- sage/algebras/lie_algebras/rank_two_heisenberg_virasoro.py +355 -0
- sage/algebras/lie_algebras/representation.py +1040 -0
- sage/algebras/lie_algebras/structure_coefficients.py +459 -0
- sage/algebras/lie_algebras/subalgebra.py +967 -0
- sage/algebras/lie_algebras/symplectic_derivation.py +289 -0
- sage/algebras/lie_algebras/verma_module.py +1630 -0
- sage/algebras/lie_algebras/virasoro.py +1186 -0
- sage/algebras/octonion_algebra.cpython-314-x86_64-linux-musl.so +0 -0
- sage/algebras/octonion_algebra.pxd +20 -0
- sage/algebras/octonion_algebra.pyx +987 -0
- sage/algebras/orlik_solomon.py +907 -0
- sage/algebras/orlik_terao.py +779 -0
- sage/algebras/steenrod/all.py +7 -0
- sage/algebras/steenrod/steenrod_algebra.py +4258 -0
- sage/algebras/steenrod/steenrod_algebra_bases.py +1179 -0
- sage/algebras/steenrod/steenrod_algebra_misc.py +1167 -0
- sage/algebras/steenrod/steenrod_algebra_mult.py +954 -0
- sage/algebras/weyl_algebra.py +1126 -0
- sage/all__sagemath_modules.py +62 -0
- sage/calculus/all__sagemath_modules.py +19 -0
- sage/calculus/expr.py +205 -0
- sage/calculus/integration.cpython-314-x86_64-linux-musl.so +0 -0
- sage/calculus/integration.pyx +698 -0
- sage/calculus/interpolation.cpython-314-x86_64-linux-musl.so +0 -0
- sage/calculus/interpolation.pxd +13 -0
- sage/calculus/interpolation.pyx +387 -0
- sage/calculus/interpolators.cpython-314-x86_64-linux-musl.so +0 -0
- sage/calculus/interpolators.pyx +326 -0
- sage/calculus/ode.cpython-314-x86_64-linux-musl.so +0 -0
- sage/calculus/ode.pxd +5 -0
- sage/calculus/ode.pyx +610 -0
- sage/calculus/riemann.cpython-314-x86_64-linux-musl.so +0 -0
- sage/calculus/riemann.pyx +1521 -0
- sage/calculus/test_sympy.py +201 -0
- sage/calculus/transforms/all.py +7 -0
- sage/calculus/transforms/dft.py +844 -0
- sage/calculus/transforms/dwt.cpython-314-x86_64-linux-musl.so +0 -0
- sage/calculus/transforms/dwt.pxd +7 -0
- sage/calculus/transforms/dwt.pyx +160 -0
- sage/calculus/transforms/fft.cpython-314-x86_64-linux-musl.so +0 -0
- sage/calculus/transforms/fft.pxd +12 -0
- sage/calculus/transforms/fft.pyx +487 -0
- sage/calculus/wester.py +662 -0
- sage/coding/abstract_code.py +1108 -0
- sage/coding/ag_code.py +868 -0
- sage/coding/ag_code_decoders.cpython-314-x86_64-linux-musl.so +0 -0
- sage/coding/ag_code_decoders.pyx +2639 -0
- sage/coding/all.py +15 -0
- sage/coding/bch_code.py +494 -0
- sage/coding/binary_code.cpython-314-x86_64-linux-musl.so +0 -0
- sage/coding/binary_code.pxd +124 -0
- sage/coding/binary_code.pyx +4139 -0
- sage/coding/bounds_catalog.py +43 -0
- sage/coding/channel.py +819 -0
- sage/coding/channels_catalog.py +29 -0
- sage/coding/code_bounds.py +755 -0
- sage/coding/code_constructions.py +804 -0
- sage/coding/codes_catalog.py +111 -0
- sage/coding/cyclic_code.py +1329 -0
- sage/coding/databases.py +316 -0
- sage/coding/decoder.py +373 -0
- sage/coding/decoders_catalog.py +88 -0
- sage/coding/delsarte_bounds.py +709 -0
- sage/coding/encoder.py +390 -0
- sage/coding/encoders_catalog.py +64 -0
- sage/coding/extended_code.py +468 -0
- sage/coding/gabidulin_code.py +1058 -0
- sage/coding/golay_code.py +404 -0
- sage/coding/goppa_code.py +441 -0
- sage/coding/grs_code.py +2371 -0
- sage/coding/guava.py +107 -0
- sage/coding/guruswami_sudan/all.py +1 -0
- sage/coding/guruswami_sudan/gs_decoder.py +897 -0
- sage/coding/guruswami_sudan/interpolation.py +409 -0
- sage/coding/guruswami_sudan/utils.py +176 -0
- sage/coding/hamming_code.py +176 -0
- sage/coding/information_set_decoder.py +1032 -0
- sage/coding/kasami_codes.cpython-314-x86_64-linux-musl.so +0 -0
- sage/coding/kasami_codes.pyx +351 -0
- sage/coding/linear_code.py +3067 -0
- sage/coding/linear_code_no_metric.py +1354 -0
- sage/coding/linear_rank_metric.py +961 -0
- sage/coding/parity_check_code.py +353 -0
- sage/coding/punctured_code.py +719 -0
- sage/coding/reed_muller_code.py +999 -0
- sage/coding/self_dual_codes.py +942 -0
- sage/coding/source_coding/all.py +2 -0
- sage/coding/source_coding/huffman.py +553 -0
- sage/coding/subfield_subcode.py +423 -0
- sage/coding/two_weight_db.py +399 -0
- sage/combinat/all__sagemath_modules.py +7 -0
- sage/combinat/cartesian_product.py +347 -0
- sage/combinat/family.py +11 -0
- sage/combinat/free_module.py +1977 -0
- sage/combinat/root_system/all.py +147 -0
- sage/combinat/root_system/ambient_space.py +527 -0
- sage/combinat/root_system/associahedron.py +471 -0
- sage/combinat/root_system/braid_move_calculator.py +143 -0
- sage/combinat/root_system/braid_orbit.cpython-314-x86_64-linux-musl.so +0 -0
- sage/combinat/root_system/braid_orbit.pyx +144 -0
- sage/combinat/root_system/branching_rules.py +2301 -0
- sage/combinat/root_system/cartan_matrix.py +1245 -0
- sage/combinat/root_system/cartan_type.py +3069 -0
- sage/combinat/root_system/coxeter_group.py +162 -0
- sage/combinat/root_system/coxeter_matrix.py +1261 -0
- sage/combinat/root_system/coxeter_type.py +681 -0
- sage/combinat/root_system/dynkin_diagram.py +900 -0
- sage/combinat/root_system/extended_affine_weyl_group.py +2993 -0
- sage/combinat/root_system/fundamental_group.py +795 -0
- sage/combinat/root_system/hecke_algebra_representation.py +1203 -0
- sage/combinat/root_system/integrable_representations.py +1227 -0
- sage/combinat/root_system/non_symmetric_macdonald_polynomials.py +1965 -0
- sage/combinat/root_system/pieri_factors.py +1147 -0
- sage/combinat/root_system/plot.py +1615 -0
- sage/combinat/root_system/root_lattice_realization_algebras.py +1214 -0
- sage/combinat/root_system/root_lattice_realizations.py +4628 -0
- sage/combinat/root_system/root_space.py +487 -0
- sage/combinat/root_system/root_system.py +882 -0
- sage/combinat/root_system/type_A.py +348 -0
- sage/combinat/root_system/type_A_affine.py +227 -0
- sage/combinat/root_system/type_A_infinity.py +241 -0
- sage/combinat/root_system/type_B.py +347 -0
- sage/combinat/root_system/type_BC_affine.py +287 -0
- sage/combinat/root_system/type_B_affine.py +216 -0
- sage/combinat/root_system/type_C.py +317 -0
- sage/combinat/root_system/type_C_affine.py +188 -0
- sage/combinat/root_system/type_D.py +357 -0
- sage/combinat/root_system/type_D_affine.py +208 -0
- sage/combinat/root_system/type_E.py +641 -0
- sage/combinat/root_system/type_E_affine.py +231 -0
- sage/combinat/root_system/type_F.py +387 -0
- sage/combinat/root_system/type_F_affine.py +137 -0
- sage/combinat/root_system/type_G.py +293 -0
- sage/combinat/root_system/type_G_affine.py +132 -0
- sage/combinat/root_system/type_H.py +105 -0
- sage/combinat/root_system/type_I.py +110 -0
- sage/combinat/root_system/type_Q.py +150 -0
- sage/combinat/root_system/type_affine.py +509 -0
- sage/combinat/root_system/type_dual.py +704 -0
- sage/combinat/root_system/type_folded.py +301 -0
- sage/combinat/root_system/type_marked.py +748 -0
- sage/combinat/root_system/type_reducible.py +601 -0
- sage/combinat/root_system/type_relabel.py +730 -0
- sage/combinat/root_system/type_super_A.py +837 -0
- sage/combinat/root_system/weight_lattice_realizations.py +1188 -0
- sage/combinat/root_system/weight_space.py +639 -0
- sage/combinat/root_system/weyl_characters.py +2238 -0
- sage/crypto/__init__.py +4 -0
- sage/crypto/all.py +28 -0
- sage/crypto/block_cipher/all.py +7 -0
- sage/crypto/block_cipher/des.py +1065 -0
- sage/crypto/block_cipher/miniaes.py +2171 -0
- sage/crypto/block_cipher/present.py +909 -0
- sage/crypto/block_cipher/sdes.py +1527 -0
- sage/crypto/boolean_function.cpython-314-x86_64-linux-musl.so +0 -0
- sage/crypto/boolean_function.pxd +10 -0
- sage/crypto/boolean_function.pyx +1487 -0
- sage/crypto/cipher.py +78 -0
- sage/crypto/classical.py +3668 -0
- sage/crypto/classical_cipher.py +569 -0
- sage/crypto/cryptosystem.py +387 -0
- sage/crypto/key_exchange/all.py +7 -0
- sage/crypto/key_exchange/catalog.py +24 -0
- sage/crypto/key_exchange/diffie_hellman.py +323 -0
- sage/crypto/key_exchange/key_exchange_scheme.py +107 -0
- sage/crypto/lattice.py +312 -0
- sage/crypto/lfsr.py +295 -0
- sage/crypto/lwe.py +840 -0
- sage/crypto/mq/__init__.py +4 -0
- sage/crypto/mq/mpolynomialsystemgenerator.py +204 -0
- sage/crypto/mq/rijndael_gf.py +2345 -0
- sage/crypto/mq/sbox.py +7 -0
- sage/crypto/mq/sr.py +3344 -0
- sage/crypto/public_key/all.py +5 -0
- sage/crypto/public_key/blum_goldwasser.py +776 -0
- sage/crypto/sbox.cpython-314-x86_64-linux-musl.so +0 -0
- sage/crypto/sbox.pyx +2090 -0
- sage/crypto/sboxes.py +2090 -0
- sage/crypto/stream.py +390 -0
- sage/crypto/stream_cipher.py +297 -0
- sage/crypto/util.py +519 -0
- sage/ext/all__sagemath_modules.py +1 -0
- sage/ext/interpreters/__init__.py +1 -0
- sage/ext/interpreters/all__sagemath_modules.py +2 -0
- sage/ext/interpreters/wrapper_cc.cpython-314-x86_64-linux-musl.so +0 -0
- sage/ext/interpreters/wrapper_cc.pxd +30 -0
- sage/ext/interpreters/wrapper_cc.pyx +252 -0
- sage/ext/interpreters/wrapper_cdf.cpython-314-x86_64-linux-musl.so +0 -0
- sage/ext/interpreters/wrapper_cdf.pxd +26 -0
- sage/ext/interpreters/wrapper_cdf.pyx +245 -0
- sage/ext/interpreters/wrapper_rdf.cpython-314-x86_64-linux-musl.so +0 -0
- sage/ext/interpreters/wrapper_rdf.pxd +23 -0
- sage/ext/interpreters/wrapper_rdf.pyx +221 -0
- sage/ext/interpreters/wrapper_rr.cpython-314-x86_64-linux-musl.so +0 -0
- sage/ext/interpreters/wrapper_rr.pxd +28 -0
- sage/ext/interpreters/wrapper_rr.pyx +335 -0
- sage/geometry/all__sagemath_modules.py +5 -0
- sage/geometry/toric_lattice.py +1745 -0
- sage/geometry/toric_lattice_element.cpython-314-x86_64-linux-musl.so +0 -0
- sage/geometry/toric_lattice_element.pyx +432 -0
- sage/groups/abelian_gps/abelian_group.py +1925 -0
- sage/groups/abelian_gps/abelian_group_element.py +164 -0
- sage/groups/abelian_gps/all__sagemath_modules.py +5 -0
- sage/groups/abelian_gps/dual_abelian_group.py +421 -0
- sage/groups/abelian_gps/dual_abelian_group_element.py +179 -0
- sage/groups/abelian_gps/element_base.py +341 -0
- sage/groups/abelian_gps/values.py +488 -0
- sage/groups/additive_abelian/additive_abelian_group.py +476 -0
- sage/groups/additive_abelian/additive_abelian_wrapper.py +857 -0
- sage/groups/additive_abelian/all.py +4 -0
- sage/groups/additive_abelian/qmodnz.py +231 -0
- sage/groups/additive_abelian/qmodnz_element.py +349 -0
- sage/groups/affine_gps/affine_group.py +535 -0
- sage/groups/affine_gps/all.py +1 -0
- sage/groups/affine_gps/catalog.py +17 -0
- sage/groups/affine_gps/euclidean_group.py +246 -0
- sage/groups/affine_gps/group_element.py +562 -0
- sage/groups/all__sagemath_modules.py +12 -0
- sage/groups/galois_group.py +479 -0
- sage/groups/matrix_gps/all.py +4 -0
- sage/groups/matrix_gps/all__sagemath_modules.py +13 -0
- sage/groups/matrix_gps/catalog.py +26 -0
- sage/groups/matrix_gps/coxeter_group.py +927 -0
- sage/groups/matrix_gps/finitely_generated.py +487 -0
- sage/groups/matrix_gps/group_element.cpython-314-x86_64-linux-musl.so +0 -0
- sage/groups/matrix_gps/group_element.pxd +11 -0
- sage/groups/matrix_gps/group_element.pyx +431 -0
- sage/groups/matrix_gps/linear.py +440 -0
- sage/groups/matrix_gps/matrix_group.py +617 -0
- sage/groups/matrix_gps/named_group.py +296 -0
- sage/groups/matrix_gps/orthogonal.py +544 -0
- sage/groups/matrix_gps/symplectic.py +251 -0
- sage/groups/matrix_gps/unitary.py +436 -0
- sage/groups/misc_gps/all__sagemath_modules.py +1 -0
- sage/groups/misc_gps/argument_groups.py +1905 -0
- sage/groups/misc_gps/imaginary_groups.py +479 -0
- sage/groups/perm_gps/all__sagemath_modules.py +1 -0
- sage/groups/perm_gps/partn_ref/all__sagemath_modules.py +1 -0
- sage/groups/perm_gps/partn_ref/refinement_binary.cpython-314-x86_64-linux-musl.so +0 -0
- sage/groups/perm_gps/partn_ref/refinement_binary.pxd +41 -0
- sage/groups/perm_gps/partn_ref/refinement_binary.pyx +1167 -0
- sage/groups/perm_gps/partn_ref/refinement_matrices.cpython-314-x86_64-linux-musl.so +0 -0
- sage/groups/perm_gps/partn_ref/refinement_matrices.pxd +31 -0
- sage/groups/perm_gps/partn_ref/refinement_matrices.pyx +385 -0
- sage/homology/algebraic_topological_model.py +595 -0
- sage/homology/all.py +2 -0
- sage/homology/all__sagemath_modules.py +8 -0
- sage/homology/chain_complex.py +2148 -0
- sage/homology/chain_complex_homspace.py +165 -0
- sage/homology/chain_complex_morphism.py +629 -0
- sage/homology/chain_homotopy.py +604 -0
- sage/homology/chains.py +653 -0
- sage/homology/free_resolution.py +923 -0
- sage/homology/graded_resolution.py +567 -0
- sage/homology/hochschild_complex.py +756 -0
- sage/homology/homology_group.py +188 -0
- sage/homology/homology_morphism.py +422 -0
- sage/homology/homology_vector_space_with_basis.py +1454 -0
- sage/homology/koszul_complex.py +169 -0
- sage/homology/matrix_utils.py +205 -0
- sage/libs/all__sagemath_modules.py +1 -0
- sage/libs/gsl/__init__.py +1 -0
- sage/libs/gsl/airy.pxd +56 -0
- sage/libs/gsl/all.pxd +66 -0
- sage/libs/gsl/array.cpython-314-x86_64-linux-musl.so +0 -0
- sage/libs/gsl/array.pxd +5 -0
- sage/libs/gsl/array.pyx +102 -0
- sage/libs/gsl/bessel.pxd +208 -0
- sage/libs/gsl/blas.pxd +116 -0
- sage/libs/gsl/blas_types.pxd +34 -0
- sage/libs/gsl/block.pxd +52 -0
- sage/libs/gsl/chebyshev.pxd +37 -0
- sage/libs/gsl/clausen.pxd +12 -0
- sage/libs/gsl/combination.pxd +47 -0
- sage/libs/gsl/complex.pxd +151 -0
- sage/libs/gsl/coulomb.pxd +30 -0
- sage/libs/gsl/coupling.pxd +21 -0
- sage/libs/gsl/dawson.pxd +12 -0
- sage/libs/gsl/debye.pxd +24 -0
- sage/libs/gsl/dilog.pxd +14 -0
- sage/libs/gsl/eigen.pxd +46 -0
- sage/libs/gsl/elementary.pxd +12 -0
- sage/libs/gsl/ellint.pxd +48 -0
- sage/libs/gsl/elljac.pxd +8 -0
- sage/libs/gsl/erf.pxd +32 -0
- sage/libs/gsl/errno.pxd +26 -0
- sage/libs/gsl/exp.pxd +44 -0
- sage/libs/gsl/expint.pxd +44 -0
- sage/libs/gsl/fermi_dirac.pxd +44 -0
- sage/libs/gsl/fft.pxd +121 -0
- sage/libs/gsl/fit.pxd +50 -0
- sage/libs/gsl/gamma.pxd +94 -0
- sage/libs/gsl/gegenbauer.pxd +26 -0
- sage/libs/gsl/histogram.pxd +176 -0
- sage/libs/gsl/hyperg.pxd +52 -0
- sage/libs/gsl/integration.pxd +69 -0
- sage/libs/gsl/interp.pxd +109 -0
- sage/libs/gsl/laguerre.pxd +24 -0
- sage/libs/gsl/lambert.pxd +16 -0
- sage/libs/gsl/legendre.pxd +90 -0
- sage/libs/gsl/linalg.pxd +185 -0
- sage/libs/gsl/log.pxd +26 -0
- sage/libs/gsl/math.pxd +43 -0
- sage/libs/gsl/matrix.pxd +143 -0
- sage/libs/gsl/matrix_complex.pxd +130 -0
- sage/libs/gsl/min.pxd +67 -0
- sage/libs/gsl/monte.pxd +56 -0
- sage/libs/gsl/ntuple.pxd +32 -0
- sage/libs/gsl/odeiv.pxd +70 -0
- sage/libs/gsl/permutation.pxd +78 -0
- sage/libs/gsl/poly.pxd +40 -0
- sage/libs/gsl/pow_int.pxd +12 -0
- sage/libs/gsl/psi.pxd +28 -0
- sage/libs/gsl/qrng.pxd +29 -0
- sage/libs/gsl/random.pxd +257 -0
- sage/libs/gsl/rng.pxd +100 -0
- sage/libs/gsl/roots.pxd +72 -0
- sage/libs/gsl/sort.pxd +36 -0
- sage/libs/gsl/statistics.pxd +59 -0
- sage/libs/gsl/sum.pxd +55 -0
- sage/libs/gsl/synchrotron.pxd +16 -0
- sage/libs/gsl/transport.pxd +24 -0
- sage/libs/gsl/trig.pxd +58 -0
- sage/libs/gsl/types.pxd +137 -0
- sage/libs/gsl/vector.pxd +101 -0
- sage/libs/gsl/vector_complex.pxd +83 -0
- sage/libs/gsl/wavelet.pxd +49 -0
- sage/libs/gsl/zeta.pxd +28 -0
- sage/libs/mpc/__init__.pxd +114 -0
- sage/libs/mpc/types.pxd +28 -0
- sage/libs/mpfr/__init__.pxd +299 -0
- sage/libs/mpfr/types.pxd +26 -0
- sage/libs/mpmath/__init__.py +1 -0
- sage/libs/mpmath/all.py +27 -0
- sage/libs/mpmath/all__sagemath_modules.py +1 -0
- sage/libs/mpmath/utils.cpython-314-x86_64-linux-musl.so +0 -0
- sage/libs/mpmath/utils.pxd +4 -0
- sage/libs/mpmath/utils.pyx +319 -0
- sage/matrix/action.cpython-314-x86_64-linux-musl.so +0 -0
- sage/matrix/action.pxd +26 -0
- sage/matrix/action.pyx +596 -0
- sage/matrix/all.py +9 -0
- sage/matrix/args.cpython-314-x86_64-linux-musl.so +0 -0
- sage/matrix/args.pxd +144 -0
- sage/matrix/args.pyx +1668 -0
- sage/matrix/benchmark.py +1258 -0
- sage/matrix/berlekamp_massey.py +95 -0
- sage/matrix/compute_J_ideal.py +926 -0
- sage/matrix/constructor.cpython-314-x86_64-linux-musl.so +0 -0
- sage/matrix/constructor.pyx +750 -0
- sage/matrix/docs.py +430 -0
- sage/matrix/echelon_matrix.cpython-314-x86_64-linux-musl.so +0 -0
- sage/matrix/echelon_matrix.pyx +155 -0
- sage/matrix/matrix.pxd +2 -0
- sage/matrix/matrix0.cpython-314-x86_64-linux-musl.so +0 -0
- sage/matrix/matrix0.pxd +68 -0
- sage/matrix/matrix0.pyx +6324 -0
- sage/matrix/matrix1.cpython-314-x86_64-linux-musl.so +0 -0
- sage/matrix/matrix1.pxd +8 -0
- sage/matrix/matrix1.pyx +2851 -0
- sage/matrix/matrix2.cpython-314-x86_64-linux-musl.so +0 -0
- sage/matrix/matrix2.pxd +25 -0
- sage/matrix/matrix2.pyx +20181 -0
- sage/matrix/matrix_cdv.cpython-314-x86_64-linux-musl.so +0 -0
- sage/matrix/matrix_cdv.pxd +4 -0
- sage/matrix/matrix_cdv.pyx +93 -0
- sage/matrix/matrix_complex_double_dense.cpython-314-x86_64-linux-musl.so +0 -0
- sage/matrix/matrix_complex_double_dense.pxd +5 -0
- sage/matrix/matrix_complex_double_dense.pyx +98 -0
- sage/matrix/matrix_dense.cpython-314-x86_64-linux-musl.so +0 -0
- sage/matrix/matrix_dense.pxd +5 -0
- sage/matrix/matrix_dense.pyx +343 -0
- sage/matrix/matrix_domain_dense.pxd +5 -0
- sage/matrix/matrix_domain_sparse.pxd +5 -0
- sage/matrix/matrix_double_dense.cpython-314-x86_64-linux-musl.so +0 -0
- sage/matrix/matrix_double_dense.pxd +7 -0
- sage/matrix/matrix_double_dense.pyx +3906 -0
- sage/matrix/matrix_double_sparse.cpython-314-x86_64-linux-musl.so +0 -0
- sage/matrix/matrix_double_sparse.pxd +6 -0
- sage/matrix/matrix_double_sparse.pyx +248 -0
- sage/matrix/matrix_generic_dense.cpython-314-x86_64-linux-musl.so +0 -0
- sage/matrix/matrix_generic_dense.pxd +7 -0
- sage/matrix/matrix_generic_dense.pyx +354 -0
- sage/matrix/matrix_generic_sparse.cpython-314-x86_64-linux-musl.so +0 -0
- sage/matrix/matrix_generic_sparse.pxd +7 -0
- sage/matrix/matrix_generic_sparse.pyx +461 -0
- sage/matrix/matrix_laurent_mpolynomial_dense.cpython-314-x86_64-linux-musl.so +0 -0
- sage/matrix/matrix_laurent_mpolynomial_dense.pxd +5 -0
- sage/matrix/matrix_laurent_mpolynomial_dense.pyx +115 -0
- sage/matrix/matrix_misc.py +313 -0
- sage/matrix/matrix_numpy_dense.cpython-314-x86_64-linux-musl.so +0 -0
- sage/matrix/matrix_numpy_dense.pxd +14 -0
- sage/matrix/matrix_numpy_dense.pyx +450 -0
- sage/matrix/matrix_numpy_integer_dense.cpython-314-x86_64-linux-musl.so +0 -0
- sage/matrix/matrix_numpy_integer_dense.pxd +7 -0
- sage/matrix/matrix_numpy_integer_dense.pyx +59 -0
- sage/matrix/matrix_polynomial_dense.cpython-314-x86_64-linux-musl.so +0 -0
- sage/matrix/matrix_polynomial_dense.pxd +5 -0
- sage/matrix/matrix_polynomial_dense.pyx +5341 -0
- sage/matrix/matrix_real_double_dense.cpython-314-x86_64-linux-musl.so +0 -0
- sage/matrix/matrix_real_double_dense.pxd +7 -0
- sage/matrix/matrix_real_double_dense.pyx +122 -0
- sage/matrix/matrix_space.py +2848 -0
- sage/matrix/matrix_sparse.cpython-314-x86_64-linux-musl.so +0 -0
- sage/matrix/matrix_sparse.pxd +5 -0
- sage/matrix/matrix_sparse.pyx +1222 -0
- sage/matrix/matrix_window.cpython-314-x86_64-linux-musl.so +0 -0
- sage/matrix/matrix_window.pxd +37 -0
- sage/matrix/matrix_window.pyx +242 -0
- sage/matrix/misc_mpfr.cpython-314-x86_64-linux-musl.so +0 -0
- sage/matrix/misc_mpfr.pyx +80 -0
- sage/matrix/operation_table.py +1182 -0
- sage/matrix/special.py +3666 -0
- sage/matrix/strassen.cpython-314-x86_64-linux-musl.so +0 -0
- sage/matrix/strassen.pyx +851 -0
- sage/matrix/symplectic_basis.py +541 -0
- sage/matrix/template.pxd +6 -0
- sage/matrix/tests.py +71 -0
- sage/matroids/advanced.py +77 -0
- sage/matroids/all.py +13 -0
- sage/matroids/basis_exchange_matroid.cpython-314-x86_64-linux-musl.so +0 -0
- sage/matroids/basis_exchange_matroid.pxd +96 -0
- sage/matroids/basis_exchange_matroid.pyx +2344 -0
- sage/matroids/basis_matroid.cpython-314-x86_64-linux-musl.so +0 -0
- sage/matroids/basis_matroid.pxd +45 -0
- sage/matroids/basis_matroid.pyx +1217 -0
- sage/matroids/catalog.py +44 -0
- sage/matroids/chow_ring.py +473 -0
- sage/matroids/chow_ring_ideal.py +849 -0
- sage/matroids/circuit_closures_matroid.cpython-314-x86_64-linux-musl.so +0 -0
- sage/matroids/circuit_closures_matroid.pxd +16 -0
- sage/matroids/circuit_closures_matroid.pyx +559 -0
- sage/matroids/circuits_matroid.cpython-314-x86_64-linux-musl.so +0 -0
- sage/matroids/circuits_matroid.pxd +38 -0
- sage/matroids/circuits_matroid.pyx +947 -0
- sage/matroids/constructor.py +1086 -0
- sage/matroids/database_collections.py +365 -0
- sage/matroids/database_matroids.py +5338 -0
- sage/matroids/dual_matroid.py +583 -0
- sage/matroids/extension.cpython-314-x86_64-linux-musl.so +0 -0
- sage/matroids/extension.pxd +34 -0
- sage/matroids/extension.pyx +519 -0
- sage/matroids/flats_matroid.cpython-314-x86_64-linux-musl.so +0 -0
- sage/matroids/flats_matroid.pxd +28 -0
- sage/matroids/flats_matroid.pyx +715 -0
- sage/matroids/gammoid.py +600 -0
- sage/matroids/graphic_matroid.cpython-314-x86_64-linux-musl.so +0 -0
- sage/matroids/graphic_matroid.pxd +39 -0
- sage/matroids/graphic_matroid.pyx +2024 -0
- sage/matroids/lean_matrix.cpython-314-x86_64-linux-musl.so +0 -0
- sage/matroids/lean_matrix.pxd +126 -0
- sage/matroids/lean_matrix.pyx +3667 -0
- sage/matroids/linear_matroid.cpython-314-x86_64-linux-musl.so +0 -0
- sage/matroids/linear_matroid.pxd +180 -0
- sage/matroids/linear_matroid.pyx +6649 -0
- sage/matroids/matroid.cpython-314-x86_64-linux-musl.so +0 -0
- sage/matroids/matroid.pxd +243 -0
- sage/matroids/matroid.pyx +8759 -0
- sage/matroids/matroids_catalog.py +190 -0
- sage/matroids/matroids_plot_helpers.py +890 -0
- sage/matroids/minor_matroid.py +480 -0
- sage/matroids/minorfix.h +9 -0
- sage/matroids/named_matroids.py +5 -0
- sage/matroids/rank_matroid.py +268 -0
- sage/matroids/set_system.cpython-314-x86_64-linux-musl.so +0 -0
- sage/matroids/set_system.pxd +38 -0
- sage/matroids/set_system.pyx +800 -0
- sage/matroids/transversal_matroid.cpython-314-x86_64-linux-musl.so +0 -0
- sage/matroids/transversal_matroid.pxd +14 -0
- sage/matroids/transversal_matroid.pyx +893 -0
- sage/matroids/union_matroid.cpython-314-x86_64-linux-musl.so +0 -0
- sage/matroids/union_matroid.pxd +20 -0
- sage/matroids/union_matroid.pyx +331 -0
- sage/matroids/unpickling.cpython-314-x86_64-linux-musl.so +0 -0
- sage/matroids/unpickling.pyx +843 -0
- sage/matroids/utilities.py +809 -0
- sage/misc/all__sagemath_modules.py +20 -0
- sage/misc/c3.cpython-314-x86_64-linux-musl.so +0 -0
- sage/misc/c3.pyx +238 -0
- sage/misc/compat.py +87 -0
- sage/misc/element_with_label.py +173 -0
- sage/misc/func_persist.py +79 -0
- sage/misc/pickle_old.cpython-314-x86_64-linux-musl.so +0 -0
- sage/misc/pickle_old.pyx +19 -0
- sage/misc/proof.py +7 -0
- sage/misc/replace_dot_all.py +472 -0
- sage/misc/sagedoc_conf.py +168 -0
- sage/misc/sphinxify.py +167 -0
- sage/misc/test_class_pickling.py +85 -0
- sage/modules/all.py +42 -0
- sage/modules/complex_double_vector.py +25 -0
- sage/modules/diamond_cutting.py +380 -0
- sage/modules/fg_pid/all.py +1 -0
- sage/modules/fg_pid/fgp_element.py +456 -0
- sage/modules/fg_pid/fgp_module.py +2091 -0
- sage/modules/fg_pid/fgp_morphism.py +550 -0
- sage/modules/filtered_vector_space.py +1271 -0
- sage/modules/finite_submodule_iter.cpython-314-x86_64-linux-musl.so +0 -0
- sage/modules/finite_submodule_iter.pxd +27 -0
- sage/modules/finite_submodule_iter.pyx +452 -0
- sage/modules/fp_graded/all.py +1 -0
- sage/modules/fp_graded/element.py +346 -0
- sage/modules/fp_graded/free_element.py +298 -0
- sage/modules/fp_graded/free_homspace.py +53 -0
- sage/modules/fp_graded/free_module.py +1060 -0
- sage/modules/fp_graded/free_morphism.py +217 -0
- sage/modules/fp_graded/homspace.py +563 -0
- sage/modules/fp_graded/module.py +1340 -0
- sage/modules/fp_graded/morphism.py +1990 -0
- sage/modules/fp_graded/steenrod/all.py +1 -0
- sage/modules/fp_graded/steenrod/homspace.py +65 -0
- sage/modules/fp_graded/steenrod/module.py +477 -0
- sage/modules/fp_graded/steenrod/morphism.py +404 -0
- sage/modules/fp_graded/steenrod/profile.py +241 -0
- sage/modules/free_module.py +8447 -0
- sage/modules/free_module_element.cpython-314-x86_64-linux-musl.so +0 -0
- sage/modules/free_module_element.pxd +22 -0
- sage/modules/free_module_element.pyx +5445 -0
- sage/modules/free_module_homspace.py +369 -0
- sage/modules/free_module_integer.py +896 -0
- sage/modules/free_module_morphism.py +823 -0
- sage/modules/free_module_pseudohomspace.py +352 -0
- sage/modules/free_module_pseudomorphism.py +578 -0
- sage/modules/free_quadratic_module.py +1706 -0
- sage/modules/free_quadratic_module_integer_symmetric.py +1790 -0
- sage/modules/matrix_morphism.py +1745 -0
- sage/modules/misc.py +103 -0
- sage/modules/module_functors.py +192 -0
- sage/modules/multi_filtered_vector_space.py +719 -0
- sage/modules/ore_module.py +2208 -0
- sage/modules/ore_module_element.py +178 -0
- sage/modules/ore_module_homspace.py +147 -0
- sage/modules/ore_module_morphism.py +968 -0
- sage/modules/quotient_module.py +699 -0
- sage/modules/real_double_vector.py +22 -0
- sage/modules/submodule.py +255 -0
- sage/modules/tensor_operations.py +567 -0
- sage/modules/torsion_quadratic_module.py +1352 -0
- sage/modules/tutorial_free_modules.py +248 -0
- sage/modules/vector_complex_double_dense.cpython-314-x86_64-linux-musl.so +0 -0
- sage/modules/vector_complex_double_dense.pxd +6 -0
- sage/modules/vector_complex_double_dense.pyx +117 -0
- sage/modules/vector_double_dense.cpython-314-x86_64-linux-musl.so +0 -0
- sage/modules/vector_double_dense.pxd +6 -0
- sage/modules/vector_double_dense.pyx +604 -0
- sage/modules/vector_integer_dense.cpython-314-x86_64-linux-musl.so +0 -0
- sage/modules/vector_integer_dense.pxd +15 -0
- sage/modules/vector_integer_dense.pyx +361 -0
- sage/modules/vector_integer_sparse.cpython-314-x86_64-linux-musl.so +0 -0
- sage/modules/vector_integer_sparse.pxd +29 -0
- sage/modules/vector_integer_sparse.pyx +406 -0
- sage/modules/vector_modn_dense.cpython-314-x86_64-linux-musl.so +0 -0
- sage/modules/vector_modn_dense.pxd +12 -0
- sage/modules/vector_modn_dense.pyx +394 -0
- sage/modules/vector_modn_sparse.cpython-314-x86_64-linux-musl.so +0 -0
- sage/modules/vector_modn_sparse.pxd +21 -0
- sage/modules/vector_modn_sparse.pyx +298 -0
- sage/modules/vector_numpy_dense.cpython-314-x86_64-linux-musl.so +0 -0
- sage/modules/vector_numpy_dense.pxd +15 -0
- sage/modules/vector_numpy_dense.pyx +304 -0
- sage/modules/vector_numpy_integer_dense.cpython-314-x86_64-linux-musl.so +0 -0
- sage/modules/vector_numpy_integer_dense.pxd +7 -0
- sage/modules/vector_numpy_integer_dense.pyx +54 -0
- sage/modules/vector_rational_dense.cpython-314-x86_64-linux-musl.so +0 -0
- sage/modules/vector_rational_dense.pxd +15 -0
- sage/modules/vector_rational_dense.pyx +387 -0
- sage/modules/vector_rational_sparse.cpython-314-x86_64-linux-musl.so +0 -0
- sage/modules/vector_rational_sparse.pxd +30 -0
- sage/modules/vector_rational_sparse.pyx +413 -0
- sage/modules/vector_real_double_dense.cpython-314-x86_64-linux-musl.so +0 -0
- sage/modules/vector_real_double_dense.pxd +6 -0
- sage/modules/vector_real_double_dense.pyx +126 -0
- sage/modules/vector_space_homspace.py +430 -0
- sage/modules/vector_space_morphism.py +989 -0
- sage/modules/with_basis/all.py +15 -0
- sage/modules/with_basis/cell_module.py +494 -0
- sage/modules/with_basis/indexed_element.cpython-314-x86_64-linux-musl.so +0 -0
- sage/modules/with_basis/indexed_element.pxd +13 -0
- sage/modules/with_basis/indexed_element.pyx +1058 -0
- sage/modules/with_basis/invariant.py +1075 -0
- sage/modules/with_basis/morphism.py +1636 -0
- sage/modules/with_basis/representation.py +2939 -0
- sage/modules/with_basis/subquotient.py +685 -0
- sage/numerical/all__sagemath_modules.py +6 -0
- sage/numerical/gauss_legendre.cpython-314-x86_64-linux-musl.so +0 -0
- sage/numerical/gauss_legendre.pyx +381 -0
- sage/numerical/optimize.py +910 -0
- sage/probability/all.py +10 -0
- sage/probability/probability_distribution.cpython-314-x86_64-linux-musl.so +0 -0
- sage/probability/probability_distribution.pyx +1242 -0
- sage/probability/random_variable.py +411 -0
- sage/quadratic_forms/all.py +4 -0
- sage/quadratic_forms/all__sagemath_modules.py +15 -0
- sage/quadratic_forms/binary_qf.py +2042 -0
- sage/quadratic_forms/bqf_class_group.py +748 -0
- sage/quadratic_forms/constructions.py +93 -0
- sage/quadratic_forms/count_local_2.cpython-314-x86_64-linux-musl.so +0 -0
- sage/quadratic_forms/count_local_2.pyx +365 -0
- sage/quadratic_forms/extras.py +195 -0
- sage/quadratic_forms/quadratic_form.py +1753 -0
- sage/quadratic_forms/quadratic_form__count_local_2.py +221 -0
- sage/quadratic_forms/quadratic_form__equivalence_testing.py +708 -0
- sage/quadratic_forms/quadratic_form__evaluate.cpython-314-x86_64-linux-musl.so +0 -0
- sage/quadratic_forms/quadratic_form__evaluate.pyx +139 -0
- sage/quadratic_forms/quadratic_form__local_density_congruence.py +977 -0
- sage/quadratic_forms/quadratic_form__local_field_invariants.py +1072 -0
- sage/quadratic_forms/quadratic_form__neighbors.py +424 -0
- sage/quadratic_forms/quadratic_form__reduction_theory.py +488 -0
- sage/quadratic_forms/quadratic_form__split_local_covering.py +416 -0
- sage/quadratic_forms/quadratic_form__ternary_Tornaria.py +657 -0
- sage/quadratic_forms/quadratic_form__theta.py +352 -0
- sage/quadratic_forms/quadratic_form__variable_substitutions.py +370 -0
- sage/quadratic_forms/random_quadraticform.py +209 -0
- sage/quadratic_forms/ternary.cpython-314-x86_64-linux-musl.so +0 -0
- sage/quadratic_forms/ternary.pyx +1154 -0
- sage/quadratic_forms/ternary_qf.py +2027 -0
- sage/rings/all__sagemath_modules.py +28 -0
- sage/rings/asymptotic/all__sagemath_modules.py +1 -0
- sage/rings/asymptotic/misc.py +1252 -0
- sage/rings/cc.py +4 -0
- sage/rings/cfinite_sequence.py +1306 -0
- sage/rings/complex_conversion.cpython-314-x86_64-linux-musl.so +0 -0
- sage/rings/complex_conversion.pxd +8 -0
- sage/rings/complex_conversion.pyx +23 -0
- sage/rings/complex_double.cpython-314-x86_64-linux-musl.so +0 -0
- sage/rings/complex_double.pxd +21 -0
- sage/rings/complex_double.pyx +2654 -0
- sage/rings/complex_mpc.cpython-314-x86_64-linux-musl.so +0 -0
- sage/rings/complex_mpc.pxd +21 -0
- sage/rings/complex_mpc.pyx +2576 -0
- sage/rings/complex_mpfr.cpython-314-x86_64-linux-musl.so +0 -0
- sage/rings/complex_mpfr.pxd +18 -0
- sage/rings/complex_mpfr.pyx +3602 -0
- sage/rings/derivation.py +2334 -0
- sage/rings/finite_rings/all__sagemath_modules.py +1 -0
- sage/rings/finite_rings/maps_finite_field.py +191 -0
- sage/rings/function_field/all__sagemath_modules.py +8 -0
- sage/rings/function_field/derivations.py +102 -0
- sage/rings/function_field/derivations_rational.py +132 -0
- sage/rings/function_field/differential.py +853 -0
- sage/rings/function_field/divisor.py +1107 -0
- sage/rings/function_field/drinfeld_modules/action.py +199 -0
- sage/rings/function_field/drinfeld_modules/all.py +1 -0
- sage/rings/function_field/drinfeld_modules/charzero_drinfeld_module.py +673 -0
- sage/rings/function_field/drinfeld_modules/drinfeld_module.py +2087 -0
- sage/rings/function_field/drinfeld_modules/finite_drinfeld_module.py +1131 -0
- sage/rings/function_field/drinfeld_modules/homset.py +420 -0
- sage/rings/function_field/drinfeld_modules/morphism.py +820 -0
- sage/rings/function_field/hermite_form_polynomial.cpython-314-x86_64-linux-musl.so +0 -0
- sage/rings/function_field/hermite_form_polynomial.pyx +188 -0
- sage/rings/function_field/khuri_makdisi.cpython-314-x86_64-linux-musl.so +0 -0
- sage/rings/function_field/khuri_makdisi.pyx +935 -0
- sage/rings/invariants/all.py +4 -0
- sage/rings/invariants/invariant_theory.py +4597 -0
- sage/rings/invariants/reconstruction.py +395 -0
- sage/rings/polynomial/all__sagemath_modules.py +17 -0
- sage/rings/polynomial/integer_valued_polynomials.py +1230 -0
- sage/rings/polynomial/laurent_polynomial_mpair.cpython-314-x86_64-linux-musl.so +0 -0
- sage/rings/polynomial/laurent_polynomial_mpair.pxd +15 -0
- sage/rings/polynomial/laurent_polynomial_mpair.pyx +2023 -0
- sage/rings/polynomial/ore_function_element.py +952 -0
- sage/rings/polynomial/ore_function_field.py +1028 -0
- sage/rings/polynomial/ore_polynomial_element.cpython-314-x86_64-linux-musl.so +0 -0
- sage/rings/polynomial/ore_polynomial_element.pxd +48 -0
- sage/rings/polynomial/ore_polynomial_element.pyx +3145 -0
- sage/rings/polynomial/ore_polynomial_ring.py +1334 -0
- sage/rings/polynomial/polynomial_real_mpfr_dense.cpython-314-x86_64-linux-musl.so +0 -0
- sage/rings/polynomial/polynomial_real_mpfr_dense.pyx +788 -0
- sage/rings/polynomial/q_integer_valued_polynomials.py +1264 -0
- sage/rings/polynomial/skew_polynomial_element.cpython-314-x86_64-linux-musl.so +0 -0
- sage/rings/polynomial/skew_polynomial_element.pxd +9 -0
- sage/rings/polynomial/skew_polynomial_element.pyx +684 -0
- sage/rings/polynomial/skew_polynomial_finite_field.cpython-314-x86_64-linux-musl.so +0 -0
- sage/rings/polynomial/skew_polynomial_finite_field.pxd +19 -0
- sage/rings/polynomial/skew_polynomial_finite_field.pyx +1093 -0
- sage/rings/polynomial/skew_polynomial_finite_order.cpython-314-x86_64-linux-musl.so +0 -0
- sage/rings/polynomial/skew_polynomial_finite_order.pxd +10 -0
- sage/rings/polynomial/skew_polynomial_finite_order.pyx +567 -0
- sage/rings/polynomial/skew_polynomial_ring.py +908 -0
- sage/rings/real_double_element_gsl.cpython-314-x86_64-linux-musl.so +0 -0
- sage/rings/real_double_element_gsl.pxd +8 -0
- sage/rings/real_double_element_gsl.pyx +794 -0
- sage/rings/real_field.py +58 -0
- sage/rings/real_mpfr.cpython-314-x86_64-linux-musl.so +0 -0
- sage/rings/real_mpfr.pxd +29 -0
- sage/rings/real_mpfr.pyx +6122 -0
- sage/rings/ring_extension.cpython-314-x86_64-linux-musl.so +0 -0
- sage/rings/ring_extension.pxd +42 -0
- sage/rings/ring_extension.pyx +2779 -0
- sage/rings/ring_extension_conversion.cpython-314-x86_64-linux-musl.so +0 -0
- sage/rings/ring_extension_conversion.pxd +16 -0
- sage/rings/ring_extension_conversion.pyx +462 -0
- sage/rings/ring_extension_element.cpython-314-x86_64-linux-musl.so +0 -0
- sage/rings/ring_extension_element.pxd +21 -0
- sage/rings/ring_extension_element.pyx +1635 -0
- sage/rings/ring_extension_homset.py +64 -0
- sage/rings/ring_extension_morphism.cpython-314-x86_64-linux-musl.so +0 -0
- sage/rings/ring_extension_morphism.pxd +35 -0
- sage/rings/ring_extension_morphism.pyx +920 -0
- sage/schemes/all__sagemath_modules.py +1 -0
- sage/schemes/projective/all__sagemath_modules.py +1 -0
- sage/schemes/projective/coherent_sheaf.py +300 -0
- sage/schemes/projective/cohomology.py +510 -0
- sage/stats/all.py +15 -0
- sage/stats/basic_stats.py +489 -0
- sage/stats/distributions/all.py +7 -0
- sage/stats/distributions/catalog.py +34 -0
- sage/stats/distributions/dgs.h +50 -0
- sage/stats/distributions/dgs.pxd +111 -0
- sage/stats/distributions/dgs_bern.h +400 -0
- sage/stats/distributions/dgs_gauss.h +614 -0
- sage/stats/distributions/dgs_misc.h +104 -0
- sage/stats/distributions/discrete_gaussian_integer.cpython-314-x86_64-linux-musl.so +0 -0
- sage/stats/distributions/discrete_gaussian_integer.pxd +14 -0
- sage/stats/distributions/discrete_gaussian_integer.pyx +498 -0
- sage/stats/distributions/discrete_gaussian_lattice.py +908 -0
- sage/stats/distributions/discrete_gaussian_polynomial.py +141 -0
- sage/stats/hmm/all.py +15 -0
- sage/stats/hmm/chmm.cpython-314-x86_64-linux-musl.so +0 -0
- sage/stats/hmm/chmm.pyx +1595 -0
- sage/stats/hmm/distributions.cpython-314-x86_64-linux-musl.so +0 -0
- sage/stats/hmm/distributions.pxd +29 -0
- sage/stats/hmm/distributions.pyx +531 -0
- sage/stats/hmm/hmm.cpython-314-x86_64-linux-musl.so +0 -0
- sage/stats/hmm/hmm.pxd +17 -0
- sage/stats/hmm/hmm.pyx +1388 -0
- sage/stats/hmm/util.cpython-314-x86_64-linux-musl.so +0 -0
- sage/stats/hmm/util.pxd +7 -0
- sage/stats/hmm/util.pyx +165 -0
- sage/stats/intlist.cpython-314-x86_64-linux-musl.so +0 -0
- sage/stats/intlist.pxd +14 -0
- sage/stats/intlist.pyx +588 -0
- sage/stats/r.py +49 -0
- sage/stats/time_series.cpython-314-x86_64-linux-musl.so +0 -0
- sage/stats/time_series.pxd +6 -0
- sage/stats/time_series.pyx +2546 -0
- sage/tensor/all.py +2 -0
- sage/tensor/modules/all.py +8 -0
- sage/tensor/modules/alternating_contr_tensor.py +761 -0
- sage/tensor/modules/comp.py +5598 -0
- sage/tensor/modules/ext_pow_free_module.py +824 -0
- sage/tensor/modules/finite_rank_free_module.py +3589 -0
- sage/tensor/modules/format_utilities.py +333 -0
- sage/tensor/modules/free_module_alt_form.py +858 -0
- sage/tensor/modules/free_module_automorphism.py +1207 -0
- sage/tensor/modules/free_module_basis.py +1074 -0
- sage/tensor/modules/free_module_element.py +284 -0
- sage/tensor/modules/free_module_homset.py +652 -0
- sage/tensor/modules/free_module_linear_group.py +564 -0
- sage/tensor/modules/free_module_morphism.py +1581 -0
- sage/tensor/modules/free_module_tensor.py +3289 -0
- sage/tensor/modules/reflexive_module.py +386 -0
- sage/tensor/modules/tensor_free_module.py +780 -0
- sage/tensor/modules/tensor_free_submodule.py +538 -0
- sage/tensor/modules/tensor_free_submodule_basis.py +140 -0
- sage/tensor/modules/tensor_with_indices.py +1043 -0
|
@@ -0,0 +1,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
|