File: test_geom.c

package info (click to toggle)
bart 0.9.00-3
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 9,040 kB
  • sloc: ansic: 116,116; python: 1,329; sh: 726; makefile: 639; javascript: 589; cpp: 106
file content (83 lines) | stat: -rw-r--r-- 1,557 bytes parent folder | download | duplicates (3)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
/* Copyright 2020. Martin Uecker.
 * All rights reserved. Use of this source code is governed by
 * a BSD-style license which can be found in the LICENSE file.
 *
 * Authors:
 * 2019-2020 Martin Uecker <muecker@gwdg.de>
 */

#include <math.h>

#include "geom/polygon.h"
#include "geom/polyhedron.h"
#include "geom/triangle.h"

#include "utest.h"


static bool test_winding_number(void)
{
	double p[2] = { 0., 0. };

	double pg[4][2] = {
		{  1., -1. },
		{  1.,  1. },
		{ -1.,  1. },
		{ -1., -1. },
	};

	return (1 == polygon_winding_number(4, pg, p));
}

UT_REGISTER_TEST(test_winding_number);


static bool test_triangle_intersect(void)
{
	float o[3] = { 0., 0., 0. };
	float d[3] = { 1., 0., 0. };
	float t[3][3] = {

		{ 1., -1., -1. },
		{ 1., -1.,  1. },
		{ 1.,  1.,  0. },
	};

	float uv[2];

	return (1. == triangle_intersect(uv, o, d, t));
}


UT_REGISTER_TEST(test_triangle_intersect);



static bool test_polygon_area(void)
{
	double pg[4][2] = { { 0., 0. }, { 1., 0. }, { 1., 1. }, { 0., 1. } };

	return (1. == polygon_area(4, pg));
}

UT_REGISTER_TEST(test_polygon_area);




static bool test_polyhedron_volume(void)
{
	double ph[4][3][3] = {
		{ { +0.5, +0.5, +0.5 }, { +0.5, -0.5, +0.5 }, { +0.5, +0.5, -0.5 } },
		{ { +0.5, +0.5, +0.5 }, { +0.5, +0.5, -0.5 }, { -0.5, +0.5, +0.5 } },
		{ { +0.5, -0.5, +0.5 }, { +0.5, +0.5, +0.5 }, { -0.5, +0.5, +0.5 } },
		{ { +0.5, -0.5, +0.5 }, { -0.5, +0.5, +0.5 }, { +0.5, +0.5, -0.5 } },
	};

	return fabs(1. / 6. - polyhedron_vol(4, ph)) < 1.E-16;
}

UT_REGISTER_TEST(test_polyhedron_volume);