snappy 3.2__cp313-cp313-macosx_11_0_arm64.whl

Sign up to get free protection for your applications and to get access to all the features.
Files changed (503) hide show
  1. snappy/CyOpenGL.cpython-313-darwin.so +0 -0
  2. snappy/SnapPy.cpython-313-darwin.so +0 -0
  3. snappy/SnapPy.ico +0 -0
  4. snappy/SnapPy.png +0 -0
  5. snappy/SnapPyHP.cpython-313-darwin.so +0 -0
  6. snappy/__init__.py +760 -0
  7. snappy/app.py +605 -0
  8. snappy/app_menus.py +372 -0
  9. snappy/browser.py +998 -0
  10. snappy/cache.py +25 -0
  11. snappy/canonical.py +249 -0
  12. snappy/cusps/__init__.py +38 -0
  13. snappy/cusps/cusp_area_matrix.py +101 -0
  14. snappy/cusps/cusp_areas_from_matrix.py +173 -0
  15. snappy/cusps/maximal_cusp_area_matrix.py +136 -0
  16. snappy/cusps/test.py +21 -0
  17. snappy/cusps/trig_cusp_area_matrix.py +63 -0
  18. snappy/database.py +454 -0
  19. snappy/db_utilities.py +79 -0
  20. snappy/decorated_isosig.py +710 -0
  21. snappy/dev/__init__.py +0 -0
  22. snappy/dev/extended_ptolemy/__init__.py +8 -0
  23. snappy/dev/extended_ptolemy/closed.py +106 -0
  24. snappy/dev/extended_ptolemy/complexVolumesClosed.py +149 -0
  25. snappy/dev/extended_ptolemy/direct.py +42 -0
  26. snappy/dev/extended_ptolemy/extended.py +406 -0
  27. snappy/dev/extended_ptolemy/giac_helper.py +43 -0
  28. snappy/dev/extended_ptolemy/giac_rur.py +129 -0
  29. snappy/dev/extended_ptolemy/gluing.py +46 -0
  30. snappy/dev/extended_ptolemy/phc_wrapper.py +220 -0
  31. snappy/dev/extended_ptolemy/printMatrices.py +70 -0
  32. snappy/dev/vericlosed/__init__.py +1 -0
  33. snappy/dev/vericlosed/computeApproxHyperbolicStructureNew.py +159 -0
  34. snappy/dev/vericlosed/computeApproxHyperbolicStructureOrb.py +90 -0
  35. snappy/dev/vericlosed/computeVerifiedHyperbolicStructure.py +111 -0
  36. snappy/dev/vericlosed/gimbalLoopFinder.py +130 -0
  37. snappy/dev/vericlosed/hyperbolicStructure.py +313 -0
  38. snappy/dev/vericlosed/krawczykCertifiedEdgeLengthsEngine.py +165 -0
  39. snappy/dev/vericlosed/oneVertexTruncatedComplex.py +122 -0
  40. snappy/dev/vericlosed/orb/__init__.py +1 -0
  41. snappy/dev/vericlosed/orb/orb_solution_for_snappea_finite_triangulation_mac +0 -0
  42. snappy/dev/vericlosed/parseVertexGramMatrixFile.py +47 -0
  43. snappy/dev/vericlosed/polishApproxHyperbolicStructure.py +61 -0
  44. snappy/dev/vericlosed/test.py +54 -0
  45. snappy/dev/vericlosed/truncatedComplex.py +176 -0
  46. snappy/dev/vericlosed/verificationError.py +58 -0
  47. snappy/dev/vericlosed/verifyHyperbolicStructureEngine.py +177 -0
  48. snappy/doc/_images/SnapPy-196.png +0 -0
  49. snappy/doc/_images/geodesics.jpg +0 -0
  50. snappy/doc/_images/m004_paper_plane_on_systole.jpg +0 -0
  51. snappy/doc/_images/m125_paper_plane.jpg +0 -0
  52. snappy/doc/_images/mac.png +0 -0
  53. snappy/doc/_images/o9_00000_systole_paper_plane.jpg +0 -0
  54. snappy/doc/_images/o9_00000_systole_paper_plane_closer.jpg +0 -0
  55. snappy/doc/_images/plink-action.png +0 -0
  56. snappy/doc/_images/ubuntu.png +0 -0
  57. snappy/doc/_images/win7.png +0 -0
  58. snappy/doc/_sources/additional_classes.rst.txt +40 -0
  59. snappy/doc/_sources/bugs.rst.txt +14 -0
  60. snappy/doc/_sources/censuses.rst.txt +51 -0
  61. snappy/doc/_sources/credits.rst.txt +75 -0
  62. snappy/doc/_sources/development.rst.txt +259 -0
  63. snappy/doc/_sources/index.rst.txt +182 -0
  64. snappy/doc/_sources/installing.rst.txt +247 -0
  65. snappy/doc/_sources/manifold.rst.txt +6 -0
  66. snappy/doc/_sources/manifoldhp.rst.txt +46 -0
  67. snappy/doc/_sources/news.rst.txt +355 -0
  68. snappy/doc/_sources/other.rst.txt +25 -0
  69. snappy/doc/_sources/platonic_census.rst.txt +20 -0
  70. snappy/doc/_sources/plink.rst.txt +102 -0
  71. snappy/doc/_sources/ptolemy.rst.txt +66 -0
  72. snappy/doc/_sources/ptolemy_classes.rst.txt +42 -0
  73. snappy/doc/_sources/ptolemy_examples1.rst.txt +298 -0
  74. snappy/doc/_sources/ptolemy_examples2.rst.txt +363 -0
  75. snappy/doc/_sources/ptolemy_examples3.rst.txt +301 -0
  76. snappy/doc/_sources/ptolemy_examples4.rst.txt +61 -0
  77. snappy/doc/_sources/ptolemy_prelim.rst.txt +105 -0
  78. snappy/doc/_sources/screenshots.rst.txt +21 -0
  79. snappy/doc/_sources/snap.rst.txt +87 -0
  80. snappy/doc/_sources/snappy.rst.txt +28 -0
  81. snappy/doc/_sources/spherogram.rst.txt +103 -0
  82. snappy/doc/_sources/todo.rst.txt +47 -0
  83. snappy/doc/_sources/triangulation.rst.txt +11 -0
  84. snappy/doc/_sources/tutorial.rst.txt +49 -0
  85. snappy/doc/_sources/verify.rst.txt +210 -0
  86. snappy/doc/_sources/verify_internals.rst.txt +79 -0
  87. snappy/doc/_static/SnapPy-horizontal-128.png +0 -0
  88. snappy/doc/_static/SnapPy.ico +0 -0
  89. snappy/doc/_static/_sphinx_javascript_frameworks_compat.js +123 -0
  90. snappy/doc/_static/basic.css +925 -0
  91. snappy/doc/_static/css/badge_only.css +1 -0
  92. snappy/doc/_static/css/fonts/Roboto-Slab-Bold.woff +0 -0
  93. snappy/doc/_static/css/fonts/Roboto-Slab-Bold.woff2 +0 -0
  94. snappy/doc/_static/css/fonts/Roboto-Slab-Regular.woff +0 -0
  95. snappy/doc/_static/css/fonts/Roboto-Slab-Regular.woff2 +0 -0
  96. snappy/doc/_static/css/fonts/fontawesome-webfont.eot +0 -0
  97. snappy/doc/_static/css/fonts/fontawesome-webfont.svg +2671 -0
  98. snappy/doc/_static/css/fonts/fontawesome-webfont.ttf +0 -0
  99. snappy/doc/_static/css/fonts/fontawesome-webfont.woff +0 -0
  100. snappy/doc/_static/css/fonts/fontawesome-webfont.woff2 +0 -0
  101. snappy/doc/_static/css/fonts/lato-bold-italic.woff +0 -0
  102. snappy/doc/_static/css/fonts/lato-bold-italic.woff2 +0 -0
  103. snappy/doc/_static/css/fonts/lato-bold.woff +0 -0
  104. snappy/doc/_static/css/fonts/lato-bold.woff2 +0 -0
  105. snappy/doc/_static/css/fonts/lato-normal-italic.woff +0 -0
  106. snappy/doc/_static/css/fonts/lato-normal-italic.woff2 +0 -0
  107. snappy/doc/_static/css/fonts/lato-normal.woff +0 -0
  108. snappy/doc/_static/css/fonts/lato-normal.woff2 +0 -0
  109. snappy/doc/_static/css/theme.css +4 -0
  110. snappy/doc/_static/doctools.js +156 -0
  111. snappy/doc/_static/documentation_options.js +13 -0
  112. snappy/doc/_static/file.png +0 -0
  113. snappy/doc/_static/fonts/Lato/lato-bold.eot +0 -0
  114. snappy/doc/_static/fonts/Lato/lato-bold.ttf +0 -0
  115. snappy/doc/_static/fonts/Lato/lato-bold.woff +0 -0
  116. snappy/doc/_static/fonts/Lato/lato-bold.woff2 +0 -0
  117. snappy/doc/_static/fonts/Lato/lato-bolditalic.eot +0 -0
  118. snappy/doc/_static/fonts/Lato/lato-bolditalic.ttf +0 -0
  119. snappy/doc/_static/fonts/Lato/lato-bolditalic.woff +0 -0
  120. snappy/doc/_static/fonts/Lato/lato-bolditalic.woff2 +0 -0
  121. snappy/doc/_static/fonts/Lato/lato-italic.eot +0 -0
  122. snappy/doc/_static/fonts/Lato/lato-italic.ttf +0 -0
  123. snappy/doc/_static/fonts/Lato/lato-italic.woff +0 -0
  124. snappy/doc/_static/fonts/Lato/lato-italic.woff2 +0 -0
  125. snappy/doc/_static/fonts/Lato/lato-regular.eot +0 -0
  126. snappy/doc/_static/fonts/Lato/lato-regular.ttf +0 -0
  127. snappy/doc/_static/fonts/Lato/lato-regular.woff +0 -0
  128. snappy/doc/_static/fonts/Lato/lato-regular.woff2 +0 -0
  129. snappy/doc/_static/fonts/RobotoSlab/roboto-slab-v7-bold.eot +0 -0
  130. snappy/doc/_static/fonts/RobotoSlab/roboto-slab-v7-bold.ttf +0 -0
  131. snappy/doc/_static/fonts/RobotoSlab/roboto-slab-v7-bold.woff +0 -0
  132. snappy/doc/_static/fonts/RobotoSlab/roboto-slab-v7-bold.woff2 +0 -0
  133. snappy/doc/_static/fonts/RobotoSlab/roboto-slab-v7-regular.eot +0 -0
  134. snappy/doc/_static/fonts/RobotoSlab/roboto-slab-v7-regular.ttf +0 -0
  135. snappy/doc/_static/fonts/RobotoSlab/roboto-slab-v7-regular.woff +0 -0
  136. snappy/doc/_static/fonts/RobotoSlab/roboto-slab-v7-regular.woff2 +0 -0
  137. snappy/doc/_static/jquery.js +2 -0
  138. snappy/doc/_static/js/badge_only.js +1 -0
  139. snappy/doc/_static/js/theme.js +1 -0
  140. snappy/doc/_static/js/versions.js +228 -0
  141. snappy/doc/_static/language_data.js +199 -0
  142. snappy/doc/_static/minus.png +0 -0
  143. snappy/doc/_static/plus.png +0 -0
  144. snappy/doc/_static/pygments.css +75 -0
  145. snappy/doc/_static/searchtools.js +620 -0
  146. snappy/doc/_static/snappy_furo.css +33 -0
  147. snappy/doc/_static/snappy_sphinx_rtd_theme.css +42 -0
  148. snappy/doc/_static/sphinx_highlight.js +154 -0
  149. snappy/doc/additional_classes.html +1500 -0
  150. snappy/doc/bugs.html +132 -0
  151. snappy/doc/censuses.html +427 -0
  152. snappy/doc/credits.html +181 -0
  153. snappy/doc/development.html +384 -0
  154. snappy/doc/genindex.html +1331 -0
  155. snappy/doc/index.html +262 -0
  156. snappy/doc/installing.html +346 -0
  157. snappy/doc/manifold.html +3452 -0
  158. snappy/doc/manifoldhp.html +180 -0
  159. snappy/doc/news.html +388 -0
  160. snappy/doc/objects.inv +0 -0
  161. snappy/doc/other.html +161 -0
  162. snappy/doc/platonic_census.html +375 -0
  163. snappy/doc/plink.html +210 -0
  164. snappy/doc/ptolemy.html +254 -0
  165. snappy/doc/ptolemy_classes.html +1144 -0
  166. snappy/doc/ptolemy_examples1.html +409 -0
  167. snappy/doc/ptolemy_examples2.html +471 -0
  168. snappy/doc/ptolemy_examples3.html +414 -0
  169. snappy/doc/ptolemy_examples4.html +195 -0
  170. snappy/doc/ptolemy_prelim.html +248 -0
  171. snappy/doc/py-modindex.html +165 -0
  172. snappy/doc/screenshots.html +141 -0
  173. snappy/doc/search.html +135 -0
  174. snappy/doc/searchindex.js +1 -0
  175. snappy/doc/snap.html +202 -0
  176. snappy/doc/snappy.html +181 -0
  177. snappy/doc/spherogram.html +1211 -0
  178. snappy/doc/todo.html +166 -0
  179. snappy/doc/triangulation.html +1584 -0
  180. snappy/doc/tutorial.html +159 -0
  181. snappy/doc/verify.html +330 -0
  182. snappy/doc/verify_internals.html +1235 -0
  183. snappy/drilling/__init__.py +456 -0
  184. snappy/drilling/barycentric.py +103 -0
  185. snappy/drilling/constants.py +5 -0
  186. snappy/drilling/crush.py +270 -0
  187. snappy/drilling/cusps.py +125 -0
  188. snappy/drilling/debug.py +242 -0
  189. snappy/drilling/epsilons.py +6 -0
  190. snappy/drilling/exceptions.py +55 -0
  191. snappy/drilling/moves.py +620 -0
  192. snappy/drilling/peripheral_curves.py +210 -0
  193. snappy/drilling/perturb.py +188 -0
  194. snappy/drilling/shorten.py +36 -0
  195. snappy/drilling/subdivide.py +274 -0
  196. snappy/drilling/test.py +23 -0
  197. snappy/drilling/test_cases.py +126 -0
  198. snappy/drilling/tracing.py +351 -0
  199. snappy/exceptions.py +26 -0
  200. snappy/export_stl.py +120 -0
  201. snappy/exterior_to_link/__init__.py +2 -0
  202. snappy/exterior_to_link/barycentric_geometry.py +463 -0
  203. snappy/exterior_to_link/exceptions.py +6 -0
  204. snappy/exterior_to_link/geodesic_map.json +14408 -0
  205. snappy/exterior_to_link/hyp_utils.py +112 -0
  206. snappy/exterior_to_link/link_projection.py +323 -0
  207. snappy/exterior_to_link/main.py +197 -0
  208. snappy/exterior_to_link/mcomplex_with_expansion.py +261 -0
  209. snappy/exterior_to_link/mcomplex_with_link.py +687 -0
  210. snappy/exterior_to_link/mcomplex_with_memory.py +162 -0
  211. snappy/exterior_to_link/pl_utils.py +491 -0
  212. snappy/exterior_to_link/put_in_S3.py +156 -0
  213. snappy/exterior_to_link/rational_linear_algebra.py +123 -0
  214. snappy/exterior_to_link/rational_linear_algebra_wrapped.py +135 -0
  215. snappy/exterior_to_link/simplify_to_base_tri.py +114 -0
  216. snappy/exterior_to_link/stored_moves.py +475 -0
  217. snappy/exterior_to_link/test.py +31 -0
  218. snappy/filedialog.py +28 -0
  219. snappy/geometric_structure/__init__.py +212 -0
  220. snappy/geometric_structure/cusp_neighborhood/__init__.py +3 -0
  221. snappy/geometric_structure/cusp_neighborhood/complex_cusp_cross_section.py +697 -0
  222. snappy/geometric_structure/cusp_neighborhood/cusp_cross_section_base.py +484 -0
  223. snappy/geometric_structure/cusp_neighborhood/exceptions.py +42 -0
  224. snappy/geometric_structure/cusp_neighborhood/real_cusp_cross_section.py +298 -0
  225. snappy/geometric_structure/cusp_neighborhood/tiles_for_cusp_neighborhood.py +159 -0
  226. snappy/geometric_structure/cusp_neighborhood/vertices.py +32 -0
  227. snappy/geometric_structure/geodesic/__init__.py +0 -0
  228. snappy/geometric_structure/geodesic/add_core_curves.py +152 -0
  229. snappy/geometric_structure/geodesic/avoid_core_curves.py +369 -0
  230. snappy/geometric_structure/geodesic/canonical_keys.py +52 -0
  231. snappy/geometric_structure/geodesic/check_away_from_core_curve.py +60 -0
  232. snappy/geometric_structure/geodesic/constants.py +6 -0
  233. snappy/geometric_structure/geodesic/exceptions.py +22 -0
  234. snappy/geometric_structure/geodesic/fixed_points.py +93 -0
  235. snappy/geometric_structure/geodesic/geodesic_start_point_info.py +435 -0
  236. snappy/geometric_structure/geodesic/graph_trace_helper.py +67 -0
  237. snappy/geometric_structure/geodesic/line.py +30 -0
  238. snappy/geometric_structure/geodesic/multiplicity.py +127 -0
  239. snappy/geometric_structure/geodesic/tiles_for_geodesic.py +101 -0
  240. snappy/geometric_structure/test.py +22 -0
  241. snappy/gui.py +121 -0
  242. snappy/horoviewer.py +443 -0
  243. snappy/hyperboloid/__init__.py +212 -0
  244. snappy/hyperboloid/distances.py +245 -0
  245. snappy/hyperboloid/horoball.py +19 -0
  246. snappy/hyperboloid/line.py +35 -0
  247. snappy/hyperboloid/point.py +9 -0
  248. snappy/hyperboloid/triangle.py +29 -0
  249. snappy/info_icon.gif +0 -0
  250. snappy/infowindow.py +65 -0
  251. snappy/isometry_signature.py +382 -0
  252. snappy/len_spec/__init__.py +596 -0
  253. snappy/len_spec/geodesic_info.py +110 -0
  254. snappy/len_spec/geodesic_key_info_dict.py +117 -0
  255. snappy/len_spec/geodesic_piece.py +143 -0
  256. snappy/len_spec/geometric_structure.py +182 -0
  257. snappy/len_spec/geometry.py +80 -0
  258. snappy/len_spec/length_spectrum_geodesic_info.py +170 -0
  259. snappy/len_spec/spine.py +206 -0
  260. snappy/len_spec/test.py +24 -0
  261. snappy/len_spec/test_cases.py +69 -0
  262. snappy/len_spec/tile.py +275 -0
  263. snappy/len_spec/word.py +86 -0
  264. snappy/manifolds/HTWKnots/alternating.gz +0 -0
  265. snappy/manifolds/HTWKnots/nonalternating.gz +0 -0
  266. snappy/manifolds/__init__.py +3 -0
  267. snappy/math_basics.py +176 -0
  268. snappy/matrix.py +525 -0
  269. snappy/number.py +657 -0
  270. snappy/numeric_output_checker.py +345 -0
  271. snappy/pari.py +41 -0
  272. snappy/phone_home.py +57 -0
  273. snappy/polyviewer.py +259 -0
  274. snappy/ptolemy/__init__.py +17 -0
  275. snappy/ptolemy/component.py +103 -0
  276. snappy/ptolemy/coordinates.py +2290 -0
  277. snappy/ptolemy/fieldExtensions.py +153 -0
  278. snappy/ptolemy/findLoops.py +473 -0
  279. snappy/ptolemy/geometricRep.py +59 -0
  280. snappy/ptolemy/homology.py +165 -0
  281. snappy/ptolemy/magma/default.magma_template +229 -0
  282. snappy/ptolemy/magma/radicalsOfPrimaryDecomposition.magma_template +79 -0
  283. snappy/ptolemy/manifoldMethods.py +395 -0
  284. snappy/ptolemy/matrix.py +350 -0
  285. snappy/ptolemy/numericalSolutionsToGroebnerBasis.py +113 -0
  286. snappy/ptolemy/polynomial.py +857 -0
  287. snappy/ptolemy/processComponents.py +173 -0
  288. snappy/ptolemy/processFileBase.py +247 -0
  289. snappy/ptolemy/processFileDispatch.py +46 -0
  290. snappy/ptolemy/processMagmaFile.py +392 -0
  291. snappy/ptolemy/processRurFile.py +150 -0
  292. snappy/ptolemy/ptolemyGeneralizedObstructionClass.py +102 -0
  293. snappy/ptolemy/ptolemyObstructionClass.py +64 -0
  294. snappy/ptolemy/ptolemyVariety.py +1029 -0
  295. snappy/ptolemy/ptolemyVarietyPrimeIdealGroebnerBasis.py +140 -0
  296. snappy/ptolemy/reginaWrapper.py +698 -0
  297. snappy/ptolemy/regina_testing_files/DT_mcbbiceaibjklmdfgh__sl2_c0.magma_out.bz2 +0 -0
  298. snappy/ptolemy/regina_testing_files/DT_mcbbiceaibjklmdfgh__sl2_c1.magma_out.bz2 +0 -0
  299. snappy/ptolemy/regina_testing_files/DT_mcbbiceaibjklmdfgh__sl2_c2.magma_out.bz2 +0 -0
  300. snappy/ptolemy/regina_testing_files/DT_mcbbiceaibjklmdfgh__sl2_c3.magma_out.bz2 +0 -0
  301. snappy/ptolemy/regina_testing_files/DT_mcbbiceaibjklmdfgh__sl2_c4.magma_out.bz2 +0 -0
  302. snappy/ptolemy/regina_testing_files/DT_mcbbiceaibjklmdfgh__sl2_c5.magma_out.bz2 +0 -0
  303. snappy/ptolemy/regina_testing_files/DT_mcbbiceaibjklmdfgh__sl2_c6.magma_out.bz2 +0 -0
  304. snappy/ptolemy/regina_testing_files/DT_mcbbiceaibjklmdfgh__sl2_c7.magma_out.bz2 +0 -0
  305. snappy/ptolemy/regina_testing_files_generalized/m003__sl3_c0.magma_out.bz2 +0 -0
  306. snappy/ptolemy/regina_testing_files_generalized/m003__sl3_c1.magma_out.bz2 +0 -0
  307. snappy/ptolemy/regina_testing_files_generalized/m015__sl2_c0.magma_out.bz2 +0 -0
  308. snappy/ptolemy/regina_testing_files_generalized/m015__sl2_c1.magma_out.bz2 +0 -0
  309. snappy/ptolemy/regina_testing_files_generalized/m015__sl3_c0.magma_out.bz2 +0 -0
  310. snappy/ptolemy/regina_testing_files_generalized/m015__sl3_c1.magma_out.bz2 +0 -0
  311. snappy/ptolemy/rur.py +545 -0
  312. snappy/ptolemy/solutionsToPrimeIdealGroebnerBasis.py +277 -0
  313. snappy/ptolemy/test.py +1126 -0
  314. snappy/ptolemy/testing_files/3_1__sl2_c0.magma_out.bz2 +0 -0
  315. snappy/ptolemy/testing_files/3_1__sl2_c1.magma_out.bz2 +0 -0
  316. snappy/ptolemy/testing_files/4_1__sl2_c0.magma_out.bz2 +0 -0
  317. snappy/ptolemy/testing_files/4_1__sl2_c1.magma_out.bz2 +0 -0
  318. snappy/ptolemy/testing_files/4_1__sl3_c0.magma_out.bz2 +0 -0
  319. snappy/ptolemy/testing_files/4_1__sl4_c0.magma_out.bz2 +0 -0
  320. snappy/ptolemy/testing_files/4_1__sl4_c1.magma_out.bz2 +0 -0
  321. snappy/ptolemy/testing_files/5_2__sl2_c0.magma_out.bz2 +0 -0
  322. snappy/ptolemy/testing_files/5_2__sl2_c1.magma_out.bz2 +0 -0
  323. snappy/ptolemy/testing_files/DT_mcbbiceaibjklmdfgh__sl2_c0.magma_out.bz2 +0 -0
  324. snappy/ptolemy/testing_files/DT_mcbbiceaibjklmdfgh__sl2_c1.magma_out.bz2 +0 -0
  325. snappy/ptolemy/testing_files/DT_mcbbiceaibjklmdfgh__sl2_c2.magma_out.bz2 +0 -0
  326. snappy/ptolemy/testing_files/DT_mcbbiceaibjklmdfgh__sl2_c3.magma_out.bz2 +0 -0
  327. snappy/ptolemy/testing_files/DT_mcbbiceaibjklmdfgh__sl2_c4.magma_out.bz2 +0 -0
  328. snappy/ptolemy/testing_files/DT_mcbbiceaibjklmdfgh__sl2_c5.magma_out.bz2 +0 -0
  329. snappy/ptolemy/testing_files/DT_mcbbiceaibjklmdfgh__sl2_c6.magma_out.bz2 +0 -0
  330. snappy/ptolemy/testing_files/DT_mcbbiceaibjklmdfgh__sl2_c7.magma_out.bz2 +0 -0
  331. snappy/ptolemy/testing_files/data/pgl2/OrientableCuspedCensus/03_tetrahedra/m019__sl2_c0.magma_out +95 -0
  332. snappy/ptolemy/testing_files/data/pgl2/OrientableCuspedCensus/03_tetrahedra/m019__sl2_c1.magma_out +95 -0
  333. snappy/ptolemy/testing_files/m015__sl3_c0.magma_out.bz2 +0 -0
  334. snappy/ptolemy/testing_files/m135__sl2_c0.magma_out.bz2 +0 -0
  335. snappy/ptolemy/testing_files/m135__sl2_c1.magma_out.bz2 +0 -0
  336. snappy/ptolemy/testing_files/m135__sl2_c2.magma_out.bz2 +0 -0
  337. snappy/ptolemy/testing_files/m135__sl2_c3.magma_out.bz2 +0 -0
  338. snappy/ptolemy/testing_files/m135__sl2_c4.magma_out.bz2 +0 -0
  339. snappy/ptolemy/testing_files/m135__sl2_c5.magma_out.bz2 +0 -0
  340. snappy/ptolemy/testing_files/m135__sl2_c6.magma_out.bz2 +0 -0
  341. snappy/ptolemy/testing_files/m135__sl2_c7.magma_out.bz2 +0 -0
  342. snappy/ptolemy/testing_files/s000__sl2_c0.magma_out.bz2 +0 -0
  343. snappy/ptolemy/testing_files/s000__sl2_c1.magma_out.bz2 +0 -0
  344. snappy/ptolemy/testing_files/t00000__sl2_c0.magma_out.bz2 +0 -0
  345. snappy/ptolemy/testing_files/t00000__sl2_c1.magma_out.bz2 +0 -0
  346. snappy/ptolemy/testing_files/v0000__sl2_c0.magma_out.bz2 +0 -0
  347. snappy/ptolemy/testing_files/v0000__sl2_c1.magma_out.bz2 +0 -0
  348. snappy/ptolemy/testing_files/v0000__sl2_c2.magma_out.bz2 +0 -0
  349. snappy/ptolemy/testing_files/v0000__sl2_c3.magma_out.bz2 +0 -0
  350. snappy/ptolemy/testing_files_generalized/m003__sl2_c0.magma_out.bz2 +0 -0
  351. snappy/ptolemy/testing_files_generalized/m003__sl2_c1.magma_out.bz2 +0 -0
  352. snappy/ptolemy/testing_files_generalized/m003__sl3_c0.magma_out.bz2 +0 -0
  353. snappy/ptolemy/testing_files_generalized/m003__sl3_c1.magma_out.bz2 +0 -0
  354. snappy/ptolemy/testing_files_generalized/m004__sl2_c0.magma_out.bz2 +0 -0
  355. snappy/ptolemy/testing_files_generalized/m004__sl2_c1.magma_out.bz2 +0 -0
  356. snappy/ptolemy/testing_files_generalized/m015__sl2_c1.magma_out.bz2 +0 -0
  357. snappy/ptolemy/testing_files_generalized/m015__sl3_c0.magma_out.bz2 +0 -0
  358. snappy/ptolemy/testing_files_rur/m052__sl3_c0.rur.bz2 +0 -0
  359. snappy/ptolemy/utilities.py +236 -0
  360. snappy/raytracing/__init__.py +64 -0
  361. snappy/raytracing/additional_horospheres.py +64 -0
  362. snappy/raytracing/additional_len_spec_choices.py +63 -0
  363. snappy/raytracing/cohomology_fractal.py +197 -0
  364. snappy/raytracing/eyeball.py +123 -0
  365. snappy/raytracing/finite_raytracing_data.py +237 -0
  366. snappy/raytracing/finite_viewer.py +590 -0
  367. snappy/raytracing/geodesic_tube_info.py +174 -0
  368. snappy/raytracing/geodesics.py +246 -0
  369. snappy/raytracing/geodesics_window.py +258 -0
  370. snappy/raytracing/gui_utilities.py +293 -0
  371. snappy/raytracing/hyperboloid_navigation.py +556 -0
  372. snappy/raytracing/hyperboloid_utilities.py +234 -0
  373. snappy/raytracing/ideal_raytracing_data.py +592 -0
  374. snappy/raytracing/inside_viewer.py +974 -0
  375. snappy/raytracing/pack.py +22 -0
  376. snappy/raytracing/raytracing_data.py +126 -0
  377. snappy/raytracing/raytracing_view.py +454 -0
  378. snappy/raytracing/shaders/Eye.png +0 -0
  379. snappy/raytracing/shaders/NonGeometric.png +0 -0
  380. snappy/raytracing/shaders/__init__.py +101 -0
  381. snappy/raytracing/shaders/fragment.glsl +1744 -0
  382. snappy/raytracing/test.py +29 -0
  383. snappy/raytracing/tooltip.py +146 -0
  384. snappy/raytracing/upper_halfspace_utilities.py +98 -0
  385. snappy/raytracing/view_scale_controller.py +98 -0
  386. snappy/raytracing/zoom_slider/__init__.py +263 -0
  387. snappy/raytracing/zoom_slider/inward.png +0 -0
  388. snappy/raytracing/zoom_slider/inward18.png +0 -0
  389. snappy/raytracing/zoom_slider/outward.png +0 -0
  390. snappy/raytracing/zoom_slider/outward18.png +0 -0
  391. snappy/raytracing/zoom_slider/test.py +20 -0
  392. snappy/sage_helper.py +117 -0
  393. snappy/settings.py +409 -0
  394. snappy/shell.py +53 -0
  395. snappy/snap/__init__.py +114 -0
  396. snappy/snap/character_varieties.py +375 -0
  397. snappy/snap/find_field.py +372 -0
  398. snappy/snap/fundamental_polyhedron.py +569 -0
  399. snappy/snap/generators.py +39 -0
  400. snappy/snap/interval_reps.py +81 -0
  401. snappy/snap/kernel_structures.py +128 -0
  402. snappy/snap/mcomplex_base.py +18 -0
  403. snappy/snap/nsagetools.py +702 -0
  404. snappy/snap/peripheral/__init__.py +1 -0
  405. snappy/snap/peripheral/dual_cellulation.py +219 -0
  406. snappy/snap/peripheral/link.py +127 -0
  407. snappy/snap/peripheral/peripheral.py +159 -0
  408. snappy/snap/peripheral/surface.py +522 -0
  409. snappy/snap/peripheral/test.py +35 -0
  410. snappy/snap/polished_reps.py +335 -0
  411. snappy/snap/shapes.py +152 -0
  412. snappy/snap/slice_obs_HKL.py +668 -0
  413. snappy/snap/t3mlite/__init__.py +2 -0
  414. snappy/snap/t3mlite/arrow.py +243 -0
  415. snappy/snap/t3mlite/corner.py +22 -0
  416. snappy/snap/t3mlite/edge.py +172 -0
  417. snappy/snap/t3mlite/face.py +37 -0
  418. snappy/snap/t3mlite/files.py +211 -0
  419. snappy/snap/t3mlite/homology.py +53 -0
  420. snappy/snap/t3mlite/linalg.py +419 -0
  421. snappy/snap/t3mlite/mcomplex.py +1499 -0
  422. snappy/snap/t3mlite/perm4.py +320 -0
  423. snappy/snap/t3mlite/setup.py +12 -0
  424. snappy/snap/t3mlite/simplex.py +199 -0
  425. snappy/snap/t3mlite/spun.py +297 -0
  426. snappy/snap/t3mlite/surface.py +519 -0
  427. snappy/snap/t3mlite/test.py +20 -0
  428. snappy/snap/t3mlite/test_vs_regina.py +86 -0
  429. snappy/snap/t3mlite/tetrahedron.py +109 -0
  430. snappy/snap/t3mlite/vertex.py +42 -0
  431. snappy/snap/test.py +134 -0
  432. snappy/snap/utilities.py +288 -0
  433. snappy/test.py +209 -0
  434. snappy/test_cases.py +263 -0
  435. snappy/testing.py +131 -0
  436. snappy/tiling/__init__.py +2 -0
  437. snappy/tiling/canonical_key_dict.py +59 -0
  438. snappy/tiling/dict_based_set.py +79 -0
  439. snappy/tiling/floor.py +49 -0
  440. snappy/tiling/hyperboloid_dict.py +54 -0
  441. snappy/tiling/iter_utils.py +78 -0
  442. snappy/tiling/lifted_tetrahedron.py +22 -0
  443. snappy/tiling/lifted_tetrahedron_set.py +54 -0
  444. snappy/tiling/real_hash_dict.py +164 -0
  445. snappy/tiling/test.py +23 -0
  446. snappy/tiling/tile.py +215 -0
  447. snappy/tiling/triangle.py +33 -0
  448. snappy/tkterminal.py +920 -0
  449. snappy/twister/__init__.py +20 -0
  450. snappy/twister/main.py +646 -0
  451. snappy/twister/surfaces/S_0_1 +3 -0
  452. snappy/twister/surfaces/S_0_2 +3 -0
  453. snappy/twister/surfaces/S_0_4 +7 -0
  454. snappy/twister/surfaces/S_0_4_Lantern +8 -0
  455. snappy/twister/surfaces/S_1 +3 -0
  456. snappy/twister/surfaces/S_1_1 +4 -0
  457. snappy/twister/surfaces/S_1_2 +5 -0
  458. snappy/twister/surfaces/S_1_2_5 +6 -0
  459. snappy/twister/surfaces/S_2 +6 -0
  460. snappy/twister/surfaces/S_2_1 +8 -0
  461. snappy/twister/surfaces/S_2_heeg +10 -0
  462. snappy/twister/surfaces/S_3 +8 -0
  463. snappy/twister/surfaces/S_3_1 +10 -0
  464. snappy/twister/surfaces/S_4_1 +12 -0
  465. snappy/twister/surfaces/S_5_1 +14 -0
  466. snappy/twister/surfaces/heeg_fig8 +9 -0
  467. snappy/twister/twister_core.cpython-313-darwin.so +0 -0
  468. snappy/upper_halfspace/__init__.py +146 -0
  469. snappy/upper_halfspace/ideal_point.py +26 -0
  470. snappy/verify/__init__.py +13 -0
  471. snappy/verify/canonical.py +542 -0
  472. snappy/verify/complex_volume/__init__.py +18 -0
  473. snappy/verify/complex_volume/adjust_torsion.py +86 -0
  474. snappy/verify/complex_volume/closed.py +168 -0
  475. snappy/verify/complex_volume/compute_ptolemys.py +90 -0
  476. snappy/verify/complex_volume/cusped.py +56 -0
  477. snappy/verify/complex_volume/extended_bloch.py +201 -0
  478. snappy/verify/cusp_translations.py +85 -0
  479. snappy/verify/edge_equations.py +80 -0
  480. snappy/verify/exceptions.py +254 -0
  481. snappy/verify/hyperbolicity.py +224 -0
  482. snappy/verify/interval_newton_shapes_engine.py +523 -0
  483. snappy/verify/interval_tree.py +400 -0
  484. snappy/verify/krawczyk_shapes_engine.py +518 -0
  485. snappy/verify/maximal_cusp_area_matrix/__init__.py +46 -0
  486. snappy/verify/maximal_cusp_area_matrix/cusp_tiling_engine.py +419 -0
  487. snappy/verify/maximal_cusp_area_matrix/cusp_translate_engine.py +153 -0
  488. snappy/verify/real_algebra.py +286 -0
  489. snappy/verify/shapes.py +25 -0
  490. snappy/verify/short_slopes.py +200 -0
  491. snappy/verify/square_extensions.py +1005 -0
  492. snappy/verify/test.py +78 -0
  493. snappy/verify/upper_halfspace/__init__.py +9 -0
  494. snappy/verify/upper_halfspace/extended_matrix.py +100 -0
  495. snappy/verify/upper_halfspace/finite_point.py +283 -0
  496. snappy/verify/upper_halfspace/ideal_point.py +426 -0
  497. snappy/verify/volume.py +128 -0
  498. snappy/version.py +2 -0
  499. snappy-3.2.dist-info/METADATA +58 -0
  500. snappy-3.2.dist-info/RECORD +503 -0
  501. snappy-3.2.dist-info/WHEEL +5 -0
  502. snappy-3.2.dist-info/entry_points.txt +2 -0
  503. snappy-3.2.dist-info/top_level.txt +28 -0
@@ -0,0 +1,212 @@
1
+ from ..matrix import make_vector, make_matrix, mat_solve
2
+
3
+ from ..sage_helper import _within_sage
4
+
5
+ """
6
+ hyperboloid contains methods relating to the hyperboloid model
7
+
8
+ { (t, x, y, z) : -t^2 + x^2 + y^2 + z^2 = -1, t > 0 }
9
+
10
+ in the Minkowski space with signature -+++.
11
+
12
+ Conventions:
13
+
14
+ Points in the space are represented as vectors of 4 real numbers.
15
+ Here vector is a vector as constructed with snappy.matrix.vector(...)
16
+ (that is either snappy's own SimpleVector or a SageMath vector type)
17
+ from a real type (either a SnapPy.Number or one
18
+ of SageMath's real types including RealIntervalField, but not python's
19
+ native float type).
20
+
21
+ Similarly, O13-matrices are represented as matrices as constructed with
22
+ snappy.matrix.matrix(...) from a real type.
23
+
24
+ Note that we mostly follow the SnapPea kernel conventions, except that
25
+ we call the same matrices O13 rather than O31. This reads better given
26
+ that the signature is -+++: O13 reflects that is the first entry in a
27
+ vector or column in matrix that has the special role corresponding to
28
+ the time component or being a time-like vector, respectively.
29
+
30
+ """
31
+
32
+
33
+ def r13_dot(u, v):
34
+ """
35
+ -+++ inner product of two 4-vectors.
36
+ """
37
+ return -u[0]*v[0] + u[1]*v[1] + u[2]*v[2] + u[3]*v[3]
38
+
39
+
40
+ def time_r13_normalise(u):
41
+ """
42
+ Given a time-like vector in Minkowski space, returns the normalised
43
+ vector (with norm -1).
44
+ """
45
+
46
+ return u / (-r13_dot(u,u)).sqrt()
47
+
48
+
49
+ def space_r13_normalise(u):
50
+ """
51
+ Given a space-like vector in Minkowski space, returns the normalised
52
+ vector (with norm 1).
53
+ """
54
+
55
+ return u / r13_dot(u,u).sqrt()
56
+
57
+
58
+ def o13_inverse(m):
59
+ """
60
+ Given a O13 matrix, return its inverse.
61
+ """
62
+
63
+ result = m.transpose()
64
+ result[0,1] = -result[0,1]
65
+ result[0,2] = -result[0,2]
66
+ result[0,3] = -result[0,3]
67
+ result[1,0] = -result[1,0]
68
+ result[2,0] = -result[2,0]
69
+ result[3,0] = -result[3,0]
70
+
71
+ return result
72
+
73
+ def so13_to_pgl2c(B):
74
+ """
75
+ Given an SO13 matrix, returns corresponding complex 2x2-matrix.
76
+ The determinant of the result is not 1 in general.
77
+
78
+ Python implementation of O31_to_Moebius (without normalization).
79
+ """
80
+
81
+ AM0A_00 = B[0,0] + B[1,0]
82
+ AM1A_00 = B[0,1] + B[1,1]
83
+ aa = AM0A_00 + AM1A_00
84
+ bb = AM0A_00 - AM1A_00
85
+
86
+ if aa > bb:
87
+ return _to_complex_matrix(
88
+ aa, 0 ,
89
+ B[0,2] + B[1,2], B[0,3] + B[1,3] ,
90
+
91
+ B[2,0] + B[2,1], -(B[3,0] + B[3,1]),
92
+ B[2,2] + B[3,3], B[2,3] - B[3,2] )
93
+ else:
94
+ return _to_complex_matrix(
95
+ B[0,2] + B[1,2], -(B[0,3] + B[1,3]),
96
+ bb , 0 ,
97
+ B[2,2] - B[3,3], -(B[2,3] + B[3,2]),
98
+ B[2,0] - B[2,1], B[3,1] - B[3,0] )
99
+
100
+ def so13_to_psl2c(m):
101
+ """
102
+ Given an SO13 matrix, returns corresponding complex 2x2-matrix
103
+ with determinant 1.
104
+
105
+ Python implementation of O31_to_Moebius (with normalization).
106
+ """
107
+
108
+ A = so13_to_pgl2c(m)
109
+ return A / A.det().sqrt()
110
+
111
+ def r13_to_klein(v):
112
+ """
113
+ Given a time-like or light-like vector, gives the respective point
114
+ in the Klein model or its boundary, respectively.
115
+ """
116
+
117
+ return make_vector([v[1] / v[0], v[2] / v[0], v[3] / v[0]])
118
+
119
+ def unit_time_vector_to_o13_hyperbolic_translation(v):
120
+ """
121
+ Takes a point (time-like unit vector) in the hyperboloid model and
122
+ returns the O13-matrix corresponding to the hyperbolic translation
123
+ moving the origin to that point (that is, the translation fixing
124
+ the geodesic between the origin and the point and introducing no
125
+ rotation about that geodesic).
126
+ """
127
+
128
+ v1 = [1 + v[0], v[1], v[2], v[3]]
129
+
130
+ m = [ [ x * y / v1[0] for x in v1] for y in v1 ]
131
+ m[0][0] -= 1
132
+ m[1][1] += 1
133
+ m[2][2] += 1
134
+ m[3][3] += 1
135
+
136
+ return make_matrix(m)
137
+
138
+
139
+ def unnormalised_plane_eqn_from_r13_points(pts):
140
+ """
141
+ Given three (finite or ideal) points in the hyperboloid model
142
+ (that is time-like or light-like vectors), compute the space-like
143
+ vector x such that the plane defined by x * y = 0 contains the
144
+ three given points.
145
+ """
146
+
147
+ return make_vector([ _det_shifted_matrix3(pts, 0),
148
+ _det_shifted_matrix3(pts, 1),
149
+ - _det_shifted_matrix3(pts, 2),
150
+ _det_shifted_matrix3(pts, 3)])
151
+
152
+
153
+ def _det_shifted_matrix3(m, i):
154
+ """
155
+ Computes determinant of 3x3 matrix obtained by picking
156
+ 3 rows from the given 3x4 matrix m.
157
+ """
158
+
159
+ i0 = (i+1) % 4
160
+ i1 = (i+2) % 4
161
+ i2 = (i+3) % 4
162
+
163
+ return ( m[0][i0] * m[1][i1] * m[2][i2]
164
+ + m[0][i1] * m[1][i2] * m[2][i0]
165
+ + m[0][i2] * m[1][i0] * m[2][i1]
166
+ - m[0][i2] * m[1][i1] * m[2][i0]
167
+ - m[0][i0] * m[1][i2] * m[2][i1]
168
+ - m[0][i1] * m[1][i0] * m[2][i2])
169
+
170
+ def compute_inradius_and_incenter_from_planes(planes):
171
+ """
172
+ Given outside-facing normals for the four faces of a
173
+ tetrahedron, compute the hyperbolic inradius and the
174
+ incenter (as unit time vector) of the tetrahedron (in the
175
+ hyperboloid model).
176
+ """
177
+
178
+ # We need to c and r such that
179
+ # * r13_dot(c, c) = -1 and
180
+ # * r13_dot(plane, c) = -sinh(r) for every plane
181
+ #
182
+ # We instead solve for the following system of linear equations:
183
+ # * r13_dot(plane, pt) = -1 for every plane
184
+
185
+ RF = planes[0][0].parent()
186
+ m = make_matrix([[-plane[0], plane[1], plane[2], plane[3]]
187
+ for plane in planes])
188
+ v = make_vector([RF(-1), RF(-1), RF(-1), RF(-1)])
189
+
190
+ pt = mat_solve(m, v)
191
+
192
+ # And then use the inverse length of pt to scale pt to be
193
+ # a unit time vector and to compute the r.
194
+ scale = 1 / (-r13_dot(pt, pt)).sqrt()
195
+
196
+ return scale.arcsinh(), scale * pt
197
+
198
+ def _to_complex_matrix(
199
+ a, b, c, d,
200
+ e, f, g, h):
201
+ RF = a.parent()
202
+ if _within_sage:
203
+ CF = RF.complex_field()
204
+ return make_matrix(
205
+ [ [ CF(a,b), CF(c, d) ],
206
+ [ CF(e,f), CF(g, h) ] ],
207
+ ring=CF)
208
+ else:
209
+ I = RF('I')
210
+ return make_matrix(
211
+ [ [ a + b * I, c + d * I ],
212
+ [ e + f * I, g + h * I ] ])
@@ -0,0 +1,245 @@
1
+ from .triangle import R13IdealTriangle
2
+ from .line import R13Line
3
+ from .point import R13Point
4
+ from .horoball import R13Horoball
5
+ from . import r13_dot
6
+
7
+ from ..math_basics import is_RealIntervalFieldElement # type: ignore
8
+ from ..sage_helper import _within_sage # type: ignore
9
+
10
+ if _within_sage:
11
+ from ..sage_helper import Infinity
12
+
13
+ __all__ = ['distance_r13_lines',
14
+ 'lower_bound_distance_r13_line_triangle']
15
+
16
+ def distance_r13_lines(line0 : R13Line, line1 : R13Line):
17
+ """
18
+ Computes distance between two hyperbolic lines.
19
+ """
20
+
21
+ p00 = r13_dot(line0.points[0], line1.points[0])
22
+ p01 = r13_dot(line0.points[0], line1.points[1])
23
+ p10 = r13_dot(line0.points[1], line1.points[0])
24
+ p11 = r13_dot(line0.points[1], line1.points[1])
25
+
26
+ pp = line0.inner_product * line1.inner_product
27
+
28
+ t0 = _safe_sqrt((p00 * p11) / pp)
29
+ t1 = _safe_sqrt((p01 * p10) / pp)
30
+
31
+ p = (t0 + t1 - 1) / 2
32
+
33
+ return 2 * _safe_sqrt(p).arcsinh()
34
+
35
+ def distance_r13_horoballs(horoball_defining_vec0,
36
+ horoball_defining_vec1):
37
+ p = -r13_dot(horoball_defining_vec0, horoball_defining_vec1) / 2
38
+ return _safe_log(p)
39
+
40
+ def distance_r13_horoball_line(horoball_defining_vec, # Light-like
41
+ line : R13Line):
42
+
43
+ p = (r13_dot(line.points[0], horoball_defining_vec) *
44
+ r13_dot(line.points[1], horoball_defining_vec))
45
+ s = -2 * p / line.inner_product
46
+
47
+ return _safe_log(s)/2
48
+
49
+ def distance_r13_horoball_plane(horoball_defining_vec, # Light-like
50
+ plane_defining_vec): # Unit space-like
51
+ p = r13_dot(horoball_defining_vec, plane_defining_vec)
52
+ return _safe_log_of_abs(p)
53
+
54
+ def distance_r13_horoball_point(horoball_defining_vec, # Light-like
55
+ pt): # Unit-time-like
56
+ p = r13_dot(horoball_defining_vec, pt)
57
+ return (-p).log()
58
+
59
+ def distance_r13_point_line(pt, # Unit time-like
60
+ line : R13Line):
61
+ """
62
+ This also works if line is degenerate and starts and ends at some point.
63
+ """
64
+
65
+ p = (r13_dot(line.points[0], pt) *
66
+ r13_dot(line.points[1], pt))
67
+ s = _safe_div(2 * p, -line.inner_product)
68
+ return _safe_arccosh(_safe_sqrt(s))
69
+
70
+ def distance_r13_point_plane(pt, # Unit time-like
71
+ plane_defining_vec): # Unit space-like
72
+ p = r13_dot(pt, plane_defining_vec)
73
+ return p.arcsinh().abs()
74
+
75
+ def distance_r13_points(pt0, # Unit time-like
76
+ pt1): # Unit time-like
77
+ """
78
+ Computes the hyperbolic distance between two points (represented
79
+ by unit time vectors) in the hyperboloid model.
80
+ """
81
+ p = r13_dot(pt0, pt1)
82
+
83
+ # Due to rounding errors, the resulting number or interval can be
84
+ # slightly less than 1 or contain numbers slightly less than 1,
85
+ # respectively - resulting in NaN's. Avoid this here.
86
+ return _safe_arccosh(-p)
87
+
88
+ def lower_bound_distance_to_r13_triangle(
89
+ geometric_object, triangle : R13IdealTriangle, verified : bool):
90
+ if isinstance(geometric_object, R13Horoball):
91
+ return lower_bound_distance_r13_horoball_triangle(
92
+ geometric_object.defining_vec, triangle, verified)
93
+ if isinstance(geometric_object, R13Line):
94
+ return lower_bound_distance_r13_line_triangle(
95
+ geometric_object, triangle, verified)
96
+ if isinstance(geometric_object, R13Point):
97
+ return lower_bound_distance_r13_point_triangle(
98
+ geometric_object.point, triangle, verified)
99
+ raise ValueError(
100
+ "Distance between %r and triangle not supported" % geometric_object)
101
+
102
+ def lower_bound_distance_r13_horoball_triangle(
103
+ horoball_defining_vec,
104
+ triangle : R13IdealTriangle, verified : bool):
105
+
106
+ if verified:
107
+ epsilon = 0
108
+ else:
109
+ RF = horoball_defining_vec[0].parent()
110
+ epsilon = _compute_epsilon(RF)
111
+
112
+ for bounding_plane, edge in zip(triangle.bounding_planes,
113
+ triangle.edges):
114
+ if r13_dot(horoball_defining_vec, bounding_plane) > epsilon:
115
+ return distance_r13_horoball_line(horoball_defining_vec, edge)
116
+
117
+ return distance_r13_horoball_plane(
118
+ horoball_defining_vec, triangle.plane)
119
+
120
+ def lower_bound_distance_r13_line_triangle(
121
+ line : R13Line, triangle : R13IdealTriangle, verified : bool):
122
+
123
+ if verified:
124
+ epsilon = 0
125
+ else:
126
+ RF = line.points[0][0].parent()
127
+ epsilon = _compute_epsilon(RF)
128
+
129
+ a0 = r13_dot(triangle.plane, line.points[0])
130
+ a1 = r13_dot(triangle.plane, line.points[1])
131
+
132
+ abs0 = abs(a0)
133
+ abs1 = abs(a1)
134
+
135
+ pt = abs1 * line.points[0] + abs0 * line.points[1]
136
+
137
+ for bounding_plane, edge in zip(triangle.bounding_planes,
138
+ triangle.edges):
139
+ if r13_dot(pt, bounding_plane) > epsilon:
140
+ return distance_r13_lines(line, edge)
141
+
142
+ p = a0 * a1
143
+
144
+ if p > 0:
145
+ return (-2 * p / line.inner_product).sqrt().arcsinh()
146
+
147
+ RF = line.points[0][0].parent()
148
+ return RF(0)
149
+
150
+ def lower_bound_distance_r13_point_triangle(
151
+ point,
152
+ triangle : R13IdealTriangle, verified : bool):
153
+
154
+ if verified:
155
+ epsilon = 0
156
+ else:
157
+ RF = point[0].parent()
158
+ epsilon = _compute_epsilon(RF)
159
+
160
+ for bounding_plane, edge in zip(triangle.bounding_planes,
161
+ triangle.edges):
162
+ if r13_dot(point, bounding_plane) > epsilon:
163
+ return distance_r13_point_line(point, edge)
164
+
165
+ return distance_r13_point_plane(point, triangle.plane)
166
+
167
+ def _compute_epsilon(RF):
168
+ return RF(0.5) ** (RF.prec() // 2)
169
+
170
+ def _safe_sqrt(p):
171
+ """
172
+ Compute the sqrt of a number that is known to be non-negative
173
+ though might not be non-negative because of floating point
174
+ issues. When using interval arithmetic, this means that
175
+ while the upper bound will be non-negative, the lower bound
176
+ we computed might be negative because it is too conservative.
177
+
178
+ Example of a quantity that can be given to this function:
179
+ negative inner product of two vectors in the positive
180
+ light cone. This is because we know that the inner product
181
+ of two such vectors is always non-positive.
182
+ """
183
+
184
+ if is_RealIntervalFieldElement(p):
185
+ RIF = p.parent()
186
+ p = p.intersection(RIF(0, Infinity))
187
+ else:
188
+ if p < 0:
189
+ RF = p.parent()
190
+ return RF(0)
191
+ return p.sqrt()
192
+
193
+ def _safe_log(p):
194
+ if is_RealIntervalFieldElement(p):
195
+ RIF = p.parent()
196
+ p = p.intersection(RIF(0, Infinity))
197
+ else:
198
+ if p <= 0:
199
+ RF = p.parent()
200
+ return RF(-1e20)
201
+ return p.log()
202
+
203
+ def _safe_log_of_abs(p):
204
+ return _safe_log_non_neg(p.abs())
205
+
206
+ def _safe_log_non_neg(p):
207
+ if p == 0:
208
+ if is_RealIntervalFieldElement(p):
209
+ RIF = p.parent()
210
+ return RIF(-Infinity)
211
+ else:
212
+ RF = p.parent()
213
+ return RF(-1e20)
214
+ else:
215
+ return p.log()
216
+
217
+ def _safe_arccosh(p):
218
+ if is_RealIntervalFieldElement(p):
219
+ RIF = p.parent()
220
+ p = p.intersection(RIF(1, Infinity))
221
+ else:
222
+ if p < 1:
223
+ RF = p.parent()
224
+ return RF(0)
225
+ return p.arccosh()
226
+
227
+ def _safe_div(a, b):
228
+ """
229
+ Compute a / b where be is known to be non-negative and we should
230
+ return infinity if b is zero.
231
+ """
232
+
233
+ if is_RealIntervalFieldElement(b):
234
+ RIF = b.parent()
235
+ if b == 0:
236
+ return RIF(Infinity)
237
+ else:
238
+ return a / b.intersection(RIF(0, Infinity))
239
+ else:
240
+ if b <= 0:
241
+ RIF = b.parent()
242
+ return RIF(1e20)
243
+ else:
244
+ return a / b
245
+
@@ -0,0 +1,19 @@
1
+ __all__ = ['R13Horoball']
2
+
3
+ class R13Horoball:
4
+ """
5
+ Horoball defined by { x : r13_dot(x, l) > -1 } where l is a
6
+ light-like vector.
7
+ """
8
+
9
+ def __init__(self,
10
+ defining_vec): # Light-like vector
11
+ self.defining_vec = defining_vec
12
+
13
+ def transformed(self,
14
+ m): # O13-matrix
15
+ """
16
+ Returns image of the horoball under given O13-matrix m.
17
+ """
18
+
19
+ return R13Horoball(m * self.defining_vec)
@@ -0,0 +1,35 @@
1
+ from ..hyperboloid import r13_dot
2
+
3
+ __all__ = [ 'R13Line' ]
4
+
5
+ class R13Line:
6
+ """
7
+ A line in the hyperboloid model - represented by two
8
+ like-like vectors spanning the line.
9
+
10
+ For distance computations, the inner product between the two
11
+ vectors is stored as well.
12
+ """
13
+
14
+ def __init__(self,
15
+ points, # Two light-like vectors
16
+ inner_product=None): # Optional: their inner product
17
+ """
18
+ inner_product can be given if known, otherwise, will be computed.
19
+ """
20
+ self.points = points
21
+ if inner_product is None:
22
+ self.inner_product = r13_dot(points[0], points[1])
23
+ else:
24
+ self.inner_product = inner_product
25
+
26
+ def transformed(self,
27
+ m): # O13-matrix
28
+ """
29
+ Returns image of the line under given O13-matrix m.
30
+ """
31
+
32
+ return R13Line(
33
+ [ m * point for point in self.points],
34
+ self.inner_product)
35
+
@@ -0,0 +1,9 @@
1
+ __all__ = [ 'R13Point' ]
2
+
3
+ class R13Point:
4
+ def __init__(self, point):
5
+ self.point = point
6
+
7
+ def transformed(self,
8
+ m): # O13-matrix
9
+ return R13Point(m * self.point)
@@ -0,0 +1,29 @@
1
+ from .line import R13Line
2
+ from . import (time_r13_normalise,
3
+ space_r13_normalise,
4
+ r13_dot)
5
+
6
+ from typing import Sequence
7
+
8
+ __all__ = ['R13IdealTriangle']
9
+
10
+ class R13IdealTriangle:
11
+ def __init__(self,
12
+ plane, # one space-like normal vector
13
+ bounding_planes, # three space-like normal vectors
14
+ edges : Sequence[R13Line] # Same order as bounding_planes
15
+ ):
16
+ self.plane = plane
17
+ self.bounding_planes = bounding_planes
18
+ self.edges = edges
19
+
20
+ def triangle_bounding_plane(v_opp, v0, v1):
21
+ m = time_r13_normalise(
22
+ -(r13_dot(v1, v_opp) * v0 + r13_dot(v0, v_opp) * v1))
23
+
24
+ return _make_r13_unit_tangent_vector(m - v_opp, m)
25
+
26
+ def _make_r13_unit_tangent_vector(direction, point):
27
+ s = r13_dot(direction, point)
28
+ return space_r13_normalise(direction + s * point)
29
+
snappy/info_icon.gif ADDED
Binary file
snappy/infowindow.py ADDED
@@ -0,0 +1,65 @@
1
+ # -*- coding: utf-8 -*-
2
+ import sys
3
+ import os
4
+ import datetime
5
+ from .gui import *
6
+ from .version import version as SnapPy_version
7
+ from IPython import __version__ as IPython_version
8
+
9
+ snappy_path = os.path.dirname(__file__)
10
+ icon_file = os.path.join(snappy_path, 'info_icon.gif')
11
+
12
+
13
+ class InfoWindow(Tk_.Toplevel):
14
+ def __init__(self, root, title, content, root_attr_name):
15
+ self.root = root
16
+ self.root_attr_name = root_attr_name
17
+ setattr(root, root_attr_name, self)
18
+ Tk_.Toplevel.__init__(self, self.root, class_='snappy')
19
+ self.title(title)
20
+ self.content = content
21
+ self.image = Tk_.PhotoImage(file=icon_file)
22
+ self.style = SnapPyStyle()
23
+ self.body()
24
+
25
+ def body(self):
26
+ self.resizable(False, False)
27
+ box = ttk.Frame(self)
28
+ icon = ttk.Label(box, image=self.image)
29
+ icon.grid(row=0, column=0, pady=30, sticky=Tk_.N)
30
+ message = Tk_.Message(box, text=self.content)
31
+ message.grid(row=0, column=1, padx=20, pady=10)
32
+ box.pack()
33
+
34
+ def destroy(self):
35
+ if hasattr(self.root, self.root_attr_name):
36
+ delattr(self.root, self.root_attr_name)
37
+ Tk_.Toplevel.destroy(self)
38
+
39
+
40
+ about_snappy_text = """
41
+ For information on how to use SnapPy, please see the Help menu.
42
+
43
+ SnapPy is a program for studying the topology and geometry of 3-manifolds, with a focus on hyperbolic structures. It was written by Marc Culler, Nathan Dunfield, Matthias Gӧrner, and Jeff Weeks, with additional contributions by many others. Its homepage is
44
+
45
+ http://snappy.computop.org/
46
+
47
+ This is version %s of SnapPy, running on Python %s using Tk %s and IPython %s.
48
+
49
+ Development of SnapPy was made possible in part by generous support from the National Science Foundation of the United States.
50
+
51
+ SnapPy is copyright © 2009-%d by Marc Culler, Nathan Dunfield, Matthias Gӧrner, Jeff Weeks, and others and is distributed under the GNU Public License, version 2 or later.
52
+ """ % (SnapPy_version,
53
+ sys.version.split()[0],
54
+ Tk_.Tcl().eval('info patchlevel'),
55
+ IPython_version,
56
+ datetime.datetime.now().year)
57
+
58
+
59
+ def about_snappy(window):
60
+ return InfoWindow(window, 'About SnapPy', about_snappy_text, 'about_snappy')
61
+
62
+
63
+ if __name__ == '__main__':
64
+ root = Tk_.Tk()
65
+ info = InfoWindow(root, title='About SnapPy', content=about_snappy_text)