/usr/share/doc/libntl-dev/NTL/mat_lzz_pE.cpp.html is in libntl-dev 9.9.1-3.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
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 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 | <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<title>/Volumes/unix-files/u/ntl-new/ntl-9.9.0dev/doc/mat_lzz_pE.cpp.html</title>
<meta name="Generator" content="Vim/7.1">
<meta http-equiv="content-type" content="text/html; charset=UTF-8">
</head>
<body bgcolor="#ffffff" text="#000000"><font face="monospace">
<br>
<font color="#0000ed"><i>/*</i></font><font color="#0000ed"><i>*************************************************************************\</i></font><br>
<br>
<font color="#0000ed"><i>MODULE: mat_zz_pE</i></font><br>
<br>
<font color="#0000ed"><i>SUMMARY:</i></font><br>
<br>
<font color="#0000ed"><i>Defines the class mat_zz_pE.</i></font><br>
<br>
<font color="#0000ed"><i>\*************************************************************************</i></font><font color="#0000ed"><i>*/</i></font><br>
<br>
<br>
<font color="#1773cc">#include </font><font color="#4a6f8b"><NTL/matrix.h></font><br>
<font color="#1773cc">#include </font><font color="#4a6f8b"><NTL/vec_vec_lzz_pE.h></font><br>
<br>
<br>
<font color="#008b00"><b>typedef</b></font> Mat<zz_pE> mat_zz_pE; <font color="#0000ed"><i>// backward compatibility</i></font><br>
<br>
<font color="#008b00"><b>void</b></font> add(mat_zz_pE& X, <font color="#008b00"><b>const</b></font> mat_zz_pE& A, <font color="#008b00"><b>const</b></font> mat_zz_pE& B); <br>
<font color="#0000ed"><i>// X = A + B</i></font><br>
<br>
<font color="#008b00"><b>void</b></font> sub(mat_zz_pE& X, <font color="#008b00"><b>const</b></font> mat_zz_pE& A, <font color="#008b00"><b>const</b></font> mat_zz_pE& B); <br>
<font color="#0000ed"><i>// X = A - B</i></font><br>
<br>
<font color="#008b00"><b>void</b></font> negate(mat_zz_pE& X, <font color="#008b00"><b>const</b></font> mat_zz_pE& A); <br>
<font color="#0000ed"><i>// X = - A</i></font><br>
<br>
<font color="#008b00"><b>void</b></font> mul(mat_zz_pE& X, <font color="#008b00"><b>const</b></font> mat_zz_pE& A, <font color="#008b00"><b>const</b></font> mat_zz_pE& B); <br>
<font color="#0000ed"><i>// X = A * B</i></font><br>
<br>
<font color="#008b00"><b>void</b></font> mul(vec_zz_pE& x, <font color="#008b00"><b>const</b></font> mat_zz_pE& A, <font color="#008b00"><b>const</b></font> vec_zz_pE& b); <br>
<font color="#0000ed"><i>// x = A * b</i></font><br>
<br>
<font color="#008b00"><b>void</b></font> mul(vec_zz_pE& x, <font color="#008b00"><b>const</b></font> vec_zz_pE& a, <font color="#008b00"><b>const</b></font> mat_zz_pE& B); <br>
<font color="#0000ed"><i>// x = a * B</i></font><br>
<br>
<font color="#008b00"><b>void</b></font> mul(mat_zz_pE& X, <font color="#008b00"><b>const</b></font> mat_zz_pE& A, <font color="#008b00"><b>const</b></font> zz_pE& b);<br>
<font color="#008b00"><b>void</b></font> mul(mat_zz_pE& X, <font color="#008b00"><b>const</b></font> mat_zz_pE& A, <font color="#008b00"><b>const</b></font> zz_p& b);<br>
<font color="#008b00"><b>void</b></font> mul(mat_zz_pE& X, <font color="#008b00"><b>const</b></font> mat_zz_pE& A, <font color="#008b00"><b>long</b></font> b);<br>
<font color="#0000ed"><i>// X = A * b</i></font><br>
<br>
<font color="#008b00"><b>void</b></font> mul(mat_zz_pE& X, <font color="#008b00"><b>const</b></font> zz_pE& a, <font color="#008b00"><b>const</b></font> mat_zz_pE& B);<br>
<font color="#008b00"><b>void</b></font> mul(mat_zz_pE& X, <font color="#008b00"><b>const</b></font> zz_p& a, <font color="#008b00"><b>const</b></font> mat_zz_pE& B);<br>
<font color="#008b00"><b>void</b></font> mul(mat_zz_pE& X, <font color="#008b00"><b>long</b></font> a, <font color="#008b00"><b>const</b></font> mat_zz_pE& B);<br>
<font color="#0000ed"><i>// X = a * B</i></font><br>
<br>
<br>
<font color="#008b00"><b>void</b></font> determinant(zz_pE& d, <font color="#008b00"><b>const</b></font> mat_zz_pE& A);<br>
zz_pE determinant(<font color="#008b00"><b>const</b></font> mat_zz_pE& a); <br>
<font color="#0000ed"><i>// d = determinant(A)</i></font><br>
<br>
<br>
<font color="#008b00"><b>void</b></font> transpose(mat_zz_pE& X, <font color="#008b00"><b>const</b></font> mat_zz_pE& A);<br>
mat_zz_pE transpose(<font color="#008b00"><b>const</b></font> mat_zz_pE& A);<br>
<font color="#0000ed"><i>// X = transpose of A</i></font><br>
<br>
<font color="#008b00"><b>void</b></font> solve(zz_pE& d, vec_zz_pE& x, <font color="#008b00"><b>const</b></font> mat_zz_pE& A, <font color="#008b00"><b>const</b></font> vec_zz_pE& b);<br>
<font color="#0000ed"><i>// A is an n x n matrix, b is a length n vector. Computes d =</i></font><br>
<font color="#0000ed"><i>// determinant(A). If d != 0, solves x*A = b.</i></font><br>
<br>
<font color="#008b00"><b>void</b></font> solve(zz_pE& d, <font color="#008b00"><b>const</b></font> mat_zz_pE& A, vec_zz_pE& x, <font color="#008b00"><b>const</b></font> vec_zz_pE& b);<br>
<font color="#0000ed"><i>// A is an n x n matrix, b is a length n vector. Computes d = determinant(A).</i></font><br>
<font color="#0000ed"><i>// If d != 0, solves A*x = b (so x and b are treated as a column vectors).</i></font><br>
<br>
<font color="#008b00"><b>void</b></font> inv(zz_pE& d, mat_zz_pE& X, <font color="#008b00"><b>const</b></font> mat_zz_pE& A);<br>
<font color="#0000ed"><i>// A is an n x n matrix. Computes d = determinant(A). If d != 0,</i></font><br>
<font color="#0000ed"><i>// computes X = A^{-1}.</i></font><br>
<br>
<font color="#008b00"><b>void</b></font> sqr(mat_zz_pE& X, <font color="#008b00"><b>const</b></font> mat_zz_pE& A);<br>
mat_zz_pE sqr(<font color="#008b00"><b>const</b></font> mat_zz_pE& A);<br>
<font color="#0000ed"><i>// X = A*A </i></font><br>
<br>
<font color="#008b00"><b>void</b></font> inv(mat_zz_pE& X, <font color="#008b00"><b>const</b></font> mat_zz_pE& A);<br>
mat_zz_pE inv(<font color="#008b00"><b>const</b></font> mat_zz_pE& A);<br>
<font color="#0000ed"><i>// X = A^{-1}; error is raised if A is singular</i></font><br>
<br>
<font color="#008b00"><b>void</b></font> power(mat_zz_pE& X, <font color="#008b00"><b>const</b></font> mat_zz_pE& A, <font color="#008b00"><b>const</b></font> ZZ& e);<br>
mat_zz_pE power(<font color="#008b00"><b>const</b></font> mat_zz_pE& A, <font color="#008b00"><b>const</b></font> ZZ& e);<br>
<br>
<font color="#008b00"><b>void</b></font> power(mat_zz_pE& X, <font color="#008b00"><b>const</b></font> mat_zz_pE& A, <font color="#008b00"><b>long</b></font> e);<br>
mat_zz_pE power(<font color="#008b00"><b>const</b></font> mat_zz_pE& A, <font color="#008b00"><b>long</b></font> e);<br>
<font color="#0000ed"><i>// X = A^e; e may be negative (in which case A must be nonsingular).</i></font><br>
<br>
<font color="#008b00"><b>void</b></font> ident(mat_zz_pE& X, <font color="#008b00"><b>long</b></font> n);<br>
mat_zz_pE ident_mat_zz_pE(<font color="#008b00"><b>long</b></font> n);<br>
<font color="#0000ed"><i>// X = n x n identity matrix</i></font><br>
<br>
<font color="#008b00"><b>long</b></font> IsIdent(<font color="#008b00"><b>const</b></font> mat_zz_pE& A, <font color="#008b00"><b>long</b></font> n);<br>
<font color="#0000ed"><i>// test if A is the n x n identity matrix</i></font><br>
<br>
<font color="#008b00"><b>void</b></font> diag(mat_zz_pE& X, <font color="#008b00"><b>long</b></font> n, <font color="#008b00"><b>const</b></font> zz_pE& d);<br>
mat_zz_pE diag(<font color="#008b00"><b>long</b></font> n, <font color="#008b00"><b>const</b></font> zz_pE& d);<br>
<font color="#0000ed"><i>// X = n x n diagonal matrix with d on diagonal</i></font><br>
<br>
<font color="#008b00"><b>long</b></font> IsDiag(<font color="#008b00"><b>const</b></font> mat_zz_pE& A, <font color="#008b00"><b>long</b></font> n, <font color="#008b00"><b>const</b></font> zz_pE& d);<br>
<font color="#0000ed"><i>// test if X is an n x n diagonal matrix with d on diagonal</i></font><br>
<br>
<br>
<br>
<br>
<font color="#008b00"><b>long</b></font> gauss(mat_zz_pE& M);<br>
<font color="#008b00"><b>long</b></font> gauss(mat_zz_pE& M, <font color="#008b00"><b>long</b></font> w);<br>
<font color="#0000ed"><i>// Performs unitary row operations so as to bring M into row echelon</i></font><br>
<font color="#0000ed"><i>// form. If the optional argument w is supplied, stops when first w</i></font><br>
<font color="#0000ed"><i>// columns are in echelon form. The return value is the rank (or the</i></font><br>
<font color="#0000ed"><i>// rank of the first w columns).</i></font><br>
<br>
<font color="#008b00"><b>void</b></font> image(mat_zz_pE& X, <font color="#008b00"><b>const</b></font> mat_zz_pE& A);<br>
<font color="#0000ed"><i>// The rows of X are computed as basis of A's row space. X is is row</i></font><br>
<font color="#0000ed"><i>// echelon form</i></font><br>
<br>
<font color="#008b00"><b>void</b></font> kernel(mat_zz_pE& X, <font color="#008b00"><b>const</b></font> mat_zz_pE& A);<br>
<font color="#0000ed"><i>// Computes a basis for the kernel of the map x -> x*A. where x is a</i></font><br>
<font color="#0000ed"><i>// row vector.</i></font><br>
<br>
<br>
<br>
<font color="#0000ed"><i>// miscellaneous:</i></font><br>
<br>
<font color="#008b00"><b>void</b></font> clear(mat_zz_pE& a);<br>
<font color="#0000ed"><i>// x = 0 (dimension unchanged)</i></font><br>
<br>
<font color="#008b00"><b>long</b></font> IsZero(<font color="#008b00"><b>const</b></font> mat_zz_pE& a);<br>
<font color="#0000ed"><i>// test if a is the zero matrix (any dimension)</i></font><br>
<br>
<br>
<font color="#0000ed"><i>// operator notation:</i></font><br>
<br>
mat_zz_pE <font color="#b02f60"><b>operator</b></font>+(<font color="#008b00"><b>const</b></font> mat_zz_pE& a, <font color="#008b00"><b>const</b></font> mat_zz_pE& b);<br>
mat_zz_pE <font color="#b02f60"><b>operator</b></font>-(<font color="#008b00"><b>const</b></font> mat_zz_pE& a, <font color="#008b00"><b>const</b></font> mat_zz_pE& b);<br>
mat_zz_pE <font color="#b02f60"><b>operator</b></font>*(<font color="#008b00"><b>const</b></font> mat_zz_pE& a, <font color="#008b00"><b>const</b></font> mat_zz_pE& b);<br>
<br>
mat_zz_pE <font color="#b02f60"><b>operator</b></font>-(<font color="#008b00"><b>const</b></font> mat_zz_pE& a);<br>
<br>
<br>
<font color="#0000ed"><i>// matrix/scalar multiplication:</i></font><br>
<br>
mat_zz_pE <font color="#b02f60"><b>operator</b></font>*(<font color="#008b00"><b>const</b></font> mat_zz_pE& a, <font color="#008b00"><b>const</b></font> zz_pE& b);<br>
mat_zz_pE <font color="#b02f60"><b>operator</b></font>*(<font color="#008b00"><b>const</b></font> mat_zz_pE& a, <font color="#008b00"><b>const</b></font> zz_p& b);<br>
mat_zz_pE <font color="#b02f60"><b>operator</b></font>*(<font color="#008b00"><b>const</b></font> mat_zz_pE& a, <font color="#008b00"><b>long</b></font> b);<br>
<br>
mat_zz_pE <font color="#b02f60"><b>operator</b></font>*(<font color="#008b00"><b>const</b></font> zz_pE& a, <font color="#008b00"><b>const</b></font> mat_zz_pE& b);<br>
mat_zz_pE <font color="#b02f60"><b>operator</b></font>*(<font color="#008b00"><b>const</b></font> zz_p& a, <font color="#008b00"><b>const</b></font> mat_zz_pE& b);<br>
mat_zz_pE <font color="#b02f60"><b>operator</b></font>*(<font color="#008b00"><b>long</b></font> a, <font color="#008b00"><b>const</b></font> mat_zz_pE& b);<br>
<br>
<font color="#0000ed"><i>// matrix/vector multiplication:</i></font><br>
<br>
vec_zz_pE <font color="#b02f60"><b>operator</b></font>*(<font color="#008b00"><b>const</b></font> mat_zz_pE& a, <font color="#008b00"><b>const</b></font> vec_zz_pE& b);<br>
<br>
vec_zz_pE <font color="#b02f60"><b>operator</b></font>*(<font color="#008b00"><b>const</b></font> vec_zz_pE& a, <font color="#008b00"><b>const</b></font> mat_zz_pE& b);<br>
<br>
<br>
<font color="#0000ed"><i>// assignment operator notation:</i></font><br>
<br>
mat_zz_pE& <font color="#b02f60"><b>operator</b></font>+=(mat_zz_pE& x, <font color="#008b00"><b>const</b></font> mat_zz_pE& a);<br>
mat_zz_pE& <font color="#b02f60"><b>operator</b></font>-=(mat_zz_pE& x, <font color="#008b00"><b>const</b></font> mat_zz_pE& a);<br>
mat_zz_pE& <font color="#b02f60"><b>operator</b></font>*=(mat_zz_pE& x, <font color="#008b00"><b>const</b></font> mat_zz_pE& a);<br>
<br>
mat_zz_pE& <font color="#b02f60"><b>operator</b></font>*=(mat_zz_pE& x, <font color="#008b00"><b>const</b></font> zz_pE& a);<br>
mat_zz_pE& <font color="#b02f60"><b>operator</b></font>*=(mat_zz_pE& x, <font color="#008b00"><b>const</b></font> zz_p& a);<br>
mat_zz_pE& <font color="#b02f60"><b>operator</b></font>*=(mat_zz_pE& x, <font color="#008b00"><b>long</b></font> a);<br>
<br>
vec_zz_pE& <font color="#b02f60"><b>operator</b></font>*=(vec_zz_pE& x, <font color="#008b00"><b>const</b></font> mat_zz_pE& a);<br>
<br>
<br>
<br>
</font></body>
</html>
|