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.
Files changed (401) hide show
  1. snappy/CyOpenGL.cpython-38-darwin.so +0 -0
  2. snappy/SnapPy.cpython-38-darwin.so +0 -0
  3. snappy/SnapPyHP.cpython-38-darwin.so +0 -0
  4. snappy/__init__.py +373 -426
  5. snappy/app.py +240 -75
  6. snappy/app_menus.py +93 -78
  7. snappy/browser.py +87 -63
  8. snappy/cache.py +5 -8
  9. snappy/canonical.py +249 -0
  10. snappy/{verify/cusp_shapes.py → cusps/__init__.py} +11 -19
  11. snappy/cusps/cusp_area_matrix.py +101 -0
  12. snappy/{verify/cusp_areas.py → cusps/cusp_areas_from_matrix.py} +39 -54
  13. snappy/cusps/maximal_cusp_area_matrix.py +136 -0
  14. snappy/cusps/test.py +21 -0
  15. snappy/cusps/trig_cusp_area_matrix.py +63 -0
  16. snappy/database.py +40 -31
  17. snappy/db_utilities.py +13 -14
  18. snappy/decorated_isosig.py +377 -133
  19. snappy/dev/extended_ptolemy/complexVolumesClosed.py +42 -9
  20. snappy/dev/extended_ptolemy/extended.py +32 -25
  21. snappy/dev/extended_ptolemy/giac_rur.py +23 -8
  22. snappy/dev/extended_ptolemy/phc_wrapper.py +10 -10
  23. snappy/dev/vericlosed/computeApproxHyperbolicStructureOrb.py +2 -1
  24. snappy/dev/vericlosed/gimbalLoopFinder.py +5 -5
  25. snappy/dev/vericlosed/hyperbolicStructure.py +3 -3
  26. snappy/dev/vericlosed/oneVertexTruncatedComplex.py +2 -2
  27. snappy/dev/vericlosed/truncatedComplex.py +3 -2
  28. snappy/dev/vericlosed/verifyHyperbolicStructureEngine.py +4 -3
  29. snappy/doc/_images/geodesics.jpg +0 -0
  30. snappy/doc/_images/m004_paper_plane_on_systole.jpg +0 -0
  31. snappy/doc/_images/m125_paper_plane.jpg +0 -0
  32. snappy/doc/_images/o9_00000_systole_paper_plane.jpg +0 -0
  33. snappy/doc/_images/o9_00000_systole_paper_plane_closer.jpg +0 -0
  34. snappy/doc/_sources/additional_classes.rst.txt +1 -0
  35. snappy/doc/_sources/credits.rst.txt +6 -1
  36. snappy/doc/_sources/development.rst.txt +69 -50
  37. snappy/doc/_sources/index.rst.txt +101 -66
  38. snappy/doc/_sources/installing.rst.txt +148 -165
  39. snappy/doc/_sources/news.rst.txt +136 -32
  40. snappy/doc/_sources/ptolemy.rst.txt +1 -1
  41. snappy/doc/_sources/ptolemy_examples1.rst.txt +9 -8
  42. snappy/doc/_sources/ptolemy_examples2.rst.txt +3 -3
  43. snappy/doc/_sources/ptolemy_examples3.rst.txt +14 -14
  44. snappy/doc/_sources/ptolemy_prelim.rst.txt +1 -1
  45. snappy/doc/_sources/snap.rst.txt +2 -2
  46. snappy/doc/_sources/snappy.rst.txt +1 -1
  47. snappy/doc/_sources/triangulation.rst.txt +3 -2
  48. snappy/doc/_sources/verify.rst.txt +89 -29
  49. snappy/doc/_sources/verify_internals.rst.txt +5 -16
  50. snappy/doc/_static/SnapPy-horizontal-128.png +0 -0
  51. snappy/doc/_static/SnapPy.ico +0 -0
  52. snappy/doc/_static/_sphinx_javascript_frameworks_compat.js +123 -0
  53. snappy/doc/_static/basic.css +47 -27
  54. snappy/doc/_static/css/badge_only.css +1 -0
  55. snappy/doc/_static/css/fonts/Roboto-Slab-Bold.woff +0 -0
  56. snappy/doc/_static/css/fonts/Roboto-Slab-Bold.woff2 +0 -0
  57. snappy/doc/_static/css/fonts/Roboto-Slab-Regular.woff +0 -0
  58. snappy/doc/_static/css/fonts/Roboto-Slab-Regular.woff2 +0 -0
  59. snappy/doc/_static/css/fonts/fontawesome-webfont.eot +0 -0
  60. snappy/doc/_static/css/fonts/fontawesome-webfont.svg +2671 -0
  61. snappy/doc/_static/css/fonts/fontawesome-webfont.ttf +0 -0
  62. snappy/doc/_static/css/fonts/fontawesome-webfont.woff +0 -0
  63. snappy/doc/_static/css/fonts/fontawesome-webfont.woff2 +0 -0
  64. snappy/doc/_static/css/fonts/lato-bold-italic.woff +0 -0
  65. snappy/doc/_static/css/fonts/lato-bold-italic.woff2 +0 -0
  66. snappy/doc/_static/css/fonts/lato-bold.woff +0 -0
  67. snappy/doc/_static/css/fonts/lato-bold.woff2 +0 -0
  68. snappy/doc/_static/css/fonts/lato-normal-italic.woff +0 -0
  69. snappy/doc/_static/css/fonts/lato-normal-italic.woff2 +0 -0
  70. snappy/doc/_static/css/fonts/lato-normal.woff +0 -0
  71. snappy/doc/_static/css/fonts/lato-normal.woff2 +0 -0
  72. snappy/doc/_static/css/theme.css +4 -0
  73. snappy/doc/_static/doctools.js +107 -274
  74. snappy/doc/_static/documentation_options.js +6 -5
  75. snappy/doc/_static/fonts/Lato/lato-bold.eot +0 -0
  76. snappy/doc/_static/fonts/Lato/lato-bold.ttf +0 -0
  77. snappy/doc/_static/fonts/Lato/lato-bold.woff +0 -0
  78. snappy/doc/_static/fonts/Lato/lato-bold.woff2 +0 -0
  79. snappy/doc/_static/fonts/Lato/lato-bolditalic.eot +0 -0
  80. snappy/doc/_static/fonts/Lato/lato-bolditalic.ttf +0 -0
  81. snappy/doc/_static/fonts/Lato/lato-bolditalic.woff +0 -0
  82. snappy/doc/_static/fonts/Lato/lato-bolditalic.woff2 +0 -0
  83. snappy/doc/_static/fonts/Lato/lato-italic.eot +0 -0
  84. snappy/doc/_static/fonts/Lato/lato-italic.ttf +0 -0
  85. snappy/doc/_static/fonts/Lato/lato-italic.woff +0 -0
  86. snappy/doc/_static/fonts/Lato/lato-italic.woff2 +0 -0
  87. snappy/doc/_static/fonts/Lato/lato-regular.eot +0 -0
  88. snappy/doc/_static/fonts/Lato/lato-regular.ttf +0 -0
  89. snappy/doc/_static/fonts/Lato/lato-regular.woff +0 -0
  90. snappy/doc/_static/fonts/Lato/lato-regular.woff2 +0 -0
  91. snappy/doc/_static/fonts/RobotoSlab/roboto-slab-v7-bold.eot +0 -0
  92. snappy/doc/_static/fonts/RobotoSlab/roboto-slab-v7-bold.ttf +0 -0
  93. snappy/doc/_static/fonts/RobotoSlab/roboto-slab-v7-bold.woff +0 -0
  94. snappy/doc/_static/fonts/RobotoSlab/roboto-slab-v7-bold.woff2 +0 -0
  95. snappy/doc/_static/fonts/RobotoSlab/roboto-slab-v7-regular.eot +0 -0
  96. snappy/doc/_static/fonts/RobotoSlab/roboto-slab-v7-regular.ttf +0 -0
  97. snappy/doc/_static/fonts/RobotoSlab/roboto-slab-v7-regular.woff +0 -0
  98. snappy/doc/_static/fonts/RobotoSlab/roboto-slab-v7-regular.woff2 +0 -0
  99. snappy/doc/_static/jquery.js +2 -2
  100. snappy/doc/_static/js/badge_only.js +1 -0
  101. snappy/doc/_static/js/theme.js +1 -0
  102. snappy/doc/_static/js/versions.js +228 -0
  103. snappy/doc/_static/language_data.js +3 -101
  104. snappy/doc/_static/pygments.css +1 -0
  105. snappy/doc/_static/searchtools.js +489 -398
  106. snappy/doc/_static/snappy_furo.css +33 -0
  107. snappy/doc/_static/snappy_sphinx_rtd_theme.css +42 -0
  108. snappy/doc/_static/sphinx_highlight.js +154 -0
  109. snappy/doc/additional_classes.html +688 -263
  110. snappy/doc/bugs.html +107 -94
  111. snappy/doc/censuses.html +155 -127
  112. snappy/doc/credits.html +115 -104
  113. snappy/doc/development.html +184 -146
  114. snappy/doc/genindex.html +287 -204
  115. snappy/doc/index.html +189 -150
  116. snappy/doc/installing.html +259 -266
  117. snappy/doc/manifold.html +1626 -592
  118. snappy/doc/manifoldhp.html +119 -105
  119. snappy/doc/news.html +198 -104
  120. snappy/doc/objects.inv +0 -0
  121. snappy/doc/other.html +117 -105
  122. snappy/doc/platonic_census.html +161 -114
  123. snappy/doc/plink.html +113 -105
  124. snappy/doc/ptolemy.html +131 -108
  125. snappy/doc/ptolemy_classes.html +242 -223
  126. snappy/doc/ptolemy_examples1.html +144 -130
  127. snappy/doc/ptolemy_examples2.html +141 -129
  128. snappy/doc/ptolemy_examples3.html +148 -132
  129. snappy/doc/ptolemy_examples4.html +131 -111
  130. snappy/doc/ptolemy_prelim.html +162 -138
  131. snappy/doc/py-modindex.html +104 -69
  132. snappy/doc/screenshots.html +117 -108
  133. snappy/doc/search.html +115 -84
  134. snappy/doc/searchindex.js +1 -1
  135. snappy/doc/snap.html +109 -96
  136. snappy/doc/snappy.html +134 -97
  137. snappy/doc/spherogram.html +259 -187
  138. snappy/doc/todo.html +107 -94
  139. snappy/doc/triangulation.html +1380 -111
  140. snappy/doc/tutorial.html +107 -94
  141. snappy/doc/verify.html +194 -125
  142. snappy/doc/verify_internals.html +248 -686
  143. snappy/drilling/__init__.py +456 -0
  144. snappy/drilling/barycentric.py +103 -0
  145. snappy/drilling/constants.py +5 -0
  146. snappy/drilling/crush.py +270 -0
  147. snappy/drilling/cusps.py +125 -0
  148. snappy/drilling/debug.py +242 -0
  149. snappy/drilling/epsilons.py +6 -0
  150. snappy/drilling/exceptions.py +55 -0
  151. snappy/drilling/moves.py +620 -0
  152. snappy/drilling/peripheral_curves.py +210 -0
  153. snappy/drilling/perturb.py +188 -0
  154. snappy/drilling/shorten.py +36 -0
  155. snappy/drilling/subdivide.py +274 -0
  156. snappy/drilling/test.py +23 -0
  157. snappy/drilling/test_cases.py +126 -0
  158. snappy/drilling/tracing.py +351 -0
  159. snappy/exceptions.py +23 -3
  160. snappy/export_stl.py +20 -14
  161. snappy/exterior_to_link/__init__.py +2 -0
  162. snappy/exterior_to_link/barycentric_geometry.py +463 -0
  163. snappy/exterior_to_link/exceptions.py +6 -0
  164. snappy/exterior_to_link/geodesic_map.json +14408 -0
  165. snappy/exterior_to_link/hyp_utils.py +112 -0
  166. snappy/exterior_to_link/link_projection.py +323 -0
  167. snappy/exterior_to_link/main.py +197 -0
  168. snappy/exterior_to_link/mcomplex_with_expansion.py +261 -0
  169. snappy/exterior_to_link/mcomplex_with_link.py +687 -0
  170. snappy/exterior_to_link/mcomplex_with_memory.py +162 -0
  171. snappy/exterior_to_link/pl_utils.py +491 -0
  172. snappy/exterior_to_link/put_in_S3.py +156 -0
  173. snappy/exterior_to_link/rational_linear_algebra.py +123 -0
  174. snappy/exterior_to_link/rational_linear_algebra_wrapped.py +135 -0
  175. snappy/exterior_to_link/simplify_to_base_tri.py +114 -0
  176. snappy/exterior_to_link/stored_moves.py +475 -0
  177. snappy/exterior_to_link/test.py +31 -0
  178. snappy/geometric_structure/__init__.py +212 -0
  179. snappy/geometric_structure/cusp_neighborhood/__init__.py +3 -0
  180. snappy/geometric_structure/cusp_neighborhood/complex_cusp_cross_section.py +697 -0
  181. snappy/geometric_structure/cusp_neighborhood/cusp_cross_section_base.py +484 -0
  182. snappy/geometric_structure/cusp_neighborhood/exceptions.py +42 -0
  183. snappy/geometric_structure/cusp_neighborhood/real_cusp_cross_section.py +298 -0
  184. snappy/geometric_structure/cusp_neighborhood/tiles_for_cusp_neighborhood.py +159 -0
  185. snappy/geometric_structure/cusp_neighborhood/vertices.py +32 -0
  186. snappy/geometric_structure/geodesic/__init__.py +0 -0
  187. snappy/geometric_structure/geodesic/add_core_curves.py +152 -0
  188. snappy/geometric_structure/geodesic/avoid_core_curves.py +369 -0
  189. snappy/geometric_structure/geodesic/canonical_keys.py +52 -0
  190. snappy/geometric_structure/geodesic/check_away_from_core_curve.py +60 -0
  191. snappy/geometric_structure/geodesic/constants.py +6 -0
  192. snappy/geometric_structure/geodesic/exceptions.py +22 -0
  193. snappy/geometric_structure/geodesic/fixed_points.py +93 -0
  194. snappy/geometric_structure/geodesic/geodesic_start_point_info.py +435 -0
  195. snappy/geometric_structure/geodesic/graph_trace_helper.py +67 -0
  196. snappy/geometric_structure/geodesic/line.py +30 -0
  197. snappy/geometric_structure/geodesic/multiplicity.py +127 -0
  198. snappy/geometric_structure/geodesic/tiles_for_geodesic.py +101 -0
  199. snappy/geometric_structure/test.py +22 -0
  200. snappy/gui.py +36 -36
  201. snappy/horoviewer.py +50 -48
  202. snappy/hyperboloid/__init__.py +212 -0
  203. snappy/hyperboloid/distances.py +245 -0
  204. snappy/hyperboloid/horoball.py +19 -0
  205. snappy/hyperboloid/line.py +35 -0
  206. snappy/hyperboloid/point.py +9 -0
  207. snappy/hyperboloid/triangle.py +29 -0
  208. snappy/{infodialog.py → infowindow.py} +32 -33
  209. snappy/isometry_signature.py +382 -0
  210. snappy/len_spec/__init__.py +596 -0
  211. snappy/len_spec/geodesic_info.py +110 -0
  212. snappy/len_spec/geodesic_key_info_dict.py +117 -0
  213. snappy/len_spec/geodesic_piece.py +143 -0
  214. snappy/len_spec/geometric_structure.py +182 -0
  215. snappy/len_spec/geometry.py +80 -0
  216. snappy/len_spec/length_spectrum_geodesic_info.py +170 -0
  217. snappy/len_spec/spine.py +206 -0
  218. snappy/len_spec/test.py +24 -0
  219. snappy/len_spec/test_cases.py +69 -0
  220. snappy/len_spec/tile.py +275 -0
  221. snappy/len_spec/word.py +86 -0
  222. snappy/manifolds/__init__.py +1 -1
  223. snappy/math_basics.py +176 -0
  224. snappy/matrix.py +525 -0
  225. snappy/number.py +97 -21
  226. snappy/numeric_output_checker.py +37 -27
  227. snappy/pari.py +30 -69
  228. snappy/phone_home.py +25 -20
  229. snappy/polyviewer.py +39 -37
  230. snappy/ptolemy/__init__.py +4 -6
  231. snappy/ptolemy/component.py +14 -12
  232. snappy/ptolemy/coordinates.py +312 -295
  233. snappy/ptolemy/fieldExtensions.py +14 -12
  234. snappy/ptolemy/findLoops.py +43 -31
  235. snappy/ptolemy/geometricRep.py +24 -26
  236. snappy/ptolemy/homology.py +12 -7
  237. snappy/ptolemy/manifoldMethods.py +69 -70
  238. snappy/ptolemy/matrix.py +65 -26
  239. snappy/ptolemy/numericalSolutionsToGroebnerBasis.py +18 -14
  240. snappy/ptolemy/polynomial.py +125 -119
  241. snappy/ptolemy/processComponents.py +36 -30
  242. snappy/ptolemy/processFileBase.py +79 -18
  243. snappy/ptolemy/processFileDispatch.py +13 -14
  244. snappy/ptolemy/processMagmaFile.py +44 -39
  245. snappy/ptolemy/processRurFile.py +18 -11
  246. snappy/ptolemy/ptolemyGeneralizedObstructionClass.py +20 -17
  247. snappy/ptolemy/ptolemyObstructionClass.py +13 -17
  248. snappy/ptolemy/ptolemyVariety.py +190 -121
  249. snappy/ptolemy/ptolemyVarietyPrimeIdealGroebnerBasis.py +20 -19
  250. snappy/ptolemy/reginaWrapper.py +25 -29
  251. snappy/ptolemy/rur.py +6 -14
  252. snappy/ptolemy/solutionsToPrimeIdealGroebnerBasis.py +27 -22
  253. snappy/ptolemy/test.py +247 -188
  254. snappy/ptolemy/utilities.py +41 -43
  255. snappy/raytracing/__init__.py +64 -0
  256. snappy/raytracing/additional_horospheres.py +64 -0
  257. snappy/raytracing/additional_len_spec_choices.py +63 -0
  258. snappy/raytracing/cohomology_fractal.py +10 -6
  259. snappy/raytracing/eyeball.py +123 -0
  260. snappy/raytracing/finite_raytracing_data.py +48 -38
  261. snappy/raytracing/finite_viewer.py +218 -210
  262. snappy/raytracing/geodesic_tube_info.py +174 -0
  263. snappy/raytracing/geodesics.py +246 -0
  264. snappy/raytracing/geodesics_window.py +258 -0
  265. snappy/raytracing/gui_utilities.py +152 -40
  266. snappy/raytracing/hyperboloid_navigation.py +102 -52
  267. snappy/raytracing/hyperboloid_utilities.py +114 -261
  268. snappy/raytracing/ideal_raytracing_data.py +256 -179
  269. snappy/raytracing/inside_viewer.py +522 -253
  270. snappy/raytracing/pack.py +22 -0
  271. snappy/raytracing/raytracing_data.py +46 -34
  272. snappy/raytracing/raytracing_view.py +190 -109
  273. snappy/raytracing/shaders/Eye.png +0 -0
  274. snappy/raytracing/shaders/NonGeometric.png +0 -0
  275. snappy/raytracing/shaders/__init__.py +60 -4
  276. snappy/raytracing/shaders/fragment.glsl +575 -148
  277. snappy/raytracing/test.py +29 -0
  278. snappy/raytracing/tooltip.py +146 -0
  279. snappy/raytracing/upper_halfspace_utilities.py +98 -0
  280. snappy/raytracing/view_scale_controller.py +98 -0
  281. snappy/raytracing/zoom_slider/__init__.py +32 -29
  282. snappy/raytracing/zoom_slider/test.py +2 -0
  283. snappy/sage_helper.py +69 -123
  284. snappy/{preferences.py → settings.py} +167 -145
  285. snappy/shell.py +4 -0
  286. snappy/snap/__init__.py +12 -8
  287. snappy/snap/character_varieties.py +24 -18
  288. snappy/snap/find_field.py +35 -34
  289. snappy/snap/fundamental_polyhedron.py +99 -85
  290. snappy/snap/generators.py +6 -8
  291. snappy/snap/interval_reps.py +18 -6
  292. snappy/snap/kernel_structures.py +8 -3
  293. snappy/snap/mcomplex_base.py +1 -2
  294. snappy/snap/nsagetools.py +107 -53
  295. snappy/snap/peripheral/__init__.py +1 -1
  296. snappy/snap/peripheral/dual_cellulation.py +15 -7
  297. snappy/snap/peripheral/link.py +20 -16
  298. snappy/snap/peripheral/peripheral.py +22 -14
  299. snappy/snap/peripheral/surface.py +47 -50
  300. snappy/snap/peripheral/test.py +8 -8
  301. snappy/snap/polished_reps.py +65 -40
  302. snappy/snap/shapes.py +41 -22
  303. snappy/snap/slice_obs_HKL.py +64 -25
  304. snappy/snap/t3mlite/arrow.py +88 -51
  305. snappy/snap/t3mlite/corner.py +5 -6
  306. snappy/snap/t3mlite/edge.py +32 -21
  307. snappy/snap/t3mlite/face.py +7 -9
  308. snappy/snap/t3mlite/files.py +31 -23
  309. snappy/snap/t3mlite/homology.py +14 -10
  310. snappy/snap/t3mlite/linalg.py +158 -56
  311. snappy/snap/t3mlite/mcomplex.py +739 -291
  312. snappy/snap/t3mlite/perm4.py +236 -84
  313. snappy/snap/t3mlite/setup.py +9 -10
  314. snappy/snap/t3mlite/simplex.py +65 -48
  315. snappy/snap/t3mlite/spun.py +42 -30
  316. snappy/snap/t3mlite/surface.py +45 -45
  317. snappy/snap/t3mlite/test.py +3 -0
  318. snappy/snap/t3mlite/test_vs_regina.py +17 -13
  319. snappy/snap/t3mlite/tetrahedron.py +25 -24
  320. snappy/snap/t3mlite/vertex.py +8 -13
  321. snappy/snap/test.py +45 -52
  322. snappy/snap/utilities.py +66 -65
  323. snappy/test.py +155 -158
  324. snappy/test_cases.py +263 -0
  325. snappy/testing.py +131 -0
  326. snappy/tiling/__init__.py +2 -0
  327. snappy/tiling/canonical_key_dict.py +59 -0
  328. snappy/tiling/dict_based_set.py +79 -0
  329. snappy/tiling/floor.py +49 -0
  330. snappy/tiling/hyperboloid_dict.py +54 -0
  331. snappy/tiling/iter_utils.py +78 -0
  332. snappy/tiling/lifted_tetrahedron.py +22 -0
  333. snappy/tiling/lifted_tetrahedron_set.py +54 -0
  334. snappy/tiling/real_hash_dict.py +164 -0
  335. snappy/tiling/test.py +23 -0
  336. snappy/tiling/tile.py +215 -0
  337. snappy/tiling/triangle.py +33 -0
  338. snappy/tkterminal.py +313 -203
  339. snappy/twister/main.py +1 -8
  340. snappy/twister/twister_core.cpython-38-darwin.so +0 -0
  341. snappy/upper_halfspace/__init__.py +146 -0
  342. snappy/upper_halfspace/ideal_point.py +26 -0
  343. snappy/verify/__init__.py +4 -8
  344. snappy/verify/{verifyCanonical.py → canonical.py} +114 -97
  345. snappy/verify/complex_volume/__init__.py +3 -2
  346. snappy/verify/complex_volume/adjust_torsion.py +13 -11
  347. snappy/verify/complex_volume/closed.py +29 -24
  348. snappy/verify/complex_volume/compute_ptolemys.py +8 -6
  349. snappy/verify/complex_volume/cusped.py +10 -9
  350. snappy/verify/complex_volume/extended_bloch.py +14 -12
  351. snappy/verify/{cuspTranslations.py → cusp_translations.py} +15 -14
  352. snappy/verify/edge_equations.py +80 -0
  353. snappy/verify/exceptions.py +23 -56
  354. snappy/verify/{verifyHyperbolicity.py → hyperbolicity.py} +19 -15
  355. snappy/verify/interval_newton_shapes_engine.py +51 -211
  356. snappy/verify/interval_tree.py +27 -25
  357. snappy/verify/krawczyk_shapes_engine.py +47 -50
  358. snappy/verify/maximal_cusp_area_matrix/__init__.py +17 -86
  359. snappy/verify/maximal_cusp_area_matrix/cusp_tiling_engine.py +58 -48
  360. snappy/verify/maximal_cusp_area_matrix/cusp_translate_engine.py +53 -57
  361. snappy/verify/{realAlgebra.py → real_algebra.py} +26 -20
  362. snappy/verify/shapes.py +10 -7
  363. snappy/verify/short_slopes.py +41 -42
  364. snappy/verify/{squareExtensions.py → square_extensions.py} +96 -92
  365. snappy/verify/test.py +59 -57
  366. snappy/verify/upper_halfspace/extended_matrix.py +5 -5
  367. snappy/verify/upper_halfspace/finite_point.py +44 -31
  368. snappy/verify/upper_halfspace/ideal_point.py +69 -57
  369. snappy/verify/volume.py +15 -12
  370. snappy/version.py +2 -3
  371. {snappy-3.0.3.dist-info → snappy-3.2.dist-info}/METADATA +14 -12
  372. snappy-3.2.dist-info/RECORD +503 -0
  373. {snappy-3.0.3.dist-info → snappy-3.2.dist-info}/WHEEL +1 -1
  374. {snappy-3.0.3.dist-info → snappy-3.2.dist-info}/entry_points.txt +0 -1
  375. {snappy-3.0.3.dist-info → snappy-3.2.dist-info}/top_level.txt +10 -1
  376. snappy/doc/_sources/verify_canon.rst.txt +0 -90
  377. snappy/doc/_static/classic.css +0 -266
  378. snappy/doc/_static/jquery-3.5.1.js +0 -10872
  379. snappy/doc/_static/sidebar.js +0 -159
  380. snappy/doc/_static/underscore-1.13.1.js +0 -2042
  381. snappy/doc/_static/underscore.js +0 -6
  382. snappy/doc/verify_canon.html +0 -283
  383. snappy/ppm_to_png.py +0 -243
  384. snappy/togl/__init__.py +0 -3
  385. snappy/togl/darwin-tk8.6/Togl2.1/LICENSE +0 -28
  386. snappy/togl/darwin-tk8.6/Togl2.1/libTogl2.1.dylib +0 -0
  387. snappy/togl/darwin-tk8.6/Togl2.1/pkgIndex.tcl +0 -5
  388. snappy/togl/linux2-x86_64-tk8.6/Togl2.1/LICENSE +0 -28
  389. snappy/togl/linux2-x86_64-tk8.6/Togl2.1/libTogl2.1.so +0 -0
  390. snappy/togl/linux2-x86_64-tk8.6/Togl2.1/pkgIndex.tcl +0 -5
  391. snappy/togl/win32VC-tk8.6/Togl2.1/LICENSE +0 -28
  392. snappy/togl/win32VC-tk8.6/Togl2.1/Togl21.dll +0 -0
  393. snappy/togl/win32VC-tk8.6/Togl2.1/Togl21.lib +0 -0
  394. snappy/togl/win32VC-tk8.6/Togl2.1/pkgIndex.tcl +0 -6
  395. snappy/togl/win32VC-x86_64-tk8.6/Togl2.1/LICENSE +0 -28
  396. snappy/togl/win32VC-x86_64-tk8.6/Togl2.1/Togl21.dll +0 -0
  397. snappy/togl/win32VC-x86_64-tk8.6/Togl2.1/Togl21.lib +0 -0
  398. snappy/togl/win32VC-x86_64-tk8.6/Togl2.1/pkgIndex.tcl +0 -6
  399. snappy/verify/cuspCrossSection.py +0 -1413
  400. snappy/verify/mathHelpers.py +0 -64
  401. snappy-3.0.3.dist-info/RECORD +0 -360
@@ -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
+
@@ -1,6 +1,7 @@
1
1
  # -*- coding: utf-8 -*-
2
- from __future__ import unicode_literals
3
- import sys, os, datetime
2
+ import sys
3
+ import os
4
+ import datetime
4
5
  from .gui import *
5
6
  from .version import version as SnapPy_version
6
7
  from IPython import __version__ as IPython_version
@@ -8,38 +9,34 @@ from IPython import __version__ as IPython_version
8
9
  snappy_path = os.path.dirname(__file__)
9
10
  icon_file = os.path.join(snappy_path, 'info_icon.gif')
10
11
 
11
- class InfoDialog(Dialog):
12
- def __init__(self, master, title='', content=''):
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)
13
20
  self.content = content
14
- self.style = ttk.Style(master)
15
21
  self.image = Tk_.PhotoImage(file=icon_file)
16
- Dialog.__init__(self, master, title=title)
17
-
18
- def body(self, master):
22
+ self.style = SnapPyStyle()
23
+ self.body()
24
+
25
+ def body(self):
19
26
  self.resizable(False, False)
20
27
  box = ttk.Frame(self)
21
28
  icon = ttk.Label(box, image=self.image)
22
29
  icon.grid(row=0, column=0, pady=30, sticky=Tk_.N)
23
- if sys.platform == 'darwin':
24
- message = Tk_.Message(box, text=self.content)
25
- else:
26
- bgColor=self.style.lookup('Button', 'background')
27
- message = Tk_.Message(box, text=self.content, bg=bgColor)
30
+ message = Tk_.Message(box, text=self.content)
28
31
  message.grid(row=0, column=1, padx=20, pady=10)
29
32
  box.pack()
30
33
 
31
- def buttonbox(self):
32
- box = ttk.Frame(self, padding=(0, 0, 0, 20))
33
- if sys.platform in ('linux', 'linux2'):
34
- # Work around a bug in linux Tk by using a clunky Tk button.
35
- w = Tk_.Button(box, text="OK", width=10, command=self.ok, default=Tk_.ACTIVE)
36
- else:
37
- w = ttk.Button(box, text="OK", width=10, command=self.ok, default=Tk_.ACTIVE)
38
- w.grid(padx=5, pady=5)
39
- self.bind("<Return>", self.ok)
40
- self.bind("<Escape>", self.ok)
41
- box.pack()
42
-
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
+
43
40
  about_snappy_text = """
44
41
  For information on how to use SnapPy, please see the Help menu.
45
42
 
@@ -51,16 +48,18 @@ This is version %s of SnapPy, running on Python %s using Tk %s and IPython %s.
51
48
 
52
49
  Development of SnapPy was made possible in part by generous support from the National Science Foundation of the United States.
53
50
 
54
- 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.
55
- """% (SnapPy_version,
56
- sys.version.split()[0],
57
- Tk_.Tcl().eval('info patchlevel'),
58
- IPython_version,
59
- datetime.datetime.now().year)
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
+
60
58
 
61
59
  def about_snappy(window):
62
- InfoDialog(window, 'About SnapPy', about_snappy_text)
60
+ return InfoWindow(window, 'About SnapPy', about_snappy_text, 'about_snappy')
61
+
63
62
 
64
63
  if __name__ == '__main__':
65
64
  root = Tk_.Tk()
66
- info = InfoDialog(root, title='About SnapPy', content=about_snappy_text)
65
+ info = InfoWindow(root, title='About SnapPy', content=about_snappy_text)