forked from wo80/CSparse.NET
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathSparseCholeskyTest.cs
More file actions
86 lines (66 loc) · 2.61 KB
/
Copy pathSparseCholeskyTest.cs
File metadata and controls
86 lines (66 loc) · 2.61 KB
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
namespace CSparse.Tests.Double.Factorization
{
using CSparse.Double;
using CSparse.Double.Factorization;
using NUnit.Framework;
using System;
public class SparseCholeskyTest
{
private const double EPS = 1.0e-6;
[Test]
public void TestSolve()
{
// Load matrix from a file.
var A = ResourceLoader.Get<double>("symmetric-40-spd.mat");
// Create test data.
var x = Helper.CreateTestVector(A.ColumnCount);
var b = Helper.Multiply(A, x);
var r = Vector.Clone(b);
var chol = SparseCholesky.Create(A, ColumnOrdering.MinimumDegreeAtPlusA);
// Solve Ax = b.
chol.Solve(b, x);
// Compute residual r = b - Ax.
A.Multiply(-1.0, x, 1.0, r);
Assert.That(Vector.Norm(r.Length, r) < EPS, Is.True);
}
[Test]
public void TestConstructorThrowsOnNonSpd()
{
// Load matrix from a file.
var A = ResourceLoader.Get<double>("symmetric-40.mat");
Assert.Throws<Exception>(() =>
{
var chol = SparseCholesky.Create(A, ColumnOrdering.MinimumDegreeAtPlusA);
});
}
[Test]
public void TestEmptyFactorize()
{
var A = new SparseMatrix(0, 0, 0);
var chol = SparseCholesky.Create(A, ColumnOrdering.MinimumDegreeAtPlusA);
Assert.That(chol, Is.Not.Null);
Assert.That(chol.NonZerosCount == 0, Is.True);
}
[Test]
public void TestRefactorize()
{
var A = ResourceLoader.Get<double>("symmetric-40-spd.mat");
var chol = SparseCholesky.Create(A, ColumnOrdering.MinimumDegreeAtPlusA);
// Same sparsity pattern, different values (B = 2*A stays SPD) : the numeric
// refactorization must reuse the cached symbolic analysis and still solve.
var B = A.Clone();
var bv = B.Values;
for (int i = 0; i < bv.Length; i++) bv[i] *= 2.0;
chol.Refactorize(B);
var x = Helper.CreateTestVector(B.ColumnCount);
var b = Helper.Multiply(B, x);
var r = Vector.Clone(b);
chol.Solve(b, x);
B.Multiply(-1.0, x, 1.0, r);
Assert.That(Vector.Norm(r.Length, r) < EPS, Is.True);
// Dimension guard.
var small = new SparseMatrix(3, 3, 0);
Assert.Throws<ArgumentException>(() => chol.Refactorize(small));
}
}
}