Joachim Schoeberl
31d5ce8be9
packed archiving
2021-06-27 12:32:51 +02:00
Joachim Schoeberl
54db7941d0
tuning mesh(un)pickling
2021-06-26 12:14:17 +02:00
Joachim Schoeberl
e84d4e90c8
add header for std::byte
2021-06-25 18:58:25 +02:00
Matthias Hochsteger
34629749d6
Merge remote-tracking branch 'origin/master' into parallel_meshing
2021-06-25 17:32:16 +02:00
Joachim Schoeberl
72fb819def
missing overloads for archive (byte)
2021-06-24 13:21:43 +02:00
Joachim Schoeberl
f6befbbe08
remove cerr << 'BFGS udate error'
2021-06-24 12:55:39 +02:00
Joachim Schoeberl
b65d3c188f
another optional table in Topology
2021-06-24 07:39:09 +02:00
Joachim Schoeberl
971d6bb465
little tuning of mesh pickling
2021-06-24 07:39:09 +02:00
Christopher Lackner
e0f3ce9cf0
fix loading of short mesh file names
2021-06-22 11:57:30 +02:00
Matthias Hochsteger
8be5b7d810
Merge remote-tracking branch 'origin/master' into parallel_meshing
2021-06-22 11:46:36 +02:00
Matthias Hochsteger
872dddbcd7
remove old meshing functions
2021-06-22 11:45:25 +02:00
Matthias Hochsteger
17b5f1c7a4
preserve locked points in all domains
2021-06-22 11:45:01 +02:00
Matthias Hochsteger
c7e9a822cc
Don't divide/merge mesh when having only one domain
2021-06-22 11:33:16 +02:00
Matthias Hochsteger
2b8a2356a0
use unique_ptr in MeshingData
2021-06-22 11:16:28 +02:00
Joachim Schoeberl
f24b962df7
fix width per refernce
2021-06-21 15:25:25 +02:00
Joachim Schoeberl
2488bd37ef
remove output, fix warning
2021-06-21 15:13:08 +02:00
Joachim Schoeberl
ebf1478048
copy ctor for MatrixFixWidth<W,double>
2021-06-21 13:57:57 +02:00
Joachim Schoeberl
780e72bf81
copyable 2d rules
2021-06-21 08:36:14 +02:00
Joachim Schoeberl
30d708f487
thread-safe CSG crosspoints and edges
2021-06-21 05:22:00 +02:00
Joachim Schoeberl
b51df253fd
pickle mesh-load also via ngsolve.Mesh('filename.vol.bin')
2021-06-17 07:58:25 +02:00
Matthias Hochsteger
6237f5542f
Build LocalH tree for each domain separately, if not already present before volume meshing
2021-06-16 15:49:23 +02:00
Matthias Hochsteger
5ec753452e
fix
2021-06-16 15:36:14 +02:00
Matthias Hochsteger
d0edaa57bb
prepare LocalH tree before blockfill sequentially
2021-06-16 15:05:58 +02:00
Matthias Hochsteger
7e344c2247
restructure MeshVolume
2021-06-16 14:04:06 +02:00
Matthias Hochsteger
62edae9b40
some timers
2021-06-16 10:49:31 +02:00
Matthias Hochsteger
8d51db278f
debugging header for utility functions
2021-06-16 10:48:38 +02:00
Matthias Hochsteger
4b40a7eb31
backward-compatible Timer interface
2021-06-14 14:55:08 +02:00
Matthias Hochsteger
958bbb1ae0
Set flags correctly when loading Element from Archive
2021-06-14 11:58:46 +02:00
Matthias Hochsteger
a51f8ed307
fix meshing empty meshes
2021-06-14 10:39:57 +02:00
Matthias Hochsteger
b83d73e919
fix meshing of close surfaces (use identifications of master mesh)
2021-06-14 10:39:57 +02:00
Matthias Hochsteger
1cf3d2a21c
always merge domains in separate meshes (consistent output)
2021-06-14 10:39:57 +02:00
Matthias Hochsteger
c835767115
Timer in ProcessTask()
2021-06-14 10:39:57 +02:00
Matthias Hochsteger
97623db219
Mesh 3d domains in parallel
...
To get consistent results, copy the LocalH tree in BlockFillLocalH
2021-06-14 10:39:57 +02:00
Matthias Hochsteger
5e3505b897
faster SwapImprove after delaunay
...
also new test results
2021-06-14 10:39:57 +02:00
Matthias Hochsteger
0b7f4fecbc
timers
2021-06-14 10:39:57 +02:00
Matthias Hochsteger
9b5aa90d38
skip deleted elements when creating tables
...
-> no need to call Compress() everytime the mesh changes
2021-06-14 10:39:57 +02:00
Matthias Hochsteger
b2af4c1069
set flags properly for new Elements
2021-06-14 10:39:57 +02:00
Joachim Schoeberl
1b5aa71ad6
fix parallel mesh pickling
2021-06-14 10:34:39 +02:00
Joachim Schöberl
44d7207380
Merge branch 'parallel_timing' into 'master'
...
Thread-safe Timer
See merge request jschoeberl/netgen!392
2021-06-11 17:03:57 +00:00
Matthias Hochsteger
b9f7b1e5a5
Register OCCGeometry for archiver
2021-06-11 15:23:21 +02:00
Matthias Hochsteger
1de1a1800e
Fix template argument deduction for Timer, remove ThreadRegionTimer
2021-06-11 15:19:30 +02:00
Matthias Hochsteger
6f7543c7dc
Timer - convenience constructors to disable tracing and/or timing
...
Examples:
Timer t0("name");
Timer t1("name", NoTracing);
Timer t2("name", NoTiming);
Timer t3("name", NoTracing, NoTiming);
Timer t4("name", NoTiming, NoTracing);
2021-06-11 10:08:06 +02:00
Matthias Hochsteger
c5639a5706
Thread-safe Timer
...
- use template arguments instead of run-time variable 'priority'
- change in paje interface for tracing
2021-06-11 09:52:58 +02:00
Matthias Hochsteger
a11294baf0
inline GetThreadI() (except on Windows, no dllexport for thread_local variables supported)
2021-06-11 09:51:23 +02:00
Joachim Schoeberl
6c73222f20
more ParallelFor in Topology
2021-06-10 21:52:22 +02:00
Joachim Schöberl
d922d3abdd
Merge branch 'small_improvements' into 'master'
...
Small improvements
See merge request jschoeberl/netgen!390
2021-06-10 10:43:13 +00:00
Matthias Hochsteger
2a17451c96
consistent criterion for conformance optimization in SwapImprove
...
Only small effect on output Meshes
2021-06-10 11:04:41 +02:00
Matthias Hochsteger
8df49eee2a
Reduce sizeof(MeshPoint) from 48 to 40 bytes
2021-06-10 10:15:55 +02:00
Matthias Hochsteger
3f93ccd3bd
remove static array in ruler3 (prepare for parallel meshing)
2021-06-10 09:56:42 +02:00
Matthias Hochsteger
80d648c005
parallel evaluation of localh in ImproveMesh()
2021-06-10 09:55:30 +02:00
Matthias Hochsteger
b677ef5e22
Fix RangeException (prepare for local optimizations, with partially filled elementsonpoint table)
2021-06-10 09:53:42 +02:00
Matthias Hochsteger
6cdfefcc82
Use CreateTable for coloring table
2021-06-10 09:51:56 +02:00
Matthias Hochsteger
c734a27621
TABLE -> Table in PointFunction
2021-06-10 09:45:14 +02:00
Matthias Hochsteger
873de8149c
thread-safe delaunay
2021-06-10 09:42:04 +02:00
Matthias Hochsteger
eee7a6d211
initialize childs in GradingBox also in default ctor
2021-06-10 09:39:23 +02:00
Matthias Hochsteger
a96a1e4624
separate memtracer.hpp
2021-06-10 09:38:00 +02:00
Matthias Hochsteger
0b90d24d81
fix tolerance in specpoints check (compare Dist2() with sqr(1e-8*geomsize) )
2021-06-08 20:03:07 +02:00
Matthias Hochsteger
d6ca80d50e
Fix SplineSeg ctor
2021-06-08 19:28:53 +02:00
Joachim Schoeberl
abb2e43ccb
optimize parallel load
2021-06-08 19:08:14 +02:00
Christopher Lackner
aceb2fac32
Merge branch 'revolution_boundaryconditions' into 'master'
...
Revolution boundaryconditions
See merge request jschoeberl/netgen!388
2021-06-08 13:01:14 +00:00
Christopher Lackner
bc0b5d538c
Merge branch 'revolution_splinegeo_sharedptr' into 'master'
...
Revolution should keep shared_ptr to splinegeo2d
See merge request jschoeberl/netgen!387
2021-06-08 13:01:06 +00:00
Christopher Lackner
b8ab3a47a7
Give bcname and maxh to revolution by adding it to spline
2021-06-08 14:35:58 +02:00
Joachim Schoeberl
c0534c5e0a
partition array also in sequential version
2021-06-08 14:33:32 +02:00
Joachim Schoeberl
d7452c34f9
sequential dummy
2021-06-08 14:09:12 +02:00
Joachim Schoeberl
aa3f778d06
separat metis-partitioning call, pickling partition number of mesh elements
2021-06-08 13:48:27 +02:00
Christopher Lackner
12a5d14967
Revolution should keep shared_ptr to splinegeo2d
2021-06-08 11:56:57 +02:00
Matthias Hochsteger
ca6d6e8ca7
revert mistakenly commited code
2021-06-04 20:04:10 +02:00
Matthias Hochsteger
bb43f669e6
Don't skip deleted elements when building point2element table
2021-06-04 19:57:21 +02:00
Matthias Hochsteger
ba148e8b3b
cleanup, more parallel
2021-06-04 16:23:18 +02:00
Matthias Hochsteger
9ddf2424e2
rewrite of DelaunayRemoveTwoTriaTets (much faster now)
2021-06-04 16:03:50 +02:00
Matthias Hochsteger
a2cc102849
delaunay - stay consistent with code on master
2021-06-04 13:32:34 +02:00
Matthias Hochsteger
6c37ce33b0
CreatePoint2ElementTable with optional points bitarray
2021-06-04 13:32:30 +02:00
Matthias Hochsteger
7623289c27
Timer to AdFront3::Inside
2021-06-04 11:33:39 +02:00
Matthias Hochsteger
17af3d0091
Timers, cleanup in delaunay
2021-06-04 11:33:39 +02:00
Matthias Hochsteger
39acabe406
split delaunay postprocessing code into smaller funtions
2021-06-04 11:33:34 +02:00
Matthias Hochsteger
3ce5b1958e
Initialize FlatArray members ( thx @mrambausek )
2021-06-02 15:45:36 +02:00
Matthias Hochsteger
32522368b9
Merge branch 'vol_bin_format' into 'master'
...
.vol.bin format using archiver
See merge request jschoeberl/netgen!385
2021-06-02 12:05:47 +00:00
Joachim Schoeberl
6dcc89ad04
some table py-features
2021-06-01 12:57:58 +02:00
Matthias Hochsteger
639bbb2c0a
.vol.bin format (using archiver)
2021-05-31 10:29:45 +02:00
Matthias Hochsteger
0aa63880c4
smaller tasks
2021-05-31 08:23:46 +02:00
Matthias Hochsteger
2c72c20c87
smaller tasks
2021-05-31 08:23:42 +02:00
Matthias Hochsteger
1045f68b97
TableCreator -> CreateSortedTable()
2021-05-31 08:23:35 +02:00
Matthias Hochsteger
073cbec108
remember search starting point in inside/outside marking after delaunay
2021-05-31 08:23:22 +02:00
Matthias Hochsteger
19176daa09
more timers in delaunay
2021-05-31 08:23:16 +02:00
Matthias Hochsteger
e721d250f8
use tuple -> std::tuple
2021-05-31 08:23:09 +02:00
Matthias Hochsteger
eb87741b70
init allocsize in NgArray
2021-05-31 08:23:01 +02:00
Joachim Schoeberl
7c4f1cf53a
minimal export of Table
2021-05-30 22:15:21 +02:00
Joachim Schoeberl
9389ecdf62
rename to GenerateStructuredMesh for not intending to override
2021-05-30 19:41:23 +02:00
Joachim Schoeberl
c3984fcc5b
just use pointer for Array - iterators (on proposal of Matthias R)
2021-05-30 18:58:34 +02:00
Joachim Schoeberl
3258b27410
fix initialization order warning
2021-05-30 18:57:14 +02:00
Matthias Hochsteger
e272f0c704
fix RangeExceptions
2021-05-17 15:35:12 +02:00
Joachim Schöberl
14570f2bfb
Merge branch 'fix_badness_in_combineimprove2d' into 'master'
...
Use sum of badnesses and not average value in CombineImprove in 2D
See merge request jschoeberl/netgen!384
2021-05-14 16:15:03 +00:00
Matthias Hochsteger
f7a08df155
Use sum of badnesses and not average value in CombineImprove in 2D
2021-05-14 17:55:09 +02:00
Matthias Hochsteger
d1ee6efc14
parallel Cluster update
2021-05-12 10:56:34 +02:00
Matthias Hochsteger
db494f4239
more Timers in Mesh
2021-05-12 10:56:21 +02:00
Matthias Hochsteger
5bba076c9e
UpdateTopology - use TasksPerThread(4) -> faster table update
2021-05-12 09:42:38 +02:00
Matthias Hochsteger
99e001fc4c
TABLE -> Table
2021-05-11 18:21:40 +02:00
Matthias Hochsteger
c8406d3b10
replace NgArray and TABLE with Array and Table
2021-05-10 16:30:40 +02:00
Matthias Hochsteger
4b53c63fba
helper functions for table creation
2021-05-10 12:03:20 +02:00
Joachim Schoeberl
955eaa682c
edges/faces on per default
2021-05-06 22:22:14 +02:00
Joachim Schoeberl
5af2413481
disable edge/faces tables for Mesh class
2021-05-06 21:46:56 +02:00
Matthias Hochsteger
786013c857
add dependency for rules file
2021-04-30 18:33:55 +02:00
Matthias Hochsteger
2eb888a8bf
generate .cpp for meshing rules automatically during the build process
2021-04-29 14:30:44 +02:00
Matthias Hochsteger
4592123f68
Merge remote-tracking branch 'origin/master' into rules_files_not_matching_cpp
2021-04-28 11:21:15 +02:00
Matthias Hochsteger
acf2b39680
Fix cross-platform archiving
...
This is a non-backward compatible change for archives on Windows!
2021-04-23 20:06:58 +02:00
Joachim Schoeberl
9033de843b
uniform refinement for quads
2021-04-18 17:53:26 +02:00
Christopher Lackner
0763e4a5d1
fix override warnings
2021-04-17 16:27:30 +02:00
Christopher Lackner
087a830a67
store cumulated angle
2021-04-15 22:48:16 +02:00
Christopher Lackner
6e87ff6ea7
allow spirals with extrusion using zones
2021-04-15 19:02:05 +02:00
Christopher Lackner
4e2d2943f6
fix csg extrusion
2021-04-13 12:11:10 +02:00
Christopher Lackner
7c6296f153
csg splinecurves -> shared_ptr
2021-04-12 15:51:40 +02:00
Joachim Schoeberl
2d9e32ba70
ArrayMem from BaseArray ctor
2021-04-09 21:30:29 +02:00
Matthias Hochsteger
190e22b06d
Find surface element of point: fix local coordinates for TRIG
...
TRIG and TRIG6 are handled differently, see nginterface_v2.cpp:1114
2021-04-09 14:14:04 +02:00
Joachim Schoeberl
d803150b87
red refinement, parent faces (thx Guosheng)
2021-04-09 08:06:30 +02:00
Christopher Lackner
daa0985a41
trace memory free only when array owns memory
2021-04-07 09:58:53 +02:00
Christopher Lackner
4fad6e0631
fix pickling on arm, store long type platform independent
2021-04-01 10:48:13 +02:00
Joachim Schoeberl
096b419f6e
parent edges for red refinement (thx Guosheng)
2021-03-31 07:50:24 +02:00
Matthias Hochsteger
44c10f663a
Boundarylayer 2d interface
2021-03-30 16:55:03 +02:00
Joachim Schoeberl
1f45601387
Array<int> ia(n); ia.Range(2, END-1)
2021-03-29 22:39:57 +02:00
Joachim Schöberl
7b62f39460
Merge branch 'fix_pointsels_in_2dgeom' into 'master'
...
Only add segment end points of 2d geometry to mesh as 0D-elements
See merge request jschoeberl/netgen!373
2021-03-29 19:38:41 +00:00
Christopher Lackner
15380a2618
Revert "more stable boundarylayer, also cut prisms at outside"
...
This reverts commit d2dc84b02c
.
2021-03-29 18:05:09 +02:00
Joachim Schöberl
f63734e4a0
Merge branch 'archive_localh' into 'master'
...
DoArchive for LocalH
See merge request jschoeberl/netgen!375
2021-03-29 12:46:18 +00:00
Christopher Lackner
d2dc84b02c
more stable boundarylayer, also cut prisms at outside
2021-03-29 14:02:00 +02:00
Christopher Lackner
001eaa32b6
DoArchive for LocalH
2021-03-29 13:55:23 +02:00
Christopher Lackner
c27fa6899b
Merge remote-tracking branch 'massimil/mleoni/indexIntegerType'
2021-03-29 11:55:10 +02:00
Matthias Hochsteger
88fd0a9cd3
2d boundary layer - some cleanup, average growth vectors along straight lines
2021-03-26 09:13:11 +01:00
Matthias Hochsteger
57a4d03d23
Merge branch 'fix_csg2d' into 'master'
...
Fix csg2d
See merge request jschoeberl/netgen!374
2021-03-24 11:35:28 +00:00
Matthias Hochsteger
5a0d07ca87
set hpref to 0.0 (fixes random values)
2021-03-24 12:04:21 +01:00
Matthias Hochsteger
b431a07c74
Fix starting point for intersection searching
2021-03-24 12:03:40 +01:00
Matthias Hochsteger
6cdeaf2d40
Only add segment end points of 2d geometry to mesh as 0D-elements
2021-03-24 10:49:46 +01:00
Christopher Lackner
a612444e77
FindElementOfPoint<1> for 2d meshes for curved segments
2021-03-23 15:08:20 +01:00
Massimiliano Leoni
a40544ddc5
Changed integer type of Element::index and Element2d::index
2021-03-23 12:11:32 +01:00
Matthias Hochsteger
bcd86a18fd
FindSurfaceElementOfPoint - use barycentric coordinates of already found volume element
...
Increases robustness for finding curved surface elements
2021-03-17 17:36:41 +01:00
Matthias Hochsteger
69bc02a74d
Increase bounding box for curved elements by 20% in element search tree
2021-03-17 17:35:30 +01:00
Matthias Hochsteger
98770dbf94
2d boundary layers
2021-03-16 18:22:14 +01:00
Matthias Hochsteger
c77da32463
skip fixed points when checking for mixed mesh
2021-03-16 18:09:07 +01:00
Christopher Lackner
0fc488e802
Merge remote-tracking branch 'stefanbruens/salome_upstreamable'
2021-03-15 09:36:01 +01:00
Christopher Lackner
0141546373
Merge remote-tracking branch 'stefanbruens/cleanup_includes'
2021-03-15 09:20:48 +01:00
Stefan Brüns
cf4d9eff33
Modernize code, replace Handle_<X> with Handle(X)
...
Same like c35297a8fb158be47772cb5fc9cee76ca88ff871
2021-03-12 23:13:01 +01:00
Stefan Brüns
3c13e41692
Remove duplicated includes from occgeom.hpp
...
Each of the duplicated header files have an include guard, so including
it twice is just a small waste of processing time.
2021-03-11 23:26:23 +01:00
Stefan Brüns
8abd52a47b
Remove two unused variables
2021-03-10 01:06:11 +01:00
Stefan Brüns
2767672286
Cleanup use of M_PI/PI defines
...
gprim/geom2d.cpp includes mystdlib.h, which already has a fallback define
for M_PI. As geomfuncs.cpp also includes mystdlib.h, use M_PI instead
of a truncated value.
occ/Partition_Loop2d.cxx already gets M_PI from the opencascade headers
(~everything includes Standard_Real.hxx, which includes Standard_math.hxx,
which sets _USE_MATH_DEFINES for Windows and includes math.h).
2021-03-10 00:46:58 +01:00
Stefan Brüns
883baf4189
Remove occconstruction.cpp from list of library sources
...
Since commit 0c3c3f32d1
("occ build visualization mesh") occgeometry.cpp does not contain
any compiled code, and it has not been used at least for 12 years.
As the file includes quite some header files removing it from the sources
should save some compile time.
2021-03-08 02:38:28 +01:00
Stefan Brüns
85e8c09ff6
Fix GetTimeCounter for Aarch64 variants
...
Neither GCC nor Clang define an __arm64__ preprocessor macro, but use
__aarch64__ (MSVC uses _MARM_64). Add a "64" suffix to the define, i.e.
NETGEN_ARCH_ARM64 to make it more obvious in only refers to aarch64, and
to be in line with NETGEN_ARCH_AMD64.
Replace the (Clang specific) __builtin_readcyclecounter with inline
asm:
- The function return cycles (i.e. varies with CPU frequency), not time
- It may return 0, depending on the PMU settings
- It may cause an illegal instruction, in case it is not trapped by the
kernel, e.g. on FreeBSD.
Reading the generic timer/counter CNTVCT_EL0 instead of PMCCNTR_EL0 avoids
these pitfalls. The inline asm works on GCC and Clang, instead of
Clang only for the builtin.
2021-03-03 17:30:33 +01:00
Matthias Hochsteger
3397e3bb9d
Merge branch 'fix_swapimprove' into 'master'
...
Fix SwapImprove
See merge request jschoeberl/netgen!370
2021-03-02 11:08:13 +00:00
Christopher Lackner
f11cb4fcfb
boundarylayers - inner corners at end of layer now possible too
2021-03-02 11:47:40 +01:00
Matthias Hochsteger
d7d12ac53d
Don't swap very bad elements in SwapImprove
...
Changes meshing -> new test results
2021-03-01 10:08:00 +01:00
Matthias Hochsteger
f8aa3d3159
util function NotTooBad() in mesh optimization
2021-03-01 09:33:47 +01:00
Matthias Hochsteger
f5432718c1
Fix ImproveMesh
2021-02-26 12:20:51 +01:00
Joachim Schoeberl
298cbc2523
less printing for face hierarchy
2021-02-22 08:30:00 +01:00