-
Notifications
You must be signed in to change notification settings - Fork 13
/
zohar.cpp
105 lines (85 loc) · 2.57 KB
/
zohar.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
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
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
// Copyright (C) 2012, 2013 Rhys Ulerich
//
// This Source Code Form is subject to the terms of the Mozilla Public
// License, v. 2.0. If a copy of the MPL was not distributed with this
// file, You can obtain one at http://mozilla.org/MPL/2.0/.
/** @file
* Test \ref ar::zohar_linear_solve routine against a reference solution.
*/
#include <algorithm>
#include <cassert>
#include <cstdlib>
#include <iostream>
#include <iterator>
#include <vector>
#include "ar.hpp"
#include "real.hpp"
int main()
{
using namespace ar;
using namespace std;
vector<real> a;
a.push_back( 2);
a.push_back( 3);
a.push_back( 5);
a.push_back( 7);
a.push_back(11);
a.push_back(13);
a.push_back(17);
cout << "Topmost row of Toeplitz matrix is: \n\t1 ";
copy(a.begin(), a.end(), ostream_iterator<real>(cout," "));
cout << endl;
vector<real> r;
r.push_back( 2);
r.push_back( 4);
r.push_back( 8);
r.push_back( 16);
r.push_back( 32);
r.push_back( 64);
r.push_back(128);
assert(a.size() == r.size());
cout << "Leftmost column of Toeplitz matrix is: \n\t1 ";
copy(r.begin(), r.end(), ostream_iterator<real>(cout," "));
cout << endl;
vector<real> d;
d.push_back(1);
d.push_back(2);
d.push_back(3);
d.push_back(4);
d.push_back(5);
d.push_back(6);
d.push_back(7);
d.push_back(8);
assert(d.size() == a.size() + 1);
cout << "Right hand side data is:\n\t";
copy(d.begin(), d.end(), ostream_iterator<real>(cout," "));
cout << endl;
vector<real> exp;
exp.push_back(-17./27);
exp.push_back( 4./27);
exp.push_back( 32./ 9);
exp.push_back(- 5./ 3);
exp.push_back( 0. );
exp.push_back(- 2. );
exp.push_back(- 1. );
exp.push_back( 2. );
assert(exp.size() == d.size());
cout << "Expected solution is:\n\t";
copy(exp.begin(), exp.end(), ostream_iterator<real>(cout," "));
cout << endl;
cout << "Solution computed by zohar_linear_solve is:\n\t";
zohar_linear_solve(a.begin(), a.end(), r.begin(), d.begin());
copy(d.begin(), d.end(), ostream_iterator<real>(cout," "));
cout << endl;
vector<real> err(exp.size());
for (size_t i = 0; i < err.size(); ++i) {
err[i] = exp[i] - d[i];
}
cout << "Term-by-term errors are:\n\t";
copy(err.begin(), err.end(), ostream_iterator<real>(cout," "));
cout << endl;
real abserr = 0;
for (size_t i = 0; i < exp.size(); ++i) abserr += std::abs(err[i]);
cout << "Sum of the absolute errors is:\n\t" << abserr << endl;
return EXIT_SUCCESS;
}