Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Isosurfacing_3 (new package) #6849

Open
wants to merge 382 commits into
base: master
Choose a base branch
from
Open
Changes from 1 commit
Commits
Show all changes
382 commits
Select commit Hold shift + click to select a range
bbd0255
Replace Explicit_Cartesian_grid_geometry with Implicit_cartesian_grid…
JulyCode Jan 24, 2023
d2a1e6a
Fix MSVC conversion error
JulyCode Jan 24, 2023
de37fbc
Revert "Replace Explicit_Cartesian_grid_geometry with Implicit_cartes…
MaelRL Jan 27, 2023
ea69ace
Remove whitespace
JulyCode Feb 2, 2023
40c6ce9
Doc fixes
MaelRL Feb 6, 2023
65ac2cc
Enhancements & fixes after Round1 review
MaelRL Feb 14, 2023
564ac1d
Fix Cartesian_grid_3 segfault
JulyCode Mar 14, 2023
4ddf24f
Start rework and testing
JulyCode Aug 8, 2023
b28d3f3
Fix tmc synchronization
JulyCode Dec 20, 2023
1892057
Example implicit sphere
palliez Dec 23, 2023
af458dd
Merge branch 'gsoc2022-isosurface' of https://github.com/JulyCode/cga…
palliez Dec 23, 2023
56692d5
example implicit sphere
palliez Dec 23, 2023
0ad9bb4
multiple offsets (for the teaser)
palliez Dec 24, 2023
be558db
replace bunny by tractor offset
palliez Dec 25, 2023
529b058
description
palliez Dec 25, 2023
b21f1da
user manual
palliez Dec 25, 2023
f62fd7d
user manual
palliez Dec 25, 2023
27550ec
added figure : output surface with boundaries
palliez Dec 25, 2023
584f324
Figure MC vs DC
palliez Dec 25, 2023
0f6fc13
use CGAL timer instead of TBB
palliez Dec 25, 2023
ac2a200
DC - iwp
palliez Dec 25, 2023
cff628e
Few more minor changes to examples
palliez Dec 25, 2023
44462c1
Change Eigen matrix to use correct type
JulyCode Jan 2, 2024
0e6b04d
Cast literals to correct type
JulyCode Jan 2, 2024
3e41b0c
Use eigen wrapper
JulyCode Jan 2, 2024
1b4b6b1
Remove unused imports
JulyCode Jan 2, 2024
10b22a9
Small fixes in examples
JulyCode Jan 2, 2024
3b572a6
Small doc change
JulyCode Jan 2, 2024
6f86165
Example DC on octree (still uses the octree wrapper)
palliez Jan 5, 2024
f304a84
Merge branch 'gsoc2022-isosurface' of https://github.com/JulyCode/cga…
palliez Jan 5, 2024
12ce300
added example that compares parallel with sequential MC
palliez Jan 5, 2024
d139540
Example : Parallel vs sequential Marching cubes
palliez Jan 5, 2024
50d0303
Add remarks
MaelRL Jan 9, 2024
b6b0e9d
Fix some compilation errors
MaelRL Jan 9, 2024
cfa307d
Merge remote-tracking branch 'cgal/master' into gsoc2022-isosurface
MaelRL Jan 9, 2024
9268b68
example uses TBB
afabri Jan 12, 2024
8e77d06
Polygon -> Triangle
afabri Jan 12, 2024
cbf3f4d
tiny fixes in user manual
afabri Jan 12, 2024
b9bbc93
Change comments
JulyCode Jan 14, 2024
ca1c78b
Deduct GeomTraits template type
JulyCode Jan 14, 2024
c1b8ca1
Revert "Deduct GeomTraits template type"
JulyCode Jan 15, 2024
8fd219c
Revert "Change comments"
JulyCode Jan 15, 2024
9e1f6d1
Unify input and make that output can be written simultaneously (for e…
afabri Jan 15, 2024
3a70a84
doxygen warnings
afabri Jan 15, 2024
ad1811c
doxygen warnings
afabri Jan 15, 2024
1fa0799
fix doc
MaelRL Jan 15, 2024
b77f216
Add missing citation
MaelRL Jan 15, 2024
97814b8
Fix dependencies and some backticks
afabri Jan 15, 2024
e4f35c9
polish and make the todos more readable
afabri Jan 16, 2024
d14f44b
typo
afabri Jan 16, 2024
17b4d21
typo: face -> cell
afabri Jan 16, 2024
d154f71
Update Isosurfacing_3/include/CGAL/Isosurfacing_3/internal/topologica…
afabri Jan 16, 2024
5290b01
fix tests
afabri Jan 16, 2024
c375952
Changes after R1 review
MaelRL Jan 17, 2024
cca4d5f
Fix inrimage example
JulyCode Jan 23, 2024
f64b3f7
Fix range requirements
MaelRL Jan 22, 2024
eedc459
Rework image from/to operators
MaelRL Jan 22, 2024
690c734
Make implicit / explicit Cartesian domains inherit rather than aliases
MaelRL Jan 22, 2024
96696a4
Misc minor doc / code fixes
MaelRL Jan 22, 2024
236ff89
Also rework the Octree domain to avoid aliases
MaelRL Jan 22, 2024
efc43a6
Fix usages of 'th `th
MaelRL Jan 22, 2024
e9c2297
Fix location of doc image
MaelRL Jan 22, 2024
ea1404e
Change bounding box type
MaelRL Jan 23, 2024
b3d6477
Fix compilation after Eigen type changes
MaelRL Jan 23, 2024
763d242
Don't compute placement if the cell is irrelevant
MaelRL Jan 23, 2024
1db32db
Misc minor changes
MaelRL Jan 23, 2024
3ba0af0
Misc minor changes
MaelRL Jan 25, 2024
2133067
Normalize gradients produced by Finite_diff_gradient_3
MaelRL Jan 31, 2024
6e08c25
Type-erase the point function in Finite_diff_gradients_3
MaelRL Jan 31, 2024
7abad57
Add default values for the parallel template parameter
MaelRL Jan 31, 2024
6659f1e
Add a helper function to visualize a Cartesian_grid_3 object
MaelRL Jan 31, 2024
a30e313
Fix narrowing conversion error
MaelRL Jan 31, 2024
c315126
Merge remote-tracking branch 'afabri/Kernel_23-squared_length-GF' int…
MaelRL Jan 31, 2024
ef311cd
Precise comment
MaelRL Feb 6, 2024
47ae855
Misc minor changes
MaelRL Feb 6, 2024
8a78301
New version of Isosurfacing_3:
MaelRL Feb 15, 2024
a653be2
Rewrite examples to emphasis data type and not contouring method
MaelRL Feb 15, 2024
55fdaab
Update doc (new concepts, examples)
MaelRL Feb 15, 2024
111b243
Move Side_of_triangle_mesh's assertion to usage rather than construction
MaelRL Feb 15, 2024
4cc1f0b
Add name parameter for Isosurfacing_3
MaelRL Feb 15, 2024
a408e98
Add missing backticks
MaelRL Feb 15, 2024
d319180
Add missing header include
MaelRL Feb 15, 2024
71e4325
static_cast
afabri Feb 15, 2024
367fb73
change #includes in examples
afabri Feb 15, 2024
05a9ccc
Address some CI errors
afabri Feb 15, 2024
ddf071c
Address some CI errors
afabri Feb 15, 2024
41fc2f0
quiet the CI
afabri Feb 16, 2024
37ed3ac
Allow resizing of the underlying data vector
MaelRL Feb 16, 2024
72ac570
Add some clamping
MaelRL Feb 16, 2024
45f7332
Fix Isosurfacing_3's Image_3 IO: ref to 'grid' in 'values' must be st…
MaelRL Feb 16, 2024
124a5c1
Minor doc fixes
MaelRL Feb 16, 2024
6f9b1cd
Update examples following Image_3 IO changes
MaelRL Feb 16, 2024
5fe73e5
Hide warning message behind macro
MaelRL Feb 16, 2024
4d160fd
Add two benchmarks for parallelism of implicit/image data
MaelRL Feb 16, 2024
4053f8c
Homogenize \return, gets, returns, etc.
MaelRL Feb 16, 2024
0fb66f7
Add missing header include
MaelRL Feb 16, 2024
9f780b2
Actually call MC
MaelRL Feb 16, 2024
ab98245
Adjust input validity checks
MaelRL Feb 16, 2024
a52939a
Add an undocumented example to compare MC and TMC
MaelRL Feb 16, 2024
6e8fcba
Make DC Octree work (again)
MaelRL Feb 23, 2024
913f879
Follow the OG paper's prescription of the SVD threshold
MaelRL Feb 23, 2024
11ddfaf
Misc minor changes
MaelRL Feb 23, 2024
17d2a98
Fix some warnings
MaelRL Feb 23, 2024
45dec3b
Simplify dichotomy + add proper error check
MaelRL Feb 23, 2024
f08ec78
Use unordered maps
MaelRL Feb 23, 2024
2bad87b
Update benchmarks
MaelRL Feb 24, 2024
c1f46d2
Remove obsolete files
MaelRL Feb 24, 2024
2823250
Minor API update for Cartesian_grid_3
MaelRL Feb 24, 2024
378ff1f
Doc improvements
MaelRL Feb 24, 2024
8bce7b1
Fix compilation of benchmarks, remove obsolete includes
MaelRL Feb 24, 2024
de5b838
Fix bitset checks and type consistency
MaelRL Feb 24, 2024
94987d6
Minor doc change
MaelRL Feb 24, 2024
bccfec0
Use traits functors, not CGAL object class member functions
MaelRL Feb 24, 2024
9e8757f
Silence warnings
MaelRL Feb 25, 2024
bb5f0d0
Benchmarks fixes
MaelRL Feb 25, 2024
1ed1140
Add point caching
MaelRL Feb 26, 2024
253f165
Tiny iostream change
MaelRL Feb 26, 2024
4d26e7b
Remove accidental (and pointless) usages of NPs meant for DC in MC
MaelRL Feb 26, 2024
884aa7e
Remove tmp code
MaelRL Feb 26, 2024
5523f23
Use a hash map in TBB-less Marching Cubes
MaelRL Feb 26, 2024
a672dca
Fix creating isolated vertices in MC
MaelRL Feb 26, 2024
a4a2f2f
Use the free functions to construct domains in the most basic examples
MaelRL Feb 26, 2024
522999a
Add missing function in IsosurfacingDomain_3 concept
MaelRL Feb 26, 2024
fbfd64b
Remove useless parameter simplify API call
MaelRL Feb 26, 2024
bed29f2
Make some minor hardcoded value parameters
MaelRL Feb 26, 2024
3526137
Tests for Isosurfacing_3
MaelRL Feb 27, 2024
b64b616
Fix template parameter of specialization + const correctness
MaelRL Feb 27, 2024
0028b5a
Use a more generic API to tolerate ranges of arrays
MaelRL Feb 27, 2024
9235994
Revert "Follow the OG paper's prescription of the SVD threshold"
MaelRL Feb 27, 2024
1dfadb7
Misc minor changes
MaelRL Feb 27, 2024
a415a02
Fix example name
MaelRL Feb 27, 2024
638b1ca
Tiny CMakeLists fix
MaelRL Feb 27, 2024
adf17a8
Fix typo (tparam > param)
MaelRL Feb 27, 2024
c727b77
Work on user manual
MaelRL Feb 28, 2024
f37a98c
Add missing header includes
MaelRL Feb 28, 2024
02dad0d
Minor benchmark tweak
MaelRL Feb 28, 2024
0d289e2
Add a comment
MaelRL Feb 28, 2024
a9907dd
Add 'Isosurfacing' to some concept names
MaelRL Feb 29, 2024
2d97a31
Add some assertions to ensure that arrays of correct size are used in…
MaelRL Feb 29, 2024
54012a7
Do not provide a default value for finite difference-based gradients
MaelRL Feb 29, 2024
020040c
Clean CMakeLists.txt
MaelRL Feb 29, 2024
6a77c7b
Avoid computing points when the cell is trivial
MaelRL Feb 29, 2024
f870241
Fix output filename
MaelRL Feb 29, 2024
910d5cf
use lower case for partition traits descriptors
MaelRL Feb 29, 2024
df96e5c
Improve doc phrasing
MaelRL Feb 29, 2024
0346018
Rename image example
MaelRL Feb 29, 2024
90db798
Add an example with VTK images
MaelRL Mar 1, 2024
4915898
Update user manual
MaelRL Mar 1, 2024
bfc9aaf
Use an array instead of a fixed size vector
MaelRL Mar 1, 2024
4c82e27
Fix VC++ max
afabri Mar 5, 2024
bc203b2
Add more VTK readers for the VTK image example
MaelRL Mar 5, 2024
1cb40fa
Use a more interesting implicit function in the DC example
MaelRL Mar 5, 2024
ac51466
Minor fixes for the implicit function example
MaelRL Mar 5, 2024
fc902c0
Update copyright
MaelRL Mar 5, 2024
605860f
use raw string
sloriot Mar 5, 2024
5e2667d
Doc improvements
MaelRL Mar 5, 2024
aed3aa4
Add missing image
MaelRL Mar 5, 2024
96a5b37
Minor doc fixes
MaelRL Mar 5, 2024
6a2d3c1
Update dependencies
MaelRL Mar 5, 2024
adb628b
fix doc warnings
sloriot Mar 5, 2024
f4ba6e3
Remove obsolete code
MaelRL Mar 5, 2024
cdfc8c0
Always use Parallel_if_available_tag in examples
MaelRL Mar 5, 2024
b990dcc
Fix warning
MaelRL Mar 5, 2024
c604235
use size_t instead of int for max range values
sloriot Mar 5, 2024
7d158b4
Fix using the mesh point when the SotM is built from a tree
MaelRL Mar 14, 2024
a731368
fix warnings
sloriot Mar 21, 2024
c232349
int -> std::size_t to avoid warning
afabri Mar 22, 2024
fb253ac
Fix double "Figure" in doc
MaelRL Mar 22, 2024
2441f91
Fixes after review
MaelRL Mar 22, 2024
d79d73b
Implement convenience function
MaelRL Mar 25, 2024
6ac3281
Safeguard against division by zero
MaelRL Mar 25, 2024
5e9e6ed
Add some documentation about "compute_discrete_gradients()"
MaelRL Mar 25, 2024
fd1651a
Fix unused variable warnings by disabling not-yet-implemented function
MaelRL Mar 27, 2024
bebb730
Try to fix "no declaration" error
MaelRL Mar 27, 2024
1fcd602
added vtk image
ange-clement Mar 27, 2024
1db1b27
Merge remote-tracking branch 'cgal/master' into HEAD
sloriot Mar 27, 2024
6bd7b80
add missing const
sloriot Mar 28, 2024
f5a24ec
update polyline writing functions
sloriot Mar 28, 2024
11a0fc7
add missing requirement
sloriot Mar 28, 2024
d6125de
accomodate API changes in the Orthtree package
sloriot Mar 28, 2024
c1dd231
replace auto with type
sloriot Mar 28, 2024
bf9235e
hide unused function
sloriot Mar 28, 2024
c1d38bb
move examples using undocumented features to test
sloriot Mar 28, 2024
2bb65f7
Add space
MaelRL Mar 27, 2024
c3391df
fixed warning
soesau Mar 28, 2024
2d66b97
update deps
sloriot Mar 28, 2024
4e7bfc0
remove example that is now in test
sloriot Mar 28, 2024
03aab53
workaround non-matching with Apple-clang
sloriot Mar 29, 2024
3feca8a
typos
afabri Apr 3, 2024
d3c17c5
Update 120 px thumbnail
MaelRL Apr 3, 2024
221300c
Rename Grid-Image_3 conversion functions
MaelRL Apr 4, 2024
dc0ce8f
Fix refinement of low level concepts
MaelRL Apr 4, 2024
6178687
Misc doc fixes
MaelRL Apr 4, 2024
d4a3d74
Add some debugging verbose
MaelRL Apr 4, 2024
be4ae04
Merge remote-tracking branch 'mine/CGAL-fix_dependencies-GF' into gso…
MaelRL Apr 4, 2024
99e4976
Add a warning for null gradient vectors
MaelRL Jun 19, 2024
3e84b6e
Fix models not honoring the concept
MaelRL Jun 19, 2024
4d4f27f
Swap around a Boolean check to avoid an empty loop
MaelRL Jun 19, 2024
d9afb1e
Debug code minor fixes
MaelRL Jun 19, 2024
8fb5ca6
Merge remote-tracking branch 'cgal/master' into gsoc2022-isosurface
MaelRL Jun 20, 2024
fccc731
Fixes after review
MaelRL Jul 8, 2024
7869155
accomodate API update
sloriot Jul 9, 2024
6c2195c
user Manual (work in progress)
palliez Jul 17, 2024
761872f
User manual
palliez Jul 17, 2024
dc61915
description
palliez Jul 17, 2024
68781f7
Examples
palliez Jul 17, 2024
9004ac5
User Manual (english fixes by Roberto Dyke)
palliez Jul 17, 2024
ce80ad7
Fixes after review
MaelRL Jul 22, 2024
0ba7267
Further fixes after review
MaelRL Jul 24, 2024
e618d96
Add some detail in the doc
MaelRL Aug 1, 2024
925c4af
removing necessity of Octree_wrapper
soesau Sep 23, 2024
b146e13
WIP adding Isosurfacing_domain_3 for Orthtree
soesau Sep 26, 2024
a394662
adding Octree_partition.h as convenience header
soesau Sep 27, 2024
834d619
reverting to Parallel_if_available_tag
soesau Sep 27, 2024
c8a41f8
moving dual_contouring_octree.cpp back into examples
soesau Sep 27, 2024
618064a
adding missing example
soesau Sep 27, 2024
2533c70
fixed includes
soesau Sep 27, 2024
3cedd54
updating dependencies
soesau Sep 27, 2024
bb413e8
added caching of vertices
soesau Sep 30, 2024
0aa8538
CI fix
soesau Sep 30, 2024
5447fbf
fixing warnings and errors
soesau Oct 4, 2024
bf2fb1d
copy -> assign
soesau Oct 4, 2024
2115a3c
bugfix
soesau Oct 4, 2024
78818d5
fix in sequential code
soesau Oct 4, 2024
ac28850
removed unused parameter
soesau Oct 6, 2024
64fa7a7
cleanup of CMakeLists.txt
afabri Oct 10, 2024
e1e3706
Merge remote-tracking branch 'cgal/master' into gsoc2022-isosurface
soesau Oct 14, 2024
610820d
Add topological test cases
JulyCode Oct 29, 2024
e531249
Fix naming error
JulyCode Oct 30, 2024
1407319
introducing small shift of implicit function value if identical to is…
soesau Nov 22, 2024
4ac30ba
making isosurfacing compatible with EPECK (resolves many self-interse…
soesau Nov 22, 2024
67f8fd7
removing whitespaces
soesau Nov 22, 2024
676a169
removing tabs
soesau Nov 22, 2024
2fb921c
added missing include
soesau Nov 22, 2024
a1e60de
making compatible with epeck
soesau Dec 6, 2024
087a3f7
asymptotic decider now chooses a more stable basis
soesau Dec 6, 2024
c3df96f
better singular case handling
soesau Dec 11, 2024
750dce6
added hidden named parameters for isovalue nudging and interior verte…
soesau Dec 16, 2024
d8c521e
Merge remote-tracking branch 'cgal/master' into gsoc2022-isosurface
sloriot Dec 16, 2024
2eeaeaf
fix warnings and compilation errors
sloriot Dec 17, 2024
96d24be
bugfixes (min/max, typos, proper boolean return for failure case)
soesau Dec 18, 2024
d851e3c
removing property map type declaration
soesau Dec 18, 2024
729c85c
fixes for warnings
soesau Dec 18, 2024
5c79fca
improvement of asymptotic decider with different cases
soesau Dec 19, 2024
59af6a8
Add topology verifier
JulyCode Dec 19, 2024
3da66d2
use std header
sloriot Dec 23, 2024
3836c09
TWS
sloriot Dec 23, 2024
99b057b
deactivating verifier test as it requires a large downloadable set of…
soesau Jan 10, 2025
602968a
using a different orientation for the hyperbola fitting in case the f…
soesau Jan 10, 2025
2d3122d
all test files pass
soesau Jan 10, 2025
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
using a different orientation for the hyperbola fitting in case the f…
…itting fails or a saddle point is not detected
  • Loading branch information
soesau committed Jan 10, 2025
commit 602968aae4de0631d35c84763f23291a8d1da818
Original file line number Diff line number Diff line change
@@ -300,8 +300,6 @@ class TMC_functor

void face_intersections(const std::array<FT, 8>& values, const std::size_t idx, const FT i0, FT& a, FT& b, FT& c, FT& d) {
const int *remap = internal::Cube_table::asymptotic_remap[idx];
// a = (values[remap[0]] - values[remap[1]]) * (-values[remap[6]] + values[remap[7]] + values[remap[4]] - values[remap[5]]) -
// (values[remap[4]] - values[remap[5]]) * (-values[remap[2]] + values[remap[3]] + values[remap[0]] - values[remap[1]]);

a = (values[remap[1]] - values[remap[0]]) * (values[remap[6]] - values[remap[7]]) + (values[remap[2]] - values[remap[3]]) * (values[remap[4]] - values[remap[5]]);
b = (i0 - values[remap[0]]) * (-values[remap[6]] + values[remap[7]] + values[remap[4]] - values[remap[5]]) +
@@ -315,13 +313,6 @@ class TMC_functor

bool calc_coordinates(const std::array<FT, 8>& values, const std::size_t idx, const FT i0, const FT a, const FT b, const FT d, const std::vector<bool> &f_flag, unsigned char &q_sol, FT ui[2], FT vi[2], FT wi[2]) {
const int* remap = internal::Cube_table::asymptotic_remap[idx];

if (values[remap[0]] == values[remap[2]] && values[remap[1]] == values[remap[3]])
return false;

if (values[remap[0]] == values[remap[4]] && values[remap[1]] == values[remap[5]])
return false;

FT d2 = sqrt(CGAL::to_double(d));

// compute u-coord of solutions
@@ -512,7 +503,7 @@ class TMC_functor

// compute oriented contours
//
// A contour consists of segment at the faces connecting the intersection of the
// A contour consists of segments at the faces connecting the intersection of the
// isosurface with the edges. For each edge, we store the edge to which the segment
// is outgoing and the edge from which the segment in coming. Therefore, a contour
// can be reconstructed by connecting the edges in the direction of the outgoing.
@@ -848,6 +839,38 @@ class TMC_functor
}
}

// counts the number of set bits
auto numberOfSetBits = [](const unsigned char n)
{
// C or C++: use uint32_t
unsigned int b = (unsigned int)(n);
b = b - ((b >> 1) & 0x55555555);
b = (b & 0x33333333) + ((b >> 2) & 0x33333333);
return (((b + (b >> 4)) & 0x0F0F0F0F) * 0x01010101) >> 24;
};

// compute the number of solutions to the quadratic equation for a given face
auto nrQSolFace = [](const unsigned int f, const unsigned char n)
{
unsigned int nr = 0;
switch (f)
{
case 0:
if ((n & 0x5) == 0x5) nr = nr + 1;
if ((n & 0xA) == 0xA) nr = nr + 1;
break;
case 1:
if ((n & 0x11) == 0x11) nr = nr + 1;
if ((n & 0x22) == 0x22) nr = nr + 1;
break;
case 2:
if ((n & 0x18) == 0x18) nr = nr + 1;
if ((n & 0x24) == 0x24) nr = nr + 1;
break;
}
return nr;
};

// compute intersection of opposite faces
//
// It is sufficient to compute a pair of solutions for one face
@@ -861,56 +884,33 @@ class TMC_functor

FT a, b, c, d;
std::size_t idx = 0;
unsigned char nr_u, nr_v, nr_w, nr_t;
for (; idx < 10; idx++) {
face_intersections(values, idx, i0, a, b, c, d);

if (a == 0 || d < 0)
continue;

if (!calc_coordinates(values, idx, i0, a, b, d, f_flag, q_sol, ui, vi, wi))
continue;

if (!std::isfinite(CGAL::to_double(ui[0])) || !std::isfinite(CGAL::to_double(ui[1])))
continue;
bool ui_invalid = !std::isfinite(CGAL::to_double(ui[0])) || !std::isfinite(CGAL::to_double(ui[1]));

// In practice, there does not seem to be a difference in choosing the first working over the best one.
break;
}
nr_u = nrQSolFace(0, q_sol);
nr_v = nrQSolFace(1, q_sol);
nr_w = nrQSolFace(2, q_sol);
nr_t = (nr_u + nr_v + nr_w);

if (idx >= 10)
return false;
if (get_cnt_size(0, c_) == 7 && (ui_invalid || nr_t == nr_u || nr_t == nr_v || nr_t == nr_w))
continue;

// counts the number of set bits
auto numberOfSetBits = [](const unsigned char n)
{
// C or C++: use uint32_t
unsigned int b = (unsigned int)(n);
b = b - ((b >> 1) & 0x55555555);
b = (b & 0x33333333) + ((b >> 2) & 0x33333333);
return (((b + (b >> 4)) & 0x0F0F0F0F) * 0x01010101) >> 24;
};
if (ui_invalid && q_sol != 0) {
if (!(nr_t == nr_u || nr_t == nr_v || nr_t == nr_w))
continue;

// compute the number of solutions to the quadratic equation for a given face
auto nrQSolFace = [](const unsigned int f, const unsigned char n)
{
unsigned int nr = 0;
switch (f)
{
case 0:
if((n & 0x5) == 0x5) nr = nr + 1;
if((n & 0xA) == 0xA) nr = nr + 1;
break;
case 1:
if((n & 0x11) == 0x11) nr = nr + 1;
if((n & 0x22) == 0x22) nr = nr + 1;
break;
case 2:
if((n & 0x18) == 0x18) nr = nr + 1;
if((n & 0x24) == 0x24) nr = nr + 1;
break;
if (numberOfSetBits(q_sol) == 6)
continue;
}
return nr;
};

break;
}

// triangulate contours
//
@@ -1210,6 +1210,9 @@ class TMC_functor
vertices[get_c(i, 5, c_)]);
}
break;
default:
std::cout << "Contour size " << get_cnt_size(i, c_) << " not supported\n";
break;
} // switch over size of contour
} // loop over contorus
}
Loading