File: NSLMathTest.cpp

package info (click to toggle)
labplot 2.12.1-2
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 78,528 kB
  • sloc: cpp: 241,047; ansic: 6,324; python: 915; xml: 400; yacc: 237; sh: 221; awk: 35; makefile: 11
file content (44 lines) | stat: -rw-r--r-- 1,520 bytes parent folder | download | duplicates (2)
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
/*
	File                 : NSLMathTest.cpp
	Project              : LabPlot
	Description          : NSL tests for math functions
	--------------------------------------------------------------------
	SPDX-FileCopyrightText: 2024 Stefan Gerlach <stefan.gerlach@uni.kn>

	SPDX-License-Identifier: GPL-2.0-or-later
*/

#include "NSLMathTest.h"

extern "C" {
#include "backend/nsl/nsl_math.h"
}

void NSLMathTest::mathMultiple() {
	// (2.5, 2.)	-> 2.,2.,4.,2.
	double value = 2.5, multiple = 2.;
	QCOMPARE(nsl_math_round_multiple(value, multiple), 2.);
	QCOMPARE(nsl_math_floor_multiple(value, multiple), 2.);
	QCOMPARE(nsl_math_ceil_multiple(value, multiple), 4.);
	QCOMPARE(nsl_math_trunc_multiple(value, multiple), 2.);

	// (4.5, 3)	-> 6.,3.,6.,3.
	value = 4.5, multiple = 3.;
	QCOMPARE(nsl_math_round_multiple(value, multiple), 6.);
	QCOMPARE(nsl_math_floor_multiple(value, multiple), 3.);
	QCOMPARE(nsl_math_ceil_multiple(value, multiple), 6.);
	QCOMPARE(nsl_math_trunc_multiple(value, multiple), 3.);

	// (-0.25, 1)	-> 0.,0.,-1.,0.
	value = -0.25, multiple = 1.;
	QCOMPARE(nsl_math_round_multiple(value, multiple), 0.);
	QCOMPARE(nsl_math_floor_multiple(value, multiple), -1.);
	QCOMPARE(nsl_math_ceil_multiple(value, multiple), 0.);
	QCOMPARE(nsl_math_trunc_multiple(value, multiple), 0.);
}

// ##############################################################################
// #################  performance
// ##############################################################################

QTEST_MAIN(NSLMathTest)