File: variables_matrix.html

package info (click to toggle)
freemat 4.0-3
  • links: PTS, VCS
  • area: main
  • in suites: squeeze
  • size: 174,756 kB
  • ctags: 67,023
  • sloc: cpp: 351,059; ansic: 255,892; sh: 40,590; makefile: 4,387; perl: 4,058; asm: 3,313; pascal: 2,718; fortran: 1,722; ada: 1,681; ml: 1,360; cs: 879; csh: 795; python: 430; sed: 162; lisp: 160; awk: 5
file content (105 lines) | stat: -rw-r--r-- 3,010 bytes parent folder | download | duplicates (2)
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
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 3.2 Final//EN">

<HTML>
<HEAD>
<TITLE>MATRIX Matrix Definitions
</TITLE>
</HEAD>
<BODY>
<H2>MATRIX Matrix Definitions
</H2>
<P>
Section: <A HREF=sec_variables.html> Variables and Arrays </A>
<H3>Usage</H3>
The matrix is the basic datatype of FreeMat.  Matrices can be
defined using the following syntax
<PRE>
  A = [row_def1;row_def2;...,row_defN]
</PRE>
<P>
where each row consists of one or more elements, seperated by
commas
<PRE>
  row_defi = element_i1,element_i2,...,element_iM
</PRE>
<P>
Each element can either be a scalar value or another matrix,
provided that the resulting matrix definition makes sense.
In general this means that all of the elements belonging
to a row have the same number of rows themselves, and that
all of the row definitions have the same number of columns.
Matrices are actually special cases of N-dimensional arrays
where <code>N&lt;=2</code>.  Higher dimensional arrays cannot be constructed
using the bracket notation described above.  The type of a
matrix defined in this way (using the bracket notation) is
determined by examining the types of the elements.  The resulting
type is chosen so no information is lost on any of the elements
(or equivalently, by choosing the highest order type from those
present in the elements).
<H3>Examples</H3>
Here is an example of a matrix of <code>int32</code> elements (note that
untyped integer constants default to type <code>int32</code>).
<PRE>
--&gt; A = [1,2;5,8]

A = 
 1 2 
 5 8 
</PRE>
<P>
Now we define a new matrix by adding a column to the right of
<code>A</code>, and using float constants.
<PRE>
--&gt; B = [A,[3.2f;5.1f]]

B = 
    1.0000    2.0000    3.2000 
    5.0000    8.0000    5.1000 
</PRE>
<P>
Next, we add extend <code>B</code> by adding a row at the bottom.  Note
how the use of an untyped floating point constant forces the
result to be of type <code>double</code>
<PRE>
--&gt; C = [B;5.2,1.0,0.0]

C = 
    1.0000    2.0000    3.2000 
    5.0000    8.0000    5.1000 
    5.2000    1.0000         0 
</PRE>
<P>
If we instead add a row of <code>complex</code> values (recall that <code>i</code> is
a <code>complex</code> constant, not a <code>dcomplex</code> constant)
<PRE>
--&gt; D = [B;2.0f+3.0f*i,i,0.0f]

D = 
   1.0000 +  0.0000i   2.0000 +  0.0000i   3.2000 +  0.0000i 
   5.0000 +  0.0000i   8.0000 +  0.0000i   5.1000 +  0.0000i 
   2.0000 +  3.0000i   0.0000 +  1.0000i        0           
</PRE>
<P>
Likewise, but using <code>dcomplex</code> constants
<PRE>
--&gt; E = [B;2.0+3.0*i,i,0.0]

E = 
   1.0000 +  0.0000i   2.0000 +  0.0000i   3.2000 +  0.0000i 
   5.0000 +  0.0000i   8.0000 +  0.0000i   5.1000 +  0.0000i 
   2.0000 +  3.0000i   0.0000 +  1.0000i        0           
</PRE>
<P>
Finally, in FreeMat, you can construct matrices with strings
as contents, but you have to make sure that if the matrix has
more than one row, that all the strings have the same length.
<PRE>
--&gt; F = ['hello';'there']

F = 
hello
there
</PRE>
<P>
</BODY>
</HTML>