ngsolve 6.2.2506.post74.dev0__cp314-cp314-macosx_10_15_universal2.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.
- netgen/include/analytic_integrals.hpp +10 -0
- netgen/include/arnoldi.hpp +55 -0
- netgen/include/bandmatrix.hpp +334 -0
- netgen/include/basematrix.hpp +957 -0
- netgen/include/basevector.hpp +1268 -0
- netgen/include/bdbequations.hpp +2805 -0
- netgen/include/bdbintegrator.hpp +1660 -0
- netgen/include/bem_diffops.hpp +475 -0
- netgen/include/bessel.hpp +1064 -0
- netgen/include/bilinearform.hpp +963 -0
- netgen/include/bla.hpp +29 -0
- netgen/include/blockalloc.hpp +95 -0
- netgen/include/blockjacobi.hpp +328 -0
- netgen/include/bspline.hpp +116 -0
- netgen/include/calcinverse.hpp +141 -0
- netgen/include/cg.hpp +368 -0
- netgen/include/chebyshev.hpp +44 -0
- netgen/include/cholesky.hpp +720 -0
- netgen/include/clapack.h +7254 -0
- netgen/include/code_generation.hpp +296 -0
- netgen/include/coefficient.hpp +2033 -0
- netgen/include/coefficient_impl.hpp +19 -0
- netgen/include/coefficient_stdmath.hpp +167 -0
- netgen/include/commutingAMG.hpp +106 -0
- netgen/include/comp.hpp +79 -0
- netgen/include/compatibility.hpp +41 -0
- netgen/include/complex_wrapper.hpp +73 -0
- netgen/include/compressedfespace.hpp +110 -0
- netgen/include/contact.hpp +235 -0
- netgen/include/diagonalmatrix.hpp +154 -0
- netgen/include/differentialoperator.hpp +276 -0
- netgen/include/diffop.hpp +1286 -0
- netgen/include/diffop_impl.hpp +328 -0
- netgen/include/diffopwithfactor.hpp +123 -0
- netgen/include/discontinuous.hpp +84 -0
- netgen/include/dump.hpp +949 -0
- netgen/include/ectypes.hpp +121 -0
- netgen/include/eigen.hpp +60 -0
- netgen/include/eigensystem.hpp +18 -0
- netgen/include/elasticity_equations.hpp +595 -0
- netgen/include/elementbyelement.hpp +195 -0
- netgen/include/elementtopology.hpp +1760 -0
- netgen/include/elementtransformation.hpp +339 -0
- netgen/include/evalfunc.hpp +405 -0
- netgen/include/expr.hpp +1686 -0
- netgen/include/facetfe.hpp +175 -0
- netgen/include/facetfespace.hpp +180 -0
- netgen/include/facethofe.hpp +111 -0
- netgen/include/facetsurffespace.hpp +112 -0
- netgen/include/fe_interfaces.hpp +32 -0
- netgen/include/fem.hpp +87 -0
- netgen/include/fesconvert.hpp +14 -0
- netgen/include/fespace.hpp +1449 -0
- netgen/include/finiteelement.hpp +286 -0
- netgen/include/globalinterfacespace.hpp +77 -0
- netgen/include/globalspace.hpp +115 -0
- netgen/include/gridfunction.hpp +525 -0
- netgen/include/h1amg.hpp +124 -0
- netgen/include/h1hofe.hpp +188 -0
- netgen/include/h1hofe_impl.hpp +1262 -0
- netgen/include/h1hofefo.hpp +148 -0
- netgen/include/h1hofefo_impl.hpp +185 -0
- netgen/include/h1hofespace.hpp +167 -0
- netgen/include/h1lofe.hpp +1240 -0
- netgen/include/h1lumping.hpp +41 -0
- netgen/include/hcurl_equations.hpp +1381 -0
- netgen/include/hcurlcurlfe.hpp +2241 -0
- netgen/include/hcurlcurlfespace.hpp +78 -0
- netgen/include/hcurlfe.hpp +259 -0
- netgen/include/hcurlfe_utils.hpp +107 -0
- netgen/include/hcurlhdiv_dshape.hpp +857 -0
- netgen/include/hcurlhdivfes.hpp +308 -0
- netgen/include/hcurlhofe.hpp +175 -0
- netgen/include/hcurlhofe_impl.hpp +1871 -0
- netgen/include/hcurlhofespace.hpp +193 -0
- netgen/include/hcurllofe.hpp +1146 -0
- netgen/include/hdiv_equations.hpp +880 -0
- netgen/include/hdivdivfe.hpp +2923 -0
- netgen/include/hdivdivsurfacespace.hpp +76 -0
- netgen/include/hdivfe.hpp +206 -0
- netgen/include/hdivfe_utils.hpp +717 -0
- netgen/include/hdivfes.hpp +75 -0
- netgen/include/hdivhofe.hpp +447 -0
- netgen/include/hdivhofe_impl.hpp +1107 -0
- netgen/include/hdivhofefo.hpp +229 -0
- netgen/include/hdivhofespace.hpp +177 -0
- netgen/include/hdivhosurfacefespace.hpp +106 -0
- netgen/include/hdivlofe.hpp +773 -0
- netgen/include/hidden.hpp +74 -0
- netgen/include/householder.hpp +181 -0
- netgen/include/hypre_ams_precond.hpp +123 -0
- netgen/include/hypre_precond.hpp +73 -0
- netgen/include/integrator.hpp +2012 -0
- netgen/include/integratorcf.hpp +253 -0
- netgen/include/interpolate.hpp +49 -0
- netgen/include/intrule.hpp +2542 -0
- netgen/include/intrules_SauterSchwab.hpp +25 -0
- netgen/include/irspace.hpp +49 -0
- netgen/include/jacobi.hpp +153 -0
- netgen/include/kernels.hpp +762 -0
- netgen/include/l2hofe.hpp +194 -0
- netgen/include/l2hofe_impl.hpp +564 -0
- netgen/include/l2hofefo.hpp +542 -0
- netgen/include/l2hofespace.hpp +344 -0
- netgen/include/la.hpp +38 -0
- netgen/include/linearform.hpp +266 -0
- netgen/include/matrix.hpp +2140 -0
- netgen/include/memusage.hpp +41 -0
- netgen/include/meshaccess.hpp +1359 -0
- netgen/include/mgpre.hpp +204 -0
- netgen/include/mp_coefficient.hpp +145 -0
- netgen/include/mptools.hpp +2281 -0
- netgen/include/multigrid.hpp +42 -0
- netgen/include/multivector.hpp +447 -0
- netgen/include/mumpsinverse.hpp +187 -0
- netgen/include/mycomplex.hpp +361 -0
- netgen/include/ng_lapack.hpp +1661 -0
- netgen/include/ngblas.hpp +1232 -0
- netgen/include/ngs_defines.hpp +30 -0
- netgen/include/ngs_stdcpp_include.hpp +106 -0
- netgen/include/ngs_utils.hpp +121 -0
- netgen/include/ngsobject.hpp +1019 -0
- netgen/include/ngsstream.hpp +113 -0
- netgen/include/ngstd.hpp +72 -0
- netgen/include/nodalhofe.hpp +96 -0
- netgen/include/nodalhofe_impl.hpp +141 -0
- netgen/include/normalfacetfe.hpp +223 -0
- netgen/include/normalfacetfespace.hpp +98 -0
- netgen/include/normalfacetsurfacefespace.hpp +84 -0
- netgen/include/order.hpp +251 -0
- netgen/include/parallel_matrices.hpp +222 -0
- netgen/include/paralleldofs.hpp +340 -0
- netgen/include/parallelngs.hpp +23 -0
- netgen/include/parallelvector.hpp +269 -0
- netgen/include/pardisoinverse.hpp +200 -0
- netgen/include/periodic.hpp +129 -0
- netgen/include/plateaufespace.hpp +25 -0
- netgen/include/pml.hpp +275 -0
- netgen/include/pmltrafo.hpp +631 -0
- netgen/include/postproc.hpp +142 -0
- netgen/include/potentialtools.hpp +22 -0
- netgen/include/precomp.hpp +60 -0
- netgen/include/preconditioner.hpp +602 -0
- netgen/include/prolongation.hpp +377 -0
- netgen/include/python_comp.hpp +107 -0
- netgen/include/python_fem.hpp +89 -0
- netgen/include/python_linalg.hpp +58 -0
- netgen/include/python_ngstd.hpp +386 -0
- netgen/include/recursive_pol.hpp +4896 -0
- netgen/include/recursive_pol_tet.hpp +395 -0
- netgen/include/recursive_pol_trig.hpp +492 -0
- netgen/include/reorderedfespace.hpp +81 -0
- netgen/include/sample_sort.hpp +105 -0
- netgen/include/scalarfe.hpp +335 -0
- netgen/include/shapefunction_utils.hpp +113 -0
- netgen/include/simd_complex.hpp +329 -0
- netgen/include/smoother.hpp +253 -0
- netgen/include/solve.hpp +89 -0
- netgen/include/sparsecholesky.hpp +313 -0
- netgen/include/sparsematrix.hpp +1038 -0
- netgen/include/sparsematrix_dyn.hpp +90 -0
- netgen/include/sparsematrix_impl.hpp +1013 -0
- netgen/include/special_matrix.hpp +463 -0
- netgen/include/specialelement.hpp +125 -0
- netgen/include/statushandler.hpp +33 -0
- netgen/include/stringops.hpp +12 -0
- netgen/include/superluinverse.hpp +136 -0
- netgen/include/symbolicintegrator.hpp +850 -0
- netgen/include/symmetricmatrix.hpp +144 -0
- netgen/include/tangentialfacetfe.hpp +224 -0
- netgen/include/tangentialfacetfespace.hpp +91 -0
- netgen/include/tensor.hpp +522 -0
- netgen/include/tensorcoefficient.hpp +446 -0
- netgen/include/tensorproductintegrator.hpp +113 -0
- netgen/include/thcurlfe.hpp +128 -0
- netgen/include/thcurlfe_impl.hpp +380 -0
- netgen/include/thdivfe.hpp +80 -0
- netgen/include/thdivfe_impl.hpp +492 -0
- netgen/include/tpdiffop.hpp +461 -0
- netgen/include/tpfes.hpp +133 -0
- netgen/include/tpintrule.hpp +224 -0
- netgen/include/triangular.hpp +465 -0
- netgen/include/tscalarfe.hpp +245 -0
- netgen/include/tscalarfe_impl.hpp +1029 -0
- netgen/include/umfpackinverse.hpp +148 -0
- netgen/include/vector.hpp +1273 -0
- netgen/include/voxelcoefficientfunction.hpp +41 -0
- netgen/include/vtkoutput.hpp +198 -0
- netgen/include/vvector.hpp +208 -0
- netgen/include/webgui.hpp +92 -0
- netgen/libngbla.dylib +0 -0
- netgen/libngcomp.dylib +0 -0
- netgen/libngfem.dylib +0 -0
- netgen/libngla.dylib +0 -0
- netgen/libngsbem.dylib +0 -0
- netgen/libngsolve.dylib +0 -0
- netgen/libngstd.dylib +0 -0
- ngsolve/TensorProductTools.py +210 -0
- ngsolve/__console.py +94 -0
- ngsolve/__expr.py +181 -0
- ngsolve/__init__.py +148 -0
- ngsolve/__init__.pyi +233 -0
- ngsolve/_scikit_build_core_dependencies.py +30 -0
- ngsolve/bla.pyi +1153 -0
- ngsolve/bvp.py +78 -0
- ngsolve/bvp.pyi +32 -0
- ngsolve/cmake/NGSolveConfig.cmake +102 -0
- ngsolve/cmake/ngsolve-targets-release.cmake +79 -0
- ngsolve/cmake/ngsolve-targets.cmake +163 -0
- ngsolve/comp/__init__.pyi +5449 -0
- ngsolve/comp/pml.pyi +89 -0
- ngsolve/config/__init__.py +1 -0
- ngsolve/config/__init__.pyi +43 -0
- ngsolve/config/__main__.py +4 -0
- ngsolve/config/config.py +60 -0
- ngsolve/config/config.pyi +45 -0
- ngsolve/demos/TensorProduct/__init__.py +0 -0
- ngsolve/demos/TensorProduct/tp_dg_1d_1d.py +80 -0
- ngsolve/demos/TensorProduct/tp_dg_1d_2d.py +73 -0
- ngsolve/demos/TensorProduct/tp_dg_2d_1d.py +72 -0
- ngsolve/demos/TensorProduct/tp_dg_2d_2d.py +66 -0
- ngsolve/demos/__init__.py +0 -0
- ngsolve/demos/howto/__init__.py +0 -0
- ngsolve/demos/howto/hhj.py +44 -0
- ngsolve/demos/howto/hybrid_dg.py +53 -0
- ngsolve/demos/howto/mixed.py +30 -0
- ngsolve/demos/howto/nonlin.py +29 -0
- ngsolve/demos/howto/pickling.py +26 -0
- ngsolve/demos/howto/pml.py +31 -0
- ngsolve/demos/howto/taskmanager.py +20 -0
- ngsolve/demos/howto/tdnns.py +47 -0
- ngsolve/demos/howto/timeDG-skeleton.py +45 -0
- ngsolve/demos/howto/timeDG.py +38 -0
- ngsolve/demos/howto/timeDGlap.py +42 -0
- ngsolve/demos/howto/timeDGwave.py +61 -0
- ngsolve/demos/intro/__init__.py +0 -0
- ngsolve/demos/intro/adaptive.py +123 -0
- ngsolve/demos/intro/cmagnet.py +59 -0
- ngsolve/demos/intro/elasticity.py +76 -0
- ngsolve/demos/intro/navierstokes.py +74 -0
- ngsolve/demos/intro/poisson.ipynb +170 -0
- ngsolve/demos/intro/poisson.py +41 -0
- ngsolve/demos/mpi/__init__.py +0 -0
- ngsolve/demos/mpi/mpi_cmagnet.py +87 -0
- ngsolve/demos/mpi/mpi_navierstokes.py +117 -0
- ngsolve/demos/mpi/mpi_poisson.py +89 -0
- ngsolve/demos/mpi/mpi_timeDG.py +82 -0
- ngsolve/directsolvers.py +26 -0
- ngsolve/directsolvers.pyi +15 -0
- ngsolve/eigenvalues.py +364 -0
- ngsolve/eigenvalues.pyi +30 -0
- ngsolve/fem.pyi +1647 -0
- ngsolve/internal.py +89 -0
- ngsolve/krylovspace.py +1013 -0
- ngsolve/krylovspace.pyi +298 -0
- ngsolve/la.pyi +1230 -0
- ngsolve/meshes.py +748 -0
- ngsolve/ngs2petsc.py +310 -0
- ngsolve/ngscxx.py +42 -0
- ngsolve/ngslib.so +0 -0
- ngsolve/ngstd.pyi +59 -0
- ngsolve/nonlinearsolvers.py +203 -0
- ngsolve/nonlinearsolvers.pyi +95 -0
- ngsolve/preconditioners.py +11 -0
- ngsolve/preconditioners.pyi +7 -0
- ngsolve/solve.pyi +109 -0
- ngsolve/solve_implementation.py +168 -0
- ngsolve/solve_implementation.pyi +42 -0
- ngsolve/solvers.py +7 -0
- ngsolve/solvers.pyi +14 -0
- ngsolve/timestepping.py +185 -0
- ngsolve/timestepping.pyi +28 -0
- ngsolve/timing.py +108 -0
- ngsolve/timing.pyi +54 -0
- ngsolve/utils.py +167 -0
- ngsolve/utils.pyi +273 -0
- ngsolve/webgui.py +670 -0
- ngsolve-6.2.2506.post74.dev0.data/data/Netgen.icns +0 -0
- ngsolve-6.2.2506.post74.dev0.data/data/bin/ngscxx +17 -0
- ngsolve-6.2.2506.post74.dev0.data/data/bin/ngsld +13 -0
- ngsolve-6.2.2506.post74.dev0.data/data/bin/ngsolve.tcl +648 -0
- ngsolve-6.2.2506.post74.dev0.data/data/bin/ngspy +2 -0
- ngsolve-6.2.2506.post74.dev0.data/data/share/ngsolve/beam.geo +17 -0
- ngsolve-6.2.2506.post74.dev0.data/data/share/ngsolve/beam.vol +240 -0
- ngsolve-6.2.2506.post74.dev0.data/data/share/ngsolve/chip.in2d +41 -0
- ngsolve-6.2.2506.post74.dev0.data/data/share/ngsolve/chip.vol +614 -0
- ngsolve-6.2.2506.post74.dev0.data/data/share/ngsolve/coil.geo +12 -0
- ngsolve-6.2.2506.post74.dev0.data/data/share/ngsolve/coil.vol +2560 -0
- ngsolve-6.2.2506.post74.dev0.data/data/share/ngsolve/coilshield.geo +24 -0
- ngsolve-6.2.2506.post74.dev0.data/data/share/ngsolve/coilshield.vol +3179 -0
- ngsolve-6.2.2506.post74.dev0.data/data/share/ngsolve/cube.geo +19 -0
- ngsolve-6.2.2506.post74.dev0.data/data/share/ngsolve/cube.vol +1832 -0
- ngsolve-6.2.2506.post74.dev0.data/data/share/ngsolve/d10_DGdoubleglazing.pde +50 -0
- ngsolve-6.2.2506.post74.dev0.data/data/share/ngsolve/d11_chip_nitsche.pde +40 -0
- ngsolve-6.2.2506.post74.dev0.data/data/share/ngsolve/d1_square.pde +43 -0
- ngsolve-6.2.2506.post74.dev0.data/data/share/ngsolve/d2_chip.pde +35 -0
- ngsolve-6.2.2506.post74.dev0.data/data/share/ngsolve/d3_helmholtz.pde +22 -0
- ngsolve-6.2.2506.post74.dev0.data/data/share/ngsolve/d4_cube.pde +46 -0
- ngsolve-6.2.2506.post74.dev0.data/data/share/ngsolve/d5_beam.pde +74 -0
- ngsolve-6.2.2506.post74.dev0.data/data/share/ngsolve/d6_shaft.pde +73 -0
- ngsolve-6.2.2506.post74.dev0.data/data/share/ngsolve/d7_coil.pde +50 -0
- ngsolve-6.2.2506.post74.dev0.data/data/share/ngsolve/d8_coilshield.pde +49 -0
- ngsolve-6.2.2506.post74.dev0.data/data/share/ngsolve/d9_hybridDG.pde +72 -0
- ngsolve-6.2.2506.post74.dev0.data/data/share/ngsolve/doubleglazing.in2d +27 -0
- ngsolve-6.2.2506.post74.dev0.data/data/share/ngsolve/doubleglazing.vol +737 -0
- ngsolve-6.2.2506.post74.dev0.data/data/share/ngsolve/piezo2d40round4.vol.gz +0 -0
- ngsolve-6.2.2506.post74.dev0.data/data/share/ngsolve/shaft.geo +73 -0
- ngsolve-6.2.2506.post74.dev0.data/data/share/ngsolve/shaft.vol +4291 -0
- ngsolve-6.2.2506.post74.dev0.data/data/share/ngsolve/square.in2d +17 -0
- ngsolve-6.2.2506.post74.dev0.data/data/share/ngsolve/square.vol +149 -0
- ngsolve-6.2.2506.post74.dev0.dist-info/METADATA +13 -0
- ngsolve-6.2.2506.post74.dev0.dist-info/RECORD +315 -0
- ngsolve-6.2.2506.post74.dev0.dist-info/WHEEL +5 -0
- ngsolve-6.2.2506.post74.dev0.dist-info/licenses/LICENSE +504 -0
- ngsolve-6.2.2506.post74.dev0.dist-info/top_level.txt +2 -0
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
#!/bin/bash
|
|
2
|
+
NGSCXX_DIR=$( cd $(dirname $0); pwd )
|
|
3
|
+
PY_INCLUDE_FLAGS=-I$(python3 -c"import sysconfig;print(sysconfig.get_path('include'))")
|
|
4
|
+
if [ -f /Library/Developer/CommandLineTools/usr/bin/c++ ]
|
|
5
|
+
then NGSCXX=/Library/Developer/CommandLineTools/usr/bin/c++
|
|
6
|
+
else NGSCXX=c++
|
|
7
|
+
fi
|
|
8
|
+
export CCACHE_NOHASHDIR=1
|
|
9
|
+
|
|
10
|
+
Netgen_BUNDLE="`echo "$0" | sed -e 's/\/Contents\/MacOS\/ngsld//'`"
|
|
11
|
+
Netgen_MACOS="$Netgen_BUNDLE/Contents/MacOS"
|
|
12
|
+
|
|
13
|
+
$NGSCXX -isysroot /Library/Developer/CommandLineTools/SDKs/MacOSX15.2.sdk -L$Netgen_BUNDLE/Contents/MacOS -undefined dynamic_lookup $*
|
|
@@ -0,0 +1,648 @@
|
|
|
1
|
+
puts "loading ngsolve library"
|
|
2
|
+
|
|
3
|
+
# netgen_library_dir is set from python in pip packages
|
|
4
|
+
if { [ info exists netgen_library_dir ] } {
|
|
5
|
+
load $netgen_library_dir/libngsolve[info sharedlibextension] ngsolve
|
|
6
|
+
} elseif { [catch { load libngsolve[info sharedlibextension] ngsolve } result ] } {
|
|
7
|
+
set current_script_dir [file dirname [dict get [info frame 0] file]]
|
|
8
|
+
if { [catch { load $current_script_dir/../netgen/libngsolve[info sharedlibextension] ngsolve } result2 ] } {
|
|
9
|
+
puts "cannot load ngsolve"
|
|
10
|
+
puts "error1: $result"
|
|
11
|
+
puts "error2: $result2"
|
|
12
|
+
}
|
|
13
|
+
}
|
|
14
|
+
|
|
15
|
+
# check some NGS command
|
|
16
|
+
if { [catch { NGS_GetData } ] == 0 } {
|
|
17
|
+
|
|
18
|
+
set sbatchmode [Ng_GetCommandLineParameter batchmode]
|
|
19
|
+
if { $sbatchmode == "defined" } {
|
|
20
|
+
puts "batchmode ..."
|
|
21
|
+
|
|
22
|
+
set pdefilename [Ng_GetCommandLineParameter pdefile]
|
|
23
|
+
if { $pdefilename != "undefined" } {
|
|
24
|
+
NGS_LoadPDE $pdefilename;
|
|
25
|
+
set solve [Ng_GetCommandLineParameter solve]
|
|
26
|
+
|
|
27
|
+
if { $solve == "defined" } { set solve 1 }
|
|
28
|
+
if { $solve != "undefined" } {
|
|
29
|
+
set options.parthread 0
|
|
30
|
+
Ng_SetMeshingParameters
|
|
31
|
+
for { set l 1 } { $l <= $solve } { incr l } { NGS_SolvePDE $l }
|
|
32
|
+
NGS_PrintTiming
|
|
33
|
+
puts "Thank you for using $progname/NGSolve";
|
|
34
|
+
|
|
35
|
+
if { [catch { unload libngsolve[info sharedlibextension] ngsolve } result ] } {
|
|
36
|
+
puts "cannot unload ngsolve"
|
|
37
|
+
puts "error: $result"
|
|
38
|
+
}
|
|
39
|
+
|
|
40
|
+
Ng_Exit;
|
|
41
|
+
destroy .
|
|
42
|
+
exit
|
|
43
|
+
}
|
|
44
|
+
}
|
|
45
|
+
}
|
|
46
|
+
|
|
47
|
+
set pdefilename [Ng_GetCommandLineParameter pdefile]
|
|
48
|
+
if { $pdefilename != "undefined" } {
|
|
49
|
+
NGS_LoadPDE $pdefilename;
|
|
50
|
+
|
|
51
|
+
set solve [Ng_GetCommandLineParameter solve]
|
|
52
|
+
|
|
53
|
+
if { $solve == "defined" } { set solve 1 }
|
|
54
|
+
if { $solve != "undefined" } {
|
|
55
|
+
set options.parthread 0
|
|
56
|
+
Ng_SetMeshingParameters
|
|
57
|
+
for { set l 1 } { $l <= $solve } { incr l } { NGS_SolvePDE $l }
|
|
58
|
+
set selectvisual solution
|
|
59
|
+
Ng_SetVisParameters
|
|
60
|
+
redraw
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
|
|
64
|
+
set pyfilename [Ng_GetCommandLineParameter py]
|
|
65
|
+
if { $pyfilename != "undefined" } {
|
|
66
|
+
NGS_LoadPy $pyfilename;
|
|
67
|
+
}
|
|
68
|
+
|
|
69
|
+
set progname "NGSolve"
|
|
70
|
+
wm title . $progname
|
|
71
|
+
|
|
72
|
+
.ngmenu add cascade -label "Solve" -menu .ngmenu.solve -underline 1
|
|
73
|
+
|
|
74
|
+
|
|
75
|
+
menu .ngmenu.solve
|
|
76
|
+
.ngmenu.solve add command -label "Print Equations" \
|
|
77
|
+
-command { NGS_PrintRegistered }
|
|
78
|
+
|
|
79
|
+
|
|
80
|
+
|
|
81
|
+
menu .ngmenusolvehelp
|
|
82
|
+
.ngmenu.solve add cascade -label "Help" -menu .ngmenusolvehelp
|
|
83
|
+
|
|
84
|
+
.ngmenusolvehelp add command -label "Constants..." \
|
|
85
|
+
-command { tk_messageBox -title "Help" -message [ NGS_Help constant ] -type ok }
|
|
86
|
+
.ngmenusolvehelp add command -label "Coefficient..." \
|
|
87
|
+
-command { tk_messageBox -title "Help" -message [ NGS_Help coefficient ] -type ok }
|
|
88
|
+
.ngmenusolvehelp add command -label "Bilinear-form..." \
|
|
89
|
+
-command { tk_messageBox -title "Help" -message [ NGS_Help bilinearform ] -type ok }
|
|
90
|
+
.ngmenusolvehelp add command -label "Linear-form..." \
|
|
91
|
+
-command { tk_messageBox -title "Help" -message [ NGS_Help linearform ] -type ok }
|
|
92
|
+
|
|
93
|
+
# defined in C++ code:
|
|
94
|
+
menu .ngmenusolvehelpnp
|
|
95
|
+
.ngmenusolvehelp add cascade -label "Numprocs..." -menu .ngmenusolvehelpnp
|
|
96
|
+
|
|
97
|
+
|
|
98
|
+
proc SetNumProcHelpMenu {} {
|
|
99
|
+
set allnp [ NGS_Help numprocs ]
|
|
100
|
+
.ngmenusolvehelpnp delete 1 end
|
|
101
|
+
|
|
102
|
+
foreach np $allnp {
|
|
103
|
+
.ngmenusolvehelpnp add command -label "numproc $np" \
|
|
104
|
+
-command "tk_messageBox -title \"Help\" -message \[ NGS_Help numproc $np \] -type ok"
|
|
105
|
+
}
|
|
106
|
+
}
|
|
107
|
+
|
|
108
|
+
SetNumProcHelpMenu
|
|
109
|
+
|
|
110
|
+
|
|
111
|
+
.ngmenu.solve add command -label "Load PDE..." -accelerator "<l><p>"\
|
|
112
|
+
-command {
|
|
113
|
+
set types { {"Partial Differential Equation" {.pde} } }
|
|
114
|
+
set file [tk_getOpenFile -filetypes $types -initialdir $dirname]
|
|
115
|
+
if {$file != ""} {
|
|
116
|
+
set dirname [file dirname $file]
|
|
117
|
+
AddRecentNGSFile $file;
|
|
118
|
+
NGS_LoadPDE $file;
|
|
119
|
+
SetNumProcHelpMenu
|
|
120
|
+
set selectvisual mesh;
|
|
121
|
+
Ng_SetVisParameters
|
|
122
|
+
}
|
|
123
|
+
}
|
|
124
|
+
|
|
125
|
+
.ngmenu.solve add cascade -label "Recent Files" -menu .ngmenu.solve.recent
|
|
126
|
+
menu .ngmenu.solve.recent -tearoff 0
|
|
127
|
+
|
|
128
|
+
.ngmenu.solve add command -label "Load Python..." -accelerator "<l><y>"\
|
|
129
|
+
-command {
|
|
130
|
+
set types { {"Python script" {.py} } }
|
|
131
|
+
set file [tk_getOpenFile -filetypes $types -initialdir $dirname]
|
|
132
|
+
if {$file != ""} {
|
|
133
|
+
set dirname [file dirname $file]
|
|
134
|
+
AddRecentPYNGSFile $file;
|
|
135
|
+
NGS_LoadPy $file;
|
|
136
|
+
}
|
|
137
|
+
}
|
|
138
|
+
|
|
139
|
+
|
|
140
|
+
.ngmenu.solve add command -label "Components..." \
|
|
141
|
+
-command { componentsdialog }
|
|
142
|
+
|
|
143
|
+
|
|
144
|
+
.ngmenu.solve add command -label "Print Report" \
|
|
145
|
+
-command { NGS_PrintPDE }
|
|
146
|
+
|
|
147
|
+
.ngmenu.solve add command -label "Memory Usage" \
|
|
148
|
+
-command { NGS_PrintMemoryUsage }
|
|
149
|
+
|
|
150
|
+
.ngmenu.solve add command -label "Print Timing" \
|
|
151
|
+
-command { NGS_PrintTiming }
|
|
152
|
+
|
|
153
|
+
|
|
154
|
+
.ngmenu.solve add command -label "Solve Recent PDE" -accelerator "<s><r>"\
|
|
155
|
+
-command {
|
|
156
|
+
# set filename [.ngmenu.solve.recent entrycget 0 -label]
|
|
157
|
+
# puts "solve filename: $filename"
|
|
158
|
+
# NGS_LoadPDE [.ngmenu.solve.recent entrycget 0 -label]
|
|
159
|
+
.ngmenu.solve.recent invoke 0
|
|
160
|
+
if { [ string match "*.pde" [.ngmenu.solve.recent entrycget 0 -label]] } {
|
|
161
|
+
NGS_SolvePDE
|
|
162
|
+
}
|
|
163
|
+
set selectvisual solution
|
|
164
|
+
Ng_SetVisParameters
|
|
165
|
+
redraw
|
|
166
|
+
}
|
|
167
|
+
|
|
168
|
+
ttk::button .bubar.pde -text "Recent" \
|
|
169
|
+
-command { .ngmenu.solve invoke "Solve Recent PDE"; }
|
|
170
|
+
pack .bubar.pde -side right
|
|
171
|
+
|
|
172
|
+
ttk::button .bubar.solve -text "Solve PDE" \
|
|
173
|
+
-command { .ngmenu.solve invoke "Solve PDE"; }
|
|
174
|
+
pack .bubar.solve -side right
|
|
175
|
+
|
|
176
|
+
ttk::button .bubar.visualize -text "Visual" \
|
|
177
|
+
-command { visual_dialog }
|
|
178
|
+
pack .bubar.visualize -side right
|
|
179
|
+
|
|
180
|
+
.ngmenu.solve add command -label "Solve PDE" -accelerator "<s><p>"\
|
|
181
|
+
-command {
|
|
182
|
+
|
|
183
|
+
# if {[winfo exists .visoptions_dlg] == 1} {
|
|
184
|
+
# destroy .visoptions_dlg;
|
|
185
|
+
# set test 1;
|
|
186
|
+
# }
|
|
187
|
+
|
|
188
|
+
|
|
189
|
+
NGS_SolvePDE
|
|
190
|
+
set selectvisual solution
|
|
191
|
+
Ng_SetVisParameters
|
|
192
|
+
|
|
193
|
+
Ng_Vis_Set parameters;
|
|
194
|
+
|
|
195
|
+
# if { $test == 1 } {
|
|
196
|
+
# reset_visual_dialog
|
|
197
|
+
# }
|
|
198
|
+
|
|
199
|
+
redraw
|
|
200
|
+
}
|
|
201
|
+
|
|
202
|
+
.ngmenu.solve add cascade -label "Solve PDE x" -menu .ngmenu.solve.solvex
|
|
203
|
+
menu .ngmenu.solve.solvex
|
|
204
|
+
|
|
205
|
+
proc SolveX { num } {
|
|
206
|
+
for { set i 1 } { $i <= $num } { incr i } {
|
|
207
|
+
uplevel 1 "NGS_SolvePDE $i"
|
|
208
|
+
}
|
|
209
|
+
}
|
|
210
|
+
|
|
211
|
+
.ngmenu.solve.solvex add command -label "1 Level" -command { SolveX 1 }
|
|
212
|
+
.ngmenu.solve.solvex add command -label "2 Level" -command { SolveX 2 }
|
|
213
|
+
.ngmenu.solve.solvex add command -label "3 Level" -command { SolveX 3 }
|
|
214
|
+
.ngmenu.solve.solvex add command -label "4 Level" -command { SolveX 4 }
|
|
215
|
+
.ngmenu.solve.solvex add command -label "5 Level" -command { SolveX 5 }
|
|
216
|
+
.ngmenu.solve.solvex add command -label "6 Level" -command { SolveX 6 }
|
|
217
|
+
.ngmenu.solve.solvex add command -label "7 Level" -command { SolveX 7 }
|
|
218
|
+
.ngmenu.solve.solvex add command -label "8 Level" -command { SolveX 8 }
|
|
219
|
+
.ngmenu.solve.solvex add command -label "9 Level" -command { SolveX 9 }
|
|
220
|
+
.ngmenu.solve.solvex add command -label "10 Level" -command { SolveX 10 }
|
|
221
|
+
.ngmenu.solve.solvex add command -label "11 Level" -command { SolveX 11 }
|
|
222
|
+
.ngmenu.solve.solvex add command -label "12 Level" -command { SolveX 12 }
|
|
223
|
+
.ngmenu.solve.solvex add command -label "13 Level" -command { SolveX 13 }
|
|
224
|
+
.ngmenu.solve.solvex add command -label "14 Level" -command { SolveX 14 }
|
|
225
|
+
.ngmenu.solve.solvex add command -label "15 Level" -command { SolveX 15 }
|
|
226
|
+
.ngmenu.solve.solvex add command -label "16 Level" -command { SolveX 16 }
|
|
227
|
+
.ngmenu.solve.solvex add command -label "17 Level" -command { SolveX 17 }
|
|
228
|
+
.ngmenu.solve.solvex add command -label "18 Level" -command { SolveX 18 }
|
|
229
|
+
.ngmenu.solve.solvex add command -label "19 Level" -command { SolveX 19 }
|
|
230
|
+
.ngmenu.solve.solvex add command -label "20 Level" -command { SolveX 20 }
|
|
231
|
+
|
|
232
|
+
|
|
233
|
+
.ngmenu.solve add command -label "Enter Command" \
|
|
234
|
+
-command {
|
|
235
|
+
NGS_EnterCommand;
|
|
236
|
+
}
|
|
237
|
+
|
|
238
|
+
|
|
239
|
+
.ngmenu.solve add command -label "Visualization..." \
|
|
240
|
+
-command {
|
|
241
|
+
visual_dialog;
|
|
242
|
+
}
|
|
243
|
+
|
|
244
|
+
|
|
245
|
+
.ngmenu.solve add command -label "Save Solution..." \
|
|
246
|
+
-command {
|
|
247
|
+
set types { {"Solution File" {.sol} } }
|
|
248
|
+
set file [tk_getSaveFile -filetypes $types -defaultextension ".sol" ]
|
|
249
|
+
if {$file != ""} {
|
|
250
|
+
NGS_SaveSolution $file
|
|
251
|
+
}
|
|
252
|
+
}
|
|
253
|
+
|
|
254
|
+
.ngmenu.solve add command -label "Load Solution..." \
|
|
255
|
+
-command {
|
|
256
|
+
set types { {"Solution File" {.sol} } }
|
|
257
|
+
set file [tk_getOpenFile -filetypes $types -defaultextension ".sol" ]
|
|
258
|
+
if {$file != ""} {
|
|
259
|
+
NGS_LoadSolution $file
|
|
260
|
+
set selectvisual solution
|
|
261
|
+
Ng_SetVisParameters
|
|
262
|
+
redraw
|
|
263
|
+
}
|
|
264
|
+
}
|
|
265
|
+
|
|
266
|
+
.ngmenu.solve add command -label "Dump PDE" \
|
|
267
|
+
-command {
|
|
268
|
+
NGS_DumpPDE test.arch
|
|
269
|
+
}
|
|
270
|
+
|
|
271
|
+
.ngmenu.solve add command -label "Restore PDE" \
|
|
272
|
+
-command {
|
|
273
|
+
NGS_RestorePDE test.arch
|
|
274
|
+
}
|
|
275
|
+
|
|
276
|
+
.ngmenu.solve add command -label "Socket-load" \
|
|
277
|
+
-command {
|
|
278
|
+
NGS_SocketLoad 52002 128.131.37.12
|
|
279
|
+
# NGS_SocketLoad 52002 localhost
|
|
280
|
+
# numericus.asc.tuwien.ac.at
|
|
281
|
+
set selectvisual solution
|
|
282
|
+
Ng_SetVisParameters
|
|
283
|
+
redraw
|
|
284
|
+
}
|
|
285
|
+
|
|
286
|
+
.ngmenu.solve add command -label "Python shell" -accelerator "<p><y>"\
|
|
287
|
+
-command {
|
|
288
|
+
NGS_PythonShell
|
|
289
|
+
}
|
|
290
|
+
|
|
291
|
+
|
|
292
|
+
|
|
293
|
+
# .ngmenu.solve add command -label "Save Solution (ASCII)..." \
|
|
294
|
+
# -command {
|
|
295
|
+
# set types { {"Solution File" {.asol} } }
|
|
296
|
+
# set file [tk_getSaveFile -filetypes $types -defaultextension ".asol" ]
|
|
297
|
+
# if {$file != ""} {
|
|
298
|
+
# NGS_SaveSolution $file 1
|
|
299
|
+
# }
|
|
300
|
+
# }
|
|
301
|
+
|
|
302
|
+
# .ngmenu.solve add command -label "Load Solution (ASCII)..." \
|
|
303
|
+
# -command {
|
|
304
|
+
# set types { {"Solution File" {.asol} } }
|
|
305
|
+
# set file [tk_getOpenFile -filetypes $types -defaultextension ".asol" ]
|
|
306
|
+
# if {$file != ""} {
|
|
307
|
+
# NGS_LoadSolution $file 1
|
|
308
|
+
# set selectvisual solution
|
|
309
|
+
# Ng_SetVisParameters
|
|
310
|
+
# redraw
|
|
311
|
+
# }
|
|
312
|
+
# }
|
|
313
|
+
|
|
314
|
+
|
|
315
|
+
|
|
316
|
+
# .ngmenu.solve add separator
|
|
317
|
+
|
|
318
|
+
|
|
319
|
+
|
|
320
|
+
.ngmenu.help delete "About..."
|
|
321
|
+
.ngmenu.help add command -label "About..." \
|
|
322
|
+
-command {
|
|
323
|
+
tk_messageBox -message \
|
|
324
|
+
"This is NETGEN/NGSolve \n mainly written by \n Joachim Schoeberl \n\
|
|
325
|
+
at Vienna University of Technology, Austria \n\
|
|
326
|
+
and RWTH Aachen University, Germany \n\
|
|
327
|
+
and Johannes Kepler University, Linz, Austria \n\
|
|
328
|
+
supported by the Austrian Science Foundation FWF \n\
|
|
329
|
+
thanks to \n\
|
|
330
|
+
F. Bachinger, A. Becirovic, H. Egger, R. Gaisbauer, J. Gerstmayr, M. Hochsteger, G. Kitzler, U. Langer, C. Lehrenfeld, P. Rajan, A. Sinwel, M. Wabro, S. Zaglmayr"
|
|
331
|
+
}
|
|
332
|
+
|
|
333
|
+
proc AddRecentNGSFile { filename } {
|
|
334
|
+
global progname
|
|
335
|
+
catch { [.ngmenu.solve.recent delete $filename] }
|
|
336
|
+
.ngmenu.solve.recent insert 0 command -label $filename \
|
|
337
|
+
-command "AddRecentNGSFile {$filename};
|
|
338
|
+
NGS_LoadPDE {$filename};
|
|
339
|
+
set selectvisual mesh;
|
|
340
|
+
Ng_SetVisParameters
|
|
341
|
+
wm title . [concat \" $progname - $filename \"];"
|
|
342
|
+
|
|
343
|
+
if { [.ngmenu.solve.recent index last] >= 6 } {
|
|
344
|
+
.ngmenu.solve.recent delete last }
|
|
345
|
+
|
|
346
|
+
savengsinifile;
|
|
347
|
+
}
|
|
348
|
+
proc AddRecentPYNGSFile { filename } {
|
|
349
|
+
global progname
|
|
350
|
+
catch { [.ngmenu.solve.recent delete $filename] }
|
|
351
|
+
.ngmenu.solve.recent insert 0 command -label $filename \
|
|
352
|
+
-command "AddRecentPYNGSFile {$filename};
|
|
353
|
+
wm title . [concat \" $progname - $filename \"];
|
|
354
|
+
NGS_LoadPy {$filename};"
|
|
355
|
+
|
|
356
|
+
if { [.ngmenu.solve.recent index last] >= 6 } {
|
|
357
|
+
.ngmenu.solve.recent delete last }
|
|
358
|
+
|
|
359
|
+
savengsinifile;
|
|
360
|
+
}
|
|
361
|
+
|
|
362
|
+
|
|
363
|
+
# the ini file is saved on demand :
|
|
364
|
+
global ngsinifilename
|
|
365
|
+
|
|
366
|
+
set ngsinifilename [file join $nguserdir ngs.ini]
|
|
367
|
+
|
|
368
|
+
proc savengsinifile { } {
|
|
369
|
+
global ngsinifilename
|
|
370
|
+
if {[catch { set datei [open $ngsinifilename w] } result ]} {
|
|
371
|
+
puts "cannot write to $ngsinifilename file"
|
|
372
|
+
} {
|
|
373
|
+
for { set i [.ngmenu.solve.recent index last] } { $i >= 0 } { incr i -1 } {
|
|
374
|
+
puts $datei "recentfile \"[.ngmenu.solve.recent entrycget $i -label]\""
|
|
375
|
+
}
|
|
376
|
+
close $datei
|
|
377
|
+
}
|
|
378
|
+
}
|
|
379
|
+
|
|
380
|
+
proc loadngsinifile { } {
|
|
381
|
+
global ngsinifilename
|
|
382
|
+
if { [file exists $ngsinifilename] == 1 } {
|
|
383
|
+
set datei [open $ngsinifilename r]
|
|
384
|
+
while { [gets $datei line] >= 0 } {
|
|
385
|
+
if {[lindex $line 0] == "recentfile"} {
|
|
386
|
+
if { [string match "*.pde" [lindex $line 1]] } {
|
|
387
|
+
AddRecentNGSFile [lindex $line 1];
|
|
388
|
+
}
|
|
389
|
+
if { [string match "*.py" [lindex $line 1]] } {
|
|
390
|
+
AddRecentPYNGSFile [lindex $line 1];
|
|
391
|
+
}
|
|
392
|
+
}
|
|
393
|
+
}
|
|
394
|
+
close $datei
|
|
395
|
+
}
|
|
396
|
+
}
|
|
397
|
+
|
|
398
|
+
loadngsinifile;
|
|
399
|
+
|
|
400
|
+
|
|
401
|
+
proc componentsdialog { } {
|
|
402
|
+
|
|
403
|
+
set w .components_dlg
|
|
404
|
+
|
|
405
|
+
if {[winfo exists .components_dlg] == 1} {
|
|
406
|
+
wm withdraw $w
|
|
407
|
+
wm deiconify $w
|
|
408
|
+
focus $w
|
|
409
|
+
} {
|
|
410
|
+
|
|
411
|
+
toplevel $w
|
|
412
|
+
#tk::treeview $w.tree
|
|
413
|
+
#pack $w.tree -fill both -expand y
|
|
414
|
+
#$w.tree insert {} end -id widgets -text "Widget Tour"
|
|
415
|
+
ttk::treeview $w.tree
|
|
416
|
+
pack $w.tree -fill both -expand y
|
|
417
|
+
$w.tree insert {} end -id constants -text "Constants"
|
|
418
|
+
$w.tree insert {} end -id variables -text "Variables"
|
|
419
|
+
$w.tree insert {} end -id coefficients -text "Coefficients"
|
|
420
|
+
$w.tree insert {} end -id spaces -text "Spaces"
|
|
421
|
+
$w.tree insert {} end -id biforms -text "Bilinear-forms"
|
|
422
|
+
$w.tree insert {} end -id liforms -text "Linear-forms"
|
|
423
|
+
$w.tree insert {} end -id gfs -text "Grid-functions"
|
|
424
|
+
$w.tree insert {} end -id preconds -text "Preconditioners"
|
|
425
|
+
$w.tree insert {} end -id nps -text "NumProcs"
|
|
426
|
+
set constants [NGS_GetData constants]
|
|
427
|
+
foreach co $constants {
|
|
428
|
+
$w.tree insert {constants} end -text $co
|
|
429
|
+
}
|
|
430
|
+
set variables [NGS_GetData variableswithval]
|
|
431
|
+
foreach va $variables {
|
|
432
|
+
$w.tree insert {variables} end -text $va
|
|
433
|
+
}
|
|
434
|
+
set coefs [NGS_GetData coefficients]
|
|
435
|
+
foreach coef $coefs {
|
|
436
|
+
$w.tree insert {coefficients} end -text $coef
|
|
437
|
+
}
|
|
438
|
+
set spaces [NGS_GetData spaces]
|
|
439
|
+
foreach space $spaces {
|
|
440
|
+
$w.tree insert {spaces} end -text $space
|
|
441
|
+
}
|
|
442
|
+
set biforms [NGS_GetData bilinearforms]
|
|
443
|
+
foreach biform $biforms {
|
|
444
|
+
$w.tree insert {biforms} end -text $biform
|
|
445
|
+
}
|
|
446
|
+
set liforms [NGS_GetData linearforms]
|
|
447
|
+
foreach liform $liforms {
|
|
448
|
+
$w.tree insert {liforms} end -text $liform
|
|
449
|
+
}
|
|
450
|
+
set gridfuns [NGS_GetData gridfunctions]
|
|
451
|
+
foreach gridfun $gridfuns {
|
|
452
|
+
$w.tree insert {gfs} end -text $gridfun
|
|
453
|
+
}
|
|
454
|
+
set preconds [NGS_GetData preconditioners]
|
|
455
|
+
foreach precond $preconds {
|
|
456
|
+
$w.tree insert {preconds} end -text $precond
|
|
457
|
+
}
|
|
458
|
+
set numprocs [NGS_GetData numprocs]
|
|
459
|
+
foreach numproc $numprocs {
|
|
460
|
+
$w.tree insert {nps} end -text $numproc
|
|
461
|
+
}
|
|
462
|
+
#$w.tree configure -color black
|
|
463
|
+
# tixTree $w.mtre -options { separator "\\" }
|
|
464
|
+
# pack $w.mtre -fill both -expand y
|
|
465
|
+
# set hlist [$w.mtre subwidget hlist]
|
|
466
|
+
|
|
467
|
+
# $hlist configure -selectforeground black
|
|
468
|
+
# $hlist configure -selectbackground grey
|
|
469
|
+
|
|
470
|
+
# $hlist add constants -itemtype text -text "Constants"
|
|
471
|
+
# set constants [NGS_GetData constants]
|
|
472
|
+
# foreach co $constants {
|
|
473
|
+
# $hlist add constants\\$co -itemtype text -text $co
|
|
474
|
+
# }
|
|
475
|
+
|
|
476
|
+
# $hlist add variables -itemtype text -text "Variables"
|
|
477
|
+
# set variables [NGS_GetData variableswithval]
|
|
478
|
+
# foreach va $variables {
|
|
479
|
+
# $hlist add variables\\$va -itemtype text -text $va
|
|
480
|
+
# }
|
|
481
|
+
|
|
482
|
+
# $hlist add coeffs -itemtype text -text "Coefficients"
|
|
483
|
+
# set coefs [NGS_GetData coefficients]
|
|
484
|
+
# foreach coef $coefs {
|
|
485
|
+
# $hlist add coeffs\\$coef -itemtype text -text $coef
|
|
486
|
+
# }
|
|
487
|
+
|
|
488
|
+
|
|
489
|
+
# $hlist add spaces -itemtype text -text "Spaces"
|
|
490
|
+
# set spaces [NGS_GetData spaces]
|
|
491
|
+
# foreach space $spaces {
|
|
492
|
+
# $hlist add spaces\\$space -itemtype text -text $space
|
|
493
|
+
# }
|
|
494
|
+
|
|
495
|
+
# $hlist add biforms -itemtype text -text "Bilinear-forms"
|
|
496
|
+
# set biforms [NGS_GetData bilinearforms]
|
|
497
|
+
# foreach biform $biforms {
|
|
498
|
+
# $hlist add biforms\\$biform -itemtype text -text $biform
|
|
499
|
+
# }
|
|
500
|
+
|
|
501
|
+
# $hlist add liforms -itemtype text -text "Linear-forms"
|
|
502
|
+
# set liforms [NGS_GetData linearforms]
|
|
503
|
+
# foreach liform $liforms {
|
|
504
|
+
# $hlist add liforms\\$liform -itemtype text -text $liform
|
|
505
|
+
# }
|
|
506
|
+
|
|
507
|
+
# $hlist add gridfuns -itemtype text -text "Grid-functions"
|
|
508
|
+
# set gridfuns [NGS_GetData gridfunctions]
|
|
509
|
+
# foreach gridfun $gridfuns {
|
|
510
|
+
# $hlist add gridfuns\\$gridfun -itemtype text -text $gridfun
|
|
511
|
+
# }
|
|
512
|
+
|
|
513
|
+
# $hlist add preconds -itemtype text -text "Preconditioners"
|
|
514
|
+
# set preconds [NGS_GetData preconditioners]
|
|
515
|
+
# foreach precond $preconds {
|
|
516
|
+
# $hlist add preconds\\$precond -itemtype text -text $precond
|
|
517
|
+
# }
|
|
518
|
+
|
|
519
|
+
# $hlist add numprocs -itemtype text -text "NumProcs"
|
|
520
|
+
# set numprocs [NGS_GetData numprocs]
|
|
521
|
+
# foreach numproc $numprocs {
|
|
522
|
+
# $hlist add numprocs\\$numproc -itemtype text -text $numproc
|
|
523
|
+
# }
|
|
524
|
+
|
|
525
|
+
# $hlist add varis -itemtype text -text "Variables"
|
|
526
|
+
# set varis [NGS_GetData variables]
|
|
527
|
+
# foreach vari $varis {
|
|
528
|
+
# $hlist add varis\\$vari -itemtype text -text $vari
|
|
529
|
+
# }
|
|
530
|
+
|
|
531
|
+
# $hlist add varis2 -itemtype text -text "Variables2"
|
|
532
|
+
# set varis2 [NGS_GetData variablesval]
|
|
533
|
+
# foreach vari $varis2 {
|
|
534
|
+
# scan $vari "val%fname%s" vval vname
|
|
535
|
+
# $hlist add varis2\\$vari -itemtype text -text [format "%s %1.3e" $vname $vval]
|
|
536
|
+
# }
|
|
537
|
+
|
|
538
|
+
|
|
539
|
+
|
|
540
|
+
|
|
541
|
+
|
|
542
|
+
# for { set i 1 } { $i <= $nspaces } { incr i } {
|
|
543
|
+
# set name [NGS_GetData spacename $i]
|
|
544
|
+
# $hlist add spaces\\$name -itemtype text -text $name
|
|
545
|
+
# }
|
|
546
|
+
|
|
547
|
+
# $hlist add gridfunctions -itemtype text -text "Grid-functions"
|
|
548
|
+
# set ngf [NGS_GetData numgridfunctions]
|
|
549
|
+
# for { set i 1 } { $i <= $ngf } { incr i } {
|
|
550
|
+
# set name [NGS_GetData gridfunctionname $i]
|
|
551
|
+
# $hlist add gridfunctions\\$name -itemtype text -text $name
|
|
552
|
+
# }
|
|
553
|
+
|
|
554
|
+
# $hlist add bf -itemtype text -text "Bilinear-forms"
|
|
555
|
+
# set nbf [NGS_GetData numbilinearforms]
|
|
556
|
+
# for { set i 1 } { $i <= $nbf } { incr i } {
|
|
557
|
+
# set name [NGS_GetData bilinearformname $i]
|
|
558
|
+
# $hlist add bf\\$name -itemtype text -text $name
|
|
559
|
+
|
|
560
|
+
# set nbfi [NGS_GetData numbilinearformcomps $name]
|
|
561
|
+
# for { set j 1 } { $j <= $nbfi } { incr j } {
|
|
562
|
+
# set compname [NGS_GetData bilinearformcompname $name $j]
|
|
563
|
+
# $hlist add bf\\$name\\$j -itemtype text -text $compname
|
|
564
|
+
# }
|
|
565
|
+
# }
|
|
566
|
+
|
|
567
|
+
# $hlist add lf -itemtype text -text "Linear-forms"
|
|
568
|
+
# set nlf [NGS_GetData numlinearforms]
|
|
569
|
+
# for { set i 1 } { $i <= $nlf } { incr i } {
|
|
570
|
+
# set name [NGS_GetData linearformname $i]
|
|
571
|
+
# $hlist add lf\\$name -itemtype text -text $name
|
|
572
|
+
|
|
573
|
+
# set nlfi [NGS_GetData numlinearformcomps $name]
|
|
574
|
+
# for { set j 1 } { $j <= $nlfi } { incr j } {
|
|
575
|
+
# set compname [NGS_GetData linearformcompname $name $j]
|
|
576
|
+
# $hlist add lf\\$name\\$j -itemtype text -text $compname
|
|
577
|
+
# }
|
|
578
|
+
# }
|
|
579
|
+
|
|
580
|
+
# Old version
|
|
581
|
+
# $w.mtre autosetmode
|
|
582
|
+
|
|
583
|
+
|
|
584
|
+
# bind $hlist <Double-1> {
|
|
585
|
+
# set solname [[.components_dlg.mtre subwidget hlist] info selection]
|
|
586
|
+
# puts $solname
|
|
587
|
+
# set seppos [string first \\ $solname]
|
|
588
|
+
# if { $seppos != -1 } {
|
|
589
|
+
# set field [string range $solname 1 [expr $seppos-1]]
|
|
590
|
+
# set name [string range $solname [expr $seppos+1] [expr [string length $solname]-2]]
|
|
591
|
+
# puts "field = $field, name = $name"
|
|
592
|
+
# NGS_PrintPDE $field $name
|
|
593
|
+
# }
|
|
594
|
+
# }
|
|
595
|
+
|
|
596
|
+
# old version end
|
|
597
|
+
#new version
|
|
598
|
+
bind $w.tree <Double-1> {
|
|
599
|
+
set name [.components_dlg.tree item [.components_dlg.tree selection] -text ]
|
|
600
|
+
# set field [.components_dlg.tree item [.components_dlg.tree parent [.components_dlg.tree selection] ] -text]
|
|
601
|
+
set field [.components_dlg.tree parent [.components_dlg.tree selection] ]
|
|
602
|
+
|
|
603
|
+
NGS_PrintPDE $field $name
|
|
604
|
+
# puts "field = $field, name = $name"
|
|
605
|
+
|
|
606
|
+
}
|
|
607
|
+
#new version end
|
|
608
|
+
|
|
609
|
+
button $w.cl -text "Close" -command {
|
|
610
|
+
destroy .components_dlg
|
|
611
|
+
}
|
|
612
|
+
|
|
613
|
+
pack $w.cl
|
|
614
|
+
|
|
615
|
+
|
|
616
|
+
wm withdraw $w
|
|
617
|
+
wm geom $w +100+100
|
|
618
|
+
wm deiconify $w
|
|
619
|
+
wm title $w "Components"
|
|
620
|
+
focus .components_dlg
|
|
621
|
+
}
|
|
622
|
+
}
|
|
623
|
+
|
|
624
|
+
|
|
625
|
+
|
|
626
|
+
|
|
627
|
+
if { [Ng_GetCommandLineParameter recent]=="defined" } {
|
|
628
|
+
if { [catch { .ngmenu.solve invoke "Solve Recent PDE"; } errstring] == 1 } {
|
|
629
|
+
puts "TCL-ERROR handler:\n $errstring";
|
|
630
|
+
exit;
|
|
631
|
+
}
|
|
632
|
+
}
|
|
633
|
+
|
|
634
|
+
|
|
635
|
+
|
|
636
|
+
|
|
637
|
+
|
|
638
|
+
|
|
639
|
+
bind . <l><p> { .ngmenu.solve invoke "Load PDE..." } ;
|
|
640
|
+
bind . <l><y> { .ngmenu.solve invoke "Load Python..." } ;
|
|
641
|
+
bind . <s><r> { .ngmenu.solve invoke "Solve Recent PDE" } ;
|
|
642
|
+
bind . <s><p> { .ngmenu.solve invoke "Solve PDE" } ;
|
|
643
|
+
bind . <e><c> { .ngmenu.solve invoke "Enter Command" } ;
|
|
644
|
+
bind . <p><y> { .ngmenu.solve invoke "Python shell" } ;
|
|
645
|
+
|
|
646
|
+
|
|
647
|
+
}
|
|
648
|
+
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
algebraic3d
|
|
2
|
+
|
|
3
|
+
# the first plane gets boundary condition nr 1:
|
|
4
|
+
|
|
5
|
+
solid p1 = plane (0, 0, 0; -1, 0, 0) -bc=1;
|
|
6
|
+
|
|
7
|
+
# and the other faces b.c. number = 2:
|
|
8
|
+
solid beam = plane (0, 0, 0; 0, 0, -1)
|
|
9
|
+
and plane (0, 0, 0; 0, -1, 0)
|
|
10
|
+
and p1
|
|
11
|
+
and plane (10, 2, 1; 0, 0, 1)
|
|
12
|
+
and plane (10, 2, 1; 0, 1, 0)
|
|
13
|
+
and plane (10, 2, 1; 1, 0, 0) -bc=2 -maxh=2;
|
|
14
|
+
|
|
15
|
+
tlo beam;
|
|
16
|
+
|
|
17
|
+
|