snappy 3.0.3__cp38-cp38-macosx_11_0_arm64.whl → 3.2__cp38-cp38-macosx_11_0_arm64.whl
Sign up to get free protection for your applications and to get access to all the features.
- snappy/CyOpenGL.cpython-38-darwin.so +0 -0
- snappy/SnapPy.cpython-38-darwin.so +0 -0
- snappy/SnapPyHP.cpython-38-darwin.so +0 -0
- snappy/__init__.py +373 -426
- snappy/app.py +240 -75
- snappy/app_menus.py +93 -78
- snappy/browser.py +87 -63
- snappy/cache.py +5 -8
- snappy/canonical.py +249 -0
- snappy/{verify/cusp_shapes.py → cusps/__init__.py} +11 -19
- snappy/cusps/cusp_area_matrix.py +101 -0
- snappy/{verify/cusp_areas.py → cusps/cusp_areas_from_matrix.py} +39 -54
- snappy/cusps/maximal_cusp_area_matrix.py +136 -0
- snappy/cusps/test.py +21 -0
- snappy/cusps/trig_cusp_area_matrix.py +63 -0
- snappy/database.py +40 -31
- snappy/db_utilities.py +13 -14
- snappy/decorated_isosig.py +377 -133
- snappy/dev/extended_ptolemy/complexVolumesClosed.py +42 -9
- snappy/dev/extended_ptolemy/extended.py +32 -25
- snappy/dev/extended_ptolemy/giac_rur.py +23 -8
- snappy/dev/extended_ptolemy/phc_wrapper.py +10 -10
- snappy/dev/vericlosed/computeApproxHyperbolicStructureOrb.py +2 -1
- snappy/dev/vericlosed/gimbalLoopFinder.py +5 -5
- snappy/dev/vericlosed/hyperbolicStructure.py +3 -3
- snappy/dev/vericlosed/oneVertexTruncatedComplex.py +2 -2
- snappy/dev/vericlosed/truncatedComplex.py +3 -2
- snappy/dev/vericlosed/verifyHyperbolicStructureEngine.py +4 -3
- snappy/doc/_images/geodesics.jpg +0 -0
- snappy/doc/_images/m004_paper_plane_on_systole.jpg +0 -0
- snappy/doc/_images/m125_paper_plane.jpg +0 -0
- snappy/doc/_images/o9_00000_systole_paper_plane.jpg +0 -0
- snappy/doc/_images/o9_00000_systole_paper_plane_closer.jpg +0 -0
- snappy/doc/_sources/additional_classes.rst.txt +1 -0
- snappy/doc/_sources/credits.rst.txt +6 -1
- snappy/doc/_sources/development.rst.txt +69 -50
- snappy/doc/_sources/index.rst.txt +101 -66
- snappy/doc/_sources/installing.rst.txt +148 -165
- snappy/doc/_sources/news.rst.txt +136 -32
- snappy/doc/_sources/ptolemy.rst.txt +1 -1
- snappy/doc/_sources/ptolemy_examples1.rst.txt +9 -8
- snappy/doc/_sources/ptolemy_examples2.rst.txt +3 -3
- snappy/doc/_sources/ptolemy_examples3.rst.txt +14 -14
- snappy/doc/_sources/ptolemy_prelim.rst.txt +1 -1
- snappy/doc/_sources/snap.rst.txt +2 -2
- snappy/doc/_sources/snappy.rst.txt +1 -1
- snappy/doc/_sources/triangulation.rst.txt +3 -2
- snappy/doc/_sources/verify.rst.txt +89 -29
- snappy/doc/_sources/verify_internals.rst.txt +5 -16
- snappy/doc/_static/SnapPy-horizontal-128.png +0 -0
- snappy/doc/_static/SnapPy.ico +0 -0
- snappy/doc/_static/_sphinx_javascript_frameworks_compat.js +123 -0
- snappy/doc/_static/basic.css +47 -27
- snappy/doc/_static/css/badge_only.css +1 -0
- snappy/doc/_static/css/fonts/Roboto-Slab-Bold.woff +0 -0
- snappy/doc/_static/css/fonts/Roboto-Slab-Bold.woff2 +0 -0
- snappy/doc/_static/css/fonts/Roboto-Slab-Regular.woff +0 -0
- snappy/doc/_static/css/fonts/Roboto-Slab-Regular.woff2 +0 -0
- snappy/doc/_static/css/fonts/fontawesome-webfont.eot +0 -0
- snappy/doc/_static/css/fonts/fontawesome-webfont.svg +2671 -0
- snappy/doc/_static/css/fonts/fontawesome-webfont.ttf +0 -0
- snappy/doc/_static/css/fonts/fontawesome-webfont.woff +0 -0
- snappy/doc/_static/css/fonts/fontawesome-webfont.woff2 +0 -0
- snappy/doc/_static/css/fonts/lato-bold-italic.woff +0 -0
- snappy/doc/_static/css/fonts/lato-bold-italic.woff2 +0 -0
- snappy/doc/_static/css/fonts/lato-bold.woff +0 -0
- snappy/doc/_static/css/fonts/lato-bold.woff2 +0 -0
- snappy/doc/_static/css/fonts/lato-normal-italic.woff +0 -0
- snappy/doc/_static/css/fonts/lato-normal-italic.woff2 +0 -0
- snappy/doc/_static/css/fonts/lato-normal.woff +0 -0
- snappy/doc/_static/css/fonts/lato-normal.woff2 +0 -0
- snappy/doc/_static/css/theme.css +4 -0
- snappy/doc/_static/doctools.js +107 -274
- snappy/doc/_static/documentation_options.js +6 -5
- snappy/doc/_static/fonts/Lato/lato-bold.eot +0 -0
- snappy/doc/_static/fonts/Lato/lato-bold.ttf +0 -0
- snappy/doc/_static/fonts/Lato/lato-bold.woff +0 -0
- snappy/doc/_static/fonts/Lato/lato-bold.woff2 +0 -0
- snappy/doc/_static/fonts/Lato/lato-bolditalic.eot +0 -0
- snappy/doc/_static/fonts/Lato/lato-bolditalic.ttf +0 -0
- snappy/doc/_static/fonts/Lato/lato-bolditalic.woff +0 -0
- snappy/doc/_static/fonts/Lato/lato-bolditalic.woff2 +0 -0
- snappy/doc/_static/fonts/Lato/lato-italic.eot +0 -0
- snappy/doc/_static/fonts/Lato/lato-italic.ttf +0 -0
- snappy/doc/_static/fonts/Lato/lato-italic.woff +0 -0
- snappy/doc/_static/fonts/Lato/lato-italic.woff2 +0 -0
- snappy/doc/_static/fonts/Lato/lato-regular.eot +0 -0
- snappy/doc/_static/fonts/Lato/lato-regular.ttf +0 -0
- snappy/doc/_static/fonts/Lato/lato-regular.woff +0 -0
- snappy/doc/_static/fonts/Lato/lato-regular.woff2 +0 -0
- snappy/doc/_static/fonts/RobotoSlab/roboto-slab-v7-bold.eot +0 -0
- snappy/doc/_static/fonts/RobotoSlab/roboto-slab-v7-bold.ttf +0 -0
- snappy/doc/_static/fonts/RobotoSlab/roboto-slab-v7-bold.woff +0 -0
- snappy/doc/_static/fonts/RobotoSlab/roboto-slab-v7-bold.woff2 +0 -0
- snappy/doc/_static/fonts/RobotoSlab/roboto-slab-v7-regular.eot +0 -0
- snappy/doc/_static/fonts/RobotoSlab/roboto-slab-v7-regular.ttf +0 -0
- snappy/doc/_static/fonts/RobotoSlab/roboto-slab-v7-regular.woff +0 -0
- snappy/doc/_static/fonts/RobotoSlab/roboto-slab-v7-regular.woff2 +0 -0
- snappy/doc/_static/jquery.js +2 -2
- snappy/doc/_static/js/badge_only.js +1 -0
- snappy/doc/_static/js/theme.js +1 -0
- snappy/doc/_static/js/versions.js +228 -0
- snappy/doc/_static/language_data.js +3 -101
- snappy/doc/_static/pygments.css +1 -0
- snappy/doc/_static/searchtools.js +489 -398
- snappy/doc/_static/snappy_furo.css +33 -0
- snappy/doc/_static/snappy_sphinx_rtd_theme.css +42 -0
- snappy/doc/_static/sphinx_highlight.js +154 -0
- snappy/doc/additional_classes.html +688 -263
- snappy/doc/bugs.html +107 -94
- snappy/doc/censuses.html +155 -127
- snappy/doc/credits.html +115 -104
- snappy/doc/development.html +184 -146
- snappy/doc/genindex.html +287 -204
- snappy/doc/index.html +189 -150
- snappy/doc/installing.html +259 -266
- snappy/doc/manifold.html +1626 -592
- snappy/doc/manifoldhp.html +119 -105
- snappy/doc/news.html +198 -104
- snappy/doc/objects.inv +0 -0
- snappy/doc/other.html +117 -105
- snappy/doc/platonic_census.html +161 -114
- snappy/doc/plink.html +113 -105
- snappy/doc/ptolemy.html +131 -108
- snappy/doc/ptolemy_classes.html +242 -223
- snappy/doc/ptolemy_examples1.html +144 -130
- snappy/doc/ptolemy_examples2.html +141 -129
- snappy/doc/ptolemy_examples3.html +148 -132
- snappy/doc/ptolemy_examples4.html +131 -111
- snappy/doc/ptolemy_prelim.html +162 -138
- snappy/doc/py-modindex.html +104 -69
- snappy/doc/screenshots.html +117 -108
- snappy/doc/search.html +115 -84
- snappy/doc/searchindex.js +1 -1
- snappy/doc/snap.html +109 -96
- snappy/doc/snappy.html +134 -97
- snappy/doc/spherogram.html +259 -187
- snappy/doc/todo.html +107 -94
- snappy/doc/triangulation.html +1380 -111
- snappy/doc/tutorial.html +107 -94
- snappy/doc/verify.html +194 -125
- snappy/doc/verify_internals.html +248 -686
- snappy/drilling/__init__.py +456 -0
- snappy/drilling/barycentric.py +103 -0
- snappy/drilling/constants.py +5 -0
- snappy/drilling/crush.py +270 -0
- snappy/drilling/cusps.py +125 -0
- snappy/drilling/debug.py +242 -0
- snappy/drilling/epsilons.py +6 -0
- snappy/drilling/exceptions.py +55 -0
- snappy/drilling/moves.py +620 -0
- snappy/drilling/peripheral_curves.py +210 -0
- snappy/drilling/perturb.py +188 -0
- snappy/drilling/shorten.py +36 -0
- snappy/drilling/subdivide.py +274 -0
- snappy/drilling/test.py +23 -0
- snappy/drilling/test_cases.py +126 -0
- snappy/drilling/tracing.py +351 -0
- snappy/exceptions.py +23 -3
- snappy/export_stl.py +20 -14
- snappy/exterior_to_link/__init__.py +2 -0
- snappy/exterior_to_link/barycentric_geometry.py +463 -0
- snappy/exterior_to_link/exceptions.py +6 -0
- snappy/exterior_to_link/geodesic_map.json +14408 -0
- snappy/exterior_to_link/hyp_utils.py +112 -0
- snappy/exterior_to_link/link_projection.py +323 -0
- snappy/exterior_to_link/main.py +197 -0
- snappy/exterior_to_link/mcomplex_with_expansion.py +261 -0
- snappy/exterior_to_link/mcomplex_with_link.py +687 -0
- snappy/exterior_to_link/mcomplex_with_memory.py +162 -0
- snappy/exterior_to_link/pl_utils.py +491 -0
- snappy/exterior_to_link/put_in_S3.py +156 -0
- snappy/exterior_to_link/rational_linear_algebra.py +123 -0
- snappy/exterior_to_link/rational_linear_algebra_wrapped.py +135 -0
- snappy/exterior_to_link/simplify_to_base_tri.py +114 -0
- snappy/exterior_to_link/stored_moves.py +475 -0
- snappy/exterior_to_link/test.py +31 -0
- snappy/geometric_structure/__init__.py +212 -0
- snappy/geometric_structure/cusp_neighborhood/__init__.py +3 -0
- snappy/geometric_structure/cusp_neighborhood/complex_cusp_cross_section.py +697 -0
- snappy/geometric_structure/cusp_neighborhood/cusp_cross_section_base.py +484 -0
- snappy/geometric_structure/cusp_neighborhood/exceptions.py +42 -0
- snappy/geometric_structure/cusp_neighborhood/real_cusp_cross_section.py +298 -0
- snappy/geometric_structure/cusp_neighborhood/tiles_for_cusp_neighborhood.py +159 -0
- snappy/geometric_structure/cusp_neighborhood/vertices.py +32 -0
- snappy/geometric_structure/geodesic/__init__.py +0 -0
- snappy/geometric_structure/geodesic/add_core_curves.py +152 -0
- snappy/geometric_structure/geodesic/avoid_core_curves.py +369 -0
- snappy/geometric_structure/geodesic/canonical_keys.py +52 -0
- snappy/geometric_structure/geodesic/check_away_from_core_curve.py +60 -0
- snappy/geometric_structure/geodesic/constants.py +6 -0
- snappy/geometric_structure/geodesic/exceptions.py +22 -0
- snappy/geometric_structure/geodesic/fixed_points.py +93 -0
- snappy/geometric_structure/geodesic/geodesic_start_point_info.py +435 -0
- snappy/geometric_structure/geodesic/graph_trace_helper.py +67 -0
- snappy/geometric_structure/geodesic/line.py +30 -0
- snappy/geometric_structure/geodesic/multiplicity.py +127 -0
- snappy/geometric_structure/geodesic/tiles_for_geodesic.py +101 -0
- snappy/geometric_structure/test.py +22 -0
- snappy/gui.py +36 -36
- snappy/horoviewer.py +50 -48
- snappy/hyperboloid/__init__.py +212 -0
- snappy/hyperboloid/distances.py +245 -0
- snappy/hyperboloid/horoball.py +19 -0
- snappy/hyperboloid/line.py +35 -0
- snappy/hyperboloid/point.py +9 -0
- snappy/hyperboloid/triangle.py +29 -0
- snappy/{infodialog.py → infowindow.py} +32 -33
- snappy/isometry_signature.py +382 -0
- snappy/len_spec/__init__.py +596 -0
- snappy/len_spec/geodesic_info.py +110 -0
- snappy/len_spec/geodesic_key_info_dict.py +117 -0
- snappy/len_spec/geodesic_piece.py +143 -0
- snappy/len_spec/geometric_structure.py +182 -0
- snappy/len_spec/geometry.py +80 -0
- snappy/len_spec/length_spectrum_geodesic_info.py +170 -0
- snappy/len_spec/spine.py +206 -0
- snappy/len_spec/test.py +24 -0
- snappy/len_spec/test_cases.py +69 -0
- snappy/len_spec/tile.py +275 -0
- snappy/len_spec/word.py +86 -0
- snappy/manifolds/__init__.py +1 -1
- snappy/math_basics.py +176 -0
- snappy/matrix.py +525 -0
- snappy/number.py +97 -21
- snappy/numeric_output_checker.py +37 -27
- snappy/pari.py +30 -69
- snappy/phone_home.py +25 -20
- snappy/polyviewer.py +39 -37
- snappy/ptolemy/__init__.py +4 -6
- snappy/ptolemy/component.py +14 -12
- snappy/ptolemy/coordinates.py +312 -295
- snappy/ptolemy/fieldExtensions.py +14 -12
- snappy/ptolemy/findLoops.py +43 -31
- snappy/ptolemy/geometricRep.py +24 -26
- snappy/ptolemy/homology.py +12 -7
- snappy/ptolemy/manifoldMethods.py +69 -70
- snappy/ptolemy/matrix.py +65 -26
- snappy/ptolemy/numericalSolutionsToGroebnerBasis.py +18 -14
- snappy/ptolemy/polynomial.py +125 -119
- snappy/ptolemy/processComponents.py +36 -30
- snappy/ptolemy/processFileBase.py +79 -18
- snappy/ptolemy/processFileDispatch.py +13 -14
- snappy/ptolemy/processMagmaFile.py +44 -39
- snappy/ptolemy/processRurFile.py +18 -11
- snappy/ptolemy/ptolemyGeneralizedObstructionClass.py +20 -17
- snappy/ptolemy/ptolemyObstructionClass.py +13 -17
- snappy/ptolemy/ptolemyVariety.py +190 -121
- snappy/ptolemy/ptolemyVarietyPrimeIdealGroebnerBasis.py +20 -19
- snappy/ptolemy/reginaWrapper.py +25 -29
- snappy/ptolemy/rur.py +6 -14
- snappy/ptolemy/solutionsToPrimeIdealGroebnerBasis.py +27 -22
- snappy/ptolemy/test.py +247 -188
- snappy/ptolemy/utilities.py +41 -43
- snappy/raytracing/__init__.py +64 -0
- snappy/raytracing/additional_horospheres.py +64 -0
- snappy/raytracing/additional_len_spec_choices.py +63 -0
- snappy/raytracing/cohomology_fractal.py +10 -6
- snappy/raytracing/eyeball.py +123 -0
- snappy/raytracing/finite_raytracing_data.py +48 -38
- snappy/raytracing/finite_viewer.py +218 -210
- snappy/raytracing/geodesic_tube_info.py +174 -0
- snappy/raytracing/geodesics.py +246 -0
- snappy/raytracing/geodesics_window.py +258 -0
- snappy/raytracing/gui_utilities.py +152 -40
- snappy/raytracing/hyperboloid_navigation.py +102 -52
- snappy/raytracing/hyperboloid_utilities.py +114 -261
- snappy/raytracing/ideal_raytracing_data.py +256 -179
- snappy/raytracing/inside_viewer.py +522 -253
- snappy/raytracing/pack.py +22 -0
- snappy/raytracing/raytracing_data.py +46 -34
- snappy/raytracing/raytracing_view.py +190 -109
- snappy/raytracing/shaders/Eye.png +0 -0
- snappy/raytracing/shaders/NonGeometric.png +0 -0
- snappy/raytracing/shaders/__init__.py +60 -4
- snappy/raytracing/shaders/fragment.glsl +575 -148
- snappy/raytracing/test.py +29 -0
- snappy/raytracing/tooltip.py +146 -0
- snappy/raytracing/upper_halfspace_utilities.py +98 -0
- snappy/raytracing/view_scale_controller.py +98 -0
- snappy/raytracing/zoom_slider/__init__.py +32 -29
- snappy/raytracing/zoom_slider/test.py +2 -0
- snappy/sage_helper.py +69 -123
- snappy/{preferences.py → settings.py} +167 -145
- snappy/shell.py +4 -0
- snappy/snap/__init__.py +12 -8
- snappy/snap/character_varieties.py +24 -18
- snappy/snap/find_field.py +35 -34
- snappy/snap/fundamental_polyhedron.py +99 -85
- snappy/snap/generators.py +6 -8
- snappy/snap/interval_reps.py +18 -6
- snappy/snap/kernel_structures.py +8 -3
- snappy/snap/mcomplex_base.py +1 -2
- snappy/snap/nsagetools.py +107 -53
- snappy/snap/peripheral/__init__.py +1 -1
- snappy/snap/peripheral/dual_cellulation.py +15 -7
- snappy/snap/peripheral/link.py +20 -16
- snappy/snap/peripheral/peripheral.py +22 -14
- snappy/snap/peripheral/surface.py +47 -50
- snappy/snap/peripheral/test.py +8 -8
- snappy/snap/polished_reps.py +65 -40
- snappy/snap/shapes.py +41 -22
- snappy/snap/slice_obs_HKL.py +64 -25
- snappy/snap/t3mlite/arrow.py +88 -51
- snappy/snap/t3mlite/corner.py +5 -6
- snappy/snap/t3mlite/edge.py +32 -21
- snappy/snap/t3mlite/face.py +7 -9
- snappy/snap/t3mlite/files.py +31 -23
- snappy/snap/t3mlite/homology.py +14 -10
- snappy/snap/t3mlite/linalg.py +158 -56
- snappy/snap/t3mlite/mcomplex.py +739 -291
- snappy/snap/t3mlite/perm4.py +236 -84
- snappy/snap/t3mlite/setup.py +9 -10
- snappy/snap/t3mlite/simplex.py +65 -48
- snappy/snap/t3mlite/spun.py +42 -30
- snappy/snap/t3mlite/surface.py +45 -45
- snappy/snap/t3mlite/test.py +3 -0
- snappy/snap/t3mlite/test_vs_regina.py +17 -13
- snappy/snap/t3mlite/tetrahedron.py +25 -24
- snappy/snap/t3mlite/vertex.py +8 -13
- snappy/snap/test.py +45 -52
- snappy/snap/utilities.py +66 -65
- snappy/test.py +155 -158
- snappy/test_cases.py +263 -0
- snappy/testing.py +131 -0
- snappy/tiling/__init__.py +2 -0
- snappy/tiling/canonical_key_dict.py +59 -0
- snappy/tiling/dict_based_set.py +79 -0
- snappy/tiling/floor.py +49 -0
- snappy/tiling/hyperboloid_dict.py +54 -0
- snappy/tiling/iter_utils.py +78 -0
- snappy/tiling/lifted_tetrahedron.py +22 -0
- snappy/tiling/lifted_tetrahedron_set.py +54 -0
- snappy/tiling/real_hash_dict.py +164 -0
- snappy/tiling/test.py +23 -0
- snappy/tiling/tile.py +215 -0
- snappy/tiling/triangle.py +33 -0
- snappy/tkterminal.py +313 -203
- snappy/twister/main.py +1 -8
- snappy/twister/twister_core.cpython-38-darwin.so +0 -0
- snappy/upper_halfspace/__init__.py +146 -0
- snappy/upper_halfspace/ideal_point.py +26 -0
- snappy/verify/__init__.py +4 -8
- snappy/verify/{verifyCanonical.py → canonical.py} +114 -97
- snappy/verify/complex_volume/__init__.py +3 -2
- snappy/verify/complex_volume/adjust_torsion.py +13 -11
- snappy/verify/complex_volume/closed.py +29 -24
- snappy/verify/complex_volume/compute_ptolemys.py +8 -6
- snappy/verify/complex_volume/cusped.py +10 -9
- snappy/verify/complex_volume/extended_bloch.py +14 -12
- snappy/verify/{cuspTranslations.py → cusp_translations.py} +15 -14
- snappy/verify/edge_equations.py +80 -0
- snappy/verify/exceptions.py +23 -56
- snappy/verify/{verifyHyperbolicity.py → hyperbolicity.py} +19 -15
- snappy/verify/interval_newton_shapes_engine.py +51 -211
- snappy/verify/interval_tree.py +27 -25
- snappy/verify/krawczyk_shapes_engine.py +47 -50
- snappy/verify/maximal_cusp_area_matrix/__init__.py +17 -86
- snappy/verify/maximal_cusp_area_matrix/cusp_tiling_engine.py +58 -48
- snappy/verify/maximal_cusp_area_matrix/cusp_translate_engine.py +53 -57
- snappy/verify/{realAlgebra.py → real_algebra.py} +26 -20
- snappy/verify/shapes.py +10 -7
- snappy/verify/short_slopes.py +41 -42
- snappy/verify/{squareExtensions.py → square_extensions.py} +96 -92
- snappy/verify/test.py +59 -57
- snappy/verify/upper_halfspace/extended_matrix.py +5 -5
- snappy/verify/upper_halfspace/finite_point.py +44 -31
- snappy/verify/upper_halfspace/ideal_point.py +69 -57
- snappy/verify/volume.py +15 -12
- snappy/version.py +2 -3
- {snappy-3.0.3.dist-info → snappy-3.2.dist-info}/METADATA +14 -12
- snappy-3.2.dist-info/RECORD +503 -0
- {snappy-3.0.3.dist-info → snappy-3.2.dist-info}/WHEEL +1 -1
- {snappy-3.0.3.dist-info → snappy-3.2.dist-info}/entry_points.txt +0 -1
- {snappy-3.0.3.dist-info → snappy-3.2.dist-info}/top_level.txt +10 -1
- snappy/doc/_sources/verify_canon.rst.txt +0 -90
- snappy/doc/_static/classic.css +0 -266
- snappy/doc/_static/jquery-3.5.1.js +0 -10872
- snappy/doc/_static/sidebar.js +0 -159
- snappy/doc/_static/underscore-1.13.1.js +0 -2042
- snappy/doc/_static/underscore.js +0 -6
- snappy/doc/verify_canon.html +0 -283
- snappy/ppm_to_png.py +0 -243
- snappy/togl/__init__.py +0 -3
- snappy/togl/darwin-tk8.6/Togl2.1/LICENSE +0 -28
- snappy/togl/darwin-tk8.6/Togl2.1/libTogl2.1.dylib +0 -0
- snappy/togl/darwin-tk8.6/Togl2.1/pkgIndex.tcl +0 -5
- snappy/togl/linux2-x86_64-tk8.6/Togl2.1/LICENSE +0 -28
- snappy/togl/linux2-x86_64-tk8.6/Togl2.1/libTogl2.1.so +0 -0
- snappy/togl/linux2-x86_64-tk8.6/Togl2.1/pkgIndex.tcl +0 -5
- snappy/togl/win32VC-tk8.6/Togl2.1/LICENSE +0 -28
- snappy/togl/win32VC-tk8.6/Togl2.1/Togl21.dll +0 -0
- snappy/togl/win32VC-tk8.6/Togl2.1/Togl21.lib +0 -0
- snappy/togl/win32VC-tk8.6/Togl2.1/pkgIndex.tcl +0 -6
- snappy/togl/win32VC-x86_64-tk8.6/Togl2.1/LICENSE +0 -28
- snappy/togl/win32VC-x86_64-tk8.6/Togl2.1/Togl21.dll +0 -0
- snappy/togl/win32VC-x86_64-tk8.6/Togl2.1/Togl21.lib +0 -0
- snappy/togl/win32VC-x86_64-tk8.6/Togl2.1/pkgIndex.tcl +0 -6
- snappy/verify/cuspCrossSection.py +0 -1413
- snappy/verify/mathHelpers.py +0 -64
- snappy-3.0.3.dist-info/RECORD +0 -360
snappy/ptolemy/reginaWrapper.py
CHANGED
@@ -13,6 +13,7 @@ from . import utilities
|
|
13
13
|
|
14
14
|
# See addl_code/ptolemy_equations.c for more comments.
|
15
15
|
|
16
|
+
|
16
17
|
class NTriangulationForPtolemy(NTriangulation):
|
17
18
|
|
18
19
|
"""
|
@@ -39,7 +40,7 @@ class NTriangulationForPtolemy(NTriangulation):
|
|
39
40
|
"""
|
40
41
|
Constructor - takes same arguments as NTriangulation.
|
41
42
|
"""
|
42
|
-
super(
|
43
|
+
super().__init__(*args, **kwargs)
|
43
44
|
|
44
45
|
# Make sure we are oriented
|
45
46
|
if not self.isOriented():
|
@@ -61,7 +62,7 @@ class NTriangulationForPtolemy(NTriangulation):
|
|
61
62
|
"""
|
62
63
|
|
63
64
|
# Create temporary file and write text to it
|
64
|
-
f = tempfile.NamedTemporaryFile(delete
|
65
|
+
f = tempfile.NamedTemporaryFile(delete=False)
|
65
66
|
filename = f.name
|
66
67
|
f.write(text)
|
67
68
|
f.close()
|
@@ -80,7 +81,6 @@ class NTriangulationForPtolemy(NTriangulation):
|
|
80
81
|
|
81
82
|
return NTriangulationForPtolemy(T)
|
82
83
|
|
83
|
-
|
84
84
|
def ptolemy_obstruction_classes(self):
|
85
85
|
"""
|
86
86
|
Returns the obstruction classes needed to compute the
|
@@ -105,12 +105,14 @@ class NTriangulationForPtolemy(NTriangulation):
|
|
105
105
|
return manifoldMethods.get_ptolemy_obstruction_classes(self)
|
106
106
|
|
107
107
|
def ptolemy_generalized_obstruction_classes(self, N):
|
108
|
-
|
109
108
|
"""
|
110
|
-
|
111
|
-
PGL(N,C)-representations for any N
|
109
|
+
Return the obstruction classes needed to compute
|
110
|
+
PGL(N,C)-representations for any N.
|
111
|
+
|
112
|
+
It returns a list with
|
112
113
|
a representative cocycle for each element in
|
113
|
-
H^2(M, boundary M; Z/N) / (Z/N)
|
114
|
+
``H^2(M, boundary M; Z/N) / (Z/N)^*``
|
115
|
+
where ``(Z/N)^*`` are the units in Z/N.
|
114
116
|
The first element in the list always corresponds to the trivial
|
115
117
|
obstruction class.
|
116
118
|
The generalized ptolemy obstruction classes are thus a generalization
|
@@ -131,14 +133,12 @@ class NTriangulationForPtolemy(NTriangulation):
|
|
131
133
|
|
132
134
|
See help(Manifold.ptolemy_generalized_obstruction_classes()) for more.
|
133
135
|
"""
|
134
|
-
|
135
136
|
return (
|
136
137
|
manifoldMethods.get_generalized_ptolemy_obstruction_classes(
|
137
138
|
self, N))
|
138
139
|
|
139
|
-
def ptolemy_variety(self, N, obstruction_class
|
140
|
-
simplify
|
141
|
-
|
140
|
+
def ptolemy_variety(self, N, obstruction_class=None,
|
141
|
+
simplify=True, eliminate_fixed_ptolemys=False):
|
142
142
|
"""
|
143
143
|
M.ptolemy_variety(N, obstruction_class = None, simplify = True, eliminate_fixed_ptolemys = False)
|
144
144
|
|
@@ -146,10 +146,10 @@ class NTriangulationForPtolemy(NTriangulation):
|
|
146
146
|
|
147
147
|
* Stavros Garoufalidis, Dyland Thurston, Christian K. Zickert:
|
148
148
|
"The Complex Volume of SL(n,C)-Representations of 3-Manifolds"
|
149
|
-
(
|
149
|
+
(https://arxiv.org/abs/1111.2828)
|
150
150
|
* Stavros Garoufalidis, Matthias Goerner, Christian K. Zickert:
|
151
151
|
"Gluing Equations for PGL(n,C)-Representations of 3-Manifolds "
|
152
|
-
(
|
152
|
+
(https://arxiv.org/abs/1207.6711)
|
153
153
|
|
154
154
|
The variety can be exported to magma or sage and solved there. The
|
155
155
|
solutions can be processed to compute invariants.
|
@@ -169,8 +169,8 @@ class NTriangulationForPtolemy(NTriangulation):
|
|
169
169
|
|
170
170
|
return manifoldMethods.get_ptolemy_variety(
|
171
171
|
self, N, obstruction_class,
|
172
|
-
simplify
|
173
|
-
eliminate_fixed_ptolemys
|
172
|
+
simplify=simplify,
|
173
|
+
eliminate_fixed_ptolemys=eliminate_fixed_ptolemys)
|
174
174
|
|
175
175
|
def name(self):
|
176
176
|
"""
|
@@ -373,7 +373,6 @@ class NTriangulationForPtolemy(NTriangulation):
|
|
373
373
|
Also see _ptolemy_equations_boundary_map_2.
|
374
374
|
"""
|
375
375
|
|
376
|
-
|
377
376
|
def process_triangle(triangle):
|
378
377
|
row = [ 0 for i in range(self.getNumberOfTetrahedra()) ]
|
379
378
|
for i in range(2):
|
@@ -409,7 +408,7 @@ class NTriangulationForPtolemy(NTriangulation):
|
|
409
408
|
|
410
409
|
for tet_index, tet in enumerate(self.getTetrahedra()):
|
411
410
|
for pt in utilities.quadruples_with_fixed_sum_iterator(
|
412
|
-
N, skipVertices
|
411
|
+
N, skipVertices=True):
|
413
412
|
|
414
413
|
row = (N - 1) * self.getNumberOfVertices() * [ 0 ]
|
415
414
|
|
@@ -440,7 +439,7 @@ class NTriangulationForPtolemy(NTriangulation):
|
|
440
439
|
# Following Remark 5.7 of
|
441
440
|
# Garoufalidis, Goerner, Zickert:
|
442
441
|
# Gluing Equations for PGL(n,C)-Representations of 3-Manifolds
|
443
|
-
#
|
442
|
+
# https://arxiv.org/abs/1207.6711
|
444
443
|
# we discard all even entries and get a permutation called
|
445
444
|
# "effective_perm" here.
|
446
445
|
effective_perm = []
|
@@ -465,8 +464,8 @@ class NTriangulationForPtolemy(NTriangulation):
|
|
465
464
|
if len(effective_perm) == 3:
|
466
465
|
# Test whether cyclic permutation by i, including identity
|
467
466
|
for i in range(3):
|
468
|
-
if (
|
469
|
-
|
467
|
+
if (effective_perm[i] < effective_perm[(i + 1) % 3]
|
468
|
+
< effective_perm[(i + 2) % 3]):
|
470
469
|
return +1
|
471
470
|
return -1
|
472
471
|
|
@@ -517,8 +516,6 @@ class NTriangulationForPtolemy(NTriangulation):
|
|
517
516
|
self._get_obstruction_on_edge(obstruction_class,
|
518
517
|
other_tet, other_v0, other_v1))
|
519
518
|
|
520
|
-
|
521
|
-
|
522
519
|
def _get_obstruction_on_edges(self, obstruction_class, tet, face, N):
|
523
520
|
"""
|
524
521
|
This reimplements _get_obstruction_on_edges from
|
@@ -561,13 +558,12 @@ class NTriangulationForPtolemy(NTriangulation):
|
|
561
558
|
obstruction class by _get_obstruction_on_edges.
|
562
559
|
"""
|
563
560
|
|
564
|
-
|
565
561
|
v1 = (face + 2) % 4
|
566
562
|
v2 = (face + 3) % 4
|
567
563
|
return ptolemy_index[v1] * e01 + ptolemy_index[v2] * e02
|
568
564
|
|
569
565
|
def _ptolemy_equations_identified_coordinates(self, N,
|
570
|
-
obstruction_class
|
566
|
+
obstruction_class=None):
|
571
567
|
|
572
568
|
identifications = []
|
573
569
|
|
@@ -593,7 +589,7 @@ class NTriangulationForPtolemy(NTriangulation):
|
|
593
589
|
|
594
590
|
# Iterate through all the integral points on the face
|
595
591
|
for triple in utilities.triples_with_fixed_sum_iterator(
|
596
|
-
N, skipVertices
|
592
|
+
N, skipVertices=True):
|
597
593
|
# The face integral points are obtained by inserting a 0
|
598
594
|
ptolemy_index = triple[0:face] + (0,) + triple[face:]
|
599
595
|
# Get the corresponding integral point on the other tetrahedron
|
@@ -615,7 +611,7 @@ class NTriangulationForPtolemy(NTriangulation):
|
|
615
611
|
power = 0
|
616
612
|
|
617
613
|
# Get the two corresponding Ptolemy coordinates
|
618
|
-
ptolemy
|
614
|
+
ptolemy = ('c_%d%d%d%d' % ptolemy_index +
|
619
615
|
'_%d' % tet_index)
|
620
616
|
other_ptolemy = ('c_%d%d%d%d' % other_ptolemy_index +
|
621
617
|
'_%d' % other_tet_index)
|
@@ -648,8 +644,8 @@ class NTriangulationForPtolemy(NTriangulation):
|
|
648
644
|
non_generator_triangles = self.maximalForestInDualSkeleton()
|
649
645
|
|
650
646
|
# All other triangles are
|
651
|
-
generator_triangles = [
|
652
|
-
|
647
|
+
generator_triangles = [triangle for triangle in self.getTriangles()
|
648
|
+
if triangle not in non_generator_triangles]
|
653
649
|
|
654
650
|
def get_neighbors(tet):
|
655
651
|
"""
|
@@ -673,7 +669,7 @@ class NTriangulationForPtolemy(NTriangulation):
|
|
673
669
|
"""
|
674
670
|
# Get corresponding triangle
|
675
671
|
triangle = tet.getTriangle(face)
|
676
|
-
if not
|
672
|
+
if triangle not in generator_triangles:
|
677
673
|
# Not a generator, return 0
|
678
674
|
return 0
|
679
675
|
# Get the index of the generator, first generator is indexed 1
|
snappy/ptolemy/rur.py
CHANGED
@@ -1,6 +1,3 @@
|
|
1
|
-
import operator
|
2
|
-
import functools
|
3
|
-
|
4
1
|
# Dependency on pari for:
|
5
2
|
# * from_pari_fraction_and_number_field
|
6
3
|
# * evaluate_at_root
|
@@ -10,11 +7,12 @@ import functools
|
|
10
7
|
|
11
8
|
from ..sage_helper import _within_sage
|
12
9
|
from ..pari import Gen, pari
|
10
|
+
from ..math_basics import prod
|
13
11
|
if _within_sage:
|
14
12
|
from sage.rings.integer import Integer
|
15
13
|
|
16
14
|
|
17
|
-
class RUR(
|
15
|
+
class RUR():
|
18
16
|
|
19
17
|
"""
|
20
18
|
A Rational Univariate Representation of an algebraic number.
|
@@ -247,7 +245,6 @@ class RUR(object):
|
|
247
245
|
return '%s / ( %s )' % (numerator, denominator)
|
248
246
|
|
249
247
|
def number_field(self):
|
250
|
-
|
251
248
|
"""
|
252
249
|
Returns the polynomial c such that evaluating the fraction
|
253
250
|
at one of the roots yields the algebraic number this RUR is
|
@@ -260,7 +257,6 @@ class RUR(object):
|
|
260
257
|
return None
|
261
258
|
|
262
259
|
def evaluate_at_root(self, root):
|
263
|
-
|
264
260
|
"""
|
265
261
|
Given a numerical value for a root of the polynomial returned
|
266
262
|
by number_field, evaluates all polynomials at that root and
|
@@ -292,7 +288,7 @@ class RUR(object):
|
|
292
288
|
|
293
289
|
return pari(p)
|
294
290
|
|
295
|
-
return
|
291
|
+
return prod(
|
296
292
|
[ evaluate_poly(p) ** e for p, e in self._polymod_exponent_pairs ])
|
297
293
|
|
298
294
|
def multiply_terms(self):
|
@@ -414,7 +410,7 @@ class RUR(object):
|
|
414
410
|
return self._filtered_terms( -1)
|
415
411
|
|
416
412
|
def _multiply_terms(self, sgn):
|
417
|
-
return
|
413
|
+
return prod([ p ** abs(e) for p, e in self._filtered_terms(sgn) ])
|
418
414
|
|
419
415
|
def _numerator(self):
|
420
416
|
return self._multiply_terms( +1)
|
@@ -447,7 +443,7 @@ class RUR(object):
|
|
447
443
|
return
|
448
444
|
|
449
445
|
def term_to_expand_fraction_by(old_terms):
|
450
|
-
result =
|
446
|
+
result = list(new_denominator_terms)
|
451
447
|
for p, e in old_terms:
|
452
448
|
if e < 0:
|
453
449
|
subtract_denominator_from_list(p, e, result)
|
@@ -455,7 +451,7 @@ class RUR(object):
|
|
455
451
|
for p, e in result:
|
456
452
|
assert e <= 0
|
457
453
|
|
458
|
-
return
|
454
|
+
return prod([ p ** -e for p, e in result if e < 0 ])
|
459
455
|
|
460
456
|
self_expand = term_to_expand_fraction_by( self._denominator_terms())
|
461
457
|
other_expand = term_to_expand_fraction_by(other._denominator_terms())
|
@@ -547,7 +543,3 @@ class RUR(object):
|
|
547
543
|
return self._is_zero()
|
548
544
|
|
549
545
|
return (self / other)._is_one()
|
550
|
-
|
551
|
-
|
552
|
-
def _prod(iterable):
|
553
|
-
return functools.reduce(operator.mul, iterable, 1)
|
@@ -18,12 +18,12 @@ from ..pari import pari
|
|
18
18
|
|
19
19
|
# This is broken down in three steps.
|
20
20
|
|
21
|
-
# Step 1: Split into extensions and
|
21
|
+
# Step 1: Split into extensions and assignments
|
22
22
|
# extensions, assignments = extensions_and_assignments(polys)
|
23
23
|
|
24
24
|
# Split the list of polynomials into two lists, the first list
|
25
25
|
# contains triples (poly, var, degree) forming a tower of
|
26
|
-
# field
|
26
|
+
# field extensions and the second group is a dictionary assigning
|
27
27
|
# all remaining variables polynomials in the variables in the tower.
|
28
28
|
|
29
29
|
# Example:
|
@@ -45,7 +45,7 @@ from ..pari import pari
|
|
45
45
|
# So assignments will be { 'a': t^3 - 1, 'b': 2}.
|
46
46
|
#
|
47
47
|
# extensions will be empty if the solutions are in Q.
|
48
|
-
|
48
|
+
|
49
49
|
# Step 2: Process the extensions
|
50
50
|
# number_field, ext_assignments = process_extensions_to_pari(extensions)
|
51
51
|
#
|
@@ -57,11 +57,12 @@ from ..pari import pari
|
|
57
57
|
|
58
58
|
# Step 3: Subsituiting
|
59
59
|
# assignments = update_assignments_and_merge(assignments, ext_assignments)
|
60
|
-
|
60
|
+
|
61
61
|
# The other variables are given as polynomials in the variables from
|
62
62
|
# the field extension tower, do the substituition to convert them
|
63
63
|
# into polynomials in x
|
64
64
|
|
65
|
+
|
65
66
|
def _only_var_left_in_poly(poly, extension_vars):
|
66
67
|
'''
|
67
68
|
Checks whether that there is only one other variable besides
|
@@ -78,6 +79,7 @@ def _only_var_left_in_poly(poly, extension_vars):
|
|
78
79
|
return None
|
79
80
|
return list(vars_left)[0]
|
80
81
|
|
82
|
+
|
81
83
|
def _next_var_and_poly(polys, extension_vars):
|
82
84
|
'''
|
83
85
|
Applies _only_var_left_in_poly to find a polynomial that has
|
@@ -94,21 +96,22 @@ def _next_var_and_poly(polys, extension_vars):
|
|
94
96
|
"solve is probably not in lexicographic order or of a "
|
95
97
|
"0-dimensional ideal!")
|
96
98
|
|
99
|
+
|
97
100
|
def _remove(l, element):
|
98
101
|
'''
|
99
102
|
Returns a copy of list without element.
|
100
103
|
'''
|
101
|
-
return [x for x in l if
|
104
|
+
return [x for x in l if x is not element]
|
105
|
+
|
102
106
|
|
103
107
|
def extensions_and_assignments(polys):
|
104
108
|
'''
|
105
109
|
Splits into extensions and assignments s in example given above
|
106
110
|
in _exact_solutions.
|
107
111
|
'''
|
108
|
-
|
109
|
-
|
110
|
-
|
111
|
-
assignments = { } # pure assignments
|
112
|
+
extensions = [] # extension polynomials
|
113
|
+
extension_vars = []
|
114
|
+
assignments = {} # pure assignments
|
112
115
|
|
113
116
|
# Iterate while polys left
|
114
117
|
while polys:
|
@@ -131,8 +134,8 @@ def extensions_and_assignments(polys):
|
|
131
134
|
# So we can just take the following difference:
|
132
135
|
|
133
136
|
value = Polynomial.from_variable_name(var) - poly
|
134
|
-
assert not
|
135
|
-
assert not
|
137
|
+
assert var not in value.variables()
|
138
|
+
assert var not in assignments
|
136
139
|
assignments[var] = value
|
137
140
|
|
138
141
|
else:
|
@@ -142,18 +145,19 @@ def extensions_and_assignments(polys):
|
|
142
145
|
|
143
146
|
return extensions, assignments
|
144
147
|
|
148
|
+
|
145
149
|
def update_assignments_and_merge(assignments, d):
|
146
150
|
|
147
151
|
variables = sorted(set(
|
148
152
|
sum([poly.variables() for poly in assignments.values()], [])))
|
149
153
|
|
150
|
-
monomial_to_value = {
|
154
|
+
monomial_to_value = {(): pari(1)}
|
151
155
|
|
152
156
|
for var in variables:
|
153
157
|
max_degree = max([poly.degree(var) for poly in assignments.values()])
|
154
158
|
|
155
|
-
old_keys = list(monomial_to_value
|
156
|
-
|
159
|
+
old_keys = list(monomial_to_value)
|
160
|
+
|
157
161
|
v = d[var]
|
158
162
|
power_of_v = pari(1)
|
159
163
|
|
@@ -176,15 +180,16 @@ def update_assignments_and_merge(assignments, d):
|
|
176
180
|
[eval_monomial(m) for m in poly.get_monomials()],
|
177
181
|
pari(0))
|
178
182
|
|
179
|
-
new_assignments =
|
180
|
-
for key, poly in assignments.items()
|
183
|
+
new_assignments = {key: substitute(poly)
|
184
|
+
for key, poly in assignments.items()}
|
181
185
|
|
182
186
|
# Merge all the assignments of variables
|
183
187
|
new_assignments.update(d)
|
184
188
|
new_assignments['1'] = pari(1)
|
185
|
-
|
189
|
+
|
186
190
|
return new_assignments
|
187
191
|
|
192
|
+
|
188
193
|
def _process_extensions(extensions):
|
189
194
|
'''
|
190
195
|
Given a tower of field extensions, find the number field defining
|
@@ -202,7 +207,7 @@ def _process_extensions(extensions):
|
|
202
207
|
# Just rename the variable of the polynomial by x
|
203
208
|
ext_assignments = { var: Polynomial.from_variable_name('x') }
|
204
209
|
number_field = poly.substitute(ext_assignments)
|
205
|
-
|
210
|
+
|
206
211
|
# Process the other extensions
|
207
212
|
# number_field is the polynomial in x defining the number field
|
208
213
|
# obtained so far in the tower
|
@@ -222,16 +227,16 @@ def _process_extensions(extensions):
|
|
222
227
|
# The new number field is again in x but the assignments
|
223
228
|
# are assigning polynomials in the old x.
|
224
229
|
# Need to update.
|
225
|
-
ext_assignments =
|
226
|
-
|
227
|
-
for key, poly in ext_assignments.items()
|
230
|
+
ext_assignments = {
|
231
|
+
key: poly.substitute({'x' : old_x_in_new_x})
|
232
|
+
for key, poly in ext_assignments.items()}
|
228
233
|
|
229
234
|
# And compute what the root of the last polynomial was
|
230
235
|
# to assign it.
|
231
236
|
ext_assignments[var] = (
|
232
237
|
Polynomial.from_variable_name('x')
|
233
238
|
- Polynomial.constant_polynomial(k) * old_x_in_new_x)
|
234
|
-
|
239
|
+
|
235
240
|
return number_field, ext_assignments
|
236
241
|
|
237
242
|
|