source: git/ntl/doc/mat_RR.txt @ 6ce030f

spielwiese
Last change on this file since 6ce030f was 2cfffe, checked in by Hans Schönemann <hannes@…>, 21 years ago
This commit was generated by cvs2svn to compensate for changes in r6316, which included commits to RCS files with non-trunk default branches. git-svn-id: file:///usr/local/Singular/svn/trunk@6317 2c84dea3-7e68-4137-9b89-c4e89433aadc
  • Property mode set to 100644
File size: 3.4 KB
Line 
1
2/**************************************************************************\
3
4MODULE: mat_RR
5
6SUMMARY:
7
8Defines the class mat_RR.
9
10\**************************************************************************/
11
12
13#include <NTL/matrix.h>
14#include <NTL/vec_vec_RR.h>
15
16NTL_matrix_decl(RR,vec_RR,vec_vec_RR,mat_RR)
17NTL_io_matrix_decl(RR,vec_RR,vec_vec_RR,mat_RR)
18NTL_eq_matrix_decl(RR,vec_RR,vec_vec_RR,mat_RR)
19
20void add(mat_RR& X, const mat_RR& A, const mat_RR& B);
21// X = A + B
22
23void sub(mat_RR& X, const mat_RR& A, const mat_RR& B);
24// X = A - B
25
26void negate(mat_RR& X, const mat_RR& A);
27// X = - A
28
29void mul(mat_RR& X, const mat_RR& A, const mat_RR& B);
30// X = A * B
31
32void mul(vec_RR& x, const mat_RR& A, const vec_RR& b);
33// x = A * b
34
35void mul(vec_RR& x, const vec_RR& a, const mat_RR& B);
36// x = a * B
37
38void mul(mat_RR& X, const mat_RR& A, const RR& b);
39void mul(mat_RR& X, const mat_RR& A, double b);
40// X = A * b
41
42void mul(mat_RR& X, const RR& a, const mat_RR& B);
43void mul(mat_RR& X, double a, const mat_RR& B);
44// X = a * B
45
46
47void determinant(RR& d, const mat_RR& A);
48RR determinant(const mat_RR& A);
49// d = determinant(A)
50
51
52void transpose(mat_RR& X, const mat_RR& A);
53mat_RR transpose(const mat_RR& A);
54// X = transpose of A
55
56void solve(RR& d, vec_RR& X,
57           const mat_RR& A, const vec_RR& b);
58// A is an n x n matrix, b is a length n vector.  Computes d =
59// determinant(A).  If d != 0, solves x*A = b.
60
61void inv(RR& d, mat_RR& X, const mat_RR& A);
62// A is an n x n matrix.  Computes d = determinant(A).  If d != 0,
63// computes X = A^{-1}.
64
65void sqr(mat_RR& X, const mat_RR& A);
66mat_RR sqr(const mat_RR& A);
67// X = A*A
68
69void inv(mat_RR& X, const mat_RR& A);
70mat_RR inv(const mat_RR& A);
71// X = A^{-1}; error is raised if A is  singular
72
73void power(mat_RR& X, const mat_RR& A, const ZZ& e);
74mat_RR power(const mat_RR& A, const ZZ& e);
75
76void power(mat_RR& X, const mat_RR& A, long e);
77mat_RR power(const mat_RR& A, long e);
78// X = A^e; e may be negative (in which case A must be nonsingular).
79
80void ident(mat_RR& X, long n);
81mat_RR ident_mat_RR(long n);
82// X = n x n identity matrix
83
84long IsIdent(const mat_RR& A, long n);
85// test if A is the n x n identity matrix
86
87void diag(mat_RR& X, long n, const RR& d);
88mat_RR diag(long n, const RR& d);
89// X = n x n diagonal matrix with d on diagonal
90
91long IsDiag(const mat_RR& A, long n, const RR& d);
92// test if X is an  n x n diagonal matrix with d on diagonal
93
94
95
96
97
98// miscellaneous:
99
100void clear(mat_RR& a);
101// x = 0 (dimension unchanged)
102
103long IsZero(const mat_RR& a);
104// test if a is the zero matrix (any dimension)
105
106
107// operator notation:
108
109mat_RR operator+(const mat_RR& a, const mat_RR& b);
110mat_RR operator-(const mat_RR& a, const mat_RR& b);
111mat_RR operator*(const mat_RR& a, const mat_RR& b);
112
113mat_RR operator-(const mat_RR& a);
114
115
116// matrix/scalar multiplication:
117
118mat_RR operator*(const mat_RR& a, const RR& b);
119mat_RR operator*(const mat_RR& a, double b);
120
121mat_RR operator*(const RR& a, const mat_RR& b);
122mat_RR operator*(double a, const mat_RR& b);
123
124
125// matrix/vector multiplication:
126
127vec_RR operator*(const mat_RR& a, const vec_RR& b);
128
129vec_RR operator*(const vec_RR& a, const mat_RR& b);
130
131
132// assignment operator notation:
133
134mat_RR& operator+=(mat_RR& x, const mat_RR& a);
135mat_RR& operator-=(mat_RR& x, const mat_RR& a);
136mat_RR& operator*=(mat_RR& x, const mat_RR& a);
137
138mat_RR& operator*=(mat_RR& x, const RR& a);
139mat_RR& operator*=(mat_RR& x, double a);
140
141vec_RR& operator*=(vec_RR& x, const mat_RR& a);
142
143
144
Note: See TracBrowser for help on using the repository browser.