File: test_filter.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 (51 lines) | stat: -rw-r--r-- 913 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
/* Copyright 2017. 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:
 * 2017 Martin Uecker <martin.uecker@med.uni-goettingen.de>
 */

#include <math.h>

#include "num/filter.h"

#include "utest.h"



static bool test_weiszfeld(void)
{
	const float vec[][2] = {
		{ 1.5, 0.5 }, { -0.5, 0.5 }, { 0.5, 1.5 }, { 0.5, -0.5 },
	};

	const float g[2] = { 0.5, 0.5 };
	float m[2];

	weiszfeld(10, 4, 2, m, vec);

	return     (fabsf(m[0] - g[0]) < 1.E-3)
		&& (fabsf(m[1] - g[1]) < 1.E-3);
}


UT_REGISTER_TEST(test_weiszfeld);



static bool test_geometric_median(void)
{
	const complex float vec[] = {
		1.5 + 0.5i, -0.5 + 0.5i, 0.5 + 1.5i, 0.5 + -0.5i,
	};

	const complex float g = 0.5 + 0.5i;
	complex float m = median_complex_float(4, vec);

	return cabsf(m - g);
}


UT_REGISTER_TEST(test_geometric_median);