netgen-mesher 6.2.2506.post35.dev0__cp314-cp314-win_amd64.whl

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (340) hide show
  1. netgen/NgOCC.py +7 -0
  2. netgen/__init__.py +114 -0
  3. netgen/__init__.pyi +22 -0
  4. netgen/__main__.py +53 -0
  5. netgen/cmake/NetgenConfig.cmake +79 -0
  6. netgen/cmake/netgen-targets-release.cmake +69 -0
  7. netgen/cmake/netgen-targets.cmake +146 -0
  8. netgen/config/__init__.py +1 -0
  9. netgen/config/__init__.pyi +52 -0
  10. netgen/config/__main__.py +4 -0
  11. netgen/config/config.py +68 -0
  12. netgen/config/config.pyi +54 -0
  13. netgen/csg.py +25 -0
  14. netgen/geom2d.py +178 -0
  15. netgen/gui.py +82 -0
  16. netgen/include/core/archive.hpp +1256 -0
  17. netgen/include/core/array.hpp +1760 -0
  18. netgen/include/core/autodiff.hpp +1131 -0
  19. netgen/include/core/autodiffdiff.hpp +733 -0
  20. netgen/include/core/bitarray.hpp +240 -0
  21. netgen/include/core/concurrentqueue.h +3619 -0
  22. netgen/include/core/exception.hpp +145 -0
  23. netgen/include/core/flags.hpp +199 -0
  24. netgen/include/core/hashtable.hpp +1281 -0
  25. netgen/include/core/localheap.hpp +318 -0
  26. netgen/include/core/logging.hpp +117 -0
  27. netgen/include/core/memtracer.hpp +221 -0
  28. netgen/include/core/mpi4py_pycapi.h +245 -0
  29. netgen/include/core/mpi_wrapper.hpp +643 -0
  30. netgen/include/core/ng_mpi.hpp +94 -0
  31. netgen/include/core/ng_mpi_generated_declarations.hpp +155 -0
  32. netgen/include/core/ng_mpi_native.hpp +25 -0
  33. netgen/include/core/ngcore.hpp +32 -0
  34. netgen/include/core/ngcore_api.hpp +152 -0
  35. netgen/include/core/ngstream.hpp +115 -0
  36. netgen/include/core/paje_trace.hpp +279 -0
  37. netgen/include/core/profiler.hpp +382 -0
  38. netgen/include/core/python_ngcore.hpp +457 -0
  39. netgen/include/core/ranges.hpp +109 -0
  40. netgen/include/core/register_archive.hpp +100 -0
  41. netgen/include/core/signal.hpp +82 -0
  42. netgen/include/core/simd.hpp +160 -0
  43. netgen/include/core/simd_arm64.hpp +407 -0
  44. netgen/include/core/simd_avx.hpp +394 -0
  45. netgen/include/core/simd_avx512.hpp +285 -0
  46. netgen/include/core/simd_generic.hpp +1053 -0
  47. netgen/include/core/simd_math.hpp +178 -0
  48. netgen/include/core/simd_sse.hpp +289 -0
  49. netgen/include/core/statushandler.hpp +37 -0
  50. netgen/include/core/symboltable.hpp +153 -0
  51. netgen/include/core/table.hpp +810 -0
  52. netgen/include/core/taskmanager.hpp +1161 -0
  53. netgen/include/core/type_traits.hpp +65 -0
  54. netgen/include/core/utils.hpp +385 -0
  55. netgen/include/core/version.hpp +102 -0
  56. netgen/include/core/xbool.hpp +47 -0
  57. netgen/include/csg/algprim.hpp +563 -0
  58. netgen/include/csg/brick.hpp +150 -0
  59. netgen/include/csg/csg.hpp +43 -0
  60. netgen/include/csg/csgeom.hpp +389 -0
  61. netgen/include/csg/csgparser.hpp +101 -0
  62. netgen/include/csg/curve2d.hpp +67 -0
  63. netgen/include/csg/edgeflw.hpp +112 -0
  64. netgen/include/csg/explicitcurve2d.hpp +113 -0
  65. netgen/include/csg/extrusion.hpp +185 -0
  66. netgen/include/csg/gencyl.hpp +70 -0
  67. netgen/include/csg/geoml.hpp +16 -0
  68. netgen/include/csg/identify.hpp +213 -0
  69. netgen/include/csg/manifold.hpp +29 -0
  70. netgen/include/csg/meshsurf.hpp +46 -0
  71. netgen/include/csg/polyhedra.hpp +121 -0
  72. netgen/include/csg/revolution.hpp +180 -0
  73. netgen/include/csg/singularref.hpp +84 -0
  74. netgen/include/csg/solid.hpp +295 -0
  75. netgen/include/csg/specpoin.hpp +194 -0
  76. netgen/include/csg/spline3d.hpp +99 -0
  77. netgen/include/csg/splinesurface.hpp +85 -0
  78. netgen/include/csg/surface.hpp +394 -0
  79. netgen/include/csg/triapprox.hpp +63 -0
  80. netgen/include/csg/vscsg.hpp +34 -0
  81. netgen/include/general/autodiff.hpp +356 -0
  82. netgen/include/general/autoptr.hpp +39 -0
  83. netgen/include/general/gzstream.h +121 -0
  84. netgen/include/general/hashtabl.hpp +1692 -0
  85. netgen/include/general/myadt.hpp +48 -0
  86. netgen/include/general/mystring.hpp +226 -0
  87. netgen/include/general/netgenout.hpp +205 -0
  88. netgen/include/general/ngarray.hpp +797 -0
  89. netgen/include/general/ngbitarray.hpp +149 -0
  90. netgen/include/general/ngpython.hpp +74 -0
  91. netgen/include/general/optmem.hpp +44 -0
  92. netgen/include/general/parthreads.hpp +138 -0
  93. netgen/include/general/seti.hpp +50 -0
  94. netgen/include/general/sort.hpp +47 -0
  95. netgen/include/general/spbita2d.hpp +59 -0
  96. netgen/include/general/stack.hpp +114 -0
  97. netgen/include/general/table.hpp +280 -0
  98. netgen/include/general/template.hpp +509 -0
  99. netgen/include/geom2d/csg2d.hpp +750 -0
  100. netgen/include/geom2d/geometry2d.hpp +280 -0
  101. netgen/include/geom2d/spline2d.hpp +234 -0
  102. netgen/include/geom2d/vsgeom2d.hpp +28 -0
  103. netgen/include/gprim/adtree.hpp +1392 -0
  104. netgen/include/gprim/geom2d.hpp +858 -0
  105. netgen/include/gprim/geom3d.hpp +749 -0
  106. netgen/include/gprim/geomfuncs.hpp +212 -0
  107. netgen/include/gprim/geomobjects.hpp +544 -0
  108. netgen/include/gprim/geomops.hpp +404 -0
  109. netgen/include/gprim/geomtest3d.hpp +101 -0
  110. netgen/include/gprim/gprim.hpp +33 -0
  111. netgen/include/gprim/spline.hpp +778 -0
  112. netgen/include/gprim/splinegeometry.hpp +73 -0
  113. netgen/include/gprim/transform3d.hpp +216 -0
  114. netgen/include/include/acisgeom.hpp +3 -0
  115. netgen/include/include/csg.hpp +1 -0
  116. netgen/include/include/geometry2d.hpp +1 -0
  117. netgen/include/include/gprim.hpp +1 -0
  118. netgen/include/include/incopengl.hpp +62 -0
  119. netgen/include/include/inctcl.hpp +13 -0
  120. netgen/include/include/incvis.hpp +6 -0
  121. netgen/include/include/linalg.hpp +1 -0
  122. netgen/include/include/meshing.hpp +1 -0
  123. netgen/include/include/myadt.hpp +1 -0
  124. netgen/include/include/mydefs.hpp +70 -0
  125. netgen/include/include/mystdlib.h +59 -0
  126. netgen/include/include/netgen_config.hpp +27 -0
  127. netgen/include/include/netgen_version.hpp +9 -0
  128. netgen/include/include/nginterface_v2_impl.hpp +395 -0
  129. netgen/include/include/ngsimd.hpp +1 -0
  130. netgen/include/include/occgeom.hpp +1 -0
  131. netgen/include/include/opti.hpp +1 -0
  132. netgen/include/include/parallel.hpp +1 -0
  133. netgen/include/include/stlgeom.hpp +1 -0
  134. netgen/include/include/visual.hpp +1 -0
  135. netgen/include/interface/rw_medit.hpp +11 -0
  136. netgen/include/interface/writeuser.hpp +80 -0
  137. netgen/include/linalg/densemat.hpp +414 -0
  138. netgen/include/linalg/linalg.hpp +29 -0
  139. netgen/include/linalg/opti.hpp +142 -0
  140. netgen/include/linalg/polynomial.hpp +47 -0
  141. netgen/include/linalg/vector.hpp +217 -0
  142. netgen/include/meshing/adfront2.hpp +274 -0
  143. netgen/include/meshing/adfront3.hpp +332 -0
  144. netgen/include/meshing/basegeom.hpp +370 -0
  145. netgen/include/meshing/bcfunctions.hpp +53 -0
  146. netgen/include/meshing/bisect.hpp +72 -0
  147. netgen/include/meshing/boundarylayer.hpp +113 -0
  148. netgen/include/meshing/classifyhpel.hpp +1984 -0
  149. netgen/include/meshing/clusters.hpp +46 -0
  150. netgen/include/meshing/curvedelems.hpp +274 -0
  151. netgen/include/meshing/delaunay2d.hpp +73 -0
  152. netgen/include/meshing/fieldlines.hpp +103 -0
  153. netgen/include/meshing/findip.hpp +198 -0
  154. netgen/include/meshing/findip2.hpp +103 -0
  155. netgen/include/meshing/geomsearch.hpp +69 -0
  156. netgen/include/meshing/global.hpp +54 -0
  157. netgen/include/meshing/hpref_hex.hpp +330 -0
  158. netgen/include/meshing/hpref_prism.hpp +3405 -0
  159. netgen/include/meshing/hpref_pyramid.hpp +154 -0
  160. netgen/include/meshing/hpref_quad.hpp +2082 -0
  161. netgen/include/meshing/hpref_segm.hpp +122 -0
  162. netgen/include/meshing/hpref_tet.hpp +4230 -0
  163. netgen/include/meshing/hpref_trig.hpp +848 -0
  164. netgen/include/meshing/hprefinement.hpp +366 -0
  165. netgen/include/meshing/improve2.hpp +178 -0
  166. netgen/include/meshing/improve3.hpp +151 -0
  167. netgen/include/meshing/localh.hpp +223 -0
  168. netgen/include/meshing/meshclass.hpp +1076 -0
  169. netgen/include/meshing/meshfunc.hpp +47 -0
  170. netgen/include/meshing/meshing.hpp +63 -0
  171. netgen/include/meshing/meshing2.hpp +163 -0
  172. netgen/include/meshing/meshing3.hpp +123 -0
  173. netgen/include/meshing/meshtool.hpp +90 -0
  174. netgen/include/meshing/meshtype.hpp +1930 -0
  175. netgen/include/meshing/msghandler.hpp +62 -0
  176. netgen/include/meshing/paralleltop.hpp +172 -0
  177. netgen/include/meshing/python_mesh.hpp +206 -0
  178. netgen/include/meshing/ruler2.hpp +172 -0
  179. netgen/include/meshing/ruler3.hpp +211 -0
  180. netgen/include/meshing/soldata.hpp +141 -0
  181. netgen/include/meshing/specials.hpp +17 -0
  182. netgen/include/meshing/surfacegeom.hpp +73 -0
  183. netgen/include/meshing/topology.hpp +1003 -0
  184. netgen/include/meshing/validate.hpp +21 -0
  185. netgen/include/meshing/visual_interface.hpp +71 -0
  186. netgen/include/mydefs.hpp +70 -0
  187. netgen/include/nginterface.h +474 -0
  188. netgen/include/nginterface_v2.hpp +406 -0
  189. netgen/include/nglib.h +697 -0
  190. netgen/include/nglib_occ.h +50 -0
  191. netgen/include/occ/occ_edge.hpp +47 -0
  192. netgen/include/occ/occ_face.hpp +52 -0
  193. netgen/include/occ/occ_solid.hpp +23 -0
  194. netgen/include/occ/occ_utils.hpp +376 -0
  195. netgen/include/occ/occ_vertex.hpp +30 -0
  196. netgen/include/occ/occgeom.hpp +659 -0
  197. netgen/include/occ/occmeshsurf.hpp +168 -0
  198. netgen/include/occ/vsocc.hpp +33 -0
  199. netgen/include/pybind11/LICENSE +29 -0
  200. netgen/include/pybind11/attr.h +722 -0
  201. netgen/include/pybind11/buffer_info.h +208 -0
  202. netgen/include/pybind11/cast.h +2361 -0
  203. netgen/include/pybind11/chrono.h +228 -0
  204. netgen/include/pybind11/common.h +2 -0
  205. netgen/include/pybind11/complex.h +74 -0
  206. netgen/include/pybind11/conduit/README.txt +15 -0
  207. netgen/include/pybind11/conduit/pybind11_conduit_v1.h +116 -0
  208. netgen/include/pybind11/conduit/pybind11_platform_abi_id.h +87 -0
  209. netgen/include/pybind11/conduit/wrap_include_python_h.h +72 -0
  210. netgen/include/pybind11/critical_section.h +56 -0
  211. netgen/include/pybind11/detail/class.h +823 -0
  212. netgen/include/pybind11/detail/common.h +1348 -0
  213. netgen/include/pybind11/detail/cpp_conduit.h +75 -0
  214. netgen/include/pybind11/detail/descr.h +226 -0
  215. netgen/include/pybind11/detail/dynamic_raw_ptr_cast_if_possible.h +39 -0
  216. netgen/include/pybind11/detail/exception_translation.h +71 -0
  217. netgen/include/pybind11/detail/function_record_pyobject.h +191 -0
  218. netgen/include/pybind11/detail/init.h +538 -0
  219. netgen/include/pybind11/detail/internals.h +799 -0
  220. netgen/include/pybind11/detail/native_enum_data.h +209 -0
  221. netgen/include/pybind11/detail/pybind11_namespace_macros.h +82 -0
  222. netgen/include/pybind11/detail/struct_smart_holder.h +378 -0
  223. netgen/include/pybind11/detail/type_caster_base.h +1591 -0
  224. netgen/include/pybind11/detail/typeid.h +65 -0
  225. netgen/include/pybind11/detail/using_smart_holder.h +22 -0
  226. netgen/include/pybind11/detail/value_and_holder.h +90 -0
  227. netgen/include/pybind11/eigen/common.h +9 -0
  228. netgen/include/pybind11/eigen/matrix.h +723 -0
  229. netgen/include/pybind11/eigen/tensor.h +521 -0
  230. netgen/include/pybind11/eigen.h +12 -0
  231. netgen/include/pybind11/embed.h +320 -0
  232. netgen/include/pybind11/eval.h +161 -0
  233. netgen/include/pybind11/functional.h +147 -0
  234. netgen/include/pybind11/gil.h +199 -0
  235. netgen/include/pybind11/gil_safe_call_once.h +102 -0
  236. netgen/include/pybind11/gil_simple.h +37 -0
  237. netgen/include/pybind11/iostream.h +265 -0
  238. netgen/include/pybind11/native_enum.h +67 -0
  239. netgen/include/pybind11/numpy.h +2312 -0
  240. netgen/include/pybind11/operators.h +202 -0
  241. netgen/include/pybind11/options.h +92 -0
  242. netgen/include/pybind11/pybind11.h +3645 -0
  243. netgen/include/pybind11/pytypes.h +2680 -0
  244. netgen/include/pybind11/stl/filesystem.h +114 -0
  245. netgen/include/pybind11/stl.h +666 -0
  246. netgen/include/pybind11/stl_bind.h +858 -0
  247. netgen/include/pybind11/subinterpreter.h +299 -0
  248. netgen/include/pybind11/trampoline_self_life_support.h +65 -0
  249. netgen/include/pybind11/type_caster_pyobject_ptr.h +61 -0
  250. netgen/include/pybind11/typing.h +298 -0
  251. netgen/include/pybind11/warnings.h +75 -0
  252. netgen/include/stlgeom/meshstlsurface.hpp +67 -0
  253. netgen/include/stlgeom/stlgeom.hpp +491 -0
  254. netgen/include/stlgeom/stlline.hpp +193 -0
  255. netgen/include/stlgeom/stltool.hpp +331 -0
  256. netgen/include/stlgeom/stltopology.hpp +419 -0
  257. netgen/include/stlgeom/vsstl.hpp +58 -0
  258. netgen/include/visualization/meshdoc.hpp +42 -0
  259. netgen/include/visualization/mvdraw.hpp +325 -0
  260. netgen/include/visualization/vispar.hpp +128 -0
  261. netgen/include/visualization/visual.hpp +28 -0
  262. netgen/include/visualization/visual_api.hpp +10 -0
  263. netgen/include/visualization/vssolution.hpp +399 -0
  264. netgen/lib/libnggui.lib +0 -0
  265. netgen/lib/ngcore.lib +0 -0
  266. netgen/lib/nglib.lib +0 -0
  267. netgen/lib/togl.lib +0 -0
  268. netgen/libnggui.dll +0 -0
  269. netgen/libngguipy.lib +0 -0
  270. netgen/libngguipy.pyd +0 -0
  271. netgen/libngpy/_NgOCC.pyi +1545 -0
  272. netgen/libngpy/__init__.pyi +7 -0
  273. netgen/libngpy/_csg.pyi +259 -0
  274. netgen/libngpy/_geom2d.pyi +323 -0
  275. netgen/libngpy/_meshing.pyi +1111 -0
  276. netgen/libngpy/_stl.pyi +131 -0
  277. netgen/libngpy.lib +0 -0
  278. netgen/libngpy.pyd +0 -0
  279. netgen/meshing.py +65 -0
  280. netgen/ngcore.dll +0 -0
  281. netgen/nglib.dll +0 -0
  282. netgen/occ.py +52 -0
  283. netgen/read_gmsh.py +259 -0
  284. netgen/read_meshio.py +22 -0
  285. netgen/stl.py +2 -0
  286. netgen/togl.dll +0 -0
  287. netgen/version.py +2 -0
  288. netgen/webgui.py +529 -0
  289. netgen_mesher-6.2.2506.post35.dev0.data/data/share/netgen/boundarycondition.geo +16 -0
  290. netgen_mesher-6.2.2506.post35.dev0.data/data/share/netgen/boxcyl.geo +32 -0
  291. netgen_mesher-6.2.2506.post35.dev0.data/data/share/netgen/circle_on_cube.geo +27 -0
  292. netgen_mesher-6.2.2506.post35.dev0.data/data/share/netgen/cone.geo +13 -0
  293. netgen_mesher-6.2.2506.post35.dev0.data/data/share/netgen/cube.geo +16 -0
  294. netgen_mesher-6.2.2506.post35.dev0.data/data/share/netgen/cubeandring.geo +55 -0
  295. netgen_mesher-6.2.2506.post35.dev0.data/data/share/netgen/cubeandspheres.geo +21 -0
  296. netgen_mesher-6.2.2506.post35.dev0.data/data/share/netgen/cubemcyl.geo +18 -0
  297. netgen_mesher-6.2.2506.post35.dev0.data/data/share/netgen/cubemsphere.geo +19 -0
  298. netgen_mesher-6.2.2506.post35.dev0.data/data/share/netgen/cylinder.geo +12 -0
  299. netgen_mesher-6.2.2506.post35.dev0.data/data/share/netgen/cylsphere.geo +12 -0
  300. netgen_mesher-6.2.2506.post35.dev0.data/data/share/netgen/doc/ng4.pdf +0 -0
  301. netgen_mesher-6.2.2506.post35.dev0.data/data/share/netgen/ellipsoid.geo +8 -0
  302. netgen_mesher-6.2.2506.post35.dev0.data/data/share/netgen/ellipticcyl.geo +10 -0
  303. netgen_mesher-6.2.2506.post35.dev0.data/data/share/netgen/extrusion.geo +99 -0
  304. netgen_mesher-6.2.2506.post35.dev0.data/data/share/netgen/fichera.geo +24 -0
  305. netgen_mesher-6.2.2506.post35.dev0.data/data/share/netgen/frame.step +11683 -0
  306. netgen_mesher-6.2.2506.post35.dev0.data/data/share/netgen/hinge.stl +8486 -0
  307. netgen_mesher-6.2.2506.post35.dev0.data/data/share/netgen/lshape3d.geo +26 -0
  308. netgen_mesher-6.2.2506.post35.dev0.data/data/share/netgen/manyholes.geo +26 -0
  309. netgen_mesher-6.2.2506.post35.dev0.data/data/share/netgen/manyholes2.geo +26 -0
  310. netgen_mesher-6.2.2506.post35.dev0.data/data/share/netgen/matrix.geo +27 -0
  311. netgen_mesher-6.2.2506.post35.dev0.data/data/share/netgen/ortho.geo +11 -0
  312. netgen_mesher-6.2.2506.post35.dev0.data/data/share/netgen/part1.stl +2662 -0
  313. netgen_mesher-6.2.2506.post35.dev0.data/data/share/netgen/period.geo +33 -0
  314. netgen_mesher-6.2.2506.post35.dev0.data/data/share/netgen/py_tutorials/exportNeutral.py +26 -0
  315. netgen_mesher-6.2.2506.post35.dev0.data/data/share/netgen/py_tutorials/mesh.py +19 -0
  316. netgen_mesher-6.2.2506.post35.dev0.data/data/share/netgen/py_tutorials/shaft.geo +65 -0
  317. netgen_mesher-6.2.2506.post35.dev0.data/data/share/netgen/revolution.geo +18 -0
  318. netgen_mesher-6.2.2506.post35.dev0.data/data/share/netgen/screw.step +1694 -0
  319. netgen_mesher-6.2.2506.post35.dev0.data/data/share/netgen/sculpture.geo +13 -0
  320. netgen_mesher-6.2.2506.post35.dev0.data/data/share/netgen/shaft.geo +65 -0
  321. netgen_mesher-6.2.2506.post35.dev0.data/data/share/netgen/shell.geo +10 -0
  322. netgen_mesher-6.2.2506.post35.dev0.data/data/share/netgen/sphere.geo +8 -0
  323. netgen_mesher-6.2.2506.post35.dev0.data/data/share/netgen/sphereincube.geo +17 -0
  324. netgen_mesher-6.2.2506.post35.dev0.data/data/share/netgen/square.in2d +35 -0
  325. netgen_mesher-6.2.2506.post35.dev0.data/data/share/netgen/squarecircle.in2d +48 -0
  326. netgen_mesher-6.2.2506.post35.dev0.data/data/share/netgen/squarehole.in2d +47 -0
  327. netgen_mesher-6.2.2506.post35.dev0.data/data/share/netgen/torus.geo +8 -0
  328. netgen_mesher-6.2.2506.post35.dev0.data/data/share/netgen/trafo.geo +57 -0
  329. netgen_mesher-6.2.2506.post35.dev0.data/data/share/netgen/twobricks.geo +15 -0
  330. netgen_mesher-6.2.2506.post35.dev0.data/data/share/netgen/twocubes.geo +18 -0
  331. netgen_mesher-6.2.2506.post35.dev0.data/data/share/netgen/twocyl.geo +16 -0
  332. netgen_mesher-6.2.2506.post35.dev0.dist-info/METADATA +15 -0
  333. netgen_mesher-6.2.2506.post35.dev0.dist-info/RECORD +340 -0
  334. netgen_mesher-6.2.2506.post35.dev0.dist-info/WHEEL +5 -0
  335. netgen_mesher-6.2.2506.post35.dev0.dist-info/entry_points.txt +2 -0
  336. netgen_mesher-6.2.2506.post35.dev0.dist-info/licenses/AUTHORS +1 -0
  337. netgen_mesher-6.2.2506.post35.dev0.dist-info/licenses/LICENSE +504 -0
  338. netgen_mesher-6.2.2506.post35.dev0.dist-info/top_level.txt +2 -0
  339. pyngcore/__init__.py +1 -0
  340. pyngcore/pyngcore.cp314-win_amd64.pyd +0 -0
@@ -0,0 +1,73 @@
1
+ /*
2
+
3
+
4
+ JS, Nov 2007
5
+
6
+
7
+ The 2D/3D template-base classes should go into the libsrc/gprim directory
8
+
9
+ in geom2d only 2D - Geometry classes (with material properties etc.)
10
+
11
+
12
+ */
13
+
14
+ #include "spline.hpp"
15
+
16
+
17
+ #ifndef _FILE_SPLINEGEOMETRY
18
+ #define _FILE_SPLINEGEOMETRY
19
+
20
+ namespace netgen
21
+ {
22
+
23
+
24
+ template < int D >
25
+ class DLL_HEADER SplineGeometry
26
+ {
27
+ // protected:
28
+ public:
29
+ NgArray < GeomPoint<D> > geompoints;
30
+ NgArray < SplineSeg<D>* > splines;
31
+
32
+ SplineGeometry() : geompoints{}, splines{} { ; }
33
+ virtual ~SplineGeometry();
34
+
35
+ int Load (const NgArray<double> & raw_data, const int startpos = 0);
36
+
37
+ virtual void DoArchive(Archive& ar)
38
+ {
39
+ ar & geompoints & splines;
40
+ }
41
+
42
+ void GetRawData (NgArray<double> & raw_data) const;
43
+
44
+
45
+ const NgArray<SplineSeg<D>*> & GetSplines () const
46
+ { return splines; }
47
+
48
+ int GetNSplines (void) const { return splines.Size(); }
49
+ string GetSplineType (const int i) const { return splines[i]->GetType(); }
50
+ SplineSeg<D> & GetSpline (const int i) {return *splines[i];}
51
+ const SplineSeg<D> & GetSpline (const int i) const {return *splines[i];}
52
+
53
+ void GetBoundingBox (Box<D> & box) const;
54
+ Box<D> GetBoundingBox () const
55
+ { Box<D> box; GetBoundingBox (box); return box; }
56
+
57
+ int GetNP () const { return geompoints.Size(); }
58
+ const GeomPoint<D> & GetPoint(int i) const { return geompoints[i]; }
59
+
60
+ // void SetGrading (const double grading);
61
+ void AppendPoint (const Point<D> & p, const double reffac = 1., const bool hpref = false);
62
+
63
+ void AppendSegment(SplineSeg<D> * spline)
64
+ {
65
+ splines.Append (spline);
66
+ }
67
+ };
68
+
69
+
70
+
71
+ }
72
+
73
+ #endif // _FILE_SPLINEGEOMETRY
@@ -0,0 +1,216 @@
1
+ #ifndef FILE_TRANSFORM3D
2
+ #define FILE_TRANSFORM3D
3
+
4
+ /* *************************************************************************/
5
+ /* File: transform3d.hh */
6
+ /* Author: Joachim Schoeberl */
7
+ /* Date: 22. Mar. 98 */
8
+ /* *************************************************************************/
9
+
10
+ /*
11
+ Affine - Linear mapping in 3D space
12
+ */
13
+
14
+ #include "geom3d.hpp"
15
+ #include "geomfuncs.hpp"
16
+
17
+ namespace netgen
18
+ {
19
+
20
+ class Transformation3d;
21
+ ostream & operator<< (ostream & ost, Transformation3d & trans);
22
+
23
+ class Transformation3d
24
+ {
25
+ double lin[3][3];
26
+ double offset[3];
27
+ public:
28
+ ///
29
+ Transformation3d ();
30
+ /// Unit tet is mapped to tet described by pp
31
+ Transformation3d (const Point3d ** pp);
32
+ /// Unit tet is mapped to tet described by pp
33
+ Transformation3d (const Point3d pp[]);
34
+ /// translation
35
+ Transformation3d (const Vec3d & translate);
36
+ /// rotation with ...
37
+ Transformation3d (const Point3d & c, double alpha, double beta, double gamma);
38
+ ///
39
+ void CalcInverse (Transformation3d & inv) const;
40
+ /// this = ta x tb
41
+ void Combine (const Transformation3d & ta, const Transformation3d & tb);
42
+ /// dir = 1..3 (== x..z)
43
+ void SetAxisRotation (int dir, double alpha);
44
+ ///
45
+ void Transform (const Point3d & from, Point3d & to) const
46
+ {
47
+ for (int i = 1; i <= 3; i++)
48
+ {
49
+ to.X(i) = offset[i-1] + lin[i-1][0] * from.X(1) +
50
+ lin[i-1][1] * from.X(2) + lin[i-1][2] * from.X(3);
51
+ }
52
+ }
53
+
54
+ ///
55
+ void Transform (Point3d & p) const
56
+ {
57
+ Point3d hp;
58
+ Transform (p, hp);
59
+ p = hp;
60
+ }
61
+
62
+ /// transform vector, apply only linear part, not offset
63
+ void Transform (const Vec3d & from, Vec3d & to) const
64
+ {
65
+ for (int i = 1; i <= 3; i++)
66
+ {
67
+ to.X(i) = lin[i-1][0] * from.X(1) +
68
+ lin[i-1][1] * from.X(2) + lin[i-1][2] * from.X(3);
69
+ }
70
+ }
71
+ friend ostream & operator<< (ostream & ost, Transformation3d & trans);
72
+ };
73
+
74
+
75
+
76
+
77
+
78
+
79
+
80
+
81
+
82
+
83
+
84
+
85
+
86
+
87
+ template <int D>
88
+ class Transformation
89
+ {
90
+ Mat<D> m;
91
+ Vec<D> v;
92
+ public:
93
+ ///
94
+ Transformation () { m = 0; v = 0; }
95
+
96
+ /// Unit tet is mapped to tet described by pp
97
+ Transformation (const Point<D> * pp);
98
+
99
+ /// translation
100
+ Transformation (const Vec<D> & translate)
101
+ {
102
+ v = translate;
103
+ m = 0;
104
+ for (int i = 0; i < D; i++)
105
+ m(i,i) = 1;
106
+ }
107
+
108
+ Transformation (const Point<D> & c, const Vec<3> & axes, double angle);
109
+
110
+ // rotation with ...
111
+ Transformation (const Point<D> & c, double alpha, double beta, double gamma)
112
+ {
113
+ // total = T_c x Rot_0 x T_c^{-1}
114
+ // Use Euler angles, see many books from tech mech, e.g.
115
+ // Shabana "multibody systems"
116
+
117
+ Vec<D> vc(c);
118
+ Transformation<D> tc(vc);
119
+ Transformation<D> tcinv(-vc);
120
+ // tc.CalcInverse (tcinv);
121
+
122
+ Transformation<D> r1, r2, r3, ht, ht2;
123
+ r1.SetAxisRotation (3, alpha);
124
+ r2.SetAxisRotation (1, beta);
125
+ r3.SetAxisRotation (3, gamma);
126
+
127
+ ht.Combine (tc, r3);
128
+ ht2.Combine (ht, r2);
129
+ ht.Combine (ht2, r1);
130
+ Combine (ht, tcinv);
131
+
132
+ // cout << "Rotation - Transformation:" << (*this) << endl;
133
+ // (*testout) << "Rotation - Transformation:" << (*this) << endl;
134
+ }
135
+
136
+ Mat<D> & GetMatrix() { return m; }
137
+ Vec<D> & GetVector() { return v; }
138
+
139
+ void DoArchive(Archive& ar)
140
+ {
141
+ ar & m & v;
142
+ }
143
+
144
+ ///
145
+ Transformation CalcInverse () const
146
+ {
147
+ Transformation inv;
148
+ // inv.m = Inv(m);
149
+ ::netgen::CalcInverse (m, inv.m);
150
+ inv.v = inv.m * (-v);
151
+ return inv;
152
+ }
153
+
154
+ /// this = ta x tb
155
+ void Combine (const Transformation & ta, const Transformation & tb)
156
+ {
157
+ v = ta.v + ta.m * tb.v;
158
+ m = ta.m * tb.m;
159
+ }
160
+
161
+
162
+
163
+ /// dir = 1..3 (== x..z)
164
+ void SetAxisRotation (int dir, double alpha)
165
+ {
166
+ double co = cos(alpha);
167
+ double si = sin(alpha);
168
+ dir--;
169
+ int pos1 = (dir+1) % 3;
170
+ int pos2 = (dir+2) % 3;
171
+
172
+ int i, j;
173
+ for (i = 0; i <= 2; i++)
174
+ {
175
+ v(i) = 0;
176
+ for (j = 0; j <= 2; j++)
177
+ m(i,j) = 0;
178
+ }
179
+
180
+ m(dir,dir) = 1;
181
+ m(pos1, pos1) = co;
182
+ m(pos2, pos2) = co;
183
+ m(pos1, pos2) = si;
184
+ m(pos2, pos1) = -si;
185
+ }
186
+
187
+ ///
188
+ void Transform (const Point<D> & from, Point<D> & to) const
189
+ {
190
+ to = Point<D> (v + m * Vec<D>(from));
191
+ }
192
+
193
+ void Transform (Point<D> & p) const
194
+ {
195
+ p = Point<D> (v + m * Vec<D>(p));
196
+ }
197
+
198
+
199
+
200
+ /// transform vector, apply only linear part, not offset
201
+ void Transform (const Vec<D> & from, Vec<D> & to) const
202
+ {
203
+ to = m * from;
204
+ }
205
+
206
+ Point<D> operator() (Point<D> from) const { Point<D> to; Transform(from, to); return to; }
207
+ Vec<D> operator() (Vec<D> from) const { Vec<D> to; Transform(from, to); return to; }
208
+ };
209
+
210
+ template <int D>
211
+ ostream & operator<< (ostream & ost, Transformation<D> & trans);
212
+
213
+
214
+ }
215
+
216
+ #endif
@@ -0,0 +1,3 @@
1
+ #ifdef ACIS
2
+ #include "../acisgeom/acisgeom.hpp"
3
+ #endif
@@ -0,0 +1 @@
1
+ #include "../csg/csg.hpp"
@@ -0,0 +1 @@
1
+ #include "../geom2d/geometry2d.hpp"
@@ -0,0 +1 @@
1
+ #include "../gprim/gprim.hpp"
@@ -0,0 +1,62 @@
1
+ #ifndef INCOPENGL_HPP___
2
+ #define INCOPENGL_HPP___
3
+ #define GL_GLEXT_PROTOTYPES
4
+
5
+ #include <mystdlib.h>
6
+ #include <mydefs.hpp>
7
+
8
+ #ifdef WIN32
9
+ #define WIN32_LEAN_AND_MEAN
10
+ #include <windows.h>
11
+ #endif
12
+
13
+ # ifdef __APPLE__
14
+ #define GL_SILENCE_DEPRECATION
15
+ #define GL_DO_NOT_WARN_IF_MULTI_GL_VERSION_HEADERS_INCLUDED
16
+ # include <OpenGL/gl3.h>
17
+ # include <OpenGL/glu.h>
18
+ # else
19
+ # include <GL/gl.h>
20
+ # include <GL/glu.h>
21
+ # endif
22
+
23
+
24
+ #ifdef TOGL_X11
25
+ // parallel
26
+ #define GLX_GLXEXT_PROTOTYPES
27
+ #include <GL/glx.h>
28
+ #include <GL/glxext.h>
29
+ #endif
30
+
31
+ #ifdef WIN32
32
+ // part of OpenGL 1.2, but not in Microsoft's OpenGL 1.1 header:
33
+ // GL version should be checked at runtime
34
+ #define GL_CLAMP_TO_EDGE 0x812F
35
+ #define GL_ARRAY_BUFFER 0x8892
36
+ #define GL_ELEMENT_ARRAY_BUFFER 0x8893
37
+ #define GL_STATIC_DRAW 0x88E4
38
+ #define GL_FRAMEBUFFER_COMPLETE 0x8CD5
39
+ #define GL_FRAMEBUFFER 0x8D40
40
+ #define GL_RENDERBUFFER 0x8D41
41
+ #define GL_DEPTH_ATTACHMENT 0x8D00
42
+ #define GL_COLOR_ATTACHMENT0 0x8CE0
43
+ typedef ptrdiff_t GLintptr;
44
+ typedef ptrdiff_t GLsizeiptr;
45
+ extern void (*glBindBuffer) (GLenum a, GLuint b);
46
+ extern void (*glDeleteBuffers) (GLsizei a, const GLuint *b);
47
+ extern void (*glGenBuffers) (GLsizei a, GLuint *b);
48
+ extern void (*glBufferData) (GLenum a, GLsizeiptr b, const GLvoid *c, GLenum d);
49
+ extern void (*glBufferSubData) (GLenum a, GLintptr b, GLsizeiptr c, const GLvoid *d);
50
+
51
+ extern GLenum (*glCheckFramebufferStatus) (GLenum target);
52
+ extern void (*glBindFramebuffer) (GLenum target, GLuint framebuffer);
53
+ extern void (*glBindRenderbuffer) (GLenum target, GLuint renderbuffer);
54
+ extern void (*glDeleteFramebuffers) (GLsizei n, const GLuint *framebuffers);
55
+ extern void (*glDeleteRenderbuffers) (GLsizei n, const GLuint *renderbuffers);
56
+ extern void (*glGenFramebuffers) (GLsizei n, GLuint *framebuffers);
57
+ extern void (*glGenRenderbuffers) (GLsizei n, GLuint *renderbuffers);
58
+ extern void (*glRenderbufferStorage) (GLenum target, GLenum internalformat, GLsizei width, GLsizei height);
59
+ extern void (*glFramebufferRenderbuffer) (GLenum target, GLenum attachment, GLenum renderbuffertarget, GLuint renderbuffer);
60
+ #endif
61
+ DLL_HEADER void LoadOpenGLFunctionPointers();
62
+ #endif // INCOPENGL_HPP___
@@ -0,0 +1,13 @@
1
+ #ifdef WIN32
2
+ #define WIN32_LEAN_AND_MEAN
3
+ #include <windows.h>
4
+ #endif
5
+
6
+ #include <tcl.h>
7
+ #include <tk.h>
8
+
9
+ #if TK_MAJOR_VERSION==8 && TK_MINOR_VERSION>=4
10
+ #define tcl_const const
11
+ #else
12
+ #define tcl_const
13
+ #endif
@@ -0,0 +1,6 @@
1
+ // libraries for User interface:
2
+
3
+ nicht mehr verwendet
4
+
5
+ #include "inctcl.hpp"
6
+ #include "incopengl.hpp"
@@ -0,0 +1 @@
1
+ #include "../linalg/linalg.hpp"
@@ -0,0 +1 @@
1
+ #include <../meshing/meshing.hpp>
@@ -0,0 +1 @@
1
+ #include <../general/myadt.hpp>
@@ -0,0 +1,70 @@
1
+ #ifndef FILE_MYDEFS
2
+ #define FILE_MYDEFS
3
+
4
+ /**************************************************************************/
5
+ /* File: mydefs.hh */
6
+ /* Author: Joachim Schoeberl */
7
+ /* Date: 10. Mar. 98 */
8
+ /**************************************************************************/
9
+
10
+ /*
11
+ defines for graphics, testmodes, ...
12
+ */
13
+
14
+ #include <core/ngcore.hpp>
15
+ #define PACKAGE_VERSION "6.2-dev"
16
+
17
+ // #define DEBUG
18
+
19
+ #if defined(nglib_EXPORTS)
20
+ #define DLL_HEADER NGCORE_API_EXPORT
21
+ #else
22
+ #define DLL_HEADER NGCORE_API_IMPORT
23
+ #endif
24
+
25
+
26
+
27
+
28
+ #ifndef __assume
29
+ #ifdef __GNUC__
30
+ #define __assume(cond) if (!(cond)) __builtin_unreachable(); else;
31
+ #else
32
+ #define __assume(cond)
33
+ #endif
34
+ #endif
35
+
36
+
37
+ #ifndef NG_INLINE
38
+ #ifdef __INTEL_COMPILER
39
+ #ifdef WIN32
40
+ #define NG_INLINE __forceinline inline
41
+ #else
42
+ #define NG_INLINE __forceinline inline
43
+ #endif
44
+ #else
45
+ #ifdef __GNUC__
46
+ #define NG_INLINE __attribute__ ((__always_inline__)) inline
47
+ #define VLA
48
+ #else
49
+ #define NG_INLINE inline
50
+ #endif
51
+ #endif
52
+ #endif
53
+
54
+
55
+ // #define BASE0
56
+ // #define DEBUG
57
+
58
+
59
+ #define noDEMOVERSION
60
+ #define noDEVELOP
61
+ #define noSTEP
62
+ #define noSOLIDGEOM
63
+
64
+ #define noDEMOAPP
65
+ #define noMODELLER
66
+
67
+ #define noSTAT_STREAM
68
+ #define noLOG_STREAM
69
+
70
+ #endif
@@ -0,0 +1,59 @@
1
+ #ifndef FILE_MYSTDLIB
2
+ #define FILE_MYSTDLIB
3
+
4
+ #include <iostream>
5
+ #include <iomanip>
6
+ #include <fstream>
7
+ #include <sstream>
8
+
9
+
10
+ #include <cstdlib>
11
+ #include <cstdio>
12
+ #include <cmath>
13
+ #include <cctype>
14
+ #include <ctime>
15
+ #include <cstring>
16
+ #include <climits>
17
+ #include <algorithm>
18
+ #include <memory>
19
+ #include <thread>
20
+ #include <mutex>
21
+ #include <atomic>
22
+ #include <optional>
23
+ #include <cassert>
24
+
25
+ #include <new>
26
+ #include <string>
27
+ #include <typeinfo>
28
+
29
+
30
+ #ifndef M_PI
31
+ #define M_PI 3.14159265358979323846
32
+ #endif
33
+
34
+ /*** Windows headers ***/
35
+ #ifdef _MSC_VER
36
+ # define WIN32_LEAN_AND_MEAN
37
+ # ifndef NO_PARALLEL_THREADS
38
+ # ifdef MSVC_EXPRESS
39
+ # else
40
+ // # include <afxwin.h>
41
+ // # include <afxmt.h>
42
+ # endif // MSVC_EXPRESS
43
+ # endif
44
+ // # include <windows.h>
45
+ # undef WIN32_LEAN_AND_MEAN
46
+ // # include <winnt.h>
47
+ #else // Not using MC VC++
48
+ #endif
49
+
50
+
51
+ // using namespace std;
52
+ namespace netgen
53
+ {
54
+ using namespace std;
55
+ }
56
+
57
+
58
+ #endif
59
+
@@ -0,0 +1,27 @@
1
+ #ifndef NETGEN_CONFIG_HPP_INCLUDED___
2
+ #define NETGEN_CONFIG_HPP_INCLUDED___
3
+
4
+ #define NETGEN_USE_NATIVE_ARCH 0
5
+ #define NETGEN_USE_GUI 1
6
+ #define NETGEN_USE_PYTHON 1
7
+ #define NETGEN_USE_MPI 1
8
+ #define NETGEN_USE_MPI4PY 0
9
+ #define NETGEN_USE_OCC 1
10
+ #define NETGEN_USE_JPEG 1
11
+ #define NETGEN_USE_MPEG 1
12
+ #define NETGEN_USE_CGNS 1
13
+ #define NETGEN_USE_NUMA 1
14
+ #define NETGEN_INTEL_MIC 1
15
+ #define NETGEN_INSTALL_PROFILES 0
16
+ #define NETGEN_USE_CCACHE 1
17
+ #define NETGEN_USE_INTERNAL_TCL 1
18
+ #define NETGEN_ENABLE_UNIT_TESTS 0
19
+ #define NETGEN_ENABLE_CPP_CORE_GUIDELINES_CHECK 0
20
+ #define NETGEN_USE_SPDLOG 0
21
+ #define NETGEN_DEBUG_LOG 0
22
+ #define NETGEN_USE_CHECK_RANGE 0
23
+ #define NETGEN_BUILD_STUB_FILES 1
24
+ #define NETGEN_BUILD_FOR_CONDA 1
25
+ #define NETGEN_SHARED_LIBRARY_SUFFIX ".dll"
26
+
27
+ #endif // NETGEN_CONFIG_HPP_INCLUDED___
@@ -0,0 +1,9 @@
1
+ #ifndef NETGEN_VERSION_HPP_INCLUDED
2
+ #define NETGEN_VERSION_HPP_INCLUDED
3
+ #define NETGEN_VERSION "6.2.2506-35-ga9438ce2"
4
+ #define NETGEN_VERSION_MAJOR 6
5
+ #define NETGEN_VERSION_MINOR 2
6
+ #define NETGEN_VERSION_PATCH 2506
7
+ #define NETGEN_VERSION_TWEAK 35
8
+ #define NETGEN_VERSION_HASH "ga9438ce2"
9
+ #endif // NETGEN_VERSION_HPP_INCLUDED