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

Disable collinearity tolerance #40

Merged
merged 4 commits into from
Mar 23, 2022

Conversation

roystgnr
Copy link
Contributor

This is a naive way to fix #39 ... but at least for my cases, it works!

When I ran the poly2tri unit test suite, I got a failure ... but it turned out that the "failure" was that it stopped failing in a test that had previously been failing, so I'm going to call that a success instead and change the test to assert so.

I've added a new unit test too, with the original problem from #39 (rewritten to match the coding style of the other tests more closely), so even if it turns out that the Orient2d change isn't the best fix here, we can make sure subsequent fixes don't revert that progress.

With this in place my refinement code seems to be working, so I'll start conjuring up a bunch of test cases via that and see if I can trigger any other bugs that this fix missed or any previously-non-bug cases that this fix regressed.

This fixes failures for me when trying to triangulate
concave-by-less-than-epsilon boundary polylines.
This is from the case I originally got to trigger the problem.  We could
probably boil it down to something smaller (by temporarily reverting the
Orient2d change to make sure the failure still occurs) but this doesn't
seem too bloated for a unit test as-is.
poly2tri/common/utils.h Outdated Show resolved Hide resolved
@roystgnr
Copy link
Contributor Author

I'll start conjuring up a bunch of test cases via that

I'm definitely still hitting a problem, if you want to wait on merging until I've had more time to investigate. I think this one's more likely to be in my code than in yours, though.

@roystgnr
Copy link
Contributor Author

That problem was a false alarm. When I was cleaning up my own code's recent changes to strip out the "attempted workaround for poly2tri bug" parts, I accidentally also removed an in-progress fix for one of my own tolerance-related bugs because it looked similar. Restoring that fix and getting rid of my own excessive tolerance fixed the problem for most cases, then switching to a more robust test in my code fixed the problem for every case I've tried, and I can now use this branch when refining triangulations into the millions-of-elements range (far past what my users need in 2D; their element count explodes when extruding meshes into 3D afterwards) without problems.

@roystgnr
Copy link
Contributor Author

And non-uniform refinement works too. I'm having a lot of fun with this.

adaptive_tri_trans

I think non-uniform anisotropic refinement is going to be where it gets scary. The above mesh is still Delaunay in the Euclidean metric, so except for this little bugfix I didn't have to touch poly2tri internals. But if I want thin boundary layer elements that track one boundary orientation in one area and a different boundary orientation in another, that'll be a different story. I may just wrap things up for the year at this point; this is all the functionality my users need right away. If I get ambitious, though... how open are you to much-more-intrusive PRs?

roystgnr added a commit to roystgnr/libmesh that referenced this pull request Mar 17, 2022
This is an update to a branch on my fork rather than to the master; I'm
not sure what the eta on jhasse/poly2tri#40 is
going to be but I'm even less sure we'll be able to get this working
without that fix.  If it gets merged upstream I'll update to that in a
future PR.
@roystgnr
Copy link
Contributor Author

Is there anything else I can do to push for getting this merged? I'm now developing using a forked branch downstream, and I was hoping to be able to switch that back to a hash on your master branch before users start relying on it.

I admit I'm not thrilled with this PR either; ideally solutions to hairy FP precision issues ought to be backed up via "mathematical proof in the docs", not "more passes in the test suite". But "more passes in the test suite" is still a big step up from "fewer passes in the test suite".

@jhasse
Copy link
Owner

jhasse commented Mar 23, 2022

I agree.

Let's merge this and see if someone complains.

@jhasse jhasse merged commit 529470f into jhasse:master Mar 23, 2022
@jhasse
Copy link
Owner

jhasse commented Mar 23, 2022

Forgot to mention: Thank you very much! Especially for the detailed comments.

@roystgnr roystgnr deleted the no_collinearity_tolerance branch March 23, 2022 20:38
@roystgnr
Copy link
Contributor Author

You're welcome!

Let's merge this and see if someone complains.

There's probably a Russell conjugation here: "He breaks the code base; you add new features too hastily; I encourage collaborators to write more test coverage."

Tag me in any issues that come up if someone finds a regression? The short-term solution might still be "tack on a revert commit" (you never rewrite history on master, right?) if a more longstanding user's needs conflict, but I'd definitely want to help make sure that the long-term solution was "find a fix that works for both issues" rather than "maintain a code fork" or "get stuck at an old commit".

@roystgnr roystgnr restored the no_collinearity_tolerance branch March 23, 2022 20:52
@jhasse
Copy link
Owner

jhasse commented Mar 24, 2022

Yes, I would not force push. So your hash on this repo will always be valid :)

brandon-kohn added a commit to brandon-kohn/poly2tri that referenced this pull request Sep 29, 2022
commit 2c7ef27c0f666101f339f42400396f30edadd676
Author: Brandon Kohn <blkohn@hotmail.com>
Date:   Tue Sep 20 11:59:30 2022 -0400

    Fixed compile issues.

commit 740ea0dfd10d160fef2e4610671039a1fd15f00f
Merge: f189424 81612cb
Author: Brandon Kohn <blkohn@hotmail.com>
Date:   Tue Sep 20 11:52:44 2022 -0400

    Merge remote-tracking branch 'upstream/master' into update/merge_from_upstream

commit 81612cb
Merge: d6ecda3 563239d
Author: Jan Niklas Hasse <jhasse@bixense.com>
Date:   Fri May 20 15:46:44 2022 +0200

    Merge pull request jhasse#43 from AndriyAndreyev/stability_fixes

    Stability fixes

commit d6ecda3
Merge: 54af704 505f63d
Author: Jan Niklas Hasse <jhasse@bixense.com>
Date:   Mon May 9 10:08:46 2022 +0200

    Merge pull request jhasse#47 from pierre-dejoue/pragma-once

    Replace header guards by pragma once

commit 505f63d
Author: Pierre Dejoue <pierre.dejoue@gmail.com>
Date:   Sun May 8 19:26:22 2022 +0200

    Pragma once and for all

commit 54af704
Merge: dbc52ac abdf448
Author: Jan Niklas Hasse <jhasse@bixense.com>
Date:   Fri May 6 07:56:47 2022 +0200

    Merge pull request jhasse#46 from pierre-dejoue/testbed-autozoom

    QoL: Add auto-zoom feature to the testbed app

commit 563239d
Author: AndriyAndreyev <andriy.a.andreyev@gmail.com>
Date:   Fri May 6 00:49:31 2022 +0300

    Add unittest to check stack overflow crash

    Signed-off-by: AndriyAndreyev <andriy.a.andreyev@gmail.com>

commit afee326
Merge: 15dfbc2 dbc52ac
Author: AndriyAndreyev <andriy.a.andreyev@gmail.com>
Date:   Fri May 6 00:50:55 2022 +0300

    Merge remote-tracking branch 'upstream/master'

commit abdf448
Author: Pierre Dejoue <pierre.dejoue@gmail.com>
Date:   Sun Apr 24 17:36:35 2022 +0200

    Testbed autozoom feature

commit 36e5514
Author: Pierre Dejoue <pierre.dejoue@gmail.com>
Date:   Sun Apr 24 16:36:26 2022 +0200

    Testbed usage note

commit 39a5f47
Author: Pierre Dejoue <pierre.dejoue@gmail.com>
Date:   Sun Apr 24 17:10:22 2022 +0200

    Testbed: global config variable to set the window size

commit bdd6e3b
Author: Pierre Dejoue <pierre.dejoue@gmail.com>
Date:   Thu Apr 21 01:04:32 2022 +0200

    Add to the testbed report the result of the Delaunay test

commit dbc52ac
Merge: a8247ae 49a12eb
Author: Jan Niklas Hasse <jhasse@bixense.com>
Date:   Thu May 5 18:25:29 2022 +0200

    Merge pull request jhasse#42 from pierre-dejoue/dllexport

    Rework on dllexport/dllimport definitions

commit 15dfbc2
Merge: 1bf8fad a8247ae
Author: AndriyAndreyev <andriy.a.andreyev@gmail.com>
Date:   Thu May 5 01:11:12 2022 +0300

    Merge remote-tracking branch 'upstream/master'

commit a8247ae
Merge: 3380f5c de70670
Author: Jan Niklas Hasse <jhasse@bixense.com>
Date:   Tue May 3 08:57:24 2022 +0200

    Merge pull request jhasse#44 from pierre-dejoue/test-case-issue-10

    Test polygons from issue jhasse#10

commit de70670
Author: Pierre Dejoue <pierre.dejoue@gmail.com>
Date:   Sun Nov 1 22:10:03 2020 +0100

    Test polygons from issue jhasse#10

commit 1bf8fad
Author: AndriyAndreyev <andriy.a.andreyev@gmail.com>
Date:   Tue Apr 26 21:46:45 2022 +0300

    Add test case to check stack overflow crash

    Without additional check is angle negative or not in the LargeHole_DontFill
    function this test case leads to stack overflow.

    Signed-off-by: AndriyAndreyev <andriy.a.andreyev@gmail.com>

commit 64636de
Author: AndriyAndreyev <andriy.a.andreyev@gmail.com>
Date:   Tue Apr 26 21:46:11 2022 +0300

    Сonsider that LargeHole_DontFill is true if angle is negative

    Otherwise, a wrong triangle can be generated

    Signed-off-by: AndriyAndreyev <andriy.a.andreyev@gmail.com>

commit 49a12eb
Author: Pierre Dejoue <pierre.dejoue@gmail.com>
Date:   Wed Apr 20 22:12:21 2022 +0200

    Set the API export symbols based on CMake BUILD_SHARED_LIBS

    By default poly2tri is built as a static library.

commit 7f5846b
Author: Pierre Dejoue <pierre.dejoue@gmail.com>
Date:   Sun Apr 17 14:12:01 2022 +0200

    Retakes on dllexport/dllimport

commit ad184c3
Author: Clifford Yapp <238416+starseeker@users.noreply.github.com>
Date:   Tue Aug 3 17:19:16 2021 -0400

    Add dllexport/dllimport definitions.

commit 3380f5c
Author: Jan Niklas Hasse <jhasse@bixense.com>
Date:   Fri Mar 25 08:49:45 2022 +0100

    Apply even more clang-tidy fixes

commit dcdb744
Author: Jan Niklas Hasse <jhasse@bixense.com>
Date:   Fri Mar 25 07:56:30 2022 +0100

    Apply several clang-tidy fixes

commit 529470f
Merge: 8b5fa15 30279f7
Author: Jan Niklas Hasse <jhasse@bixense.com>
Date:   Wed Mar 23 21:34:31 2022 +0100

    Merge pull request jhasse#40 from roystgnr/no_collinearity_tolerance

    Disable collinearity tolerance

commit 30279f7
Author: Roy Stogner <Roy.Stogner@inl.gov>
Date:   Wed Mar 16 08:35:34 2022 -0500

    Use std::fpclassify for double==0 tests

commit 19ec7c7
Author: Roy Stogner <Roy.Stogner@inl.gov>
Date:   Tue Mar 15 20:37:14 2022 -0500

    ConcaveBoundaryTest unit test

    This is from the case I originally got to trigger the problem.  We could
    probably boil it down to something smaller (by temporarily reverting the
    Orient2d change to make sure the failure still occurs) but this doesn't
    seem too bloated for a unit test as-is.

commit cc1e657
Author: Roy Stogner <Roy.Stogner@inl.gov>
Date:   Tue Mar 15 20:36:53 2022 -0500

    NarrowQuadTest triangulation succeeds now

commit 57b3039
Author: Roy Stogner <Roy.Stogner@inl.gov>
Date:   Tue Mar 15 19:16:40 2022 -0500

    Disable tolerance in Orient2d collinearity test

    This fixes failures for me when trying to triangulate
    concave-by-less-than-epsilon boundary polylines.

commit 8b5fa15
Merge: 136fa7a 4581f1f
Author: Jan Niklas Hasse <jhasse@bixense.com>
Date:   Thu Dec 2 15:46:35 2021 +0100

    Merge pull request jhasse#34 from roystgnr/instructions_update

    File naming, build/run instruction updates

commit 4581f1f
Author: Roy Stogner <Roy.Stogner@inl.gov>
Date:   Wed Dec 1 17:38:53 2021 -0600

    Consistent executable path in README.md

    These commands run (from the source directory; would commands as run
    from the build directory be clearer?) for me as-is (after the testbed
    executable has been built) now.

commit 4fd0287
Author: Roy Stogner <Roy.Stogner@inl.gov>
Date:   Wed Dec 1 17:38:23 2021 -0600

    Fix, clarify build instructions

    If we're in a build subdirectory, we need `..` to tell cmake where to
    find the source directory.

commit cbc025a
Author: Roy Stogner <Roy.Stogner@inl.gov>
Date:   Wed Dec 1 17:37:18 2021 -0600

    Note unit test dependencies

    I already had most of Boost installed, but not enough.

commit ebf0c4d
Author: Roy Stogner <Roy.Stogner@inl.gov>
Date:   Wed Dec 1 17:36:31 2021 -0600

    Rename testbed/testbed to testbed/p2t

    That's what README.md has been referencing as the executable name, and
    it's more meaningful.

commit 136fa7a
Author: Jan Niklas Hasse <jhasse@bixense.com>
Date:   Sat Aug 21 17:28:47 2021 +0200

    Move Point ctor into .cc file to hide shadowing from users

    See jhasse#15 and jhasse#31.

commit 7f0487a
Merge: 4a323bf 905a765
Author: Jan Niklas Hasse <jhasse@bixense.com>
Date:   Tue May 18 10:24:21 2021 +0200

    Merge pull request jhasse#29 from piotrkania-here/sanity_checks

    Additional sanity checks for triangulate operation

commit 905a765
Author: Piotr Kania <ext-piotr.kania@here.com>
Date:   Thu Apr 29 11:51:05 2021 +0200

    Additional sanity checks for triangulate operation

commit 4a323bf
Merge: 444ee57 af36bac
Author: Jan Niklas Hasse <jhasse@bixense.com>
Date:   Mon Apr 26 17:02:23 2021 +0200

    Merge pull request jhasse#28 from piotrkania-here/check_ptr

    Check pointer before dereferencing it

commit af36bac
Author: Piotr Kania <ext-piotr.kania@here.com>
Date:   Mon Apr 26 10:25:12 2021 +0200

    Check pointer before dereferencing it

commit 444ee57
Merge: d949f3c b4534b3
Author: Jan Niklas Hasse <jhasse@bixense.com>
Date:   Sat Apr 24 11:11:52 2021 +0200

    Merge pull request jhasse#27 from piotrkania-here/fixed_point_operator

    Fixed inequality operator for Point struct

commit b4534b3
Author: Piotr Kania <ext-piotr.kania@here.com>
Date:   Fri Apr 23 14:32:39 2021 +0200

    Fixed inequality operator for Point struct

commit d949f3c
Author: Jan Niklas Hasse <jhasse@bixense.com>
Date:   Sat Jan 16 18:43:00 2021 +0100

    Add namespace comment

commit 8b8e6cb
Author: Jan Niklas Hasse <jhasse@bixense.com>
Date:   Thu Dec 17 23:12:58 2020 +0100

    Ignore .cache/

commit 4515f65
Merge: 83680d9 8388a74
Author: Jan Niklas Hasse <jhasse@bixense.com>
Date:   Fri Nov 20 11:38:31 2020 +0100

    Merge pull request jhasse#23 from pierre-dejoue/master

    Improvement to the testbed application

commit 8388a74
Author: Pierre Dejoue <pierre.dejoue@gmail.com>
Date:   Wed Nov 11 22:04:39 2020 +0100

    Improve testbed data file format

    Data file format now has optional sections for holes polylines
    and Steiner points identified with tokens "HOLE" and "STEINER".

    Rework the data file dude.dat accordingly.

    Add data file steiner.dat for an example with Steiner points.

commit cf5f95d
Author: Pierre Dejoue <pierre.dejoue@gmail.com>
Date:   Wed Nov 11 19:57:54 2020 +0100

    Fix compilation warnings in testbed

commit 83680d9
Author: Jan Niklas Hasse <jhasse@bixense.com>
Date:   Fri Nov 6 22:37:50 2020 +0000

    Remove Waf build system, fix jhasse#14

commit e9938d9
Merge: c4404a7 718d687
Author: Jan Niklas Hasse <jhasse@bixense.com>
Date:   Mon Oct 26 20:18:51 2020 +0000

    Merge pull request jhasse#22 from pierre-dejoue/master

    Add documentation and code patches for maintenability

commit 718d687
Author: Pierre Dejoue <pierre.dejoue@gmail.com>
Date:   Mon Oct 26 09:15:52 2020 +0100

    Add references section to README

    The flipscan picture by Thomas Ahlen was found on those pages:
    https://blackflux.wordpress.com/2014/03/01/meshing-in-voxel-engines-part-2/
    https://groups.google.com/g/poly2tri/c/LNfxMtVyhqs

commit 1054475
Author: Pierre Dejoue <pierre.dejoue@gmail.com>
Date:   Sun Oct 25 17:32:28 2020 +0100

    Triangle::NeighborAcross to return a pointer

    Same as Triangle::NeighborCW and Triangle::NeighborCCW

commit 35b2fa9
Author: Pierre Dejoue <pierre.dejoue@gmail.com>
Date:   Sun Oct 25 14:56:23 2020 +0100

    Patch inversion of head and tail in the advancing front initialization

    No functional impact, the code is equivalent. We just assign
    head_ to af_head_ and tail_ to af_tail_ as one would expect.

commit 5aa0c22
Author: Pierre Dejoue <pierre.dejoue@gmail.com>
Date:   Sun Oct 25 15:58:16 2020 +0100

    Add headers in project files generated by cmake

commit c480777
Author: Pierre Dejoue <pierre.dejoue@gmail.com>
Date:   Sat Oct 24 19:56:43 2020 +0200

    Update README for cmake

commit c4404a7
Author: Jan Niklas Hasse <jhasse@bixense.com>
Date:   Sun Oct 25 20:50:14 2020 +0100

    Avoid redefinition of BOOST_TEST_DYN_LINK

commit 6febaed
Author: Jan Niklas Hasse <jhasse@bixense.com>
Date:   Mon Oct 19 18:27:52 2020 +0200

    Add debug configurations for VSCode

commit a3a6456
Author: Jan Niklas Hasse <jhasse@bixense.com>
Date:   Mon Oct 19 18:27:21 2020 +0200

    Add namespace comment for clang-tidy

commit f6ca87a
Author: Jan Niklas Hasse <jhasse@bixense.com>
Date:   Mon Oct 19 18:24:46 2020 +0200

    Add .clang-format

commit f91fcd9
Merge: a269fb4 0554608
Author: Jan Niklas Hasse <jhasse@bixense.com>
Date:   Thu Aug 27 20:09:59 2020 +0200

    Merge pull request jhasse#20 from pierre-dejoue/master

    Add CMake files for the unit tests and the testbed app

commit 0554608
Author: Pierre Dejoue <pierre.dejoue@gmail.com>
Date:   Thu Aug 27 19:12:15 2020 +0200

    Add CMake files for the testbed

commit 7125fdb
Author: Pierre Dejoue <pierre.dejoue@gmail.com>
Date:   Tue Jul 14 18:16:18 2020 +0200

    Add CMake files for the unit tests

    - Building unit tests is optional, disabled by default to prevent
      the library clients from pulling the dependency on boost
    - Add the unit tests to the Github Actions.
    - Use boost::filesystem to manipulate paths for better portability

commit a269fb4
Merge: 6c184d1 2c6bec6
Author: Jan Niklas Hasse <jhasse@bixense.com>
Date:   Thu Aug 6 23:54:23 2020 +0200

    Merge pull request jhasse#19 from pierre-dejoue/master

    Add one exception case in Triangle::NeighborAcross

commit 2c6bec6
Author: Pierre Dejoue <pierre.dejoue@gmail.com>
Date:   Thu May 21 16:14:10 2020 +0200

    Throw in Triangle::NeighborAcross in case of null pointer

    Add an example quad for which the exception is throwni in the tests

commit 06b0f14
Author: Pierre Dejoue <pierre.dejoue@gmail.com>
Date:   Thu May 21 15:47:13 2020 +0200

    Actually throw exceptions

commit 7f8c4c5
Author: Pierre Dejoue <pierre.dejoue@gmail.com>
Date:   Sun Jul 12 11:57:01 2020 +0200

    Rename local index for readability

commit 3e583f5
Author: Pierre Dejoue <pierre.dejoue@gmail.com>
Date:   Thu Aug 6 19:36:19 2020 +0200

    Fix linux build action

commit 6c184d1
Author: Jan Niklas Hasse <jhasse@bixense.com>
Date:   Sun Jun 14 20:14:58 2020 +0200

    Use nullptr instead of NULL or 0

commit f5f9d33
Author: Jan Niklas Hasse <jhasse@bixense.com>
Date:   Thu Jun 4 22:40:09 2020 +0200

    Add simple Doxyfile

commit f16f016
Author: Jan Niklas Hasse <jhasse@bixense.com>
Date:   Tue May 5 13:31:21 2020 +0200

    Remove Azure Pipelines config

commit 722ddf7
Author: Jan Niklas Hasse <jhasse@bixense.com>
Date:   Tue May 5 13:29:33 2020 +0200

    Add GitHub Actions configuration (jhasse#16)

commit e66d045
Author: Martin Dobias <wonder.sk@gmail.com>
Date:   Mon Jan 20 10:19:20 2020 +0100

    Fix jhasse#11 - regression causing crash when abs(p1.y - p2.y) < 1e10 (jhasse#12)

    This reverts commit e0ba327.

    While the orignal commit silences a compiler warning, it introduces incorrect
    behavior in Edge constructor that causes crash later during triangulation.

    See jhasse#11 for an example of a simple polygon that would cause crash

commit e6e63dd
Author: Jan Niklas Hasse <jhasse@bixense.com>
Date:   Sat Nov 30 14:03:43 2019 +0100

    Update waf to 2.0.19

commit 5a171da
Author: Jan Niklas Hasse <jhasse@bixense.com>
Date:   Tue Jun 11 12:05:12 2019 +0200

    Add missing include for GCC 9.1

commit 3a2db01
Author: Jan Niklas Hasse <jhasse@bixense.com>
Date:   Tue Mar 12 13:38:06 2019 +0100

    Create path for TestbedFilesTest relative to build folder

commit 0898bb2
Author: Jan Niklas Hasse <jhasse@bixense.com>
Date:   Thu Feb 21 14:42:20 2019 +0100

    Add function IsDelaunay to check if results are valid

commit 96b08ee
Author: Jan Niklas Hasse <jhasse@bixense.com>
Date:   Thu Feb 21 14:34:37 2019 +0100

    Add new function Triangle::CircumcicleContains

commit e945488
Author: Jan Niklas Hasse <jhasse@bixense.com>
Date:   Fri Jan 25 00:20:39 2019 +0100

    Set up CI with Azure Pipelines (jhasse#7)

commit 48f545c
Author: Jan Niklas Hasse <jhasse@bixense.com>
Date:   Wed Sep 26 11:09:14 2018 +0200

    Meson: Add poly2tri_dep variable

commit a41b316
Author: Jan Niklas Hasse <jhasse@bixense.com>
Date:   Tue Sep 11 13:02:47 2018 +0200

    Add tasks.json for VS Code

commit 4973f2e
Author: Jan Niklas Hasse <jhasse@bixense.com>
Date:   Tue Sep 11 13:00:49 2018 +0200

    Change BSD-3 license formatting a little bit so that GitHub detects it

commit 9c8b474
Author: Jan Niklas Hasse <jhasse@bixense.com>
Date:   Tue Sep 11 12:53:31 2018 +0200

    Update project URL and copyright year

commit e0ba327
Author: Jan Niklas Hasse <jhasse@bixense.com>
Date:   Tue Aug 21 13:07:06 2018 +0200

    Do not compare doubles with ==

commit 0105437
Author: Jan Niklas Hasse <jhasse@bixense.com>
Date:   Mon Aug 13 14:46:34 2018 +0200

    Add simple CMakeLists.txt

commit a9d2cf8
Author: Jan Niklas Hasse <jhasse@bixense.com>
Date:   Mon May 28 19:55:02 2018 +0200

    Add very simple unit test

commit 1271d6b
Author: Jan Niklas Hasse <jhasse@bixense.com>
Date:   Mon May 28 13:56:27 2018 +0200

    Overload operator<< for Point

commit 66ff955
Author: Jan Niklas Hasse <jhasse@bixense.com>
Date:   Fri Apr 13 19:29:10 2018 +0200

    Remove unused parameter from CreateAdvancingFront, fix jhasse#3

commit 1ed5e08
Author: Jan Niklas Hasse <jhasse@bixense.com>
Date:   Fri Apr 13 19:16:30 2018 +0200

    Include shapes.h and cmath instead of math.h

commit 001b5cd
Author: Jan Niklas Hasse <jhasse@bixense.com>
Date:   Fri Apr 13 19:15:44 2018 +0200

    Settings for VS Code

commit 053fce6
Author: Jan Niklas Hasse <jhasse@bixense.com>
Date:   Tue Mar 13 16:04:11 2018 +0100

    Add Meson build file

commit f0a1641
Author: Jan Niklas Hasse <jhasse@bixense.com>
Date:   Wed Feb 28 17:34:54 2018 +0100

    Throw an exception instead of assert(false) for repeat points

commit 76b3b53
Author: Jan Niklas Hasse <jhasse@bixense.com>
Date:   Wed Apr 13 17:56:42 2016 +0200

    Update waf to 1.8.20
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

"EdgeEvent - null triangle" from valid but not-quite-collinear points
2 participants