-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy pathtest_zeta.cpp
35 lines (32 loc) · 899 Bytes
/
test_zeta.cpp
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
#define DOCTEST_CONFIG_IMPLEMENT_WITH_MAIN 1
#include "doctest.h"
#include "test.hpp"
#include "zeta.hpp"
#include <cmath>
TEST_CASE("test_fixed_values")
{
using polylogarithm::zeta;
if (has_inf()) {
CHECK(std::isinf(zeta(-263)));
}
CHECK(zeta(-262) == 0.0);
if (has_inf()) {
CHECK(std::isinf(zeta(-261)));
}
CHECK(zeta(-259) == 8.7601563446229215e306);
CHECK(zeta(-257) == -5.1754977470366798e303);
CHECK(zeta(-255) == 3.1055517596048927e300);
CHECK(zeta(-4) == 0.0);
CHECK(zeta(-3) == 1.0/120.0);
CHECK(zeta(-2) == 0.0);
CHECK(zeta(-1) == -1.0/12.0);
CHECK(zeta(0) == -0.5);
if (has_inf()) {
CHECK(std::isinf(zeta(1)));
}
CHECK(zeta(2) == M_PI*M_PI/6.0);
CHECK(zeta(32) == 1.0000000002328312);
CHECK(zeta(33) == 1.0000000001164155);
CHECK(zeta(34) == 1.0000000000582077);
CHECK(zeta(35) == 1.0000000000291039);
}