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
@@ -91,26 +91,59 @@ def has_value(v, values):
|
|
91
91
|
RIF = RealIntervalField(212)
|
92
92
|
|
93
93
|
for value in values:
|
94
|
-
if abs(RIF(v.imag()) - RIF(value.imag())) < 1e-20:
|
94
|
+
if abs(RIF(v.imag()) - RIF(value.imag())) < RIF(1e-20):
|
95
95
|
r = (RIF(v.real()) - RIF(value.real())) / RIF(pi**2/2)
|
96
96
|
|
97
97
|
is_int, k = r.is_int()
|
98
98
|
if is_int:
|
99
|
-
if abs(r - k) < 1e-20:
|
99
|
+
if abs(r - k) < RIF(1e-20):
|
100
100
|
return True
|
101
101
|
return False
|
102
102
|
|
103
103
|
if __name__ == '__main__':
|
104
|
-
|
104
|
+
# Use 5_2(1,2) as an example.
|
105
105
|
from snappy import ManifoldHP
|
106
106
|
|
107
107
|
M = ManifoldHP("5_2")
|
108
108
|
M.chern_simons()
|
109
109
|
M.dehn_fill((1,2))
|
110
110
|
|
111
|
-
|
112
|
-
|
113
|
-
|
114
|
-
|
115
|
-
|
116
|
-
|
111
|
+
# Complex volume of geometric representation of 5_2(1,2).
|
112
|
+
# Unverified.
|
113
|
+
geom_cvol = M.complex_volume()
|
114
|
+
|
115
|
+
# This file uses a different convention (simply adding Neumann's
|
116
|
+
# extensions of Roger's dilogarithm to the Abelian cover of C \ {0,1})
|
117
|
+
# from the rest of SnapPy, so convert.
|
118
|
+
geom_cvol = sage.all.I * geom_cvol
|
119
|
+
|
120
|
+
# The complex volumes as verified intervals of the SL(2,C)-representations
|
121
|
+
# detected by the (spun-)triangulation.
|
122
|
+
# Grouped by algebraic component of the extended Ptolemy variety.
|
123
|
+
#
|
124
|
+
# We can only compute it in this file up to multiples of pi^2/2.
|
125
|
+
#
|
126
|
+
# (Note that Neumann's method can compute it up to multiple of pi^2 but
|
127
|
+
# assumes an ordered triangulation. Most census triangulations are not
|
128
|
+
# orderable and would require subdivision).
|
129
|
+
#
|
130
|
+
# The method uses SageMath's giac to compute the rational univariate
|
131
|
+
# representation and evaluates it at the roots of the defining polynomial
|
132
|
+
# using complex intervals.
|
133
|
+
#
|
134
|
+
# It can be accessed from sage (with SnapPy installed) by:
|
135
|
+
# from snappy.dev.extended_ptolemy.complexVolumesClosed import complex_volumes
|
136
|
+
#
|
137
|
+
# Tested with SageMath 9.7 and 10.0.
|
138
|
+
#
|
139
|
+
cvols_by_component = complex_volumes(M, precision = 300)
|
140
|
+
|
141
|
+
print(cvols_by_component)
|
142
|
+
|
143
|
+
# Concatenate the grouped complex volumes to just have a single list.
|
144
|
+
cvols = sum(cvols_by_component, [])
|
145
|
+
|
146
|
+
if not has_value(geom_cvol, cvols):
|
147
|
+
raise RuntimeError(
|
148
|
+
"There is a problem. The complex volume of the geometric "
|
149
|
+
"representation is not included.")
|
@@ -1,4 +1,3 @@
|
|
1
|
-
from __future__ import print_function
|
2
1
|
"""
|
3
2
|
Computing the extended Ptolemy variety of Goerner-Zickert for N = 2.
|
4
3
|
"""
|
@@ -17,10 +16,12 @@ t3m_edge_to_tuple = {t3m.E01:(0,1), t3m.E02:(0,2), t3m.E03:(0,3),
|
|
17
16
|
to_t3m_edge = {(0,1):t3m.E01, (0,2):t3m.E02, (0,3):t3m.E03,
|
18
17
|
(1,2):t3m.E12, (1,3):t3m.E13, (2,3):t3m.E23}
|
19
18
|
|
19
|
+
|
20
20
|
def arrow(mcomplex, tet, face, edge):
|
21
21
|
return t3m.Arrow(to_t3m_edge[edge], t3m.TwoSubsimplices[face],
|
22
22
|
mcomplex.Tetrahedra[tet])
|
23
23
|
|
24
|
+
|
24
25
|
def faces_around_edge(mcomplex, tet, edge):
|
25
26
|
face = min(set(range(4)) - set(edge))
|
26
27
|
ans = [(tet, face, edge)]
|
@@ -56,17 +57,20 @@ def arrows_around_edges(manifold):
|
|
56
57
|
ans = []
|
57
58
|
return [faces_around_edge(T, tet, edge) for tet, edge in starts]
|
58
59
|
|
60
|
+
|
59
61
|
def parse_ptolemy_edge(var):
|
60
62
|
c, index, tet = var.split('_')
|
61
63
|
tet = int(tet)
|
62
64
|
edge = tuple(i for i in range(4) if index[i] == '1')
|
63
65
|
return tet, edge
|
64
66
|
|
67
|
+
|
65
68
|
def parse_ptolemy_face(var):
|
66
69
|
s, index, tet = var.split('_')
|
67
70
|
return int(tet), int(index)
|
68
71
|
|
69
|
-
|
72
|
+
|
73
|
+
class EdgeGluings():
|
70
74
|
def __init__(self, gen_obs_class):
|
71
75
|
assert gen_obs_class._N == 2
|
72
76
|
M = gen_obs_class._manifold
|
@@ -149,7 +153,7 @@ def simplify_equation(poly):
|
|
149
153
|
def extended_ptolemy_equations(manifold, gen_obs_class=None,
|
150
154
|
nonzero_cond=True, return_full_var_dict = False,
|
151
155
|
notation = 'short'):
|
152
|
-
"""
|
156
|
+
r"""
|
153
157
|
We assign ptolemy coordinates ['a', 'b', 'c', 'd', 'e', 'f'] to the
|
154
158
|
*directed* edges::
|
155
159
|
|
@@ -157,27 +161,25 @@ def extended_ptolemy_equations(manifold, gen_obs_class=None,
|
|
157
161
|
|
158
162
|
|
159
163
|
where recall that the basic orientation convention of t3m and
|
160
|
-
SnapPy is that a positively oriented simplex is as below.
|
161
|
-
|
162
|
-
|
163
|
-
|
164
|
-
|
165
|
-
|
166
|
-
|
167
|
-
|
168
|
-
|
169
|
-
|
170
|
-
|
171
|
-
|
172
|
-
|
173
|
-
0
|
164
|
+
SnapPy is that a positively oriented simplex is as below. ::
|
165
|
+
|
166
|
+
1
|
167
|
+
/|\
|
168
|
+
d / | \ e
|
169
|
+
/ | \
|
170
|
+
/ | \
|
171
|
+
2----|----3 with back edge from 2 to 3 labelled f.
|
172
|
+
\ | /
|
173
|
+
b \ |a / c
|
174
|
+
\ | /
|
175
|
+
\|/
|
176
|
+
0
|
174
177
|
|
175
178
|
sage: M = Manifold('m016')
|
176
179
|
sage: I = extended_ptolemy_equations(M)
|
177
180
|
sage: I.dimension()
|
178
181
|
1
|
179
182
|
"""
|
180
|
-
|
181
183
|
if gen_obs_class is None:
|
182
184
|
gen_obs_class = manifold.ptolemy_generalized_obstruction_classes(2)[0]
|
183
185
|
|
@@ -197,7 +199,8 @@ def extended_ptolemy_equations(manifold, gen_obs_class=None,
|
|
197
199
|
'c_0011_']
|
198
200
|
first_var_name = 'c_1100_0'
|
199
201
|
|
200
|
-
tet_vars = [
|
202
|
+
tet_vars = [x + repr(d) for d in range(n) for x in var_names]
|
203
|
+
|
201
204
|
def var(tet, edge):
|
202
205
|
return tet_vars[6*tet + directed_edges.index(edge)]
|
203
206
|
|
@@ -258,6 +261,7 @@ def extended_ptolemy_equations(manifold, gen_obs_class=None,
|
|
258
261
|
else:
|
259
262
|
return R.ideal(rels)
|
260
263
|
|
264
|
+
|
261
265
|
def apoly(manifold, rational_coeff=False, method='sage'):
|
262
266
|
"""
|
263
267
|
Computes the SL(2, C) version of the A-polynomial starting from
|
@@ -273,7 +277,7 @@ def apoly(manifold, rational_coeff=False, method='sage'):
|
|
273
277
|
"""
|
274
278
|
I = extended_ptolemy_equations(manifold)
|
275
279
|
R = I.ring()
|
276
|
-
if rational_coeff
|
280
|
+
if rational_coeff is False:
|
277
281
|
F = GF(31991)
|
278
282
|
R = R.change_ring(F)
|
279
283
|
I = I.change_ring(R)
|
@@ -287,6 +291,7 @@ def apoly(manifold, rational_coeff=False, method='sage'):
|
|
287
291
|
else:
|
288
292
|
raise ValueError("method flag should be in ['sage', 'M2']")
|
289
293
|
|
294
|
+
|
290
295
|
def sample_apoly_points_via_giac_rur(manifold, n):
|
291
296
|
import giac_rur
|
292
297
|
I = extended_ptolemy_equations(manifold)
|
@@ -388,12 +393,14 @@ def shapes_of_SL2C_reps_for_filled(manifold, phc_solver=None):
|
|
388
393
|
ans.append(shape_dict)
|
389
394
|
return ans
|
390
395
|
|
396
|
+
|
391
397
|
def doctest_globals():
|
392
398
|
import snappy
|
393
|
-
return {'Manifold':snappy.Manifold}
|
399
|
+
return {'Manifold': snappy.Manifold}
|
400
|
+
|
394
401
|
|
395
402
|
if __name__ == '__main__':
|
396
|
-
|
397
|
-
|
398
|
-
|
399
|
-
|
403
|
+
from snappy.sage_helper import doctest_modules
|
404
|
+
import sys
|
405
|
+
current_module = sys.modules[__name__]
|
406
|
+
doctest_modules([current_module], extraglobs=doctest_globals())
|
@@ -60,9 +60,22 @@ def rational_univariate_representation(ideal):
|
|
60
60
|
|
61
61
|
"""
|
62
62
|
R = ideal.ring()
|
63
|
-
|
63
|
+
|
64
|
+
# A "feature" introduced in Sage-9.4 is that
|
65
|
+
# ideal.gens() vs R.gens()
|
66
|
+
# returns
|
67
|
+
# a <class 'sage.rings.polynomial.multi_polynomial_sequence.PolynomialSequence_generic’>
|
68
|
+
# vs a
|
69
|
+
# <class 'sage.rings.polynomial.multi_polynomial_libsingular.MPolynomial_libsingular’>
|
70
|
+
# so that giac(_) turns the variable x into x vs sageVARx.
|
71
|
+
#
|
72
|
+
# And giving "gbasis([x],[sageVARx],rur)" instead of "gbasis([x],[x],rur)" doesn't
|
73
|
+
# produce the desired result...
|
74
|
+
#
|
75
|
+
# Thus, we have the following work-around:
|
76
|
+
good_vars = R.ideal(R.gens()).gens()
|
64
77
|
J = giac(ideal.gens())
|
65
|
-
rur = J.gbasis(
|
78
|
+
rur = J.gbasis(good_vars, 'rur')
|
66
79
|
# Yikes: giacpy_sage vs the giac interface give different types.
|
67
80
|
# So using repr.
|
68
81
|
if repr(rur[0]) != 'rur':
|
@@ -97,18 +110,20 @@ def rational_univariate_representation(ideal):
|
|
97
110
|
|
98
111
|
denom = toK(rur[3])
|
99
112
|
rep = [toK(f)/denom for f in rur[4:]]
|
100
|
-
sub_dict = dict(zip(
|
113
|
+
sub_dict = dict(zip(R.gens(), rep))
|
101
114
|
assert all(g.subs(sub_dict) == 0 for g in ideal.gens())
|
102
115
|
ans.append((K, sub_dict, e))
|
103
116
|
|
104
117
|
return ans
|
105
118
|
|
119
|
+
|
106
120
|
def doctest_globals():
|
107
121
|
import snappy
|
108
|
-
return {'Manifold':snappy.Manifold}
|
122
|
+
return {'Manifold': snappy.Manifold}
|
123
|
+
|
109
124
|
|
110
125
|
if __name__ == '__main__':
|
111
|
-
|
112
|
-
|
113
|
-
|
114
|
-
|
126
|
+
from snappy.sage_helper import doctest_modules
|
127
|
+
import sys
|
128
|
+
current_module = sys.modules[__name__]
|
129
|
+
doctest_modules([current_module], extraglobs=doctest_globals())
|
@@ -41,9 +41,9 @@ def restore_forbidden(var_str):
|
|
41
41
|
def ideal_to_file(ideal, filename):
|
42
42
|
outfile = open(filename, 'w')
|
43
43
|
polys = ideal.gens()
|
44
|
-
outfile.write('%d\n' % len(polys))
|
44
|
+
outfile.write(r'%d\n' % len(polys))
|
45
45
|
for p in polys:
|
46
|
-
outfile.write(' ' + remove_forbidden(repr(p)) + ';\n')
|
46
|
+
outfile.write(' ' + remove_forbidden(repr(p)) + r';\n')
|
47
47
|
outfile.close()
|
48
48
|
|
49
49
|
def parse_file(filename, prec=53):
|
@@ -55,14 +55,14 @@ def parse_file(filename, prec=53):
|
|
55
55
|
data = data.split('THE SOLUTIONS')[-1]
|
56
56
|
data = re.subn('[*]{3,}', '', data)[0]
|
57
57
|
ans = []
|
58
|
-
solutions = re.findall('(solution \d+ : \s* start residual .*?) ==', data, re.DOTALL)
|
58
|
+
solutions = re.findall(r'(solution \d+ : \s* start residual .*?) ==', data, re.DOTALL)
|
59
59
|
for sol in solutions:
|
60
60
|
kind = sol.split('=')[-1].strip()
|
61
61
|
if kind == 'no solution':
|
62
62
|
continue
|
63
|
-
mult = int(re.search('^m : (\d+)', sol, re.MULTILINE).group(1))
|
64
|
-
err = float(re.search('== err :\s+(.*?)\s+= ', sol).group(1))
|
65
|
-
coors = re.findall('^ (.*) :\s+(\S*)\s+(\S*)', sol, re.MULTILINE)
|
63
|
+
mult = int(re.search(r'^m : (\d+)', sol, re.MULTILINE).group(1))
|
64
|
+
err = float(re.search(r'== err :\s+(.*?)\s+= ', sol).group(1))
|
65
|
+
coors = re.findall(r'^ (.*) :\s+(\S*)\s+(\S*)', sol, re.MULTILINE)
|
66
66
|
if kind.startswith('real'):
|
67
67
|
coors = {restore_forbidden(var):RR(real) for var, real, imag in coors}
|
68
68
|
ans.append({'kind':'real', 'mult':mult, 'err':err, 'coors':coors})
|
@@ -70,8 +70,8 @@ def parse_file(filename, prec=53):
|
|
70
70
|
coors = {restore_forbidden(var):CC(RR(real), RR(imag)) for var, real, imag in coors}
|
71
71
|
ans.append({'kind':'complex', 'mult':mult, 'err':err, 'coors':coors})
|
72
72
|
|
73
|
-
num_real = int(re.search('Number of real solutions\s+:\s(.*).', data).group(1))
|
74
|
-
num_complex = int(re.search('Number of complex solutions\s+:\s(.*).', data).group(1))
|
73
|
+
num_real = int(re.search(r'Number of real solutions\s+:\s(.*).', data).group(1))
|
74
|
+
num_complex = int(re.search(r'Number of complex solutions\s+:\s(.*).', data).group(1))
|
75
75
|
kinds = [sol['kind'] for sol in ans]
|
76
76
|
assert kinds.count('real') == num_real
|
77
77
|
assert kinds.count('complex') == num_complex
|
@@ -185,9 +185,9 @@ def direct_hack(backend, ideal, **kwargs):
|
|
185
185
|
polys = [repr(eqn) for eqn in ideal.gens()]
|
186
186
|
|
187
187
|
data = {'backend':backend, 'vars':vars, 'polys':polys, 'kwargs':kwargs}
|
188
|
-
problem_data = json.dumps(data).encode('base64').replace('\n', '')
|
188
|
+
problem_data = json.dumps(data).encode('base64').replace(r'\n', '')
|
189
189
|
ans_data = os.popen('sage -python ' + __file__ + ' ' + problem_data).read()
|
190
|
-
ans_data = re.sub('PHCv.*? released .*? works!\n', '', ans_data)
|
190
|
+
ans_data = re.sub(r'PHCv.*? released .*? works!\n', '', ans_data)
|
191
191
|
if len(ans_data):
|
192
192
|
ans = json.loads(ans_data)
|
193
193
|
for sol in ans:
|
@@ -46,7 +46,7 @@ class GimbalLoopFinder:
|
|
46
46
|
edge_index_and_end = (
|
47
47
|
self.truncated_complex.get_edge_index_and_end_from_tet_and_perm(
|
48
48
|
edge.tet_and_perm))
|
49
|
-
if not
|
49
|
+
if edge_index_and_end not in self.uncovered_edge_ends:
|
50
50
|
return position
|
51
51
|
|
52
52
|
self.uncovered_edge_ends.remove(edge_index_and_end)
|
@@ -114,10 +114,11 @@ class GimbalLoopFinder:
|
|
114
114
|
def __repr__(self):
|
115
115
|
return repr(self.edges)
|
116
116
|
|
117
|
+
|
117
118
|
def _group_loop(loop):
|
118
|
-
indices = [
|
119
|
-
|
120
|
-
if not
|
119
|
+
indices = [i for i, edge in enumerate(loop)
|
120
|
+
if edge.subcomplex_type == 'edgeLoop'] + [len(loop)]
|
121
|
+
if 0 not in indices:
|
121
122
|
raise Exception("Missing edgeLoop")
|
122
123
|
result = [
|
123
124
|
[loop[indices[i]], loop[indices[i]+1:indices[i+1]]]
|
@@ -127,4 +128,3 @@ def _group_loop(loop):
|
|
127
128
|
raise Exception("Error in _group_loop")
|
128
129
|
|
129
130
|
return result
|
130
|
-
|
@@ -281,9 +281,9 @@ def _find_rows_and_columns_for_full_rank_submatrix(m, expected_rank):
|
|
281
281
|
for c in cols_left:
|
282
282
|
m.add_multiple_of_column(c, col, -m[row, c ] / m[row, col])
|
283
283
|
|
284
|
-
return (
|
285
|
-
|
286
|
-
|
284
|
+
return ([row for row in range(num_rows) if row not in rows_left],
|
285
|
+
[col for col in range(num_cols) if col not in cols_left])
|
286
|
+
|
287
287
|
|
288
288
|
def _cofactor_matrices_for_submatrices(m):
|
289
289
|
def cofactor_matrix(r, c):
|
@@ -5,7 +5,7 @@ from truncatedComplex import *
|
|
5
5
|
class OneVertexTruncatedComplex(TruncatedComplex):
|
6
6
|
|
7
7
|
def __init__(self, hyperbolic_structure):
|
8
|
-
super(
|
8
|
+
super().__init__(
|
9
9
|
hyperbolic_structure.mcomplex)
|
10
10
|
|
11
11
|
self.hyperbolic_structure = hyperbolic_structure
|
@@ -50,7 +50,7 @@ class OneVertexTruncatedComplex(TruncatedComplex):
|
|
50
50
|
|
51
51
|
key = self.get_key(tet_and_perm_of_end)
|
52
52
|
|
53
|
-
if not
|
53
|
+
if key not in self.tet_and_perm_to_edge:
|
54
54
|
self.tet_and_perm_to_edge[key] = edge
|
55
55
|
pending.append(tet_and_perm_of_end)
|
56
56
|
|
@@ -2,9 +2,10 @@ from snappy.snap import t3mlite as t3m
|
|
2
2
|
|
3
3
|
__all__ = ['TruncatedComplex']
|
4
4
|
|
5
|
-
class TruncatedComplex(object):
|
6
5
|
|
7
|
-
|
6
|
+
class TruncatedComplex():
|
7
|
+
|
8
|
+
class SubcomplexBase():
|
8
9
|
def __init__(self, subcomplex_type, tet_and_perm):
|
9
10
|
self.subcomplex_type = subcomplex_type
|
10
11
|
self.tet_and_perm = tet_and_perm
|
@@ -7,6 +7,7 @@ from sage.all import matrix, prod, RealDoubleField, pi
|
|
7
7
|
|
8
8
|
__all__ = [ 'VerifyHyperbolicStructureEngine']
|
9
9
|
|
10
|
+
|
10
11
|
class VerifyHyperbolicStructureEngine:
|
11
12
|
def __init__(self, hyperbolic_structure):
|
12
13
|
self.hyperbolic_structure = hyperbolic_structure
|
@@ -21,8 +22,8 @@ class VerifyHyperbolicStructureEngine:
|
|
21
22
|
num_edges = len(self.mcomplex.Edges)
|
22
23
|
exact_edges = set(hyperbolic_structure.exact_edges)
|
23
24
|
|
24
|
-
self.approx_edges = [
|
25
|
-
|
25
|
+
self.approx_edges = [i for i in range(num_edges)
|
26
|
+
if i not in exact_edges]
|
26
27
|
|
27
28
|
self.truncated_complex = TruncatedComplex(self.mcomplex)
|
28
29
|
|
@@ -74,7 +75,7 @@ class VerifyHyperbolicStructureEngine:
|
|
74
75
|
two_pi = RIF(2 * pi)
|
75
76
|
|
76
77
|
for angle in self.hyperbolic_structure.angle_sums:
|
77
|
-
if not
|
78
|
+
if two_pi not in angle:
|
78
79
|
raise AngleSumIntervalNotContainingTwoPiError()
|
79
80
|
|
80
81
|
def assert_vertex_gram_matrices_valid(self):
|
Binary file
|
Binary file
|
Binary file
|
Binary file
|
Binary file
|
@@ -20,7 +20,10 @@ Additional contributions:
|
|
20
20
|
|
21
21
|
* Robert Lipschitz and Jennet Dickinson, improvements to Spherogram.
|
22
22
|
|
23
|
-
* Malik Obeidin, improvements to Spherogram and the manifold
|
23
|
+
* Malik Obeidin, improvements to Spherogram and the manifold
|
24
|
+
databases.
|
25
|
+
|
26
|
+
* Malik Obeidin and Cameron Rudd, exterior to link diagram code.
|
24
27
|
|
25
28
|
* Jose Sanchez, 3D printing code.
|
26
29
|
|
@@ -36,6 +39,8 @@ Additional contributions:
|
|
36
39
|
* `QD quad-double library
|
37
40
|
<http://crd-legacy.lbl.gov/~dhbailey/mpdist/>`_.
|
38
41
|
|
42
|
+
* Frédéric Chapoton, code cleanup and linting.
|
43
|
+
|
39
44
|
* Others, please let Marc or Nathan know if we've forgotten you.
|
40
45
|
|
41
46
|
Citing SnapPy
|