forked from skelterjohn/go.matrix
-
Notifications
You must be signed in to change notification settings - Fork 0
/
pivot_basic.go
61 lines (50 loc) · 1.4 KB
/
pivot_basic.go
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
// Copyright 2009 The GoMatrix Authors. All rights reserved.
// Use of this source code is governed by a BSD-style
// license that can be found in the LICENSE file.
package matrix
import "math"
/*
Swap two rows in this PivotMatrix.
*/
func (P *PivotMatrix) SwapRows(r1, r2 int) error {
// tmp := P.pivots[r1];
// P.pivots[r1] = P.pivots[r2];
// P.pivots[r2] = tmp;
P.pivots[r1], P.pivots[r2] = P.pivots[r2], P.pivots[r1]
P.pivotSign *= -1
return nil
}
func (P *PivotMatrix) Symmetric() bool {
for i := 0; i < P.rows; i++ {
if P.pivots[P.pivots[i]] != i {
return false
}
}
return true
}
func (A *PivotMatrix) Inverse() *PivotMatrix { return A.Transpose() }
func (P *PivotMatrix) Transpose() *PivotMatrix {
newPivots := make([]int, P.rows)
for i := 0; i < P.rows; i++ {
newPivots[P.pivots[i]] = i
}
return MakePivotMatrix(newPivots, P.pivotSign)
}
func (P *PivotMatrix) Det() float64 { return P.pivotSign }
func (P *PivotMatrix) Trace() (r float64) {
for i := 0; i < len(P.pivots); i++ {
if P.pivots[i] == i {
r += 1
}
}
return
}
/*
Returns x such that Px=b.
*/
func (P *PivotMatrix) Solve(b MatrixRO) (Matrix, error) {
return P.Transpose().Times(b) //error comes from times
}
func (A *PivotMatrix) OneNorm() float64 { return float64(A.rows) }
func (A *PivotMatrix) TwoNorm() float64 { return math.Sqrt(float64(A.rows)) }
func (A *PivotMatrix) InfinityNorm() float64 { return 1 }