ngsolve 6.2.2506.post75.dev0__cp314-cp314-manylinux_2_28_x86_64.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.
Potentially problematic release.
This version of ngsolve might be problematic. Click here for more details.
- ngsolve-6.2.2506.post75.dev0.data/data/bin/ngs_nvcc +14 -0
- ngsolve-6.2.2506.post75.dev0.data/data/bin/ngs_nvlink +14 -0
- ngsolve-6.2.2506.post75.dev0.data/data/bin/ngscxx +15 -0
- ngsolve-6.2.2506.post75.dev0.data/data/bin/ngsld +11 -0
- ngsolve-6.2.2506.post75.dev0.data/data/bin/ngsolve.tcl +648 -0
- ngsolve-6.2.2506.post75.dev0.data/data/bin/ngspy +2 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/analytic_integrals.hpp +10 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/arnoldi.hpp +55 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/bandmatrix.hpp +334 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/basematrix.hpp +957 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/basevector.hpp +1268 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/bdbequations.hpp +2805 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/bdbintegrator.hpp +1660 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/bem_diffops.hpp +475 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/bessel.hpp +1064 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/bilinearform.hpp +963 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/bla.hpp +29 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/blockalloc.hpp +95 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/blockjacobi.hpp +328 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/bspline.hpp +116 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/calcinverse.hpp +141 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/cg.hpp +368 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/chebyshev.hpp +44 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/cholesky.hpp +720 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/clapack.h +7254 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/code_generation.hpp +296 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/coefficient.hpp +2033 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/coefficient_impl.hpp +19 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/coefficient_stdmath.hpp +167 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/commutingAMG.hpp +106 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/comp.hpp +79 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/compatibility.hpp +41 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/complex_wrapper.hpp +73 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/compressedfespace.hpp +110 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/contact.hpp +235 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/cuda_linalg.hpp +175 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/cuda_ngbla.hpp +226 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/cuda_ngstd.hpp +527 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/cuda_profiler.hpp +240 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/diagonalmatrix.hpp +154 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/differentialoperator.hpp +276 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/diffop.hpp +1286 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/diffop_impl.hpp +328 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/diffopwithfactor.hpp +123 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/discontinuous.hpp +84 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/dump.hpp +949 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/ectypes.hpp +121 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/eigen.hpp +60 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/eigensystem.hpp +18 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/elasticity_equations.hpp +595 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/elementbyelement.hpp +195 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/elementtopology.hpp +1760 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/elementtransformation.hpp +339 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/evalfunc.hpp +405 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/expr.hpp +1686 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/facetfe.hpp +175 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/facetfespace.hpp +180 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/facethofe.hpp +111 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/facetsurffespace.hpp +112 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/fe_interfaces.hpp +32 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/fem.hpp +87 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/fesconvert.hpp +14 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/fespace.hpp +1449 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/finiteelement.hpp +286 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/globalinterfacespace.hpp +77 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/globalspace.hpp +115 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/gridfunction.hpp +525 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/h1amg.hpp +124 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/h1hofe.hpp +188 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/h1hofe_impl.hpp +1262 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/h1hofefo.hpp +148 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/h1hofefo_impl.hpp +185 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/h1hofespace.hpp +167 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/h1lofe.hpp +1240 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/h1lumping.hpp +41 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/hcurl_equations.hpp +1381 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/hcurlcurlfe.hpp +2241 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/hcurlcurlfespace.hpp +78 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/hcurlfe.hpp +259 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/hcurlfe_utils.hpp +107 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/hcurlhdiv_dshape.hpp +857 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/hcurlhdivfes.hpp +308 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/hcurlhofe.hpp +175 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/hcurlhofe_impl.hpp +1871 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/hcurlhofespace.hpp +193 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/hcurllofe.hpp +1146 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/hdiv_equations.hpp +880 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/hdivdivfe.hpp +2923 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/hdivdivsurfacespace.hpp +76 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/hdivfe.hpp +206 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/hdivfe_utils.hpp +717 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/hdivfes.hpp +75 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/hdivhofe.hpp +447 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/hdivhofe_impl.hpp +1107 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/hdivhofefo.hpp +229 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/hdivhofespace.hpp +177 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/hdivhosurfacefespace.hpp +106 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/hdivlofe.hpp +773 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/hidden.hpp +74 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/householder.hpp +181 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/hypre_ams_precond.hpp +123 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/hypre_precond.hpp +73 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/integrator.hpp +2012 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/integratorcf.hpp +253 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/interpolate.hpp +49 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/intrule.hpp +2542 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/intrules_SauterSchwab.hpp +25 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/irspace.hpp +49 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/jacobi.hpp +153 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/kernels.hpp +762 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/l2hofe.hpp +194 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/l2hofe_impl.hpp +564 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/l2hofefo.hpp +542 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/l2hofespace.hpp +344 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/la.hpp +38 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/linalg_kernels.hpp +102 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/linearform.hpp +266 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/matrix.hpp +2140 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/memusage.hpp +41 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/meshaccess.hpp +1359 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/mgpre.hpp +204 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/mp_coefficient.hpp +145 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/mptools.hpp +2281 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/multigrid.hpp +42 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/multivector.hpp +447 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/mumpsinverse.hpp +187 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/mycomplex.hpp +361 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/ng_lapack.hpp +1661 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/ngblas.hpp +1232 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/ngs_defines.hpp +30 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/ngs_stdcpp_include.hpp +106 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/ngs_utils.hpp +121 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/ngsobject.hpp +1019 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/ngsstream.hpp +113 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/ngstd.hpp +72 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/nodalhofe.hpp +96 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/nodalhofe_impl.hpp +141 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/normalfacetfe.hpp +223 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/normalfacetfespace.hpp +98 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/normalfacetsurfacefespace.hpp +84 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/order.hpp +251 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/parallel_matrices.hpp +222 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/paralleldofs.hpp +340 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/parallelngs.hpp +23 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/parallelvector.hpp +269 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/pardisoinverse.hpp +200 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/periodic.hpp +129 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/plateaufespace.hpp +25 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/pml.hpp +275 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/pmltrafo.hpp +631 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/postproc.hpp +142 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/potentialtools.hpp +22 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/precomp.hpp +60 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/preconditioner.hpp +602 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/prolongation.hpp +377 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/python_comp.hpp +107 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/python_fem.hpp +89 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/python_linalg.hpp +58 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/python_ngstd.hpp +386 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/recursive_pol.hpp +4896 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/recursive_pol_tet.hpp +395 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/recursive_pol_trig.hpp +492 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/reorderedfespace.hpp +81 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/sample_sort.hpp +105 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/scalarfe.hpp +335 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/shapefunction_utils.hpp +113 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/simd_complex.hpp +329 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/smoother.hpp +253 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/solve.hpp +89 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/sparsecholesky.hpp +313 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/sparsematrix.hpp +1038 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/sparsematrix_dyn.hpp +90 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/sparsematrix_impl.hpp +1013 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/special_matrix.hpp +463 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/specialelement.hpp +125 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/statushandler.hpp +33 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/stringops.hpp +12 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/superluinverse.hpp +136 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/symbolicintegrator.hpp +850 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/symmetricmatrix.hpp +144 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/tangentialfacetfe.hpp +224 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/tangentialfacetfespace.hpp +91 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/tensor.hpp +522 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/tensorcoefficient.hpp +446 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/tensorproductintegrator.hpp +113 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/thcurlfe.hpp +128 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/thcurlfe_impl.hpp +380 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/thdivfe.hpp +80 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/thdivfe_impl.hpp +492 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/tpdiffop.hpp +461 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/tpfes.hpp +133 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/tpintrule.hpp +224 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/triangular.hpp +465 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/tscalarfe.hpp +245 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/tscalarfe_impl.hpp +1029 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/umfpackinverse.hpp +148 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/unifiedvector.hpp +103 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/vector.hpp +1273 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/voxelcoefficientfunction.hpp +41 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/vtkoutput.hpp +198 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/vvector.hpp +208 -0
- ngsolve-6.2.2506.post75.dev0.data/data/include/netgen/webgui.hpp +92 -0
- ngsolve-6.2.2506.post75.dev0.data/data/lib/cmake/ngsolve/NGSolveConfig.cmake +102 -0
- ngsolve-6.2.2506.post75.dev0.data/data/lib/cmake/ngsolve/ngsolve-targets-release.cmake +89 -0
- ngsolve-6.2.2506.post75.dev0.data/data/lib/cmake/ngsolve/ngsolve-targets.cmake +173 -0
- ngsolve-6.2.2506.post75.dev0.data/data/lib/python3.14/site-packages/netgen_mesher.libs/libngbla.so +0 -0
- ngsolve-6.2.2506.post75.dev0.data/data/lib/python3.14/site-packages/netgen_mesher.libs/libngcomp.so +0 -0
- ngsolve-6.2.2506.post75.dev0.data/data/lib/python3.14/site-packages/netgen_mesher.libs/libngfem.so +0 -0
- ngsolve-6.2.2506.post75.dev0.data/data/lib/python3.14/site-packages/netgen_mesher.libs/libngla.so +0 -0
- ngsolve-6.2.2506.post75.dev0.data/data/lib/python3.14/site-packages/netgen_mesher.libs/libngsbem.so +0 -0
- ngsolve-6.2.2506.post75.dev0.data/data/lib/python3.14/site-packages/netgen_mesher.libs/libngscudalib.so +0 -0
- ngsolve-6.2.2506.post75.dev0.data/data/lib/python3.14/site-packages/netgen_mesher.libs/libngsolve.so +0 -0
- ngsolve-6.2.2506.post75.dev0.data/data/lib/python3.14/site-packages/netgen_mesher.libs/libngstd.so +0 -0
- ngsolve-6.2.2506.post75.dev0.data/data/lib/python3.14/site-packages/ngsolve/TensorProductTools.py +210 -0
- ngsolve-6.2.2506.post75.dev0.data/data/lib/python3.14/site-packages/ngsolve/__console.py +94 -0
- ngsolve-6.2.2506.post75.dev0.data/data/lib/python3.14/site-packages/ngsolve/__expr.py +181 -0
- ngsolve-6.2.2506.post75.dev0.data/data/lib/python3.14/site-packages/ngsolve/__init__.py +148 -0
- ngsolve-6.2.2506.post75.dev0.data/data/lib/python3.14/site-packages/ngsolve/_scikit_build_core_dependencies.py +30 -0
- ngsolve-6.2.2506.post75.dev0.data/data/lib/python3.14/site-packages/ngsolve/bvp.py +78 -0
- ngsolve-6.2.2506.post75.dev0.data/data/lib/python3.14/site-packages/ngsolve/config/__init__.py +1 -0
- ngsolve-6.2.2506.post75.dev0.data/data/lib/python3.14/site-packages/ngsolve/config/__main__.py +4 -0
- ngsolve-6.2.2506.post75.dev0.data/data/lib/python3.14/site-packages/ngsolve/config/config.py +60 -0
- ngsolve-6.2.2506.post75.dev0.data/data/lib/python3.14/site-packages/ngsolve/demos/TensorProduct/__init__.py +0 -0
- ngsolve-6.2.2506.post75.dev0.data/data/lib/python3.14/site-packages/ngsolve/demos/TensorProduct/tp_dg_1d_1d.py +80 -0
- ngsolve-6.2.2506.post75.dev0.data/data/lib/python3.14/site-packages/ngsolve/demos/TensorProduct/tp_dg_1d_2d.py +73 -0
- ngsolve-6.2.2506.post75.dev0.data/data/lib/python3.14/site-packages/ngsolve/demos/TensorProduct/tp_dg_2d_1d.py +72 -0
- ngsolve-6.2.2506.post75.dev0.data/data/lib/python3.14/site-packages/ngsolve/demos/TensorProduct/tp_dg_2d_2d.py +66 -0
- ngsolve-6.2.2506.post75.dev0.data/data/lib/python3.14/site-packages/ngsolve/demos/__init__.py +0 -0
- ngsolve-6.2.2506.post75.dev0.data/data/lib/python3.14/site-packages/ngsolve/demos/howto/__init__.py +0 -0
- ngsolve-6.2.2506.post75.dev0.data/data/lib/python3.14/site-packages/ngsolve/demos/howto/hhj.py +44 -0
- ngsolve-6.2.2506.post75.dev0.data/data/lib/python3.14/site-packages/ngsolve/demos/howto/hybrid_dg.py +53 -0
- ngsolve-6.2.2506.post75.dev0.data/data/lib/python3.14/site-packages/ngsolve/demos/howto/mixed.py +30 -0
- ngsolve-6.2.2506.post75.dev0.data/data/lib/python3.14/site-packages/ngsolve/demos/howto/nonlin.py +29 -0
- ngsolve-6.2.2506.post75.dev0.data/data/lib/python3.14/site-packages/ngsolve/demos/howto/pickling.py +26 -0
- ngsolve-6.2.2506.post75.dev0.data/data/lib/python3.14/site-packages/ngsolve/demos/howto/pml.py +31 -0
- ngsolve-6.2.2506.post75.dev0.data/data/lib/python3.14/site-packages/ngsolve/demos/howto/taskmanager.py +20 -0
- ngsolve-6.2.2506.post75.dev0.data/data/lib/python3.14/site-packages/ngsolve/demos/howto/tdnns.py +47 -0
- ngsolve-6.2.2506.post75.dev0.data/data/lib/python3.14/site-packages/ngsolve/demos/howto/timeDG-skeleton.py +45 -0
- ngsolve-6.2.2506.post75.dev0.data/data/lib/python3.14/site-packages/ngsolve/demos/howto/timeDG.py +38 -0
- ngsolve-6.2.2506.post75.dev0.data/data/lib/python3.14/site-packages/ngsolve/demos/howto/timeDGlap.py +42 -0
- ngsolve-6.2.2506.post75.dev0.data/data/lib/python3.14/site-packages/ngsolve/demos/howto/timeDGwave.py +61 -0
- ngsolve-6.2.2506.post75.dev0.data/data/lib/python3.14/site-packages/ngsolve/demos/intro/__init__.py +0 -0
- ngsolve-6.2.2506.post75.dev0.data/data/lib/python3.14/site-packages/ngsolve/demos/intro/adaptive.py +123 -0
- ngsolve-6.2.2506.post75.dev0.data/data/lib/python3.14/site-packages/ngsolve/demos/intro/cmagnet.py +59 -0
- ngsolve-6.2.2506.post75.dev0.data/data/lib/python3.14/site-packages/ngsolve/demos/intro/elasticity.py +76 -0
- ngsolve-6.2.2506.post75.dev0.data/data/lib/python3.14/site-packages/ngsolve/demos/intro/navierstokes.py +74 -0
- ngsolve-6.2.2506.post75.dev0.data/data/lib/python3.14/site-packages/ngsolve/demos/intro/poisson.ipynb +170 -0
- ngsolve-6.2.2506.post75.dev0.data/data/lib/python3.14/site-packages/ngsolve/demos/intro/poisson.py +41 -0
- ngsolve-6.2.2506.post75.dev0.data/data/lib/python3.14/site-packages/ngsolve/demos/mpi/__init__.py +0 -0
- ngsolve-6.2.2506.post75.dev0.data/data/lib/python3.14/site-packages/ngsolve/demos/mpi/mpi_cmagnet.py +87 -0
- ngsolve-6.2.2506.post75.dev0.data/data/lib/python3.14/site-packages/ngsolve/demos/mpi/mpi_navierstokes.py +117 -0
- ngsolve-6.2.2506.post75.dev0.data/data/lib/python3.14/site-packages/ngsolve/demos/mpi/mpi_poisson.py +89 -0
- ngsolve-6.2.2506.post75.dev0.data/data/lib/python3.14/site-packages/ngsolve/demos/mpi/mpi_timeDG.py +82 -0
- ngsolve-6.2.2506.post75.dev0.data/data/lib/python3.14/site-packages/ngsolve/directsolvers.py +26 -0
- ngsolve-6.2.2506.post75.dev0.data/data/lib/python3.14/site-packages/ngsolve/eigenvalues.py +364 -0
- ngsolve-6.2.2506.post75.dev0.data/data/lib/python3.14/site-packages/ngsolve/internal.py +89 -0
- ngsolve-6.2.2506.post75.dev0.data/data/lib/python3.14/site-packages/ngsolve/krylovspace.py +1013 -0
- ngsolve-6.2.2506.post75.dev0.data/data/lib/python3.14/site-packages/ngsolve/meshes.py +748 -0
- ngsolve-6.2.2506.post75.dev0.data/data/lib/python3.14/site-packages/ngsolve/ngs2petsc.py +310 -0
- ngsolve-6.2.2506.post75.dev0.data/data/lib/python3.14/site-packages/ngsolve/ngscuda.so +0 -0
- ngsolve-6.2.2506.post75.dev0.data/data/lib/python3.14/site-packages/ngsolve/ngscxx.py +42 -0
- ngsolve-6.2.2506.post75.dev0.data/data/lib/python3.14/site-packages/ngsolve/ngslib.so +0 -0
- ngsolve-6.2.2506.post75.dev0.data/data/lib/python3.14/site-packages/ngsolve/nonlinearsolvers.py +203 -0
- ngsolve-6.2.2506.post75.dev0.data/data/lib/python3.14/site-packages/ngsolve/preconditioners.py +11 -0
- ngsolve-6.2.2506.post75.dev0.data/data/lib/python3.14/site-packages/ngsolve/solve_implementation.py +168 -0
- ngsolve-6.2.2506.post75.dev0.data/data/lib/python3.14/site-packages/ngsolve/solvers.py +7 -0
- ngsolve-6.2.2506.post75.dev0.data/data/lib/python3.14/site-packages/ngsolve/timestepping.py +185 -0
- ngsolve-6.2.2506.post75.dev0.data/data/lib/python3.14/site-packages/ngsolve/timing.py +108 -0
- ngsolve-6.2.2506.post75.dev0.data/data/lib/python3.14/site-packages/ngsolve/utils.py +167 -0
- ngsolve-6.2.2506.post75.dev0.data/data/lib/python3.14/site-packages/ngsolve/webgui.py +670 -0
- ngsolve-6.2.2506.post75.dev0.data/data/share/ngsolve/beam.geo +17 -0
- ngsolve-6.2.2506.post75.dev0.data/data/share/ngsolve/beam.vol +240 -0
- ngsolve-6.2.2506.post75.dev0.data/data/share/ngsolve/chip.in2d +41 -0
- ngsolve-6.2.2506.post75.dev0.data/data/share/ngsolve/chip.vol +614 -0
- ngsolve-6.2.2506.post75.dev0.data/data/share/ngsolve/coil.geo +12 -0
- ngsolve-6.2.2506.post75.dev0.data/data/share/ngsolve/coil.vol +2560 -0
- ngsolve-6.2.2506.post75.dev0.data/data/share/ngsolve/coilshield.geo +24 -0
- ngsolve-6.2.2506.post75.dev0.data/data/share/ngsolve/coilshield.vol +3179 -0
- ngsolve-6.2.2506.post75.dev0.data/data/share/ngsolve/cube.geo +19 -0
- ngsolve-6.2.2506.post75.dev0.data/data/share/ngsolve/cube.vol +1832 -0
- ngsolve-6.2.2506.post75.dev0.data/data/share/ngsolve/d10_DGdoubleglazing.pde +50 -0
- ngsolve-6.2.2506.post75.dev0.data/data/share/ngsolve/d11_chip_nitsche.pde +40 -0
- ngsolve-6.2.2506.post75.dev0.data/data/share/ngsolve/d1_square.pde +43 -0
- ngsolve-6.2.2506.post75.dev0.data/data/share/ngsolve/d2_chip.pde +35 -0
- ngsolve-6.2.2506.post75.dev0.data/data/share/ngsolve/d3_helmholtz.pde +22 -0
- ngsolve-6.2.2506.post75.dev0.data/data/share/ngsolve/d4_cube.pde +46 -0
- ngsolve-6.2.2506.post75.dev0.data/data/share/ngsolve/d5_beam.pde +74 -0
- ngsolve-6.2.2506.post75.dev0.data/data/share/ngsolve/d6_shaft.pde +73 -0
- ngsolve-6.2.2506.post75.dev0.data/data/share/ngsolve/d7_coil.pde +50 -0
- ngsolve-6.2.2506.post75.dev0.data/data/share/ngsolve/d8_coilshield.pde +49 -0
- ngsolve-6.2.2506.post75.dev0.data/data/share/ngsolve/d9_hybridDG.pde +72 -0
- ngsolve-6.2.2506.post75.dev0.data/data/share/ngsolve/doubleglazing.in2d +27 -0
- ngsolve-6.2.2506.post75.dev0.data/data/share/ngsolve/doubleglazing.vol +737 -0
- ngsolve-6.2.2506.post75.dev0.data/data/share/ngsolve/piezo2d40round4.vol.gz +0 -0
- ngsolve-6.2.2506.post75.dev0.data/data/share/ngsolve/shaft.geo +73 -0
- ngsolve-6.2.2506.post75.dev0.data/data/share/ngsolve/shaft.vol +4291 -0
- ngsolve-6.2.2506.post75.dev0.data/data/share/ngsolve/square.in2d +17 -0
- ngsolve-6.2.2506.post75.dev0.data/data/share/ngsolve/square.vol +149 -0
- ngsolve-6.2.2506.post75.dev0.dist-info/METADATA +14 -0
- ngsolve-6.2.2506.post75.dev0.dist-info/RECORD +303 -0
- ngsolve-6.2.2506.post75.dev0.dist-info/WHEEL +5 -0
- ngsolve-6.2.2506.post75.dev0.dist-info/licenses/LICENSE +504 -0
- ngsolve-6.2.2506.post75.dev0.dist-info/top_level.txt +1 -0
|
@@ -0,0 +1,377 @@
|
|
|
1
|
+
#ifndef FILE_PROLONGATION
|
|
2
|
+
#define FILE_PROLONGATION
|
|
3
|
+
|
|
4
|
+
/*********************************************************************/
|
|
5
|
+
/* File: prolongation.hh */
|
|
6
|
+
/* Author: Joachim Schoeberl */
|
|
7
|
+
/* Date: 20. Apr. 2000 */
|
|
8
|
+
/*********************************************************************/
|
|
9
|
+
|
|
10
|
+
namespace ngcomp { class NedelecFESpace; }
|
|
11
|
+
namespace ngla { class SparseFactorization; }
|
|
12
|
+
namespace ngmg
|
|
13
|
+
{
|
|
14
|
+
|
|
15
|
+
/**
|
|
16
|
+
Grid Transfer operators
|
|
17
|
+
*/
|
|
18
|
+
class NGS_DLL_HEADER Prolongation
|
|
19
|
+
{
|
|
20
|
+
Array<DofRange> leveldofs;
|
|
21
|
+
|
|
22
|
+
public:
|
|
23
|
+
///
|
|
24
|
+
Prolongation();
|
|
25
|
+
///
|
|
26
|
+
virtual ~Prolongation();
|
|
27
|
+
|
|
28
|
+
///
|
|
29
|
+
virtual void Update (const FESpace & fes);
|
|
30
|
+
virtual size_t GetNDofLevel (int level) { throw Exception("Prolongation::GetNDofLevel not overloaded"); }
|
|
31
|
+
DofRange LevelDofs (int level) const;
|
|
32
|
+
|
|
33
|
+
///
|
|
34
|
+
virtual shared_ptr<SparseMatrix< double >> CreateProlongationMatrix( int finelevel ) const = 0;
|
|
35
|
+
///
|
|
36
|
+
virtual void ProlongateInline (int finelevel, BaseVector & v) const = 0;
|
|
37
|
+
///
|
|
38
|
+
virtual void RestrictInline (int finelevel, BaseVector & v) const = 0;
|
|
39
|
+
|
|
40
|
+
virtual shared_ptr<BitArray> GetInnerDofs (int finelevel) const { return nullptr; }
|
|
41
|
+
};
|
|
42
|
+
|
|
43
|
+
|
|
44
|
+
class ProlongationOperator : public BaseMatrix
|
|
45
|
+
{
|
|
46
|
+
shared_ptr<Prolongation> prol;
|
|
47
|
+
int level;
|
|
48
|
+
public:
|
|
49
|
+
ProlongationOperator (shared_ptr<Prolongation> aprol, int alevel)
|
|
50
|
+
: prol(aprol), level(alevel) { }
|
|
51
|
+
|
|
52
|
+
virtual bool IsComplex() const override { return false; }
|
|
53
|
+
|
|
54
|
+
virtual int VHeight() const override { return prol->GetNDofLevel(level); }
|
|
55
|
+
virtual int VWidth() const override { return prol->GetNDofLevel(level-1); }
|
|
56
|
+
|
|
57
|
+
virtual void Mult (const BaseVector & x, BaseVector & y) const override
|
|
58
|
+
{
|
|
59
|
+
y.Range(0, VWidth()) = x;
|
|
60
|
+
prol->ProlongateInline (level, y);
|
|
61
|
+
}
|
|
62
|
+
virtual void MultTrans (const BaseVector & x, BaseVector & y) const override
|
|
63
|
+
{
|
|
64
|
+
auto tmp = x.CreateVector();
|
|
65
|
+
tmp = x;
|
|
66
|
+
prol->RestrictInline (level, tmp);
|
|
67
|
+
y = tmp.Range(0, VWidth());
|
|
68
|
+
}
|
|
69
|
+
|
|
70
|
+
AutoVector CreateRowVector() const override { return make_unique<VVector<double>> (VWidth()); }
|
|
71
|
+
AutoVector CreateColVector() const override { return make_unique<VVector<double>> (VHeight()); }
|
|
72
|
+
};
|
|
73
|
+
|
|
74
|
+
|
|
75
|
+
|
|
76
|
+
|
|
77
|
+
/**
|
|
78
|
+
Standard Prolongation.
|
|
79
|
+
Child nodes between 2 parent nodes.
|
|
80
|
+
*/
|
|
81
|
+
class LinearProlongation : public Prolongation
|
|
82
|
+
{
|
|
83
|
+
shared_ptr<MeshAccess> ma;
|
|
84
|
+
Array<size_t> nvlevel;
|
|
85
|
+
bool allow_parallel = true;
|
|
86
|
+
public:
|
|
87
|
+
LinearProlongation(shared_ptr<MeshAccess> ama)
|
|
88
|
+
: ma(ama) { ; }
|
|
89
|
+
|
|
90
|
+
virtual ~LinearProlongation();
|
|
91
|
+
|
|
92
|
+
virtual void Update (const FESpace & fes) override;
|
|
93
|
+
virtual size_t GetNDofLevel (int level) override { return nvlevel[level]; }
|
|
94
|
+
|
|
95
|
+
virtual shared_ptr<SparseMatrix< double >> CreateProlongationMatrix( int finelevel ) const override;
|
|
96
|
+
virtual void ProlongateInline (int finelevel, BaseVector & v) const override;
|
|
97
|
+
virtual void RestrictInline (int finelevel, BaseVector & v) const override;
|
|
98
|
+
};
|
|
99
|
+
|
|
100
|
+
|
|
101
|
+
/*
|
|
102
|
+
/// Prolongation for non-conforming P1 triangle.
|
|
103
|
+
class NonConformingProlongation : public Prolongation
|
|
104
|
+
{
|
|
105
|
+
///
|
|
106
|
+
shared_ptr<MeshAccess> ma;
|
|
107
|
+
///
|
|
108
|
+
const NonConformingFESpace & space;
|
|
109
|
+
public:
|
|
110
|
+
///
|
|
111
|
+
NonConformingProlongation(shared_ptr<MeshAccess> ama,
|
|
112
|
+
const NonConformingFESpace & aspace);
|
|
113
|
+
///
|
|
114
|
+
virtual ~NonConformingProlongation();
|
|
115
|
+
|
|
116
|
+
///
|
|
117
|
+
virtual void Update ();
|
|
118
|
+
|
|
119
|
+
///
|
|
120
|
+
virtual SparseMatrix< double >* CreateProlongationMatrix( int finelevel ) const
|
|
121
|
+
{ return NULL; }
|
|
122
|
+
///
|
|
123
|
+
virtual void ProlongateInline (int finelevel, BaseVector & v) const;
|
|
124
|
+
///
|
|
125
|
+
virtual void RestrictInline (int finelevel, BaseVector & v) const;
|
|
126
|
+
};
|
|
127
|
+
*/
|
|
128
|
+
|
|
129
|
+
|
|
130
|
+
/// Piecewise constant prolongaton.
|
|
131
|
+
class ElementProlongation : public Prolongation
|
|
132
|
+
{
|
|
133
|
+
///
|
|
134
|
+
shared_ptr<MeshAccess> ma;
|
|
135
|
+
///
|
|
136
|
+
const FESpace & space;
|
|
137
|
+
VorB vb;
|
|
138
|
+
public:
|
|
139
|
+
///
|
|
140
|
+
ElementProlongation(const FESpace & aspace, VorB avb = VOL);
|
|
141
|
+
|
|
142
|
+
virtual ~ElementProlongation();
|
|
143
|
+
|
|
144
|
+
///
|
|
145
|
+
virtual void Update (const FESpace & fes) override;
|
|
146
|
+
|
|
147
|
+
virtual shared_ptr<SparseMatrix< double >> CreateProlongationMatrix( int finelevel ) const override;
|
|
148
|
+
|
|
149
|
+
///
|
|
150
|
+
virtual void ProlongateInline (int finelevel, BaseVector & v) const override;
|
|
151
|
+
virtual void RestrictInline (int finelevel, BaseVector & v) const override;
|
|
152
|
+
};
|
|
153
|
+
|
|
154
|
+
|
|
155
|
+
|
|
156
|
+
|
|
157
|
+
/// Prolongation for edge-elements.
|
|
158
|
+
// template <class TV>
|
|
159
|
+
class EdgeProlongation : public Prolongation
|
|
160
|
+
{
|
|
161
|
+
///
|
|
162
|
+
shared_ptr<MeshAccess> ma;
|
|
163
|
+
///
|
|
164
|
+
const NedelecFESpace & space;
|
|
165
|
+
public:
|
|
166
|
+
///
|
|
167
|
+
EdgeProlongation(const NedelecFESpace & aspace);
|
|
168
|
+
///
|
|
169
|
+
virtual ~EdgeProlongation() { ; }
|
|
170
|
+
|
|
171
|
+
///
|
|
172
|
+
virtual void Update (const FESpace & fes) override { ; }
|
|
173
|
+
|
|
174
|
+
///
|
|
175
|
+
virtual shared_ptr<SparseMatrix< double >> CreateProlongationMatrix( int finelevel ) const override
|
|
176
|
+
{ return NULL; }
|
|
177
|
+
|
|
178
|
+
///
|
|
179
|
+
virtual void ProlongateInline (int finelevel, BaseVector & v) const override;
|
|
180
|
+
virtual void RestrictInline (int finelevel, BaseVector & v) const override;
|
|
181
|
+
|
|
182
|
+
///
|
|
183
|
+
void ApplyGradient (int level, const BaseVector & pot, BaseVector & grad) const
|
|
184
|
+
{
|
|
185
|
+
cout << "apply grad" << endl;
|
|
186
|
+
}
|
|
187
|
+
};
|
|
188
|
+
|
|
189
|
+
|
|
190
|
+
|
|
191
|
+
|
|
192
|
+
/// Product space prolongation, combination of elementary prolongations
|
|
193
|
+
class NGS_DLL_HEADER CompoundProlongation : public Prolongation
|
|
194
|
+
{
|
|
195
|
+
protected:
|
|
196
|
+
///
|
|
197
|
+
const CompoundFESpace * space;
|
|
198
|
+
///
|
|
199
|
+
Array<shared_ptr<Prolongation>> prols;
|
|
200
|
+
public:
|
|
201
|
+
///
|
|
202
|
+
CompoundProlongation(const CompoundFESpace * aspace);
|
|
203
|
+
///
|
|
204
|
+
CompoundProlongation(const CompoundFESpace * aspace,
|
|
205
|
+
Array<shared_ptr<Prolongation>> & aprols);
|
|
206
|
+
///
|
|
207
|
+
virtual ~CompoundProlongation();
|
|
208
|
+
// { ; }
|
|
209
|
+
|
|
210
|
+
///
|
|
211
|
+
virtual void Update (const FESpace & fes) override;
|
|
212
|
+
virtual size_t GetNDofLevel (int level) override;
|
|
213
|
+
|
|
214
|
+
virtual shared_ptr<BitArray> GetInnerDofs (int finelevel) const override;
|
|
215
|
+
|
|
216
|
+
void AddProlongation (shared_ptr<Prolongation> prol)
|
|
217
|
+
{
|
|
218
|
+
prols.Append (prol);
|
|
219
|
+
}
|
|
220
|
+
|
|
221
|
+
///
|
|
222
|
+
virtual shared_ptr<SparseMatrix< double >> CreateProlongationMatrix( int finelevel ) const override
|
|
223
|
+
{ return NULL; }
|
|
224
|
+
|
|
225
|
+
|
|
226
|
+
///
|
|
227
|
+
virtual void ProlongateInline (int finelevel, BaseVector & v) const override;
|
|
228
|
+
|
|
229
|
+
///
|
|
230
|
+
virtual void RestrictInline (int finelevel, BaseVector & v) const override;
|
|
231
|
+
};
|
|
232
|
+
|
|
233
|
+
class NGS_DLL_HEADER HarmonicProlongation : public Prolongation
|
|
234
|
+
{
|
|
235
|
+
shared_ptr<Prolongation> baseprol;
|
|
236
|
+
weak_ptr<BilinearForm> wbfa;
|
|
237
|
+
Array<shared_ptr<BaseMatrix>> innerinverses;
|
|
238
|
+
Array<size_t> facets_on_level;
|
|
239
|
+
Array<shared_ptr<BitArray>> freedofs;
|
|
240
|
+
string inverse;
|
|
241
|
+
public:
|
|
242
|
+
HarmonicProlongation (shared_ptr<Prolongation> abaseprol,
|
|
243
|
+
shared_ptr<BilinearForm> abfa, string ainverse);
|
|
244
|
+
|
|
245
|
+
virtual void Update (const FESpace & fes) override;
|
|
246
|
+
|
|
247
|
+
virtual size_t GetNDofLevel (int level) override { return baseprol->GetNDofLevel(level); }
|
|
248
|
+
|
|
249
|
+
virtual shared_ptr<SparseMatrix< double >> CreateProlongationMatrix( int finelevel ) const override;
|
|
250
|
+
virtual void ProlongateInline (int finelevel, BaseVector & v) const override;
|
|
251
|
+
virtual void RestrictInline (int finelevel, BaseVector & v) const override;
|
|
252
|
+
};
|
|
253
|
+
|
|
254
|
+
|
|
255
|
+
|
|
256
|
+
|
|
257
|
+
|
|
258
|
+
template <int DIM>
|
|
259
|
+
class FacetProlongation : public Prolongation
|
|
260
|
+
{
|
|
261
|
+
protected:
|
|
262
|
+
shared_ptr<MeshAccess> ma;
|
|
263
|
+
|
|
264
|
+
int dofs_per_facet = -1;
|
|
265
|
+
Array<Array<int>> first_dofs;
|
|
266
|
+
Array<int> prol_class; // which prol to use ?
|
|
267
|
+
Array<size_t> facets_on_level;
|
|
268
|
+
|
|
269
|
+
static constexpr int NUMPROL = (DIM==2) ? 2 : 32;
|
|
270
|
+
array<Matrix<double>,NUMPROL> facetprol;
|
|
271
|
+
|
|
272
|
+
bool haveprols = false;
|
|
273
|
+
|
|
274
|
+
public:
|
|
275
|
+
FacetProlongation (shared_ptr<MeshAccess> ama)
|
|
276
|
+
: ma(ama) { }
|
|
277
|
+
|
|
278
|
+
|
|
279
|
+
virtual shared_ptr<SparseMatrix< double >> CreateProlongationMatrix( int finelevel ) const override
|
|
280
|
+
{
|
|
281
|
+
return nullptr; // or NULL ?
|
|
282
|
+
}
|
|
283
|
+
|
|
284
|
+
|
|
285
|
+
virtual void ProlongateInline (int finelevel, BaseVector & v) const override
|
|
286
|
+
{
|
|
287
|
+
auto fv = v.FV<double>();
|
|
288
|
+
Matrix<double> tmp(facets_on_level[finelevel], dofs_per_facet);
|
|
289
|
+
tmp = 0.0;
|
|
290
|
+
|
|
291
|
+
for (size_t i = 0; i < first_dofs[finelevel-1].Size()-1; i++)
|
|
292
|
+
{
|
|
293
|
+
IntRange r(first_dofs[finelevel-1][i], first_dofs[finelevel-1][i+1]);
|
|
294
|
+
if (r.Size() > 0)
|
|
295
|
+
tmp.Row(i) = fv.Range(r);
|
|
296
|
+
}
|
|
297
|
+
|
|
298
|
+
if constexpr (DIM==2)
|
|
299
|
+
{
|
|
300
|
+
for (int i = facets_on_level[finelevel-1]; i < facets_on_level[finelevel]; i++)
|
|
301
|
+
if (auto parents = get<1>(ma->GetParentEdges(i)); parents[1] == -1)
|
|
302
|
+
{
|
|
303
|
+
int pe = parents[0];
|
|
304
|
+
tmp.Row(i) = facetprol[prol_class[i]] * tmp.Row(pe);
|
|
305
|
+
}
|
|
306
|
+
}
|
|
307
|
+
else
|
|
308
|
+
{
|
|
309
|
+
for (int i = facets_on_level[finelevel-1]; i < facets_on_level[finelevel]; i++)
|
|
310
|
+
if (auto parents = get<1>(ma->GetParentFaces(i)); parents[1] == -1)
|
|
311
|
+
{
|
|
312
|
+
int pe = parents[0];
|
|
313
|
+
tmp.Row(i) = facetprol[prol_class[i]] * tmp.Row(pe);
|
|
314
|
+
}
|
|
315
|
+
}
|
|
316
|
+
|
|
317
|
+
for (size_t i = 0; i < first_dofs[finelevel].Size()-1; i++)
|
|
318
|
+
{
|
|
319
|
+
IntRange r(first_dofs[finelevel][i], first_dofs[finelevel][i+1]);
|
|
320
|
+
if (r.Size() > 0)
|
|
321
|
+
fv.Range(r) = tmp.Row(i);
|
|
322
|
+
}
|
|
323
|
+
}
|
|
324
|
+
|
|
325
|
+
virtual void RestrictInline (int finelevel, BaseVector & v) const override
|
|
326
|
+
{
|
|
327
|
+
auto fv = v.FV<double>();
|
|
328
|
+
Matrix<double> tmp(facets_on_level[finelevel], dofs_per_facet);
|
|
329
|
+
tmp = 0.0;
|
|
330
|
+
|
|
331
|
+
for (size_t i = 0; i < first_dofs[finelevel].Size()-1; i++)
|
|
332
|
+
{
|
|
333
|
+
IntRange r(first_dofs[finelevel][i], first_dofs[finelevel][i+1]);
|
|
334
|
+
if (r.Size() > 0)
|
|
335
|
+
tmp.Row(i) = fv.Range(r);
|
|
336
|
+
}
|
|
337
|
+
|
|
338
|
+
|
|
339
|
+
if constexpr (DIM==2)
|
|
340
|
+
{
|
|
341
|
+
for (int i = facets_on_level[finelevel-1]; i < facets_on_level[finelevel]; i++)
|
|
342
|
+
if (auto parents = get<1>(ma->GetParentEdges(i)); parents[1] == -1)
|
|
343
|
+
{
|
|
344
|
+
int pe = parents[0];
|
|
345
|
+
tmp.Row(pe) += Trans(facetprol[prol_class[i]]) * tmp.Row(i);
|
|
346
|
+
}
|
|
347
|
+
}
|
|
348
|
+
else
|
|
349
|
+
{
|
|
350
|
+
// for (int i = facets_on_level[finelevel-1]; i < facets_on_level[finelevel]; i++)
|
|
351
|
+
for (int i = facets_on_level[finelevel]-1; i >= facets_on_level[finelevel-1]; i--)
|
|
352
|
+
if (auto parents = get<1>(ma->GetParentFaces(i)); parents[1] == -1)
|
|
353
|
+
{
|
|
354
|
+
int pe = parents[0];
|
|
355
|
+
tmp.Row(pe) += Trans(facetprol[prol_class[i]]) * tmp.Row(i);
|
|
356
|
+
tmp.Row(i) = 0.0; // optional, for testing
|
|
357
|
+
}
|
|
358
|
+
}
|
|
359
|
+
|
|
360
|
+
fv = 0.0;
|
|
361
|
+
for (size_t i = 0; i < first_dofs[finelevel-1].Size()-1; i++)
|
|
362
|
+
{
|
|
363
|
+
IntRange r(first_dofs[finelevel-1][i], first_dofs[finelevel-1][i+1]);
|
|
364
|
+
if (r.Size() > 0)
|
|
365
|
+
fv.Range(r) = tmp.Row(i);
|
|
366
|
+
}
|
|
367
|
+
|
|
368
|
+
}
|
|
369
|
+
|
|
370
|
+
};
|
|
371
|
+
|
|
372
|
+
|
|
373
|
+
|
|
374
|
+
}
|
|
375
|
+
|
|
376
|
+
|
|
377
|
+
#endif
|
|
@@ -0,0 +1,107 @@
|
|
|
1
|
+
#ifndef NGSOLVE_PYTHON_COMP_HPP
|
|
2
|
+
#define NGSOLVE_PYTHON_COMP_HPP
|
|
3
|
+
|
|
4
|
+
#include <python_ngstd.hpp>
|
|
5
|
+
#include <python_linalg.hpp>
|
|
6
|
+
|
|
7
|
+
// #include "comp.hpp"
|
|
8
|
+
|
|
9
|
+
#include "gridfunction.hpp"
|
|
10
|
+
#include "periodic.hpp"
|
|
11
|
+
|
|
12
|
+
namespace pybind11
|
|
13
|
+
{
|
|
14
|
+
// specialized implementation of polymorphic_type_hook to allow
|
|
15
|
+
// unregistered derived types convert to registered derived types
|
|
16
|
+
// by trying to dynamic cast
|
|
17
|
+
template<>
|
|
18
|
+
struct polymorphic_type_hook<ngcomp::FESpace>
|
|
19
|
+
{
|
|
20
|
+
static const void* get(const ngcomp::FESpace* src, const type_info*& type)
|
|
21
|
+
{
|
|
22
|
+
// for example this could be a QuasiPeriodicFESpace<double>, ...
|
|
23
|
+
if(auto cast = dynamic_cast<const ngcomp::PeriodicFESpace*>(src))
|
|
24
|
+
{
|
|
25
|
+
type = &typeid(ngcomp::PeriodicFESpace);
|
|
26
|
+
return cast;
|
|
27
|
+
}
|
|
28
|
+
// if it's not one of these spaces use the default implementation
|
|
29
|
+
// for dynamic types
|
|
30
|
+
type = src ? &typeid(*src) : nullptr;
|
|
31
|
+
return dynamic_cast<const void*>(src);
|
|
32
|
+
}
|
|
33
|
+
};
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
namespace ngcomp
|
|
37
|
+
{
|
|
38
|
+
// TODO: use Archive structure to pickle fespaces
|
|
39
|
+
inline py::tuple fesPickle (const FESpace& fes)
|
|
40
|
+
{
|
|
41
|
+
auto flags = fes.GetFlags();
|
|
42
|
+
auto mesh = fes.GetMeshAccess();
|
|
43
|
+
auto type = fes.type;
|
|
44
|
+
return py::make_tuple(type,mesh,flags);
|
|
45
|
+
}
|
|
46
|
+
|
|
47
|
+
template<typename FESPACE>
|
|
48
|
+
shared_ptr<FESPACE> fesUnpickle(py::tuple state)
|
|
49
|
+
{
|
|
50
|
+
auto fes = CreateFESpace(state[0].cast<string>(),
|
|
51
|
+
state[1].cast<shared_ptr<MeshAccess>>(),
|
|
52
|
+
state[2].cast<Flags>());
|
|
53
|
+
fes->Update();
|
|
54
|
+
fes->FinalizeUpdate();
|
|
55
|
+
// MR: connect_auto_update?
|
|
56
|
+
return dynamic_pointer_cast<FESPACE>(fes);
|
|
57
|
+
};
|
|
58
|
+
|
|
59
|
+
|
|
60
|
+
inline void connect_auto_update(FESpace* fes) {
|
|
61
|
+
fes->ConnectAutoUpdate();
|
|
62
|
+
}
|
|
63
|
+
|
|
64
|
+
/*
|
|
65
|
+
inline void connect_auto_update(GridFunction* gf) {
|
|
66
|
+
gf->ConnectAutoUpdate();
|
|
67
|
+
}
|
|
68
|
+
*/
|
|
69
|
+
|
|
70
|
+
template <typename FES, typename BASE=FESpace>
|
|
71
|
+
auto ExportFESpace (py::module & m, string pyname, bool module_local = false)
|
|
72
|
+
{
|
|
73
|
+
auto docu = FES::GetDocu();
|
|
74
|
+
string docstring = docu.GetPythonDocString();
|
|
75
|
+
// string docuboth = docu.short_docu + "\n\n" + docu.long_docu;
|
|
76
|
+
auto pyspace = py::class_<FES, shared_ptr<FES>,BASE> (m, pyname.c_str(), docstring.c_str(), py::module_local(module_local));
|
|
77
|
+
|
|
78
|
+
pyspace
|
|
79
|
+
.def(py::init([pyspace](shared_ptr<MeshAccess> ma, py::kwargs kwargs)
|
|
80
|
+
{
|
|
81
|
+
py::list info;
|
|
82
|
+
info.append(ma);
|
|
83
|
+
auto flags = CreateFlagsFromKwArgs(kwargs, pyspace, info);
|
|
84
|
+
auto fes = make_shared<FES>(ma,flags);
|
|
85
|
+
fes->Update();
|
|
86
|
+
fes->FinalizeUpdate();
|
|
87
|
+
// connect_auto_update(fes.get());
|
|
88
|
+
fes -> ConnectAutoUpdate();
|
|
89
|
+
return fes;
|
|
90
|
+
}),py::arg("mesh"))
|
|
91
|
+
|
|
92
|
+
.def(py::pickle(&fesPickle,
|
|
93
|
+
(shared_ptr<FES>(*)(py::tuple)) fesUnpickle<FES>))
|
|
94
|
+
;
|
|
95
|
+
|
|
96
|
+
pyspace.def_static("__flags_doc__", [docu]()
|
|
97
|
+
{
|
|
98
|
+
py::dict flags_doc;
|
|
99
|
+
for (auto & flagdoc : FES::GetDocu().arguments)
|
|
100
|
+
flags_doc[get<0> (flagdoc).c_str()] = get<1> (flagdoc);
|
|
101
|
+
return flags_doc;
|
|
102
|
+
});
|
|
103
|
+
|
|
104
|
+
return pyspace;
|
|
105
|
+
}
|
|
106
|
+
}
|
|
107
|
+
#endif // NGSOLVE_PYTHON_COMP_HPP
|
|
@@ -0,0 +1,89 @@
|
|
|
1
|
+
#ifndef PYTHON_FEM_HPP___
|
|
2
|
+
#define PYTHON_FEM_HPP___
|
|
3
|
+
#ifdef NGS_PYTHON
|
|
4
|
+
|
|
5
|
+
#include <core/register_archive.hpp>
|
|
6
|
+
// #include <fem.hpp>
|
|
7
|
+
#include <coefficient.hpp>
|
|
8
|
+
#include <finiteelement.hpp>
|
|
9
|
+
|
|
10
|
+
namespace ngfem
|
|
11
|
+
{
|
|
12
|
+
shared_ptr<CoefficientFunction> MakeCoefficient (py::object val);
|
|
13
|
+
Array<shared_ptr<CoefficientFunction>> MakeCoefficients (py::object py_coef);
|
|
14
|
+
|
|
15
|
+
template <typename FUNC>
|
|
16
|
+
void ExportStdMathFunction(py::module &m, string name, string description)
|
|
17
|
+
{
|
|
18
|
+
static RegisterClassForArchive<cl_UnaryOpCF<FUNC>, CoefficientFunction> reguopcf;
|
|
19
|
+
|
|
20
|
+
m.def (name.c_str(), [name] (py::object x) -> py::object
|
|
21
|
+
{
|
|
22
|
+
FUNC func;
|
|
23
|
+
py::extract<double> ed(x);
|
|
24
|
+
if (ed.check()) return py::cast(func(ed()));
|
|
25
|
+
if (py::extract<Complex> (x).check())
|
|
26
|
+
return py::cast(func(py::extract<Complex> (x)()));
|
|
27
|
+
if (py::extract<shared_ptr<CoefficientFunction>>(x).check())
|
|
28
|
+
{
|
|
29
|
+
auto coef = py::extract<shared_ptr<CoefficientFunction>>(x)();
|
|
30
|
+
return py::cast(UnaryOpCF(coef, func, FUNC::Name()));
|
|
31
|
+
}
|
|
32
|
+
throw py::type_error (string("can't compute math-function, type = ")
|
|
33
|
+
+ typeid(FUNC).name());
|
|
34
|
+
}, py::arg("x"), description.c_str());
|
|
35
|
+
}
|
|
36
|
+
|
|
37
|
+
template <typename FUNC>
|
|
38
|
+
void ExportStdMathFunction_(py::module &m, string name,
|
|
39
|
+
string description)
|
|
40
|
+
{
|
|
41
|
+
static RegisterClassForArchive<cl_UnaryOpCF<FUNC>, CoefficientFunction> reguopcf;
|
|
42
|
+
|
|
43
|
+
m.def(name.c_str(), py::vectorize([](double x)
|
|
44
|
+
{
|
|
45
|
+
FUNC func;
|
|
46
|
+
return func(x);
|
|
47
|
+
}), py::arg("x"), description.c_str());
|
|
48
|
+
m.def(name.c_str(), py::vectorize([](Complex x)
|
|
49
|
+
{
|
|
50
|
+
FUNC func;
|
|
51
|
+
return func(x);
|
|
52
|
+
}), py::arg("x"), description.c_str());
|
|
53
|
+
m.def(name.c_str(), [] (shared_ptr<CoefficientFunction> x) -> shared_ptr<CoefficientFunction> {
|
|
54
|
+
FUNC func;
|
|
55
|
+
return func(x);
|
|
56
|
+
}, py::arg("x"), description.c_str());
|
|
57
|
+
}
|
|
58
|
+
|
|
59
|
+
|
|
60
|
+
template <typename FUNC>
|
|
61
|
+
void ExportStdMathFunction2(py::module &m, string name, string description, string arg0="x", string arg1="y")
|
|
62
|
+
{
|
|
63
|
+
static RegisterClassForArchive<cl_BinaryOpCF<FUNC>, CoefficientFunction> regbinopcf;
|
|
64
|
+
|
|
65
|
+
m.def(name.c_str(), py::vectorize([](double x, double y)
|
|
66
|
+
{
|
|
67
|
+
FUNC func;
|
|
68
|
+
return func(x,y);
|
|
69
|
+
}), py::arg(arg0.c_str()), py::arg(arg1.c_str()), description.c_str());
|
|
70
|
+
m.def(name.c_str(), py::vectorize([](Complex x, Complex y)
|
|
71
|
+
{
|
|
72
|
+
FUNC func;
|
|
73
|
+
return func(x,y);
|
|
74
|
+
}), py::arg(arg0.c_str()), py::arg(arg1.c_str()), description.c_str());
|
|
75
|
+
m.def(name.c_str(),
|
|
76
|
+
[](shared_ptr<CoefficientFunction> x,
|
|
77
|
+
shared_ptr<CoefficientFunction> y)
|
|
78
|
+
-> shared_ptr<CoefficientFunction>
|
|
79
|
+
{
|
|
80
|
+
FUNC func;
|
|
81
|
+
return BinaryOpCF(x, y, func, FUNC::Name());
|
|
82
|
+
}, py::arg(arg0.c_str()), py::arg(arg1.c_str()), description.c_str());
|
|
83
|
+
}
|
|
84
|
+
|
|
85
|
+
|
|
86
|
+
} // namespace ngfem
|
|
87
|
+
|
|
88
|
+
#endif // NGS_PYTHON
|
|
89
|
+
#endif // PYTHON_FEM_HPP___
|
|
@@ -0,0 +1,58 @@
|
|
|
1
|
+
#ifndef NGSOLVE_PYTHON_LINALG_HPP
|
|
2
|
+
#define NGSOLVE_PYTHON_LINALG_HPP
|
|
3
|
+
|
|
4
|
+
#include <la.hpp>
|
|
5
|
+
|
|
6
|
+
// Workaround to ensure same lifetime for C++ and Python objects
|
|
7
|
+
// see https://github.com/pybind/pybind11/issues/1546
|
|
8
|
+
namespace pybind11::detail {
|
|
9
|
+
using ngla::BaseMatrix;
|
|
10
|
+
template<>
|
|
11
|
+
struct type_caster<std::shared_ptr<BaseMatrix>>
|
|
12
|
+
{
|
|
13
|
+
PYBIND11_TYPE_CASTER (std::shared_ptr<BaseMatrix>, _("BaseMatrix"));
|
|
14
|
+
|
|
15
|
+
using BaseCaster = copyable_holder_caster<BaseMatrix, std::shared_ptr<BaseMatrix>>;
|
|
16
|
+
|
|
17
|
+
bool load (pybind11::handle src, bool b)
|
|
18
|
+
{
|
|
19
|
+
BaseCaster bc;
|
|
20
|
+
bool success = bc.load (src, b);
|
|
21
|
+
if (!success)
|
|
22
|
+
{
|
|
23
|
+
return false;
|
|
24
|
+
}
|
|
25
|
+
|
|
26
|
+
auto py_obj = reinterpret_borrow<object>(src);
|
|
27
|
+
auto base_ptr = static_cast<std::shared_ptr<BaseMatrix>> (bc);
|
|
28
|
+
|
|
29
|
+
// Construct a shared_ptr to the py::object
|
|
30
|
+
auto py_obj_ptr = std::shared_ptr<object>{
|
|
31
|
+
new object{py_obj},
|
|
32
|
+
[](object * py_object_ptr) {
|
|
33
|
+
// It's possible that when the shared_ptr dies we won't have the
|
|
34
|
+
// gil (if the last holder is in a non-Python thread), so we
|
|
35
|
+
// make sure to acquire it in the deleter.
|
|
36
|
+
gil_scoped_acquire gil;
|
|
37
|
+
delete py_object_ptr;
|
|
38
|
+
}
|
|
39
|
+
};
|
|
40
|
+
|
|
41
|
+
value = std::shared_ptr<BaseMatrix> (py_obj_ptr, base_ptr.get ());
|
|
42
|
+
return true;
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
static handle cast (std::shared_ptr<BaseMatrix> base,
|
|
46
|
+
return_value_policy rvp,
|
|
47
|
+
handle h)
|
|
48
|
+
{
|
|
49
|
+
return BaseCaster::cast (base, rvp, h);
|
|
50
|
+
}
|
|
51
|
+
};
|
|
52
|
+
|
|
53
|
+
template <>
|
|
54
|
+
struct is_holder_type<BaseMatrix, std::shared_ptr<BaseMatrix>> : std::true_type {};
|
|
55
|
+
}
|
|
56
|
+
|
|
57
|
+
#endif // NGSOLVE_PYTHON_LINALG_HPP
|
|
58
|
+
|