annotate src/pt-const.cc @ 455:8c6b86564cee

[project @ 1994-06-06 00:24:19 by jwe]
author jwe
date Mon, 06 Jun 1994 00:24:19 +0000
parents 5e778965b6ea
children 794b6f480d72
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1 // The constants for the tree class. -*- C++ -*-
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2 /*
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
3
296
3c23b8ea9099 [project @ 1994-01-17 02:49:15 by jwe]
jwe
parents: 279
diff changeset
4 Copyright (C) 1992, 1993, 1994 John W. Eaton
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
5
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
6 This file is part of Octave.
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
7
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
8 Octave is free software; you can redistribute it and/or modify it
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
9 under the terms of the GNU General Public License as published by the
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
10 Free Software Foundation; either version 2, or (at your option) any
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
11 later version.
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
12
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
13 Octave is distributed in the hope that it will be useful, but WITHOUT
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
14 ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
15 FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
16 for more details.
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
17
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
18 You should have received a copy of the GNU General Public License
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
19 along with Octave; see the file COPYING. If not, write to the Free
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
20 Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA.
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
21
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
22 */
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
23
240
a99f28f5e351 [project @ 1993-11-30 20:24:36 by jwe]
jwe
parents: 217
diff changeset
24 #ifdef HAVE_CONFIG_H
a99f28f5e351 [project @ 1993-11-30 20:24:36 by jwe]
jwe
parents: 217
diff changeset
25 #include "config.h"
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
26 #endif
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
27
455
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
28 #if defined (__GNUG__)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
29 #pragma implementation
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
30 #endif
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
31
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
32 #include <ctype.h>
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
33 #include <string.h>
455
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
34 #include <fstream.h>
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
35 #include <iostream.h>
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
36 #include <strstream.h>
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
37 #include <math.h>
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
38
455
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
39 #include "mx-base.h"
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
40 #include "Range.h"
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
41
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
42 #include "variables.h"
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
43 #include "error.h"
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
44 #include "gripes.h"
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
45 #include "user-prefs.h"
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
46 #include "utils.h"
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
47 #include "pager.h"
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
48 #include "mappers.h"
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
49 #include "pr-output.h"
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
50 #include "tree-const.h"
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
51 #include "arith-ops.h"
455
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
52 #include "idx-vector.h"
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
53 #include "unwind-prot.h"
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
54 #include "octave.h"
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
55 #include "input.h"
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
56 #include "octave-hist.h"
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
57 #include "parse.h"
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
58 #include "lex.h"
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
59
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
60 #include "tc-inlines.cc"
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
61
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
62 // A couple of handy helper functions.
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
63
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
64 static int
330
fe6e790846f5 [project @ 1994-02-04 04:54:47 by jwe]
jwe
parents: 312
diff changeset
65 any_element_less_than (const Matrix& a, double val)
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
66 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
67 int nr = a.rows ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
68 int nc = a.columns ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
69 for (int j = 0; j < nc; j++)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
70 for (int i = 0; i < nr; i++)
330
fe6e790846f5 [project @ 1994-02-04 04:54:47 by jwe]
jwe
parents: 312
diff changeset
71 if (a.elem (i, j) < val)
fe6e790846f5 [project @ 1994-02-04 04:54:47 by jwe]
jwe
parents: 312
diff changeset
72 return 1;
fe6e790846f5 [project @ 1994-02-04 04:54:47 by jwe]
jwe
parents: 312
diff changeset
73 return 0;
fe6e790846f5 [project @ 1994-02-04 04:54:47 by jwe]
jwe
parents: 312
diff changeset
74 }
fe6e790846f5 [project @ 1994-02-04 04:54:47 by jwe]
jwe
parents: 312
diff changeset
75
fe6e790846f5 [project @ 1994-02-04 04:54:47 by jwe]
jwe
parents: 312
diff changeset
76 static int
fe6e790846f5 [project @ 1994-02-04 04:54:47 by jwe]
jwe
parents: 312
diff changeset
77 any_element_greater_than (const Matrix& a, double val)
fe6e790846f5 [project @ 1994-02-04 04:54:47 by jwe]
jwe
parents: 312
diff changeset
78 {
fe6e790846f5 [project @ 1994-02-04 04:54:47 by jwe]
jwe
parents: 312
diff changeset
79 int nr = a.rows ();
fe6e790846f5 [project @ 1994-02-04 04:54:47 by jwe]
jwe
parents: 312
diff changeset
80 int nc = a.columns ();
fe6e790846f5 [project @ 1994-02-04 04:54:47 by jwe]
jwe
parents: 312
diff changeset
81 for (int j = 0; j < nc; j++)
fe6e790846f5 [project @ 1994-02-04 04:54:47 by jwe]
jwe
parents: 312
diff changeset
82 for (int i = 0; i < nr; i++)
fe6e790846f5 [project @ 1994-02-04 04:54:47 by jwe]
jwe
parents: 312
diff changeset
83 if (a.elem (i, j) > val)
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
84 return 1;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
85 return 0;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
86 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
87
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
88 static int
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
89 any_element_is_complex (const ComplexMatrix& a)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
90 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
91 int nr = a.rows ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
92 int nc = a.columns ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
93 for (int j = 0; j < nc; j++)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
94 for (int i = 0; i < nr; i++)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
95 if (imag (a.elem (i, j)) != 0.0)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
96 return 1;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
97 return 0;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
98 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
99
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
100 // Now, the classes.
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
101
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
102 /*
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
103 * The real representation of constants.
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
104 */
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
105 tree_constant_rep::tree_constant_rep (void)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
106 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
107 type_tag = unknown_constant;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
108 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
109
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
110 tree_constant_rep::tree_constant_rep (double d)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
111 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
112 scalar = d;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
113 type_tag = scalar_constant;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
114 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
115
161
21b599370728 [project @ 1993-10-16 17:20:32 by jwe]
jwe
parents: 145
diff changeset
116 tree_constant_rep::tree_constant_rep (const Matrix& m)
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
117 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
118 if (m.rows () == 1 && m.columns () == 1)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
119 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
120 scalar = m.elem (0, 0);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
121 type_tag = scalar_constant;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
122 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
123 else
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
124 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
125 matrix = new Matrix (m);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
126 type_tag = matrix_constant;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
127 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
128 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
129
161
21b599370728 [project @ 1993-10-16 17:20:32 by jwe]
jwe
parents: 145
diff changeset
130 tree_constant_rep::tree_constant_rep (const DiagMatrix& d)
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
131 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
132 if (d.rows () == 1 && d.columns () == 1)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
133 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
134 scalar = d.elem (0, 0);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
135 type_tag = scalar_constant;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
136 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
137 else
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
138 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
139 matrix = new Matrix (d);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
140 type_tag = matrix_constant;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
141 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
142 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
143
455
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
144 tree_constant_rep::tree_constant_rep (const RowVector& v, int
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
145 prefer_column_vector)
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
146 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
147 int len = v.capacity ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
148 if (len == 1)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
149 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
150 scalar = v.elem (0);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
151 type_tag = scalar_constant;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
152 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
153 else
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
154 {
455
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
155 int pcv = (prefer_column_vector < 0)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
156 ? user_pref.prefer_column_vectors
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
157 : prefer_column_vector;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
158
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
159 if (pcv)
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
160 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
161 Matrix m (len, 1);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
162 for (int i = 0; i < len; i++)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
163 m.elem (i, 0) = v.elem (i);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
164 matrix = new Matrix (m);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
165 type_tag = matrix_constant;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
166 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
167 else
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
168 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
169 Matrix m (1, len);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
170 for (int i = 0; i < len; i++)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
171 m.elem (0, i) = v.elem (i);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
172 matrix = new Matrix (m);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
173 type_tag = matrix_constant;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
174 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
175 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
176 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
177
161
21b599370728 [project @ 1993-10-16 17:20:32 by jwe]
jwe
parents: 145
diff changeset
178 tree_constant_rep::tree_constant_rep (const ColumnVector& v,
455
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
179 int prefer_column_vector)
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
180 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
181 int len = v.capacity ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
182 if (len == 1)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
183 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
184 scalar = v.elem (0);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
185 type_tag = scalar_constant;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
186 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
187 else
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
188 {
455
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
189 int pcv = (prefer_column_vector < 0)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
190 ? user_pref.prefer_column_vectors
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
191 : prefer_column_vector;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
192
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
193 if (pcv)
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
194 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
195 Matrix m (len, 1);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
196 for (int i = 0; i < len; i++)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
197 m.elem (i, 0) = v.elem (i);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
198 matrix = new Matrix (m);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
199 type_tag = matrix_constant;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
200 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
201 else
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
202 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
203 Matrix m (1, len);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
204 for (int i = 0; i < len; i++)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
205 m.elem (0, i) = v.elem (i);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
206 matrix = new Matrix (m);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
207 type_tag = matrix_constant;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
208 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
209 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
210 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
211
161
21b599370728 [project @ 1993-10-16 17:20:32 by jwe]
jwe
parents: 145
diff changeset
212 tree_constant_rep::tree_constant_rep (const Complex& c)
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
213 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
214 complex_scalar = new Complex (c);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
215 type_tag = complex_scalar_constant;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
216 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
217
161
21b599370728 [project @ 1993-10-16 17:20:32 by jwe]
jwe
parents: 145
diff changeset
218 tree_constant_rep::tree_constant_rep (const ComplexMatrix& m)
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
219 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
220 if (m.rows () == 1 && m.columns () == 1)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
221 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
222 complex_scalar = new Complex (m.elem (0, 0));
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
223 type_tag = complex_scalar_constant;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
224 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
225 else
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
226 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
227 complex_matrix = new ComplexMatrix (m);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
228 type_tag = complex_matrix_constant;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
229 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
230 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
231
161
21b599370728 [project @ 1993-10-16 17:20:32 by jwe]
jwe
parents: 145
diff changeset
232 tree_constant_rep::tree_constant_rep (const ComplexDiagMatrix& d)
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
233 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
234 if (d.rows () == 1 && d.columns () == 1)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
235 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
236 complex_scalar = new Complex (d.elem (0, 0));
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
237 type_tag = complex_scalar_constant;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
238 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
239 else
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
240 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
241 complex_matrix = new ComplexMatrix (d);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
242 type_tag = complex_matrix_constant;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
243 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
244 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
245
161
21b599370728 [project @ 1993-10-16 17:20:32 by jwe]
jwe
parents: 145
diff changeset
246 tree_constant_rep::tree_constant_rep (const ComplexRowVector& v,
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
247 int prefer_column_vector)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
248 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
249 int len = v.capacity ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
250 if (len == 1)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
251 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
252 complex_scalar = new Complex (v.elem (0));
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
253 type_tag = complex_scalar_constant;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
254 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
255 else
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
256 {
455
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
257 int pcv = (prefer_column_vector < 0)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
258 ? user_pref.prefer_column_vectors
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
259 : prefer_column_vector;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
260
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
261 if (pcv)
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
262 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
263 ComplexMatrix m (len, 1);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
264 for (int i = 0; i < len; i++)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
265 m.elem (i, 0) = v.elem (i);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
266 complex_matrix = new ComplexMatrix (m);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
267 type_tag = complex_matrix_constant;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
268 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
269 else
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
270 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
271 ComplexMatrix m (1, len);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
272 for (int i = 0; i < len; i++)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
273 m.elem (0, i) = v.elem (i);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
274 complex_matrix = new ComplexMatrix (m);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
275 type_tag = complex_matrix_constant;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
276 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
277 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
278 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
279
161
21b599370728 [project @ 1993-10-16 17:20:32 by jwe]
jwe
parents: 145
diff changeset
280 tree_constant_rep::tree_constant_rep (const ComplexColumnVector& v,
455
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
281 int prefer_column_vector)
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
282 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
283 int len = v.capacity ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
284 if (len == 1)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
285 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
286 complex_scalar = new Complex (v.elem (0));
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
287 type_tag = complex_scalar_constant;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
288 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
289 else
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
290 {
455
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
291 int pcv = (prefer_column_vector < 0)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
292 ? user_pref.prefer_column_vectors
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
293 : prefer_column_vector;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
294
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
295 if (pcv)
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
296 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
297 ComplexMatrix m (len, 1);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
298 for (int i = 0; i < len; i++)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
299 m.elem (i, 0) = v.elem (i);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
300 complex_matrix = new ComplexMatrix (m);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
301 type_tag = complex_matrix_constant;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
302 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
303 else
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
304 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
305 ComplexMatrix m (1, len);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
306 for (int i = 0; i < len; i++)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
307 m.elem (0, i) = v.elem (i);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
308 complex_matrix = new ComplexMatrix (m);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
309 type_tag = complex_matrix_constant;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
310 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
311 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
312 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
313
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
314 tree_constant_rep::tree_constant_rep (const char *s)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
315 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
316 string = strsave (s);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
317 type_tag = string_constant;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
318 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
319
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
320 tree_constant_rep::tree_constant_rep (double b, double l, double i)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
321 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
322 range = new Range (b, l, i);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
323 int nel = range->nelem ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
324 if (nel < 0)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
325 {
191
b6b4d8c513fe [project @ 1993-10-29 23:41:39 by jwe]
jwe
parents: 164
diff changeset
326 delete range;
b6b4d8c513fe [project @ 1993-10-29 23:41:39 by jwe]
jwe
parents: 164
diff changeset
327 type_tag = unknown_constant;
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
328 if (nel == -1)
240
a99f28f5e351 [project @ 1993-11-30 20:24:36 by jwe]
jwe
parents: 217
diff changeset
329 ::error ("number of elements in range exceeds INT_MAX");
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
330 else
240
a99f28f5e351 [project @ 1993-11-30 20:24:36 by jwe]
jwe
parents: 217
diff changeset
331 ::error ("invalid range");
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
332 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
333 else if (nel > 1)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
334 type_tag = range_constant;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
335 else
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
336 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
337 delete range;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
338 if (nel == 1)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
339 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
340 scalar = b;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
341 type_tag = scalar_constant;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
342 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
343 else if (nel == 0)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
344 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
345 matrix = new Matrix ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
346 type_tag = matrix_constant;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
347 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
348 else
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
349 panic_impossible ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
350 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
351 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
352
161
21b599370728 [project @ 1993-10-16 17:20:32 by jwe]
jwe
parents: 145
diff changeset
353 tree_constant_rep::tree_constant_rep (const Range& r)
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
354 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
355 if (r.nelem () > 1)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
356 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
357 range = new Range (r);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
358 type_tag = range_constant;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
359 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
360 else if (r.nelem () == 1)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
361 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
362 scalar = r.base ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
363 type_tag = scalar_constant;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
364 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
365 else if (r.nelem () == 0)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
366 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
367 matrix = new Matrix ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
368 type_tag = matrix_constant;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
369 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
370 else
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
371 panic_impossible ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
372 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
373
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
374 tree_constant_rep::tree_constant_rep (tree_constant_rep::constant_type t)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
375 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
376 assert (t == magic_colon);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
377
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
378 type_tag = magic_colon;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
379 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
380
161
21b599370728 [project @ 1993-10-16 17:20:32 by jwe]
jwe
parents: 145
diff changeset
381 tree_constant_rep::tree_constant_rep (const tree_constant_rep& t)
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
382 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
383 type_tag = t.type_tag;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
384
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
385 switch (t.type_tag)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
386 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
387 case unknown_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
388 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
389 case scalar_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
390 scalar = t.scalar;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
391 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
392 case matrix_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
393 matrix = new Matrix (*(t.matrix));
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
394 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
395 case string_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
396 string = strsave (t.string);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
397 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
398 case complex_matrix_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
399 complex_matrix = new ComplexMatrix (*(t.complex_matrix));
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
400 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
401 case complex_scalar_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
402 complex_scalar = new Complex (*(t.complex_scalar));
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
403 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
404 case range_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
405 range = new Range (*(t.range));
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
406 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
407 case magic_colon:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
408 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
409 default:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
410 panic_impossible ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
411 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
412 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
413 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
414
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
415 tree_constant_rep::~tree_constant_rep (void)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
416 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
417 switch (type_tag)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
418 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
419 case unknown_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
420 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
421 case scalar_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
422 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
423 case matrix_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
424 delete matrix;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
425 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
426 case complex_scalar_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
427 delete complex_scalar;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
428 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
429 case complex_matrix_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
430 delete complex_matrix;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
431 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
432 case string_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
433 delete [] string;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
434 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
435 case range_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
436 delete range;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
437 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
438 case magic_colon:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
439 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
440 default:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
441 panic_impossible ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
442 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
443 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
444 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
445
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
446 #if defined (MDEBUG)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
447 void *
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
448 tree_constant_rep::operator new (size_t size)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
449 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
450 tree_constant_rep *p = ::new tree_constant_rep;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
451 cerr << "tree_constant_rep::new(): " << p << "\n";
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
452 return p;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
453 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
454
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
455 void
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
456 tree_constant_rep::operator delete (void *p, size_t size)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
457 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
458 cerr << "tree_constant_rep::delete(): " << p << "\n";
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
459 ::delete p;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
460 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
461 #endif
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
462
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
463 void
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
464 tree_constant_rep::resize (int i, int j)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
465 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
466 switch (type_tag)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
467 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
468 case matrix_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
469 matrix->resize (i, j);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
470 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
471 case complex_matrix_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
472 complex_matrix->resize (i, j);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
473 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
474 default:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
475 panic_impossible ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
476 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
477 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
478 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
479
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
480 void
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
481 tree_constant_rep::resize (int i, int j, double val)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
482 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
483 switch (type_tag)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
484 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
485 case matrix_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
486 matrix->resize (i, j, val);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
487 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
488 case complex_matrix_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
489 complex_matrix->resize (i, j, val);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
490 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
491 default:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
492 panic_impossible ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
493 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
494 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
495 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
496
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
497 void
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
498 tree_constant_rep::maybe_resize (int i, int j)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
499 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
500 int nr = rows ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
501 int nc = columns ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
502
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
503 i++;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
504 j++;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
505
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
506 assert (i > 0 && j > 0);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
507
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
508 if (i > nr || j > nc)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
509 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
510 if (user_pref.resize_on_range_error)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
511 resize (MAX (i, nr), MAX (j, nc), 0.0);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
512 else
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
513 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
514 if (i > nr)
240
a99f28f5e351 [project @ 1993-11-30 20:24:36 by jwe]
jwe
parents: 217
diff changeset
515 ::error ("row index = %d exceeds max row dimension = %d", i, nr);
191
b6b4d8c513fe [project @ 1993-10-29 23:41:39 by jwe]
jwe
parents: 164
diff changeset
516
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
517 if (j > nc)
240
a99f28f5e351 [project @ 1993-11-30 20:24:36 by jwe]
jwe
parents: 217
diff changeset
518 ::error ("column index = %d exceeds max column dimension = %d",
a99f28f5e351 [project @ 1993-11-30 20:24:36 by jwe]
jwe
parents: 217
diff changeset
519 j, nc);
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
520 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
521 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
522 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
523
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
524 void
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
525 tree_constant_rep::maybe_resize (int i, force_orient f_orient = no_orient)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
526 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
527 int nr = rows ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
528 int nc = columns ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
529
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
530 i++;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
531
344
a7fd0923e4e4 [project @ 1994-02-08 05:52:11 by jwe]
jwe
parents: 330
diff changeset
532 assert (i >= 0 && (nr <= 1 || nc <= 1));
a7fd0923e4e4 [project @ 1994-02-08 05:52:11 by jwe]
jwe
parents: 330
diff changeset
533
a7fd0923e4e4 [project @ 1994-02-08 05:52:11 by jwe]
jwe
parents: 330
diff changeset
534 // This function never reduces the size of a vector, and all vectors
a7fd0923e4e4 [project @ 1994-02-08 05:52:11 by jwe]
jwe
parents: 330
diff changeset
535 // have dimensions of at least 0x0. If i is 0, it is either because
a7fd0923e4e4 [project @ 1994-02-08 05:52:11 by jwe]
jwe
parents: 330
diff changeset
536 // a vector has been indexed with a vector of all zeros (in which case
a7fd0923e4e4 [project @ 1994-02-08 05:52:11 by jwe]
jwe
parents: 330
diff changeset
537 // the index vector is empty and nothing will happen) or a vector has
a7fd0923e4e4 [project @ 1994-02-08 05:52:11 by jwe]
jwe
parents: 330
diff changeset
538 // been indexed with 0 (an error which will be caught elsewhere).
a7fd0923e4e4 [project @ 1994-02-08 05:52:11 by jwe]
jwe
parents: 330
diff changeset
539 if (i == 0)
a7fd0923e4e4 [project @ 1994-02-08 05:52:11 by jwe]
jwe
parents: 330
diff changeset
540 return;
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
541
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
542 if (nr <= 1 && nc <= 1 && i >= 1)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
543 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
544 if (user_pref.resize_on_range_error)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
545 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
546 if (f_orient == row_orient)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
547 resize (1, i, 0.0);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
548 else if (f_orient == column_orient)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
549 resize (i, 1, 0.0);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
550 else if (user_pref.prefer_column_vectors)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
551 resize (i, 1, 0.0);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
552 else
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
553 resize (1, i, 0.0);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
554 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
555 else
240
a99f28f5e351 [project @ 1993-11-30 20:24:36 by jwe]
jwe
parents: 217
diff changeset
556 ::error ("matrix index = %d exceeds max dimension = %d", i, nc);
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
557 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
558 else if (nr == 1 && i > nc)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
559 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
560 if (user_pref.resize_on_range_error)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
561 resize (1, i, 0.0);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
562 else
240
a99f28f5e351 [project @ 1993-11-30 20:24:36 by jwe]
jwe
parents: 217
diff changeset
563 ::error ("matrix index = %d exceeds max dimension = %d", i, nc);
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
564 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
565 else if (nc == 1 && i > nr)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
566 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
567 if (user_pref.resize_on_range_error)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
568 resize (i, 1, 0.0);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
569 else
240
a99f28f5e351 [project @ 1993-11-30 20:24:36 by jwe]
jwe
parents: 217
diff changeset
570 ::error ("matrix index = %d exceeds max dimension = ", i, nc);
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
571 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
572 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
573
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
574 double
164
e2c950dd96d2 [project @ 1993-10-18 19:32:00 by jwe]
jwe
parents: 161
diff changeset
575 tree_constant_rep::to_scalar (void) const
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
576 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
577 tree_constant tmp = make_numeric ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
578
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
579 double retval = 0.0;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
580
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
581 switch (tmp.const_type ())
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
582 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
583 case tree_constant_rep::scalar_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
584 case tree_constant_rep::complex_scalar_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
585 retval = tmp.double_value ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
586 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
587 case tree_constant_rep::matrix_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
588 if (user_pref.do_fortran_indexing)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
589 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
590 Matrix m = tmp.matrix_value ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
591 retval = m (0, 0);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
592 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
593 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
594 case tree_constant_rep::complex_matrix_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
595 if (user_pref.do_fortran_indexing)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
596 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
597 int flag = user_pref.ok_to_lose_imaginary_part;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
598 if (flag == -1)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
599 warning ("implicit conversion of complex value to real value");
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
600
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
601 if (flag != 0)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
602 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
603 ComplexMatrix m = tmp.complex_matrix_value ();
240
a99f28f5e351 [project @ 1993-11-30 20:24:36 by jwe]
jwe
parents: 217
diff changeset
604 return ::real (m (0, 0));
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
605 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
606 else
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
607 jump_to_top_level ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
608 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
609 else
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
610 {
240
a99f28f5e351 [project @ 1993-11-30 20:24:36 by jwe]
jwe
parents: 217
diff changeset
611 ::error ("complex matrix used in invalid context");
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
612 jump_to_top_level ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
613 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
614 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
615 default:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
616 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
617 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
618 return retval;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
619 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
620
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
621 ColumnVector
164
e2c950dd96d2 [project @ 1993-10-18 19:32:00 by jwe]
jwe
parents: 161
diff changeset
622 tree_constant_rep::to_vector (void) const
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
623 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
624 tree_constant tmp = make_numeric ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
625
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
626 ColumnVector retval;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
627
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
628 switch (tmp.const_type ())
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
629 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
630 case tree_constant_rep::scalar_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
631 case tree_constant_rep::complex_scalar_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
632 retval.resize (1);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
633 retval.elem (0) = tmp.double_value ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
634 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
635 case tree_constant_rep::complex_matrix_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
636 case tree_constant_rep::matrix_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
637 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
638 Matrix m = tmp.matrix_value ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
639 int nr = m.rows ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
640 int nc = m.columns ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
641 if (nr == 1)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
642 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
643 retval.resize (nc);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
644 for (int i = 0; i < nc; i++)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
645 retval.elem (i) = m (0, i);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
646 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
647 else if (nc == 1)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
648 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
649 retval.resize (nr);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
650 for (int i = 0; i < nr; i++)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
651 retval.elem (i) = m.elem (i, 0);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
652 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
653 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
654 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
655 default:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
656 panic_impossible ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
657 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
658 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
659 return retval;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
660 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
661
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
662 Matrix
164
e2c950dd96d2 [project @ 1993-10-18 19:32:00 by jwe]
jwe
parents: 161
diff changeset
663 tree_constant_rep::to_matrix (void) const
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
664 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
665 tree_constant tmp = make_numeric ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
666
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
667 Matrix retval;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
668
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
669 switch (tmp.const_type ())
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
670 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
671 case tree_constant_rep::scalar_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
672 retval.resize (1, 1);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
673 retval.elem (0, 0) = tmp.double_value ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
674 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
675 case tree_constant_rep::matrix_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
676 retval = tmp.matrix_value ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
677 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
678 default:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
679 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
680 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
681 return retval;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
682 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
683
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
684 tree_constant_rep::constant_type
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
685 tree_constant_rep::force_numeric (int force_str_conv = 0)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
686 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
687 switch (type_tag)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
688 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
689 case scalar_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
690 case matrix_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
691 case complex_scalar_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
692 case complex_matrix_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
693 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
694 case string_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
695 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
696 if (! force_str_conv && ! user_pref.implicit_str_to_num_ok)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
697 {
240
a99f28f5e351 [project @ 1993-11-30 20:24:36 by jwe]
jwe
parents: 217
diff changeset
698 ::error ("failed to convert `%s' to a numeric type --", string);
a99f28f5e351 [project @ 1993-11-30 20:24:36 by jwe]
jwe
parents: 217
diff changeset
699 ::error ("default conversion turned off");
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
700 // Abort!
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
701 jump_to_top_level ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
702 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
703
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
704 int len = strlen (string);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
705 if (len > 1)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
706 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
707 type_tag = matrix_constant;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
708 Matrix *tm = new Matrix (1, len);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
709 for (int i = 0; i < len; i++)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
710 tm->elem (0, i) = toascii ((int) string[i]);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
711 matrix = tm;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
712 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
713 else if (len == 1)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
714 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
715 type_tag = scalar_constant;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
716 scalar = toascii ((int) string[0]);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
717 }
240
a99f28f5e351 [project @ 1993-11-30 20:24:36 by jwe]
jwe
parents: 217
diff changeset
718 else if (len == 0)
a99f28f5e351 [project @ 1993-11-30 20:24:36 by jwe]
jwe
parents: 217
diff changeset
719 {
a99f28f5e351 [project @ 1993-11-30 20:24:36 by jwe]
jwe
parents: 217
diff changeset
720 type_tag = matrix_constant;
a99f28f5e351 [project @ 1993-11-30 20:24:36 by jwe]
jwe
parents: 217
diff changeset
721 matrix = new Matrix (0, 0);
a99f28f5e351 [project @ 1993-11-30 20:24:36 by jwe]
jwe
parents: 217
diff changeset
722 }
a99f28f5e351 [project @ 1993-11-30 20:24:36 by jwe]
jwe
parents: 217
diff changeset
723 else
a99f28f5e351 [project @ 1993-11-30 20:24:36 by jwe]
jwe
parents: 217
diff changeset
724 panic_impossible ();
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
725 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
726 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
727 case range_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
728 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
729 int len = range->nelem ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
730 if (len > 1)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
731 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
732 type_tag = matrix_constant;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
733 Matrix *tm = new Matrix (1, len);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
734 double b = range->base ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
735 double increment = range->inc ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
736 for (int i = 0; i < len; i++)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
737 tm->elem (0, i) = b + i * increment;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
738 matrix = tm;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
739 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
740 else if (len == 1)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
741 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
742 type_tag = scalar_constant;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
743 scalar = range->base ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
744 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
745 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
746 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
747 case magic_colon:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
748 default:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
749 panic_impossible ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
750 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
751 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
752 return type_tag;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
753 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
754
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
755 tree_constant
164
e2c950dd96d2 [project @ 1993-10-18 19:32:00 by jwe]
jwe
parents: 161
diff changeset
756 tree_constant_rep::make_numeric (int force_str_conv = 0) const
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
757 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
758 tree_constant retval;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
759 switch (type_tag)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
760 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
761 case scalar_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
762 retval = tree_constant (scalar);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
763 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
764 case matrix_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
765 retval = tree_constant (*matrix);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
766 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
767 case complex_scalar_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
768 retval = tree_constant (*complex_scalar);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
769 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
770 case complex_matrix_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
771 retval = tree_constant (*complex_matrix);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
772 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
773 case string_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
774 retval = tree_constant (string);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
775 retval.force_numeric (force_str_conv);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
776 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
777 case range_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
778 retval = tree_constant (*range);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
779 retval.force_numeric (force_str_conv);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
780 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
781 case magic_colon:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
782 default:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
783 panic_impossible ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
784 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
785 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
786 return retval;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
787 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
788
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
789 tree_constant
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
790 do_binary_op (tree_constant& a, tree_constant& b, tree::expression_type t)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
791 {
143
7849db4b6dbc [project @ 1993-10-04 02:36:45 by jwe]
jwe
parents: 105
diff changeset
792 tree_constant ans;
7849db4b6dbc [project @ 1993-10-04 02:36:45 by jwe]
jwe
parents: 105
diff changeset
793
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
794 int first_empty = (a.rows () == 0 || a.columns () == 0);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
795 int second_empty = (b.rows () == 0 || b.columns () == 0);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
796
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
797 if (first_empty || second_empty)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
798 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
799 int flag = user_pref.propagate_empty_matrices;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
800 if (flag < 0)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
801 warning ("binary operation on empty matrix");
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
802 else if (flag == 0)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
803 {
240
a99f28f5e351 [project @ 1993-11-30 20:24:36 by jwe]
jwe
parents: 217
diff changeset
804 ::error ("invalid binary operation on empty matrix");
143
7849db4b6dbc [project @ 1993-10-04 02:36:45 by jwe]
jwe
parents: 105
diff changeset
805 return ans;
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
806 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
807 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
808
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
809 tree_constant tmp_a = a.make_numeric ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
810 tree_constant tmp_b = b.make_numeric ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
811
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
812 tree_constant_rep::constant_type a_type = tmp_a.const_type ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
813 tree_constant_rep::constant_type b_type = tmp_b.const_type ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
814
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
815 double d1, d2;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
816 Matrix m1, m2;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
817 Complex c1, c2;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
818 ComplexMatrix cm1, cm2;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
819
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
820 switch (a_type)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
821 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
822 case tree_constant_rep::scalar_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
823 d1 = tmp_a.double_value ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
824 switch (b_type)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
825 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
826 case tree_constant_rep::scalar_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
827 d2 = tmp_b.double_value ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
828 ans = do_binary_op (d1, d2, t);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
829 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
830 case tree_constant_rep::matrix_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
831 m2 = tmp_b.matrix_value ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
832 ans = do_binary_op (d1, m2, t);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
833 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
834 case tree_constant_rep::complex_scalar_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
835 c2 = tmp_b.complex_value ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
836 ans = do_binary_op (d1, c2, t);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
837 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
838 case tree_constant_rep::complex_matrix_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
839 cm2 = tmp_b.complex_matrix_value ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
840 ans = do_binary_op (d1, cm2, t);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
841 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
842 case tree_constant_rep::magic_colon:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
843 default:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
844 panic_impossible ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
845 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
846 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
847 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
848 case tree_constant_rep::matrix_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
849 m1 = tmp_a.matrix_value ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
850 switch (b_type)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
851 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
852 case tree_constant_rep::scalar_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
853 d2 = tmp_b.double_value ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
854 ans = do_binary_op (m1, d2, t);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
855 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
856 case tree_constant_rep::matrix_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
857 m2 = tmp_b.matrix_value ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
858 ans = do_binary_op (m1, m2, t);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
859 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
860 case tree_constant_rep::complex_scalar_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
861 c2 = tmp_b.complex_value ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
862 ans = do_binary_op (m1, c2, t);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
863 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
864 case tree_constant_rep::complex_matrix_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
865 cm2 = tmp_b.complex_matrix_value ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
866 ans = do_binary_op (m1, cm2, t);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
867 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
868 case tree_constant_rep::magic_colon:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
869 default:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
870 panic_impossible ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
871 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
872 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
873 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
874 case tree_constant_rep::complex_scalar_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
875 c1 = tmp_a.complex_value ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
876 switch (b_type)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
877 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
878 case tree_constant_rep::scalar_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
879 d2 = tmp_b.double_value ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
880 ans = do_binary_op (c1, d2, t);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
881 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
882 case tree_constant_rep::matrix_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
883 m2 = tmp_b.matrix_value ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
884 ans = do_binary_op (c1, m2, t);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
885 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
886 case tree_constant_rep::complex_scalar_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
887 c2 = tmp_b.complex_value ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
888 ans = do_binary_op (c1, c2, t);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
889 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
890 case tree_constant_rep::complex_matrix_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
891 cm2 = tmp_b.complex_matrix_value ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
892 ans = do_binary_op (c1, cm2, t);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
893 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
894 case tree_constant_rep::magic_colon:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
895 default:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
896 panic_impossible ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
897 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
898 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
899 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
900 case tree_constant_rep::complex_matrix_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
901 cm1 = tmp_a.complex_matrix_value ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
902 switch (b_type)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
903 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
904 case tree_constant_rep::scalar_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
905 d2 = tmp_b.double_value ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
906 ans = do_binary_op (cm1, d2, t);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
907 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
908 case tree_constant_rep::matrix_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
909 m2 = tmp_b.matrix_value ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
910 ans = do_binary_op (cm1, m2, t);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
911 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
912 case tree_constant_rep::complex_scalar_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
913 c2 = tmp_b.complex_value ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
914 ans = do_binary_op (cm1, c2, t);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
915 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
916 case tree_constant_rep::complex_matrix_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
917 cm2 = tmp_b.complex_matrix_value ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
918 ans = do_binary_op (cm1, cm2, t);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
919 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
920 case tree_constant_rep::magic_colon:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
921 default:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
922 panic_impossible ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
923 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
924 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
925 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
926 case tree_constant_rep::magic_colon:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
927 default:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
928 panic_impossible ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
929 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
930 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
931 return ans;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
932 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
933
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
934 tree_constant
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
935 do_unary_op (tree_constant& a, tree::expression_type t)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
936 {
143
7849db4b6dbc [project @ 1993-10-04 02:36:45 by jwe]
jwe
parents: 105
diff changeset
937 tree_constant ans;
7849db4b6dbc [project @ 1993-10-04 02:36:45 by jwe]
jwe
parents: 105
diff changeset
938
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
939 if (a.rows () == 0 || a.columns () == 0)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
940 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
941 int flag = user_pref.propagate_empty_matrices;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
942 if (flag < 0)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
943 warning ("unary operation on empty matrix");
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
944 else if (flag == 0)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
945 {
240
a99f28f5e351 [project @ 1993-11-30 20:24:36 by jwe]
jwe
parents: 217
diff changeset
946 ::error ("invalid unary operation on empty matrix");
143
7849db4b6dbc [project @ 1993-10-04 02:36:45 by jwe]
jwe
parents: 105
diff changeset
947 return ans;
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
948 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
949 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
950
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
951 tree_constant tmp_a = a.make_numeric ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
952
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
953 switch (tmp_a.const_type ())
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
954 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
955 case tree_constant_rep::scalar_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
956 ans = do_unary_op (tmp_a.double_value (), t);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
957 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
958 case tree_constant_rep::matrix_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
959 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
960 Matrix m = tmp_a.matrix_value ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
961 ans = do_unary_op (m, t);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
962 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
963 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
964 case tree_constant_rep::complex_scalar_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
965 ans = do_unary_op (tmp_a.complex_value (), t);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
966 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
967 case tree_constant_rep::complex_matrix_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
968 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
969 ComplexMatrix m = tmp_a.complex_matrix_value ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
970 ans = do_unary_op (m, t);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
971 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
972 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
973 case tree_constant_rep::magic_colon:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
974 default:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
975 panic_impossible ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
976 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
977 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
978 return ans;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
979 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
980
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
981 void
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
982 tree_constant_rep::bump_value (tree::expression_type etype)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
983 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
984 switch (etype)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
985 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
986 case tree::increment:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
987 switch (type_tag)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
988 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
989 case scalar_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
990 scalar++;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
991 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
992 case matrix_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
993 *matrix = *matrix + 1.0;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
994 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
995 case complex_scalar_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
996 *complex_scalar = *complex_scalar + 1.0;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
997 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
998 case complex_matrix_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
999 *complex_matrix = *complex_matrix + 1.0;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1000 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1001 case string_constant:
240
a99f28f5e351 [project @ 1993-11-30 20:24:36 by jwe]
jwe
parents: 217
diff changeset
1002 ::error ("string++ and ++string not implemented yet, ok?");
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1003 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1004 case range_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1005 range->set_base (range->base () + 1.0);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1006 range->set_limit (range->limit () + 1.0);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1007 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1008 case magic_colon:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1009 default:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1010 panic_impossible ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1011 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1012 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1013 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1014 case tree::decrement:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1015 switch (type_tag)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1016 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1017 case scalar_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1018 scalar--;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1019 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1020 case matrix_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1021 *matrix = *matrix - 1.0;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1022 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1023 case string_constant:
240
a99f28f5e351 [project @ 1993-11-30 20:24:36 by jwe]
jwe
parents: 217
diff changeset
1024 ::error ("string-- and -- string not implemented yet, ok?");
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1025 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1026 case range_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1027 range->set_base (range->base () - 1.0);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1028 range->set_limit (range->limit () - 1.0);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1029 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1030 case magic_colon:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1031 default:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1032 panic_impossible ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1033 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1034 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1035 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1036 default:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1037 panic_impossible ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1038 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1039 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1040 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1041
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1042 void
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1043 tree_constant_rep::eval (int print)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1044 {
143
7849db4b6dbc [project @ 1993-10-04 02:36:45 by jwe]
jwe
parents: 105
diff changeset
1045 if (error_state)
7849db4b6dbc [project @ 1993-10-04 02:36:45 by jwe]
jwe
parents: 105
diff changeset
1046 return;
7849db4b6dbc [project @ 1993-10-04 02:36:45 by jwe]
jwe
parents: 105
diff changeset
1047
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1048 switch (type_tag)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1049 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1050 case complex_scalar_constant:
240
a99f28f5e351 [project @ 1993-11-30 20:24:36 by jwe]
jwe
parents: 217
diff changeset
1051 if (::imag (*complex_scalar) == 0.0)
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1052 {
240
a99f28f5e351 [project @ 1993-11-30 20:24:36 by jwe]
jwe
parents: 217
diff changeset
1053 double d = ::real (*complex_scalar);
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1054 delete complex_scalar;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1055 scalar = d;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1056 type_tag = scalar_constant;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1057 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1058 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1059 case complex_matrix_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1060 if (! any_element_is_complex (*complex_matrix))
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1061 {
240
a99f28f5e351 [project @ 1993-11-30 20:24:36 by jwe]
jwe
parents: 217
diff changeset
1062 Matrix *m = new Matrix (::real (*complex_matrix));
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1063 delete complex_matrix;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1064 matrix = m;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1065 type_tag = matrix_constant;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1066 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1067 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1068 case scalar_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1069 case matrix_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1070 case string_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1071 case range_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1072 case magic_colon:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1073 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1074 default:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1075 panic_impossible ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1076 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1077 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1078
145
6beb84c3320e [project @ 1993-10-04 08:06:10 by jwe]
jwe
parents: 143
diff changeset
1079 // Avoid calling rows() and columns() for things like magic_colon.
143
7849db4b6dbc [project @ 1993-10-04 02:36:45 by jwe]
jwe
parents: 105
diff changeset
1080
145
6beb84c3320e [project @ 1993-10-04 08:06:10 by jwe]
jwe
parents: 143
diff changeset
1081 int nr = 1;
6beb84c3320e [project @ 1993-10-04 08:06:10 by jwe]
jwe
parents: 143
diff changeset
1082 int nc = 1;
6beb84c3320e [project @ 1993-10-04 08:06:10 by jwe]
jwe
parents: 143
diff changeset
1083 if (type_tag == matrix_constant
6beb84c3320e [project @ 1993-10-04 08:06:10 by jwe]
jwe
parents: 143
diff changeset
1084 || type_tag == complex_matrix_constant
6beb84c3320e [project @ 1993-10-04 08:06:10 by jwe]
jwe
parents: 143
diff changeset
1085 || type_tag == range_constant)
143
7849db4b6dbc [project @ 1993-10-04 02:36:45 by jwe]
jwe
parents: 105
diff changeset
1086 {
145
6beb84c3320e [project @ 1993-10-04 08:06:10 by jwe]
jwe
parents: 143
diff changeset
1087 nr = rows ();
6beb84c3320e [project @ 1993-10-04 08:06:10 by jwe]
jwe
parents: 143
diff changeset
1088 nc = columns ();
6beb84c3320e [project @ 1993-10-04 08:06:10 by jwe]
jwe
parents: 143
diff changeset
1089 }
6beb84c3320e [project @ 1993-10-04 08:06:10 by jwe]
jwe
parents: 143
diff changeset
1090
6beb84c3320e [project @ 1993-10-04 08:06:10 by jwe]
jwe
parents: 143
diff changeset
1091 switch (type_tag)
6beb84c3320e [project @ 1993-10-04 08:06:10 by jwe]
jwe
parents: 143
diff changeset
1092 {
6beb84c3320e [project @ 1993-10-04 08:06:10 by jwe]
jwe
parents: 143
diff changeset
1093 case matrix_constant:
6beb84c3320e [project @ 1993-10-04 08:06:10 by jwe]
jwe
parents: 143
diff changeset
1094 if (nr == 1 && nc == 1)
143
7849db4b6dbc [project @ 1993-10-04 02:36:45 by jwe]
jwe
parents: 105
diff changeset
1095 {
145
6beb84c3320e [project @ 1993-10-04 08:06:10 by jwe]
jwe
parents: 143
diff changeset
1096 double d = matrix->elem (0, 0);
6beb84c3320e [project @ 1993-10-04 08:06:10 by jwe]
jwe
parents: 143
diff changeset
1097 delete matrix;
6beb84c3320e [project @ 1993-10-04 08:06:10 by jwe]
jwe
parents: 143
diff changeset
1098 scalar = d;
6beb84c3320e [project @ 1993-10-04 08:06:10 by jwe]
jwe
parents: 143
diff changeset
1099 type_tag = scalar_constant;
143
7849db4b6dbc [project @ 1993-10-04 02:36:45 by jwe]
jwe
parents: 105
diff changeset
1100 }
145
6beb84c3320e [project @ 1993-10-04 08:06:10 by jwe]
jwe
parents: 143
diff changeset
1101 break;
6beb84c3320e [project @ 1993-10-04 08:06:10 by jwe]
jwe
parents: 143
diff changeset
1102 case complex_matrix_constant:
6beb84c3320e [project @ 1993-10-04 08:06:10 by jwe]
jwe
parents: 143
diff changeset
1103 if (nr == 1 && nc == 1)
6beb84c3320e [project @ 1993-10-04 08:06:10 by jwe]
jwe
parents: 143
diff changeset
1104 {
6beb84c3320e [project @ 1993-10-04 08:06:10 by jwe]
jwe
parents: 143
diff changeset
1105 Complex c = complex_matrix->elem (0, 0);
6beb84c3320e [project @ 1993-10-04 08:06:10 by jwe]
jwe
parents: 143
diff changeset
1106 delete complex_matrix;
6beb84c3320e [project @ 1993-10-04 08:06:10 by jwe]
jwe
parents: 143
diff changeset
1107 complex_scalar = new Complex (c);
6beb84c3320e [project @ 1993-10-04 08:06:10 by jwe]
jwe
parents: 143
diff changeset
1108 type_tag = complex_scalar_constant;
6beb84c3320e [project @ 1993-10-04 08:06:10 by jwe]
jwe
parents: 143
diff changeset
1109 }
6beb84c3320e [project @ 1993-10-04 08:06:10 by jwe]
jwe
parents: 143
diff changeset
1110 break;
6beb84c3320e [project @ 1993-10-04 08:06:10 by jwe]
jwe
parents: 143
diff changeset
1111 case range_constant:
6beb84c3320e [project @ 1993-10-04 08:06:10 by jwe]
jwe
parents: 143
diff changeset
1112 if (nr == 1 && nc == 1)
6beb84c3320e [project @ 1993-10-04 08:06:10 by jwe]
jwe
parents: 143
diff changeset
1113 {
6beb84c3320e [project @ 1993-10-04 08:06:10 by jwe]
jwe
parents: 143
diff changeset
1114 double d = range->base ();
6beb84c3320e [project @ 1993-10-04 08:06:10 by jwe]
jwe
parents: 143
diff changeset
1115 delete range;
6beb84c3320e [project @ 1993-10-04 08:06:10 by jwe]
jwe
parents: 143
diff changeset
1116 scalar = d;
6beb84c3320e [project @ 1993-10-04 08:06:10 by jwe]
jwe
parents: 143
diff changeset
1117 type_tag = scalar_constant;
6beb84c3320e [project @ 1993-10-04 08:06:10 by jwe]
jwe
parents: 143
diff changeset
1118 }
6beb84c3320e [project @ 1993-10-04 08:06:10 by jwe]
jwe
parents: 143
diff changeset
1119 break;
6beb84c3320e [project @ 1993-10-04 08:06:10 by jwe]
jwe
parents: 143
diff changeset
1120 default:
6beb84c3320e [project @ 1993-10-04 08:06:10 by jwe]
jwe
parents: 143
diff changeset
1121 break;
143
7849db4b6dbc [project @ 1993-10-04 02:36:45 by jwe]
jwe
parents: 105
diff changeset
1122 }
7849db4b6dbc [project @ 1993-10-04 02:36:45 by jwe]
jwe
parents: 105
diff changeset
1123
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1124 if (print)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1125 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1126 ostrstream output_buf;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1127 switch (type_tag)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1128 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1129 case scalar_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1130 octave_print_internal (output_buf, scalar);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1131 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1132 case matrix_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1133 if (nr == 0 || nc == 0)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1134 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1135 output_buf << "[]";
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1136 if (user_pref.print_empty_dimensions)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1137 output_buf << "(" << nr << "x" << nc << ")";
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1138 output_buf << "\n";
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1139 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1140 else
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1141 octave_print_internal (output_buf, *matrix);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1142 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1143 case complex_scalar_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1144 octave_print_internal (output_buf, *complex_scalar);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1145 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1146 case complex_matrix_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1147 if (nr == 0 || nc == 0)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1148 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1149 output_buf << "[]";
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1150 if (user_pref.print_empty_dimensions)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1151 output_buf << "(" << nr << "x" << nc << ")";
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1152 output_buf << "\n";
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1153 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1154 else
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1155 octave_print_internal (output_buf, *complex_matrix);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1156 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1157 case string_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1158 output_buf << string << "\n";
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1159 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1160 case range_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1161 octave_print_internal (output_buf, *range);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1162 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1163 case magic_colon:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1164 default:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1165 panic_impossible ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1166 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1167 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1168
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1169 output_buf << ends;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1170 maybe_page_output (output_buf);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1171 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1172 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1173
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1174 tree_constant *
164
e2c950dd96d2 [project @ 1993-10-18 19:32:00 by jwe]
jwe
parents: 161
diff changeset
1175 tree_constant_rep::eval (const tree_constant *args, int nargin, int nargout,
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1176 int print)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1177 {
143
7849db4b6dbc [project @ 1993-10-04 02:36:45 by jwe]
jwe
parents: 105
diff changeset
1178 if (error_state)
7849db4b6dbc [project @ 1993-10-04 02:36:45 by jwe]
jwe
parents: 105
diff changeset
1179 return NULL_TREE_CONST;
7849db4b6dbc [project @ 1993-10-04 02:36:45 by jwe]
jwe
parents: 105
diff changeset
1180
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1181 tree_constant *retval = new tree_constant [2];
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1182 switch (type_tag)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1183 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1184 case complex_scalar_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1185 case scalar_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1186 retval[0] = do_scalar_index (args, nargin);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1187 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1188 case complex_matrix_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1189 case matrix_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1190 retval[0] = do_matrix_index (args, nargin);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1191 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1192 case string_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1193 gripe_string_invalid ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1194 // retval[0] = do_string_index (args, nargin);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1195 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1196 case magic_colon:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1197 case range_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1198 // This isn\'t great, but it\'s easier than implementing a lot of
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1199 // range indexing functions.
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1200 force_numeric ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1201 assert (type_tag != magic_colon && type_tag != range_constant);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1202 return eval (args, nargin, nargout, print);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1203 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1204 default:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1205 panic_impossible ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1206 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1207 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1208
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1209 if (retval[0].is_defined ())
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1210 retval[0].eval (print);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1211 return retval;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1212 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1213
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1214 int
276
4cf3c7df0e3d [project @ 1994-01-07 02:05:57 by jwe]
jwe
parents: 259
diff changeset
1215 tree_constant_rep::save (ostream& os, int mark_as_global, int precision)
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1216 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1217 switch (type_tag)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1218 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1219 case scalar_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1220 case matrix_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1221 case complex_scalar_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1222 case complex_matrix_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1223 case string_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1224 case range_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1225 if (mark_as_global)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1226 os << "# type: global ";
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1227 else
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1228 os << "# type: ";
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1229 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1230 case magic_colon:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1231 default:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1232 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1233 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1234
276
4cf3c7df0e3d [project @ 1994-01-07 02:05:57 by jwe]
jwe
parents: 259
diff changeset
1235 long old_precision = os.precision ();
4cf3c7df0e3d [project @ 1994-01-07 02:05:57 by jwe]
jwe
parents: 259
diff changeset
1236 os.precision (precision);
4cf3c7df0e3d [project @ 1994-01-07 02:05:57 by jwe]
jwe
parents: 259
diff changeset
1237
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1238 switch (type_tag)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1239 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1240 case scalar_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1241 os << "scalar\n"
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1242 << scalar << "\n";
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1243 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1244 case matrix_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1245 os << "matrix\n"
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1246 << "# rows: " << rows () << "\n"
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1247 << "# columns: " << columns () << "\n"
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1248 << *matrix ;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1249 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1250 case complex_scalar_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1251 os << "complex scalar\n"
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1252 << *complex_scalar << "\n";
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1253 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1254 case complex_matrix_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1255 os << "complex matrix\n"
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1256 << "# rows: " << rows () << "\n"
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1257 << "# columns: " << columns () << "\n"
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1258 << *complex_matrix ;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1259 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1260 case string_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1261 os << "string\n"
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1262 << "# length: " << strlen (string) << "\n"
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1263 << string << "\n";
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1264 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1265 case range_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1266 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1267 os << "range\n"
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1268 << "# base, limit, increment\n"
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1269 << range->base () << " "
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1270 << range->limit () << " "
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1271 << range->inc () << "\n";
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1272 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1273 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1274 case magic_colon:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1275 default:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1276 panic_impossible ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1277 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1278 }
276
4cf3c7df0e3d [project @ 1994-01-07 02:05:57 by jwe]
jwe
parents: 259
diff changeset
1279
4cf3c7df0e3d [project @ 1994-01-07 02:05:57 by jwe]
jwe
parents: 259
diff changeset
1280 os.precision (old_precision);
4cf3c7df0e3d [project @ 1994-01-07 02:05:57 by jwe]
jwe
parents: 259
diff changeset
1281
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1282 // Really want to return 1 only if write is successful.
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1283 return 1;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1284 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1285
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1286 int
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1287 tree_constant_rep::save_three_d (ostream& os, int parametric)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1288 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1289 int nr = rows ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1290 int nc = columns ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1291
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1292 switch (type_tag)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1293 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1294 case matrix_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1295 os << "# 3D data...\n"
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1296 << "# type: matrix\n"
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1297 << "# total rows: " << nr << "\n"
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1298 << "# total columns: " << nc << "\n";
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1299
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1300 if (parametric)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1301 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1302 int extras = nc % 3;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1303 if (extras)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1304 warning ("ignoring last %d columns", extras);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1305
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1306 for (int i = 0; i < nc-extras; i += 3)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1307 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1308 os << matrix->extract (0, i, nr-1, i+2);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1309 if (i+3 < nc-extras)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1310 os << "\n";
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1311 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1312 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1313 else
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1314 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1315 for (int i = 0; i < nc; i++)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1316 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1317 os << matrix->extract (0, i, nr-1, i);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1318 if (i+1 < nc)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1319 os << "\n";
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1320 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1321 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1322 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1323 default:
240
a99f28f5e351 [project @ 1993-11-30 20:24:36 by jwe]
jwe
parents: 217
diff changeset
1324 ::error ("for now, I can only save real matrices in 3D format");
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1325 return 0;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1326 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1327 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1328 // Really want to return 1 only if write is successful.
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1329 return 1;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1330 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1331
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1332 int
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1333 tree_constant_rep::load (istream& is)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1334 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1335 int is_global = 0;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1336
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1337 type_tag = unknown_constant;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1338
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1339 // Look for type keyword
279
c64f870ac8d9 [project @ 1994-01-08 22:51:53 by jwe]
jwe
parents: 276
diff changeset
1340
c64f870ac8d9 [project @ 1994-01-08 22:51:53 by jwe]
jwe
parents: 276
diff changeset
1341 char *tag = extract_keyword (is, "type");
c64f870ac8d9 [project @ 1994-01-08 22:51:53 by jwe]
jwe
parents: 276
diff changeset
1342
c64f870ac8d9 [project @ 1994-01-08 22:51:53 by jwe]
jwe
parents: 276
diff changeset
1343 if (tag != (char *) NULL && *tag != '\0')
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1344 {
279
c64f870ac8d9 [project @ 1994-01-08 22:51:53 by jwe]
jwe
parents: 276
diff changeset
1345 char *ptr = strchr (tag, ' ');
c64f870ac8d9 [project @ 1994-01-08 22:51:53 by jwe]
jwe
parents: 276
diff changeset
1346 if (ptr != (char *) NULL)
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1347 {
279
c64f870ac8d9 [project @ 1994-01-08 22:51:53 by jwe]
jwe
parents: 276
diff changeset
1348 *ptr = '\0';
c64f870ac8d9 [project @ 1994-01-08 22:51:53 by jwe]
jwe
parents: 276
diff changeset
1349 is_global = (strncmp (tag, "global", 6) == 0);
c64f870ac8d9 [project @ 1994-01-08 22:51:53 by jwe]
jwe
parents: 276
diff changeset
1350 *ptr = ' ';
394
27ef550be39e [project @ 1994-03-24 09:19:09 by jwe]
jwe
parents: 344
diff changeset
1351 if (is_global)
27ef550be39e [project @ 1994-03-24 09:19:09 by jwe]
jwe
parents: 344
diff changeset
1352 ptr++;
27ef550be39e [project @ 1994-03-24 09:19:09 by jwe]
jwe
parents: 344
diff changeset
1353 else
27ef550be39e [project @ 1994-03-24 09:19:09 by jwe]
jwe
parents: 344
diff changeset
1354 ptr = tag;
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1355 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1356 else
394
27ef550be39e [project @ 1994-03-24 09:19:09 by jwe]
jwe
parents: 344
diff changeset
1357 ptr = tag;
279
c64f870ac8d9 [project @ 1994-01-08 22:51:53 by jwe]
jwe
parents: 276
diff changeset
1358
c64f870ac8d9 [project @ 1994-01-08 22:51:53 by jwe]
jwe
parents: 276
diff changeset
1359 if (strncmp (ptr, "scalar", 6) == 0)
c64f870ac8d9 [project @ 1994-01-08 22:51:53 by jwe]
jwe
parents: 276
diff changeset
1360 type_tag = load (is, scalar_constant);
c64f870ac8d9 [project @ 1994-01-08 22:51:53 by jwe]
jwe
parents: 276
diff changeset
1361 else if (strncmp (ptr, "matrix", 6) == 0)
c64f870ac8d9 [project @ 1994-01-08 22:51:53 by jwe]
jwe
parents: 276
diff changeset
1362 type_tag = load (is, matrix_constant);
c64f870ac8d9 [project @ 1994-01-08 22:51:53 by jwe]
jwe
parents: 276
diff changeset
1363 else if (strncmp (ptr, "complex scalar", 14) == 0)
c64f870ac8d9 [project @ 1994-01-08 22:51:53 by jwe]
jwe
parents: 276
diff changeset
1364 type_tag = load (is, complex_scalar_constant);
c64f870ac8d9 [project @ 1994-01-08 22:51:53 by jwe]
jwe
parents: 276
diff changeset
1365 else if (strncmp (ptr, "complex matrix", 14) == 0)
c64f870ac8d9 [project @ 1994-01-08 22:51:53 by jwe]
jwe
parents: 276
diff changeset
1366 type_tag = load (is, complex_matrix_constant);
c64f870ac8d9 [project @ 1994-01-08 22:51:53 by jwe]
jwe
parents: 276
diff changeset
1367 else if (strncmp (ptr, "string", 6) == 0)
c64f870ac8d9 [project @ 1994-01-08 22:51:53 by jwe]
jwe
parents: 276
diff changeset
1368 type_tag = load (is, string_constant);
c64f870ac8d9 [project @ 1994-01-08 22:51:53 by jwe]
jwe
parents: 276
diff changeset
1369 else if (strncmp (ptr, "range", 5) == 0)
c64f870ac8d9 [project @ 1994-01-08 22:51:53 by jwe]
jwe
parents: 276
diff changeset
1370 type_tag = load (is, range_constant);
c64f870ac8d9 [project @ 1994-01-08 22:51:53 by jwe]
jwe
parents: 276
diff changeset
1371 else
c64f870ac8d9 [project @ 1994-01-08 22:51:53 by jwe]
jwe
parents: 276
diff changeset
1372 ::error ("unknown constant type `%s'", tag);
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1373 }
279
c64f870ac8d9 [project @ 1994-01-08 22:51:53 by jwe]
jwe
parents: 276
diff changeset
1374 else
c64f870ac8d9 [project @ 1994-01-08 22:51:53 by jwe]
jwe
parents: 276
diff changeset
1375 ::error ("failed to extract keyword specifying value type");
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1376
312
069ae2896cf7 [project @ 1994-01-19 21:40:41 by jwe]
jwe
parents: 296
diff changeset
1377 delete [] tag;
069ae2896cf7 [project @ 1994-01-19 21:40:41 by jwe]
jwe
parents: 296
diff changeset
1378
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1379 return is_global;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1380 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1381
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1382 tree_constant_rep::constant_type
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1383 tree_constant_rep::load (istream& is, tree_constant_rep::constant_type t)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1384 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1385 tree_constant_rep::constant_type status = unknown_constant;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1386
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1387 switch (t)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1388 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1389 case scalar_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1390 is >> scalar;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1391 if (is)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1392 status = scalar_constant;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1393 else
240
a99f28f5e351 [project @ 1993-11-30 20:24:36 by jwe]
jwe
parents: 217
diff changeset
1394 ::error ("failed to load scalar constant");
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1395 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1396 case matrix_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1397 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1398 int nr = 0, nc = 0;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1399
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1400 if (extract_keyword (is, "rows", nr) && nr > 0
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1401 && extract_keyword (is, "columns", nc) && nc > 0)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1402 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1403 matrix = new Matrix (nr, nc);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1404 is >> *matrix;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1405 if (is)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1406 status = matrix_constant;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1407 else
240
a99f28f5e351 [project @ 1993-11-30 20:24:36 by jwe]
jwe
parents: 217
diff changeset
1408 ::error ("failed to load matrix constant");
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1409 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1410 else
240
a99f28f5e351 [project @ 1993-11-30 20:24:36 by jwe]
jwe
parents: 217
diff changeset
1411 ::error ("failed to extract number of rows and columns");
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1412 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1413 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1414 case complex_scalar_constant:
394
27ef550be39e [project @ 1994-03-24 09:19:09 by jwe]
jwe
parents: 344
diff changeset
1415 complex_scalar = new Complex;
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1416 is >> *complex_scalar;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1417 if (is)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1418 status = complex_scalar_constant;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1419 else
240
a99f28f5e351 [project @ 1993-11-30 20:24:36 by jwe]
jwe
parents: 217
diff changeset
1420 ::error ("failed to load complex scalar constant");
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1421 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1422 case complex_matrix_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1423 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1424 int nr = 0, nc = 0;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1425
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1426 if (extract_keyword (is, "rows", nr) && nr > 0
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1427 && extract_keyword (is, "columns", nc) && nc > 0)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1428 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1429 complex_matrix = new ComplexMatrix (nr, nc);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1430 is >> *complex_matrix;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1431 if (is)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1432 status = complex_matrix_constant;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1433 else
240
a99f28f5e351 [project @ 1993-11-30 20:24:36 by jwe]
jwe
parents: 217
diff changeset
1434 ::error ("failed to load complex matrix constant");
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1435 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1436 else
240
a99f28f5e351 [project @ 1993-11-30 20:24:36 by jwe]
jwe
parents: 217
diff changeset
1437 ::error ("failed to extract number of rows and columns");
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1438 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1439 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1440 case string_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1441 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1442 int len;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1443 if (extract_keyword (is, "length", len) && len > 0)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1444 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1445 string = new char [len+1];
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1446 is.get (string, len+1, EOF);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1447 if (is)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1448 status = string_constant;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1449 else
240
a99f28f5e351 [project @ 1993-11-30 20:24:36 by jwe]
jwe
parents: 217
diff changeset
1450 ::error ("failed to load string constant");
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1451 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1452 else
240
a99f28f5e351 [project @ 1993-11-30 20:24:36 by jwe]
jwe
parents: 217
diff changeset
1453 ::error ("failed to extract string length");
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1454 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1455 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1456 case range_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1457 skip_comments (is);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1458 range = new Range ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1459 is >> *range;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1460 if (is)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1461 status = range_constant;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1462 else
240
a99f28f5e351 [project @ 1993-11-30 20:24:36 by jwe]
jwe
parents: 217
diff changeset
1463 ::error ("failed to load range constant");
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1464 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1465 default:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1466 panic_impossible ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1467 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1468 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1469 return status;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1470 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1471
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1472 double
164
e2c950dd96d2 [project @ 1993-10-18 19:32:00 by jwe]
jwe
parents: 161
diff changeset
1473 tree_constant_rep::double_value (void) const
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1474 {
105
13e74a4bf262 [project @ 1993-09-13 04:00:41 by jwe]
jwe
parents: 101
diff changeset
1475 switch (type_tag)
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1476 {
105
13e74a4bf262 [project @ 1993-09-13 04:00:41 by jwe]
jwe
parents: 101
diff changeset
1477 case scalar_constant:
13e74a4bf262 [project @ 1993-09-13 04:00:41 by jwe]
jwe
parents: 101
diff changeset
1478 return scalar;
13e74a4bf262 [project @ 1993-09-13 04:00:41 by jwe]
jwe
parents: 101
diff changeset
1479 case complex_scalar_constant:
13e74a4bf262 [project @ 1993-09-13 04:00:41 by jwe]
jwe
parents: 101
diff changeset
1480 {
13e74a4bf262 [project @ 1993-09-13 04:00:41 by jwe]
jwe
parents: 101
diff changeset
1481 int flag = user_pref.ok_to_lose_imaginary_part;
13e74a4bf262 [project @ 1993-09-13 04:00:41 by jwe]
jwe
parents: 101
diff changeset
1482 if (flag == -1)
13e74a4bf262 [project @ 1993-09-13 04:00:41 by jwe]
jwe
parents: 101
diff changeset
1483 warning ("implicit conversion of complex value to real value");
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1484
105
13e74a4bf262 [project @ 1993-09-13 04:00:41 by jwe]
jwe
parents: 101
diff changeset
1485 if (flag != 0)
240
a99f28f5e351 [project @ 1993-11-30 20:24:36 by jwe]
jwe
parents: 217
diff changeset
1486 return ::real (*complex_scalar);
105
13e74a4bf262 [project @ 1993-09-13 04:00:41 by jwe]
jwe
parents: 101
diff changeset
1487
240
a99f28f5e351 [project @ 1993-11-30 20:24:36 by jwe]
jwe
parents: 217
diff changeset
1488 ::error ("implicit conversion of complex value to real value");
a99f28f5e351 [project @ 1993-11-30 20:24:36 by jwe]
jwe
parents: 217
diff changeset
1489 ::error ("not allowed");
105
13e74a4bf262 [project @ 1993-09-13 04:00:41 by jwe]
jwe
parents: 101
diff changeset
1490 jump_to_top_level ();
13e74a4bf262 [project @ 1993-09-13 04:00:41 by jwe]
jwe
parents: 101
diff changeset
1491 }
13e74a4bf262 [project @ 1993-09-13 04:00:41 by jwe]
jwe
parents: 101
diff changeset
1492 default:
13e74a4bf262 [project @ 1993-09-13 04:00:41 by jwe]
jwe
parents: 101
diff changeset
1493 panic_impossible ();
13e74a4bf262 [project @ 1993-09-13 04:00:41 by jwe]
jwe
parents: 101
diff changeset
1494 break;
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1495 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1496 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1497
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1498 Matrix
164
e2c950dd96d2 [project @ 1993-10-18 19:32:00 by jwe]
jwe
parents: 161
diff changeset
1499 tree_constant_rep::matrix_value (void) const
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1500 {
105
13e74a4bf262 [project @ 1993-09-13 04:00:41 by jwe]
jwe
parents: 101
diff changeset
1501 switch (type_tag)
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1502 {
206
1761d7a3770c [project @ 1993-11-10 21:00:31 by jwe]
jwe
parents: 191
diff changeset
1503 case scalar_constant:
240
a99f28f5e351 [project @ 1993-11-30 20:24:36 by jwe]
jwe
parents: 217
diff changeset
1504 return Matrix (1, 1, scalar);
105
13e74a4bf262 [project @ 1993-09-13 04:00:41 by jwe]
jwe
parents: 101
diff changeset
1505 case matrix_constant:
13e74a4bf262 [project @ 1993-09-13 04:00:41 by jwe]
jwe
parents: 101
diff changeset
1506 return *matrix;
206
1761d7a3770c [project @ 1993-11-10 21:00:31 by jwe]
jwe
parents: 191
diff changeset
1507 case complex_scalar_constant:
105
13e74a4bf262 [project @ 1993-09-13 04:00:41 by jwe]
jwe
parents: 101
diff changeset
1508 case complex_matrix_constant:
13e74a4bf262 [project @ 1993-09-13 04:00:41 by jwe]
jwe
parents: 101
diff changeset
1509 {
13e74a4bf262 [project @ 1993-09-13 04:00:41 by jwe]
jwe
parents: 101
diff changeset
1510 int flag = user_pref.ok_to_lose_imaginary_part;
13e74a4bf262 [project @ 1993-09-13 04:00:41 by jwe]
jwe
parents: 101
diff changeset
1511 if (flag == -1)
455
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
1512 warning ("implicit conversion of complex matrix to real matrix");
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1513
105
13e74a4bf262 [project @ 1993-09-13 04:00:41 by jwe]
jwe
parents: 101
diff changeset
1514 if (flag != 0)
206
1761d7a3770c [project @ 1993-11-10 21:00:31 by jwe]
jwe
parents: 191
diff changeset
1515 {
1761d7a3770c [project @ 1993-11-10 21:00:31 by jwe]
jwe
parents: 191
diff changeset
1516 if (type_tag == complex_scalar_constant)
240
a99f28f5e351 [project @ 1993-11-30 20:24:36 by jwe]
jwe
parents: 217
diff changeset
1517 return Matrix (1, 1, ::real (*complex_scalar));
206
1761d7a3770c [project @ 1993-11-10 21:00:31 by jwe]
jwe
parents: 191
diff changeset
1518 else if (type_tag == complex_matrix_constant)
240
a99f28f5e351 [project @ 1993-11-30 20:24:36 by jwe]
jwe
parents: 217
diff changeset
1519 return ::real (*complex_matrix);
206
1761d7a3770c [project @ 1993-11-10 21:00:31 by jwe]
jwe
parents: 191
diff changeset
1520 else
1761d7a3770c [project @ 1993-11-10 21:00:31 by jwe]
jwe
parents: 191
diff changeset
1521 panic_impossible ();
1761d7a3770c [project @ 1993-11-10 21:00:31 by jwe]
jwe
parents: 191
diff changeset
1522 }
105
13e74a4bf262 [project @ 1993-09-13 04:00:41 by jwe]
jwe
parents: 101
diff changeset
1523 else
240
a99f28f5e351 [project @ 1993-11-30 20:24:36 by jwe]
jwe
parents: 217
diff changeset
1524 {
a99f28f5e351 [project @ 1993-11-30 20:24:36 by jwe]
jwe
parents: 217
diff changeset
1525 ::error ("implicit conversion of complex matrix to real matrix");
a99f28f5e351 [project @ 1993-11-30 20:24:36 by jwe]
jwe
parents: 217
diff changeset
1526 ::error ("not allowed");
a99f28f5e351 [project @ 1993-11-30 20:24:36 by jwe]
jwe
parents: 217
diff changeset
1527 }
105
13e74a4bf262 [project @ 1993-09-13 04:00:41 by jwe]
jwe
parents: 101
diff changeset
1528 jump_to_top_level ();
13e74a4bf262 [project @ 1993-09-13 04:00:41 by jwe]
jwe
parents: 101
diff changeset
1529 }
13e74a4bf262 [project @ 1993-09-13 04:00:41 by jwe]
jwe
parents: 101
diff changeset
1530 default:
13e74a4bf262 [project @ 1993-09-13 04:00:41 by jwe]
jwe
parents: 101
diff changeset
1531 panic_impossible ();
13e74a4bf262 [project @ 1993-09-13 04:00:41 by jwe]
jwe
parents: 101
diff changeset
1532 break;
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1533 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1534 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1535
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1536 Complex
164
e2c950dd96d2 [project @ 1993-10-18 19:32:00 by jwe]
jwe
parents: 161
diff changeset
1537 tree_constant_rep::complex_value (void) const
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1538 {
101
6f35b150c579 [project @ 1993-09-13 03:07:36 by jwe]
jwe
parents: 96
diff changeset
1539 switch (type_tag)
6f35b150c579 [project @ 1993-09-13 03:07:36 by jwe]
jwe
parents: 96
diff changeset
1540 {
6f35b150c579 [project @ 1993-09-13 03:07:36 by jwe]
jwe
parents: 96
diff changeset
1541 case complex_scalar_constant:
105
13e74a4bf262 [project @ 1993-09-13 04:00:41 by jwe]
jwe
parents: 101
diff changeset
1542 return *complex_scalar;
101
6f35b150c579 [project @ 1993-09-13 03:07:36 by jwe]
jwe
parents: 96
diff changeset
1543 case scalar_constant:
105
13e74a4bf262 [project @ 1993-09-13 04:00:41 by jwe]
jwe
parents: 101
diff changeset
1544 return Complex (scalar);
101
6f35b150c579 [project @ 1993-09-13 03:07:36 by jwe]
jwe
parents: 96
diff changeset
1545 default:
6f35b150c579 [project @ 1993-09-13 03:07:36 by jwe]
jwe
parents: 96
diff changeset
1546 panic_impossible ();
6f35b150c579 [project @ 1993-09-13 03:07:36 by jwe]
jwe
parents: 96
diff changeset
1547 break;
6f35b150c579 [project @ 1993-09-13 03:07:36 by jwe]
jwe
parents: 96
diff changeset
1548 }
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1549 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1550
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1551 ComplexMatrix
164
e2c950dd96d2 [project @ 1993-10-18 19:32:00 by jwe]
jwe
parents: 161
diff changeset
1552 tree_constant_rep::complex_matrix_value (void) const
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1553 {
105
13e74a4bf262 [project @ 1993-09-13 04:00:41 by jwe]
jwe
parents: 101
diff changeset
1554 switch (type_tag)
101
6f35b150c579 [project @ 1993-09-13 03:07:36 by jwe]
jwe
parents: 96
diff changeset
1555 {
6f35b150c579 [project @ 1993-09-13 03:07:36 by jwe]
jwe
parents: 96
diff changeset
1556 case scalar_constant:
6f35b150c579 [project @ 1993-09-13 03:07:36 by jwe]
jwe
parents: 96
diff changeset
1557 {
240
a99f28f5e351 [project @ 1993-11-30 20:24:36 by jwe]
jwe
parents: 217
diff changeset
1558 return ComplexMatrix (1, 1, Complex (scalar));
101
6f35b150c579 [project @ 1993-09-13 03:07:36 by jwe]
jwe
parents: 96
diff changeset
1559 }
6f35b150c579 [project @ 1993-09-13 03:07:36 by jwe]
jwe
parents: 96
diff changeset
1560 case complex_scalar_constant:
105
13e74a4bf262 [project @ 1993-09-13 04:00:41 by jwe]
jwe
parents: 101
diff changeset
1561 {
240
a99f28f5e351 [project @ 1993-11-30 20:24:36 by jwe]
jwe
parents: 217
diff changeset
1562 return ComplexMatrix (1, 1, *complex_scalar);
105
13e74a4bf262 [project @ 1993-09-13 04:00:41 by jwe]
jwe
parents: 101
diff changeset
1563 }
101
6f35b150c579 [project @ 1993-09-13 03:07:36 by jwe]
jwe
parents: 96
diff changeset
1564 case matrix_constant:
6f35b150c579 [project @ 1993-09-13 03:07:36 by jwe]
jwe
parents: 96
diff changeset
1565 {
105
13e74a4bf262 [project @ 1993-09-13 04:00:41 by jwe]
jwe
parents: 101
diff changeset
1566 return ComplexMatrix (*matrix);
101
6f35b150c579 [project @ 1993-09-13 03:07:36 by jwe]
jwe
parents: 96
diff changeset
1567 }
6f35b150c579 [project @ 1993-09-13 03:07:36 by jwe]
jwe
parents: 96
diff changeset
1568 case complex_matrix_constant:
105
13e74a4bf262 [project @ 1993-09-13 04:00:41 by jwe]
jwe
parents: 101
diff changeset
1569 return *complex_matrix;
101
6f35b150c579 [project @ 1993-09-13 03:07:36 by jwe]
jwe
parents: 96
diff changeset
1570 break;
6f35b150c579 [project @ 1993-09-13 03:07:36 by jwe]
jwe
parents: 96
diff changeset
1571 default:
6f35b150c579 [project @ 1993-09-13 03:07:36 by jwe]
jwe
parents: 96
diff changeset
1572 panic_impossible ();
6f35b150c579 [project @ 1993-09-13 03:07:36 by jwe]
jwe
parents: 96
diff changeset
1573 break;
6f35b150c579 [project @ 1993-09-13 03:07:36 by jwe]
jwe
parents: 96
diff changeset
1574 }
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1575 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1576
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1577 char *
164
e2c950dd96d2 [project @ 1993-10-18 19:32:00 by jwe]
jwe
parents: 161
diff changeset
1578 tree_constant_rep::string_value (void) const
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1579 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1580 assert (type_tag == string_constant);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1581 return string;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1582 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1583
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1584 Range
164
e2c950dd96d2 [project @ 1993-10-18 19:32:00 by jwe]
jwe
parents: 161
diff changeset
1585 tree_constant_rep::range_value (void) const
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1586 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1587 assert (type_tag == range_constant);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1588 return *range;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1589 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1590
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1591 int
164
e2c950dd96d2 [project @ 1993-10-18 19:32:00 by jwe]
jwe
parents: 161
diff changeset
1592 tree_constant_rep::rows (void) const
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1593 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1594 int retval = -1;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1595 switch (type_tag)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1596 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1597 case scalar_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1598 case complex_scalar_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1599 case string_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1600 case range_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1601 retval = 1;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1602 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1603 case matrix_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1604 retval = matrix->rows ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1605 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1606 case complex_matrix_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1607 retval = complex_matrix->rows ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1608 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1609 case magic_colon:
240
a99f28f5e351 [project @ 1993-11-30 20:24:36 by jwe]
jwe
parents: 217
diff changeset
1610 ::error ("invalid use of colon operator");
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1611 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1612 case unknown_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1613 retval = 0;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1614 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1615 default:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1616 panic_impossible ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1617 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1618 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1619 return retval;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1620 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1621
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1622 int
164
e2c950dd96d2 [project @ 1993-10-18 19:32:00 by jwe]
jwe
parents: 161
diff changeset
1623 tree_constant_rep::columns (void) const
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1624 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1625 int retval = -1;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1626 switch (type_tag)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1627 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1628 case scalar_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1629 case complex_scalar_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1630 retval = 1;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1631 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1632 case matrix_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1633 retval = matrix->columns ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1634 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1635 case complex_matrix_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1636 retval = complex_matrix->columns ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1637 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1638 case string_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1639 retval = strlen (string);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1640 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1641 case range_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1642 retval = range->nelem ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1643 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1644 case magic_colon:
240
a99f28f5e351 [project @ 1993-11-30 20:24:36 by jwe]
jwe
parents: 217
diff changeset
1645 ::error ("invalid use of colon operator");
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1646 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1647 case unknown_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1648 retval = 0;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1649 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1650 default:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1651 panic_impossible ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1652 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1653 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1654 return retval;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1655 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1656
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1657 tree_constant
164
e2c950dd96d2 [project @ 1993-10-18 19:32:00 by jwe]
jwe
parents: 161
diff changeset
1658 tree_constant_rep::all (void) const
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1659 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1660 if (type_tag == string_constant || type_tag == range_constant)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1661 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1662 tree_constant tmp = make_numeric ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1663 return tmp.all ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1664 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1665
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1666 tree_constant retval;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1667 switch (type_tag)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1668 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1669 case scalar_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1670 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1671 double status = (scalar != 0.0);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1672 retval = tree_constant (status);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1673 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1674 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1675 case matrix_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1676 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1677 Matrix m = matrix->all ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1678 retval = tree_constant (m);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1679 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1680 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1681 case complex_scalar_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1682 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1683 double status = (*complex_scalar != 0.0);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1684 retval = tree_constant (status);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1685 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1686 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1687 case complex_matrix_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1688 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1689 Matrix m = complex_matrix->all ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1690 retval = tree_constant (m);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1691 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1692 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1693 case string_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1694 case range_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1695 case magic_colon:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1696 default:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1697 panic_impossible ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1698 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1699 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1700 return retval;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1701 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1702
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1703 tree_constant
164
e2c950dd96d2 [project @ 1993-10-18 19:32:00 by jwe]
jwe
parents: 161
diff changeset
1704 tree_constant_rep::any (void) const
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1705 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1706 if (type_tag == string_constant || type_tag == range_constant)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1707 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1708 tree_constant tmp = make_numeric ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1709 return tmp.any ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1710 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1711
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1712 tree_constant retval;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1713 switch (type_tag)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1714 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1715 case scalar_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1716 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1717 double status = (scalar != 0.0);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1718 retval = tree_constant (status);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1719 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1720 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1721 case matrix_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1722 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1723 Matrix m = matrix->any ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1724 retval = tree_constant (m);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1725 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1726 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1727 case complex_scalar_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1728 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1729 double status = (*complex_scalar != 0.0);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1730 retval = tree_constant (status);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1731 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1732 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1733 case complex_matrix_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1734 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1735 Matrix m = complex_matrix->any ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1736 retval = tree_constant (m);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1737 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1738 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1739 case string_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1740 case range_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1741 case magic_colon:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1742 default:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1743 panic_impossible ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1744 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1745 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1746 return retval;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1747 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1748
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1749 tree_constant
164
e2c950dd96d2 [project @ 1993-10-18 19:32:00 by jwe]
jwe
parents: 161
diff changeset
1750 tree_constant_rep::isstr (void) const
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1751 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1752 double status = 0.0;
164
e2c950dd96d2 [project @ 1993-10-18 19:32:00 by jwe]
jwe
parents: 161
diff changeset
1753 if (type_tag == string_constant)
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1754 status = 1.0;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1755 tree_constant retval (status);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1756 return retval;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1757 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1758
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1759 tree_constant
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1760 tree_constant_rep::convert_to_str (void)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1761 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1762 tree_constant retval;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1763
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1764 switch (type_tag)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1765 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1766 case complex_scalar_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1767 case scalar_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1768 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1769 double d = double_value ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1770 int i = NINT (d);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1771 // Warn about out of range conversions?
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1772 char s[2];
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1773 s[0] = (char) i;
240
a99f28f5e351 [project @ 1993-11-30 20:24:36 by jwe]
jwe
parents: 217
diff changeset
1774 s[1] = '\0';
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1775 retval = tree_constant (s);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1776 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1777 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1778 case complex_matrix_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1779 case matrix_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1780 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1781 ColumnVector v = to_vector ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1782 int len = v.length ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1783 if (len == 0)
240
a99f28f5e351 [project @ 1993-11-30 20:24:36 by jwe]
jwe
parents: 217
diff changeset
1784 ::error ("can only convert vectors and scalars to strings");
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1785 else
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1786 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1787 char *s = new char [len+1];
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1788 s[len] = '\0';
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1789 for (int i = 0; i < len; i++)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1790 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1791 double d = v.elem (i);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1792 int ival = NINT (d);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1793 // Warn about out of range conversions?
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1794 s[i] = (char) ival;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1795 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1796 retval = tree_constant (s);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1797 delete [] s;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1798 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1799 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1800 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1801 case range_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1802 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1803 Range r = range_value ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1804 double b = r.base ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1805 double incr = r.inc ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1806 int nel = r.nelem ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1807 char *s = new char [nel+1];
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1808 s[nel] = '\0';
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1809 for (int i = 0; i < nel; i++)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1810 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1811 double d = b + i * incr;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1812 int ival = NINT (d);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1813 // Warn about out of range conversions?
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1814 s[i] = (char) ival;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1815 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1816 retval = tree_constant (s);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1817 delete [] s;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1818 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1819 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1820 case string_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1821 retval = tree_constant (*this);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1822 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1823 case magic_colon:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1824 default:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1825 panic_impossible ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1826 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1827 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1828 return retval;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1829 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1830
435
5e778965b6ea [project @ 1994-05-25 23:59:02 by jwe]
jwe
parents: 421
diff changeset
1831 void
5e778965b6ea [project @ 1994-05-25 23:59:02 by jwe]
jwe
parents: 421
diff changeset
1832 tree_constant_rep::convert_to_row_or_column_vector (void)
5e778965b6ea [project @ 1994-05-25 23:59:02 by jwe]
jwe
parents: 421
diff changeset
1833 {
5e778965b6ea [project @ 1994-05-25 23:59:02 by jwe]
jwe
parents: 421
diff changeset
1834 assert (type_tag == matrix_constant || type_tag == complex_matrix_constant);
5e778965b6ea [project @ 1994-05-25 23:59:02 by jwe]
jwe
parents: 421
diff changeset
1835
5e778965b6ea [project @ 1994-05-25 23:59:02 by jwe]
jwe
parents: 421
diff changeset
1836 int nr = rows ();
5e778965b6ea [project @ 1994-05-25 23:59:02 by jwe]
jwe
parents: 421
diff changeset
1837 int nc = columns ();
5e778965b6ea [project @ 1994-05-25 23:59:02 by jwe]
jwe
parents: 421
diff changeset
1838
5e778965b6ea [project @ 1994-05-25 23:59:02 by jwe]
jwe
parents: 421
diff changeset
1839 int len = nr * nc;
5e778965b6ea [project @ 1994-05-25 23:59:02 by jwe]
jwe
parents: 421
diff changeset
1840
5e778965b6ea [project @ 1994-05-25 23:59:02 by jwe]
jwe
parents: 421
diff changeset
1841 assert (len > 0);
5e778965b6ea [project @ 1994-05-25 23:59:02 by jwe]
jwe
parents: 421
diff changeset
1842
5e778965b6ea [project @ 1994-05-25 23:59:02 by jwe]
jwe
parents: 421
diff changeset
1843 int new_nr = 1;
5e778965b6ea [project @ 1994-05-25 23:59:02 by jwe]
jwe
parents: 421
diff changeset
1844 int new_nc = 1;
5e778965b6ea [project @ 1994-05-25 23:59:02 by jwe]
jwe
parents: 421
diff changeset
1845
5e778965b6ea [project @ 1994-05-25 23:59:02 by jwe]
jwe
parents: 421
diff changeset
1846 if (user_pref.prefer_column_vectors)
5e778965b6ea [project @ 1994-05-25 23:59:02 by jwe]
jwe
parents: 421
diff changeset
1847 new_nr = len;
5e778965b6ea [project @ 1994-05-25 23:59:02 by jwe]
jwe
parents: 421
diff changeset
1848 else
5e778965b6ea [project @ 1994-05-25 23:59:02 by jwe]
jwe
parents: 421
diff changeset
1849 new_nc = len;
5e778965b6ea [project @ 1994-05-25 23:59:02 by jwe]
jwe
parents: 421
diff changeset
1850
5e778965b6ea [project @ 1994-05-25 23:59:02 by jwe]
jwe
parents: 421
diff changeset
1851 if (type_tag == matrix_constant)
5e778965b6ea [project @ 1994-05-25 23:59:02 by jwe]
jwe
parents: 421
diff changeset
1852 {
5e778965b6ea [project @ 1994-05-25 23:59:02 by jwe]
jwe
parents: 421
diff changeset
1853 Matrix *m = new Matrix (new_nr, new_nc);
5e778965b6ea [project @ 1994-05-25 23:59:02 by jwe]
jwe
parents: 421
diff changeset
1854
5e778965b6ea [project @ 1994-05-25 23:59:02 by jwe]
jwe
parents: 421
diff changeset
1855 double *cop_out = matrix->fortran_vec ();
5e778965b6ea [project @ 1994-05-25 23:59:02 by jwe]
jwe
parents: 421
diff changeset
1856
5e778965b6ea [project @ 1994-05-25 23:59:02 by jwe]
jwe
parents: 421
diff changeset
1857 for (int i = 0; i < len; i++)
5e778965b6ea [project @ 1994-05-25 23:59:02 by jwe]
jwe
parents: 421
diff changeset
1858 {
5e778965b6ea [project @ 1994-05-25 23:59:02 by jwe]
jwe
parents: 421
diff changeset
1859 if (new_nr == 1)
5e778965b6ea [project @ 1994-05-25 23:59:02 by jwe]
jwe
parents: 421
diff changeset
1860 m->elem (0, i) = *cop_out++;
5e778965b6ea [project @ 1994-05-25 23:59:02 by jwe]
jwe
parents: 421
diff changeset
1861 else
5e778965b6ea [project @ 1994-05-25 23:59:02 by jwe]
jwe
parents: 421
diff changeset
1862 m->elem (i, 0) = *cop_out++;
5e778965b6ea [project @ 1994-05-25 23:59:02 by jwe]
jwe
parents: 421
diff changeset
1863 }
5e778965b6ea [project @ 1994-05-25 23:59:02 by jwe]
jwe
parents: 421
diff changeset
1864
5e778965b6ea [project @ 1994-05-25 23:59:02 by jwe]
jwe
parents: 421
diff changeset
1865 delete matrix;
5e778965b6ea [project @ 1994-05-25 23:59:02 by jwe]
jwe
parents: 421
diff changeset
1866 matrix = m;
5e778965b6ea [project @ 1994-05-25 23:59:02 by jwe]
jwe
parents: 421
diff changeset
1867 }
5e778965b6ea [project @ 1994-05-25 23:59:02 by jwe]
jwe
parents: 421
diff changeset
1868 else
5e778965b6ea [project @ 1994-05-25 23:59:02 by jwe]
jwe
parents: 421
diff changeset
1869 {
5e778965b6ea [project @ 1994-05-25 23:59:02 by jwe]
jwe
parents: 421
diff changeset
1870 ComplexMatrix *cm = new ComplexMatrix (new_nr, new_nc);
5e778965b6ea [project @ 1994-05-25 23:59:02 by jwe]
jwe
parents: 421
diff changeset
1871
5e778965b6ea [project @ 1994-05-25 23:59:02 by jwe]
jwe
parents: 421
diff changeset
1872 Complex *cop_out = complex_matrix->fortran_vec ();
5e778965b6ea [project @ 1994-05-25 23:59:02 by jwe]
jwe
parents: 421
diff changeset
1873
5e778965b6ea [project @ 1994-05-25 23:59:02 by jwe]
jwe
parents: 421
diff changeset
1874 for (int i = 0; i < len; i++)
5e778965b6ea [project @ 1994-05-25 23:59:02 by jwe]
jwe
parents: 421
diff changeset
1875 {
5e778965b6ea [project @ 1994-05-25 23:59:02 by jwe]
jwe
parents: 421
diff changeset
1876 if (new_nr == 1)
5e778965b6ea [project @ 1994-05-25 23:59:02 by jwe]
jwe
parents: 421
diff changeset
1877 cm->elem (0, i) = *cop_out++;
5e778965b6ea [project @ 1994-05-25 23:59:02 by jwe]
jwe
parents: 421
diff changeset
1878 else
5e778965b6ea [project @ 1994-05-25 23:59:02 by jwe]
jwe
parents: 421
diff changeset
1879 cm->elem (i, 0) = *cop_out++;
5e778965b6ea [project @ 1994-05-25 23:59:02 by jwe]
jwe
parents: 421
diff changeset
1880 }
5e778965b6ea [project @ 1994-05-25 23:59:02 by jwe]
jwe
parents: 421
diff changeset
1881
5e778965b6ea [project @ 1994-05-25 23:59:02 by jwe]
jwe
parents: 421
diff changeset
1882 delete complex_matrix;
5e778965b6ea [project @ 1994-05-25 23:59:02 by jwe]
jwe
parents: 421
diff changeset
1883 complex_matrix = cm;
5e778965b6ea [project @ 1994-05-25 23:59:02 by jwe]
jwe
parents: 421
diff changeset
1884 }
5e778965b6ea [project @ 1994-05-25 23:59:02 by jwe]
jwe
parents: 421
diff changeset
1885 }
5e778965b6ea [project @ 1994-05-25 23:59:02 by jwe]
jwe
parents: 421
diff changeset
1886
420
b8c0ee979c15 [project @ 1994-05-23 06:55:52 by jwe]
jwe
parents: 394
diff changeset
1887 int
b8c0ee979c15 [project @ 1994-05-23 06:55:52 by jwe]
jwe
parents: 394
diff changeset
1888 tree_constant_rep::is_true (void) const
b8c0ee979c15 [project @ 1994-05-23 06:55:52 by jwe]
jwe
parents: 394
diff changeset
1889 {
b8c0ee979c15 [project @ 1994-05-23 06:55:52 by jwe]
jwe
parents: 394
diff changeset
1890 if (type_tag == string_constant || type_tag == range_constant)
b8c0ee979c15 [project @ 1994-05-23 06:55:52 by jwe]
jwe
parents: 394
diff changeset
1891 {
b8c0ee979c15 [project @ 1994-05-23 06:55:52 by jwe]
jwe
parents: 394
diff changeset
1892 tree_constant tmp = make_numeric ();
b8c0ee979c15 [project @ 1994-05-23 06:55:52 by jwe]
jwe
parents: 394
diff changeset
1893 return tmp.is_true ();
b8c0ee979c15 [project @ 1994-05-23 06:55:52 by jwe]
jwe
parents: 394
diff changeset
1894 }
b8c0ee979c15 [project @ 1994-05-23 06:55:52 by jwe]
jwe
parents: 394
diff changeset
1895
b8c0ee979c15 [project @ 1994-05-23 06:55:52 by jwe]
jwe
parents: 394
diff changeset
1896 int retval;
b8c0ee979c15 [project @ 1994-05-23 06:55:52 by jwe]
jwe
parents: 394
diff changeset
1897 switch (type_tag)
b8c0ee979c15 [project @ 1994-05-23 06:55:52 by jwe]
jwe
parents: 394
diff changeset
1898 {
b8c0ee979c15 [project @ 1994-05-23 06:55:52 by jwe]
jwe
parents: 394
diff changeset
1899 case scalar_constant:
b8c0ee979c15 [project @ 1994-05-23 06:55:52 by jwe]
jwe
parents: 394
diff changeset
1900 retval = (scalar != 0.0);
b8c0ee979c15 [project @ 1994-05-23 06:55:52 by jwe]
jwe
parents: 394
diff changeset
1901 break;
b8c0ee979c15 [project @ 1994-05-23 06:55:52 by jwe]
jwe
parents: 394
diff changeset
1902 case matrix_constant:
b8c0ee979c15 [project @ 1994-05-23 06:55:52 by jwe]
jwe
parents: 394
diff changeset
1903 {
b8c0ee979c15 [project @ 1994-05-23 06:55:52 by jwe]
jwe
parents: 394
diff changeset
1904 Matrix m = (matrix->all ()) . all ();
b8c0ee979c15 [project @ 1994-05-23 06:55:52 by jwe]
jwe
parents: 394
diff changeset
1905 retval = (m.rows () == 1
b8c0ee979c15 [project @ 1994-05-23 06:55:52 by jwe]
jwe
parents: 394
diff changeset
1906 && m.columns () == 1
b8c0ee979c15 [project @ 1994-05-23 06:55:52 by jwe]
jwe
parents: 394
diff changeset
1907 && m.elem (0, 0) != 0.0);
b8c0ee979c15 [project @ 1994-05-23 06:55:52 by jwe]
jwe
parents: 394
diff changeset
1908 }
b8c0ee979c15 [project @ 1994-05-23 06:55:52 by jwe]
jwe
parents: 394
diff changeset
1909 break;
b8c0ee979c15 [project @ 1994-05-23 06:55:52 by jwe]
jwe
parents: 394
diff changeset
1910 case complex_scalar_constant:
b8c0ee979c15 [project @ 1994-05-23 06:55:52 by jwe]
jwe
parents: 394
diff changeset
1911 retval = (*complex_scalar != 0.0);
b8c0ee979c15 [project @ 1994-05-23 06:55:52 by jwe]
jwe
parents: 394
diff changeset
1912 break;
b8c0ee979c15 [project @ 1994-05-23 06:55:52 by jwe]
jwe
parents: 394
diff changeset
1913 case complex_matrix_constant:
b8c0ee979c15 [project @ 1994-05-23 06:55:52 by jwe]
jwe
parents: 394
diff changeset
1914 {
b8c0ee979c15 [project @ 1994-05-23 06:55:52 by jwe]
jwe
parents: 394
diff changeset
1915 Matrix m = (complex_matrix->all ()) . all ();
b8c0ee979c15 [project @ 1994-05-23 06:55:52 by jwe]
jwe
parents: 394
diff changeset
1916 retval = (m.rows () == 1
b8c0ee979c15 [project @ 1994-05-23 06:55:52 by jwe]
jwe
parents: 394
diff changeset
1917 && m.columns () == 1
b8c0ee979c15 [project @ 1994-05-23 06:55:52 by jwe]
jwe
parents: 394
diff changeset
1918 && m.elem (0, 0) != 0.0);
b8c0ee979c15 [project @ 1994-05-23 06:55:52 by jwe]
jwe
parents: 394
diff changeset
1919 }
b8c0ee979c15 [project @ 1994-05-23 06:55:52 by jwe]
jwe
parents: 394
diff changeset
1920 break;
b8c0ee979c15 [project @ 1994-05-23 06:55:52 by jwe]
jwe
parents: 394
diff changeset
1921 case string_constant:
b8c0ee979c15 [project @ 1994-05-23 06:55:52 by jwe]
jwe
parents: 394
diff changeset
1922 case range_constant:
b8c0ee979c15 [project @ 1994-05-23 06:55:52 by jwe]
jwe
parents: 394
diff changeset
1923 case magic_colon:
b8c0ee979c15 [project @ 1994-05-23 06:55:52 by jwe]
jwe
parents: 394
diff changeset
1924 default:
b8c0ee979c15 [project @ 1994-05-23 06:55:52 by jwe]
jwe
parents: 394
diff changeset
1925 panic_impossible ();
b8c0ee979c15 [project @ 1994-05-23 06:55:52 by jwe]
jwe
parents: 394
diff changeset
1926 break;
b8c0ee979c15 [project @ 1994-05-23 06:55:52 by jwe]
jwe
parents: 394
diff changeset
1927 }
b8c0ee979c15 [project @ 1994-05-23 06:55:52 by jwe]
jwe
parents: 394
diff changeset
1928 return retval;
b8c0ee979c15 [project @ 1994-05-23 06:55:52 by jwe]
jwe
parents: 394
diff changeset
1929 }
b8c0ee979c15 [project @ 1994-05-23 06:55:52 by jwe]
jwe
parents: 394
diff changeset
1930
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1931 tree_constant
164
e2c950dd96d2 [project @ 1993-10-18 19:32:00 by jwe]
jwe
parents: 161
diff changeset
1932 tree_constant_rep::cumprod (void) const
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1933 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1934 if (type_tag == string_constant || type_tag == range_constant)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1935 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1936 tree_constant tmp = make_numeric ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1937 return tmp.cumprod ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1938 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1939
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1940 tree_constant retval;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1941 switch (type_tag)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1942 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1943 case scalar_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1944 retval = tree_constant (scalar);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1945 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1946 case matrix_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1947 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1948 Matrix m = matrix->cumprod ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1949 retval = tree_constant (m);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1950 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1951 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1952 case complex_scalar_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1953 retval = tree_constant (*complex_scalar);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1954 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1955 case complex_matrix_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1956 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1957 ComplexMatrix m = complex_matrix->cumprod ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1958 retval = tree_constant (m);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1959 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1960 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1961 case string_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1962 case range_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1963 case magic_colon:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1964 default:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1965 panic_impossible ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1966 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1967 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1968 return retval;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1969 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1970
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1971 tree_constant
164
e2c950dd96d2 [project @ 1993-10-18 19:32:00 by jwe]
jwe
parents: 161
diff changeset
1972 tree_constant_rep::cumsum (void) const
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1973 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1974 if (type_tag == string_constant || type_tag == range_constant)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1975 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1976 tree_constant tmp = make_numeric ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1977 return tmp.cumsum ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1978 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1979
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1980 tree_constant retval;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1981 switch (type_tag)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1982 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1983 case scalar_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1984 retval = tree_constant (scalar);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1985 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1986 case matrix_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1987 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1988 Matrix m = matrix->cumsum ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1989 retval = tree_constant (m);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1990 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1991 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1992 case complex_scalar_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1993 retval = tree_constant (*complex_scalar);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1994 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1995 case complex_matrix_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1996 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1997 ComplexMatrix m = complex_matrix->cumsum ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1998 retval = tree_constant (m);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1999 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2000 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2001 case string_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2002 case range_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2003 case magic_colon:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2004 default:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2005 panic_impossible ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2006 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2007 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2008 return retval;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2009 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2010
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2011 tree_constant
164
e2c950dd96d2 [project @ 1993-10-18 19:32:00 by jwe]
jwe
parents: 161
diff changeset
2012 tree_constant_rep::prod (void) const
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2013 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2014 if (type_tag == string_constant || type_tag == range_constant)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2015 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2016 tree_constant tmp = make_numeric ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2017 return tmp.prod ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2018 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2019
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2020 tree_constant retval;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2021 switch (type_tag)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2022 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2023 case scalar_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2024 retval = tree_constant (scalar);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2025 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2026 case matrix_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2027 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2028 Matrix m = matrix->prod ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2029 retval = tree_constant (m);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2030 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2031 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2032 case complex_scalar_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2033 retval = tree_constant (*complex_scalar);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2034 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2035 case complex_matrix_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2036 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2037 ComplexMatrix m = complex_matrix->prod ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2038 retval = tree_constant (m);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2039 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2040 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2041 case string_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2042 case range_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2043 case magic_colon:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2044 default:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2045 panic_impossible ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2046 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2047 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2048 return retval;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2049 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2050
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2051 tree_constant
164
e2c950dd96d2 [project @ 1993-10-18 19:32:00 by jwe]
jwe
parents: 161
diff changeset
2052 tree_constant_rep::sum (void) const
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2053 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2054 if (type_tag == string_constant || type_tag == range_constant)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2055 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2056 tree_constant tmp = make_numeric ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2057 return tmp.sum ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2058 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2059
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2060 tree_constant retval;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2061 switch (type_tag)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2062 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2063 case scalar_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2064 retval = tree_constant (scalar);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2065 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2066 case matrix_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2067 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2068 Matrix m = matrix->sum ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2069 retval = tree_constant (m);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2070 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2071 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2072 case complex_scalar_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2073 retval = tree_constant (*complex_scalar);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2074 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2075 case complex_matrix_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2076 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2077 ComplexMatrix m = complex_matrix->sum ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2078 retval = tree_constant (m);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2079 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2080 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2081 case string_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2082 case range_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2083 case magic_colon:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2084 default:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2085 panic_impossible ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2086 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2087 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2088 return retval;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2089 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2090
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2091 tree_constant
164
e2c950dd96d2 [project @ 1993-10-18 19:32:00 by jwe]
jwe
parents: 161
diff changeset
2092 tree_constant_rep::sumsq (void) const
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2093 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2094 if (type_tag == string_constant || type_tag == range_constant)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2095 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2096 tree_constant tmp = make_numeric ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2097 return tmp.sumsq ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2098 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2099
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2100 tree_constant retval;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2101 switch (type_tag)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2102 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2103 case scalar_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2104 retval = tree_constant (scalar * scalar);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2105 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2106 case matrix_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2107 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2108 Matrix m = matrix->sumsq ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2109 retval = tree_constant (m);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2110 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2111 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2112 case complex_scalar_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2113 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2114 Complex c (*complex_scalar);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2115 retval = tree_constant (c * c);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2116 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2117 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2118 case complex_matrix_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2119 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2120 ComplexMatrix m = complex_matrix->sumsq ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2121 retval = tree_constant (m);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2122 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2123 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2124 case string_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2125 case range_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2126 case magic_colon:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2127 default:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2128 panic_impossible ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2129 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2130 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2131 return retval;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2132 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2133
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2134 static tree_constant
164
e2c950dd96d2 [project @ 1993-10-18 19:32:00 by jwe]
jwe
parents: 161
diff changeset
2135 make_diag (const Matrix& v, int k)
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2136 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2137 int nr = v.rows ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2138 int nc = v.columns ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2139 assert (nc == 1 || nr == 1);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2140
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2141 tree_constant retval;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2142
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2143 int roff = 0;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2144 int coff = 0;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2145 if (k > 0)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2146 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2147 roff = 0;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2148 coff = k;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2149 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2150 else if (k < 0)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2151 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2152 roff = -k;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2153 coff = 0;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2154 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2155
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2156 if (nr == 1)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2157 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2158 int n = nc + ABS (k);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2159 Matrix m (n, n, 0.0);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2160 for (int i = 0; i < nc; i++)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2161 m.elem (i+roff, i+coff) = v.elem (0, i);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2162 retval = tree_constant (m);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2163 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2164 else
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2165 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2166 int n = nr + ABS (k);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2167 Matrix m (n, n, 0.0);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2168 for (int i = 0; i < nr; i++)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2169 m.elem (i+roff, i+coff) = v.elem (i, 0);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2170 retval = tree_constant (m);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2171 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2172
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2173 return retval;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2174 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2175
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2176 static tree_constant
164
e2c950dd96d2 [project @ 1993-10-18 19:32:00 by jwe]
jwe
parents: 161
diff changeset
2177 make_diag (const ComplexMatrix& v, int k)
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2178 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2179 int nr = v.rows ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2180 int nc = v.columns ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2181 assert (nc == 1 || nr == 1);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2182
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2183 tree_constant retval;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2184
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2185 int roff = 0;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2186 int coff = 0;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2187 if (k > 0)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2188 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2189 roff = 0;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2190 coff = k;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2191 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2192 else if (k < 0)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2193 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2194 roff = -k;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2195 coff = 0;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2196 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2197
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2198 if (nr == 1)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2199 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2200 int n = nc + ABS (k);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2201 ComplexMatrix m (n, n, 0.0);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2202 for (int i = 0; i < nc; i++)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2203 m.elem (i+roff, i+coff) = v.elem (0, i);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2204 retval = tree_constant (m);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2205 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2206 else
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2207 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2208 int n = nr + ABS (k);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2209 ComplexMatrix m (n, n, 0.0);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2210 for (int i = 0; i < nr; i++)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2211 m.elem (i+roff, i+coff) = v.elem (i, 0);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2212 retval = tree_constant (m);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2213 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2214
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2215 return retval;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2216 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2217
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2218 tree_constant
164
e2c950dd96d2 [project @ 1993-10-18 19:32:00 by jwe]
jwe
parents: 161
diff changeset
2219 tree_constant_rep::diag (void) const
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2220 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2221 if (type_tag == string_constant || type_tag == range_constant)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2222 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2223 tree_constant tmp = make_numeric ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2224 return tmp.diag ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2225 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2226
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2227 tree_constant retval;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2228 switch (type_tag)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2229 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2230 case scalar_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2231 retval = tree_constant (scalar);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2232 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2233 case matrix_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2234 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2235 int nr = rows ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2236 int nc = columns ();
420
b8c0ee979c15 [project @ 1994-05-23 06:55:52 by jwe]
jwe
parents: 394
diff changeset
2237 if (nr == 0 || nc == 0)
b8c0ee979c15 [project @ 1994-05-23 06:55:52 by jwe]
jwe
parents: 394
diff changeset
2238 {
421
92f07c38e821 [project @ 1994-05-23 07:07:47 by jwe]
jwe
parents: 420
diff changeset
2239 Matrix mtmp;
420
b8c0ee979c15 [project @ 1994-05-23 06:55:52 by jwe]
jwe
parents: 394
diff changeset
2240 retval = tree_constant (mtmp);
b8c0ee979c15 [project @ 1994-05-23 06:55:52 by jwe]
jwe
parents: 394
diff changeset
2241 }
b8c0ee979c15 [project @ 1994-05-23 06:55:52 by jwe]
jwe
parents: 394
diff changeset
2242 else if (nr == 1 || nc == 1)
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2243 retval = make_diag (matrix_value (), 0);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2244 else
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2245 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2246 ColumnVector v = matrix->diag ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2247 if (v.capacity () > 0)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2248 retval = tree_constant (v);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2249 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2250 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2251 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2252 case complex_scalar_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2253 retval = tree_constant (*complex_scalar);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2254 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2255 case complex_matrix_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2256 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2257 int nr = rows ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2258 int nc = columns ();
420
b8c0ee979c15 [project @ 1994-05-23 06:55:52 by jwe]
jwe
parents: 394
diff changeset
2259 if (nr == 0 || nc == 0)
b8c0ee979c15 [project @ 1994-05-23 06:55:52 by jwe]
jwe
parents: 394
diff changeset
2260 {
421
92f07c38e821 [project @ 1994-05-23 07:07:47 by jwe]
jwe
parents: 420
diff changeset
2261 Matrix mtmp;
420
b8c0ee979c15 [project @ 1994-05-23 06:55:52 by jwe]
jwe
parents: 394
diff changeset
2262 retval = tree_constant (mtmp);
b8c0ee979c15 [project @ 1994-05-23 06:55:52 by jwe]
jwe
parents: 394
diff changeset
2263 }
b8c0ee979c15 [project @ 1994-05-23 06:55:52 by jwe]
jwe
parents: 394
diff changeset
2264 else if (nr == 1 || nc == 1)
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2265 retval = make_diag (complex_matrix_value (), 0);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2266 else
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2267 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2268 ComplexColumnVector v = complex_matrix->diag ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2269 if (v.capacity () > 0)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2270 retval = tree_constant (v);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2271 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2272 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2273 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2274 case string_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2275 case range_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2276 case magic_colon:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2277 default:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2278 panic_impossible ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2279 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2280 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2281 return retval;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2282 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2283
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2284 tree_constant
164
e2c950dd96d2 [project @ 1993-10-18 19:32:00 by jwe]
jwe
parents: 161
diff changeset
2285 tree_constant_rep::diag (const tree_constant& a) const
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2286 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2287 if (type_tag == string_constant || type_tag == range_constant)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2288 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2289 tree_constant tmp = make_numeric ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2290 return tmp.diag (a);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2291 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2292
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2293 tree_constant tmp_a = a.make_numeric ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2294
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2295 tree_constant_rep::constant_type a_type = tmp_a.const_type ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2296
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2297 tree_constant retval;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2298
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2299 switch (type_tag)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2300 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2301 case scalar_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2302 if (a_type == scalar_constant)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2303 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2304 int k = NINT (tmp_a.double_value ());
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2305 int n = ABS (k) + 1;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2306 if (k == 0)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2307 retval = tree_constant (scalar);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2308 else if (k > 0)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2309 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2310 Matrix m (n, n, 0.0);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2311 m.elem (0, k) = scalar;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2312 retval = tree_constant (m);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2313 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2314 else if (k < 0)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2315 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2316 Matrix m (n, n, 0.0);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2317 m.elem (-k, 0) = scalar;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2318 retval = tree_constant (m);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2319 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2320 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2321 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2322 case matrix_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2323 if (a_type == scalar_constant)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2324 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2325 int k = NINT (tmp_a.double_value ());
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2326 int nr = rows ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2327 int nc = columns ();
420
b8c0ee979c15 [project @ 1994-05-23 06:55:52 by jwe]
jwe
parents: 394
diff changeset
2328 if (nr == 0 || nc == 0)
b8c0ee979c15 [project @ 1994-05-23 06:55:52 by jwe]
jwe
parents: 394
diff changeset
2329 {
421
92f07c38e821 [project @ 1994-05-23 07:07:47 by jwe]
jwe
parents: 420
diff changeset
2330 Matrix mtmp;
420
b8c0ee979c15 [project @ 1994-05-23 06:55:52 by jwe]
jwe
parents: 394
diff changeset
2331 retval = tree_constant (mtmp);
b8c0ee979c15 [project @ 1994-05-23 06:55:52 by jwe]
jwe
parents: 394
diff changeset
2332 }
b8c0ee979c15 [project @ 1994-05-23 06:55:52 by jwe]
jwe
parents: 394
diff changeset
2333 else if (nr == 1 || nc == 1)
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2334 retval = make_diag (matrix_value (), k);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2335 else
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2336 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2337 ColumnVector d = matrix->diag (k);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2338 retval = tree_constant (d);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2339 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2340 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2341 else
240
a99f28f5e351 [project @ 1993-11-30 20:24:36 by jwe]
jwe
parents: 217
diff changeset
2342 ::error ("diag: invalid second argument");
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2343
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2344 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2345 case complex_scalar_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2346 if (a_type == scalar_constant)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2347 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2348 int k = NINT (tmp_a.double_value ());
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2349 int n = ABS (k) + 1;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2350 if (k == 0)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2351 retval = tree_constant (*complex_scalar);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2352 else if (k > 0)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2353 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2354 ComplexMatrix m (n, n, 0.0);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2355 m.elem (0, k) = *complex_scalar;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2356 retval = tree_constant (m);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2357 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2358 else if (k < 0)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2359 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2360 ComplexMatrix m (n, n, 0.0);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2361 m.elem (-k, 0) = *complex_scalar;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2362 retval = tree_constant (m);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2363 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2364 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2365 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2366 case complex_matrix_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2367 if (a_type == scalar_constant)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2368 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2369 int k = NINT (tmp_a.double_value ());
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2370 int nr = rows ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2371 int nc = columns ();
420
b8c0ee979c15 [project @ 1994-05-23 06:55:52 by jwe]
jwe
parents: 394
diff changeset
2372 if (nr == 0 || nc == 0)
b8c0ee979c15 [project @ 1994-05-23 06:55:52 by jwe]
jwe
parents: 394
diff changeset
2373 {
421
92f07c38e821 [project @ 1994-05-23 07:07:47 by jwe]
jwe
parents: 420
diff changeset
2374 Matrix mtmp;
420
b8c0ee979c15 [project @ 1994-05-23 06:55:52 by jwe]
jwe
parents: 394
diff changeset
2375 retval = tree_constant (mtmp);
b8c0ee979c15 [project @ 1994-05-23 06:55:52 by jwe]
jwe
parents: 394
diff changeset
2376 }
b8c0ee979c15 [project @ 1994-05-23 06:55:52 by jwe]
jwe
parents: 394
diff changeset
2377 else if (nr == 1 || nc == 1)
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2378 retval = make_diag (complex_matrix_value (), k);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2379 else
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2380 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2381 ComplexColumnVector d = complex_matrix->diag (k);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2382 retval = tree_constant (d);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2383 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2384 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2385 else
240
a99f28f5e351 [project @ 1993-11-30 20:24:36 by jwe]
jwe
parents: 217
diff changeset
2386 ::error ("diag: invalid second argument");
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2387
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2388 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2389 case string_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2390 case range_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2391 case magic_colon:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2392 default:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2393 panic_impossible ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2394 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2395 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2396 return retval;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2397 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2398
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2399 tree_constant
164
e2c950dd96d2 [project @ 1993-10-18 19:32:00 by jwe]
jwe
parents: 161
diff changeset
2400 tree_constant_rep::mapper (Mapper_fcn& m_fcn, int print) const
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2401 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2402 tree_constant retval;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2403
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2404 if (type_tag == string_constant || type_tag == range_constant)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2405 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2406 tree_constant tmp = make_numeric ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2407 return tmp.mapper (m_fcn, print);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2408 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2409
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2410 switch (type_tag)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2411 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2412 case scalar_constant:
330
fe6e790846f5 [project @ 1994-02-04 04:54:47 by jwe]
jwe
parents: 312
diff changeset
2413 if (m_fcn.can_return_complex_for_real_arg
fe6e790846f5 [project @ 1994-02-04 04:54:47 by jwe]
jwe
parents: 312
diff changeset
2414 && (scalar < m_fcn.lower_limit
fe6e790846f5 [project @ 1994-02-04 04:54:47 by jwe]
jwe
parents: 312
diff changeset
2415 || scalar > m_fcn.upper_limit))
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2416 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2417 if (m_fcn.c_c_mapper != NULL)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2418 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2419 Complex c = m_fcn.c_c_mapper (Complex (scalar));
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2420 retval = tree_constant (c);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2421 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2422 else
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2423 panic_impossible ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2424 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2425 else
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2426 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2427 if (m_fcn.d_d_mapper != NULL)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2428 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2429 double d = m_fcn.d_d_mapper (scalar);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2430 retval = tree_constant (d);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2431 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2432 else
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2433 panic_impossible ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2434 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2435 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2436 case matrix_constant:
330
fe6e790846f5 [project @ 1994-02-04 04:54:47 by jwe]
jwe
parents: 312
diff changeset
2437 if (m_fcn.can_return_complex_for_real_arg
fe6e790846f5 [project @ 1994-02-04 04:54:47 by jwe]
jwe
parents: 312
diff changeset
2438 && (any_element_less_than (*matrix, m_fcn.lower_limit)
fe6e790846f5 [project @ 1994-02-04 04:54:47 by jwe]
jwe
parents: 312
diff changeset
2439 || any_element_greater_than (*matrix, m_fcn.upper_limit)))
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2440 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2441 if (m_fcn.c_c_mapper != NULL)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2442 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2443 ComplexMatrix cm = map (m_fcn.c_c_mapper,
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2444 ComplexMatrix (*matrix));
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2445 retval = tree_constant (cm);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2446 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2447 else
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2448 panic_impossible ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2449 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2450 else
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2451 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2452 if (m_fcn.d_d_mapper != NULL)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2453 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2454 Matrix m = map (m_fcn.d_d_mapper, *matrix);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2455 retval = tree_constant (m);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2456 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2457 else
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2458 panic_impossible ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2459 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2460 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2461 case complex_scalar_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2462 if (m_fcn.d_c_mapper != NULL)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2463 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2464 double d;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2465 d = m_fcn.d_c_mapper (*complex_scalar);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2466 retval = tree_constant (d);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2467 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2468 else if (m_fcn.c_c_mapper != NULL)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2469 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2470 Complex c;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2471 c = m_fcn.c_c_mapper (*complex_scalar);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2472 retval = tree_constant (c);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2473 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2474 else
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2475 panic_impossible ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2476 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2477 case complex_matrix_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2478 if (m_fcn.d_c_mapper != NULL)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2479 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2480 Matrix m;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2481 m = map (m_fcn.d_c_mapper, *complex_matrix);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2482 retval = tree_constant (m);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2483 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2484 else if (m_fcn.c_c_mapper != NULL)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2485 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2486 ComplexMatrix cm;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2487 cm = map (m_fcn.c_c_mapper, *complex_matrix);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2488 retval = tree_constant (cm);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2489 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2490 else
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2491 panic_impossible ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2492 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2493 case string_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2494 case range_constant:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2495 case magic_colon:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2496 default:
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2497 panic_impossible ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2498 break;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2499 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2500
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2501 if (retval.is_defined ())
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2502 return retval.eval (print);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2503 else
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2504 return retval;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2505 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2506
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2507 tree_constant::~tree_constant (void)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2508 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2509 #if defined (MDEBUG)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2510 cerr << "~tree_constant: rep: " << rep
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2511 << " rep->count: " << rep->count << "\n";
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2512 #endif
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2513
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2514 if (--rep->count <= 0)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2515 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2516 delete rep;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2517 rep = (tree_constant_rep *) NULL;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2518 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2519 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2520
259
23866011a5f2 [project @ 1993-12-14 22:21:12 by jwe]
jwe
parents: 240
diff changeset
2521 tree_constant
23866011a5f2 [project @ 1993-12-14 22:21:12 by jwe]
jwe
parents: 240
diff changeset
2522 tree_constant::eval (int argc, char **argv, int print)
23866011a5f2 [project @ 1993-12-14 22:21:12 by jwe]
jwe
parents: 240
diff changeset
2523 {
23866011a5f2 [project @ 1993-12-14 22:21:12 by jwe]
jwe
parents: 240
diff changeset
2524 ::error ("first element of word-list command is a constant");
23866011a5f2 [project @ 1993-12-14 22:21:12 by jwe]
jwe
parents: 240
diff changeset
2525 return tree_constant ();
23866011a5f2 [project @ 1993-12-14 22:21:12 by jwe]
jwe
parents: 240
diff changeset
2526 }
23866011a5f2 [project @ 1993-12-14 22:21:12 by jwe]
jwe
parents: 240
diff changeset
2527
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2528 #if defined (MDEBUG)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2529 void *
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2530 tree_constant::operator new (size_t size)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2531 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2532 tree_constant *p = ::new tree_constant;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2533 cerr << "tree_constant::new(): " << p << "\n";
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2534 return p;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2535 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2536
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2537 void
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2538 tree_constant::operator delete (void *p, size_t size)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2539 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2540 cerr << "tree_constant::delete(): " << p << "\n";
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2541 ::delete p;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2542 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2543 #endif
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2544
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2545 /*
96
36ff440553cd [project @ 1993-09-13 02:48:39 by jwe]
jwe
parents: 1
diff changeset
2546 * Construct return vector of empty matrices. Return empty matrices
36ff440553cd [project @ 1993-09-13 02:48:39 by jwe]
jwe
parents: 1
diff changeset
2547 * and/or gripe when appropriate.
36ff440553cd [project @ 1993-09-13 02:48:39 by jwe]
jwe
parents: 1
diff changeset
2548 */
36ff440553cd [project @ 1993-09-13 02:48:39 by jwe]
jwe
parents: 1
diff changeset
2549 tree_constant *
164
e2c950dd96d2 [project @ 1993-10-18 19:32:00 by jwe]
jwe
parents: 161
diff changeset
2550 vector_of_empties (int nargout, const char *fcn_name)
96
36ff440553cd [project @ 1993-09-13 02:48:39 by jwe]
jwe
parents: 1
diff changeset
2551 {
36ff440553cd [project @ 1993-09-13 02:48:39 by jwe]
jwe
parents: 1
diff changeset
2552 tree_constant *retval = NULL_TREE_CONST;
36ff440553cd [project @ 1993-09-13 02:48:39 by jwe]
jwe
parents: 1
diff changeset
2553
36ff440553cd [project @ 1993-09-13 02:48:39 by jwe]
jwe
parents: 1
diff changeset
2554 // Got an empty argument, check if should gripe/return empty values.
36ff440553cd [project @ 1993-09-13 02:48:39 by jwe]
jwe
parents: 1
diff changeset
2555
36ff440553cd [project @ 1993-09-13 02:48:39 by jwe]
jwe
parents: 1
diff changeset
2556 int flag = user_pref.propagate_empty_matrices;
36ff440553cd [project @ 1993-09-13 02:48:39 by jwe]
jwe
parents: 1
diff changeset
2557 if (flag != 0)
36ff440553cd [project @ 1993-09-13 02:48:39 by jwe]
jwe
parents: 1
diff changeset
2558 {
36ff440553cd [project @ 1993-09-13 02:48:39 by jwe]
jwe
parents: 1
diff changeset
2559 if (flag < 0)
36ff440553cd [project @ 1993-09-13 02:48:39 by jwe]
jwe
parents: 1
diff changeset
2560 gripe_empty_arg (fcn_name, 0);
36ff440553cd [project @ 1993-09-13 02:48:39 by jwe]
jwe
parents: 1
diff changeset
2561
36ff440553cd [project @ 1993-09-13 02:48:39 by jwe]
jwe
parents: 1
diff changeset
2562 Matrix m;
36ff440553cd [project @ 1993-09-13 02:48:39 by jwe]
jwe
parents: 1
diff changeset
2563 retval = new tree_constant [nargout+1];
36ff440553cd [project @ 1993-09-13 02:48:39 by jwe]
jwe
parents: 1
diff changeset
2564 for (int i = 0; i < nargout; i++)
36ff440553cd [project @ 1993-09-13 02:48:39 by jwe]
jwe
parents: 1
diff changeset
2565 retval[i] = tree_constant (m);
36ff440553cd [project @ 1993-09-13 02:48:39 by jwe]
jwe
parents: 1
diff changeset
2566 }
36ff440553cd [project @ 1993-09-13 02:48:39 by jwe]
jwe
parents: 1
diff changeset
2567 else
36ff440553cd [project @ 1993-09-13 02:48:39 by jwe]
jwe
parents: 1
diff changeset
2568 gripe_empty_arg (fcn_name, 1);
36ff440553cd [project @ 1993-09-13 02:48:39 by jwe]
jwe
parents: 1
diff changeset
2569
36ff440553cd [project @ 1993-09-13 02:48:39 by jwe]
jwe
parents: 1
diff changeset
2570 return retval;
36ff440553cd [project @ 1993-09-13 02:48:39 by jwe]
jwe
parents: 1
diff changeset
2571 }
36ff440553cd [project @ 1993-09-13 02:48:39 by jwe]
jwe
parents: 1
diff changeset
2572
455
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2573
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2574 /*
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2575 * Top-level tree-constant function that handles assignments. Only
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2576 * decide if the left-hand side is currently a scalar or a matrix and
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2577 * hand off to other functions to do the real work.
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2578 */
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2579 void
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2580 tree_constant_rep::assign (tree_constant& rhs, tree_constant *args, int nargs)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2581 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2582 tree_constant rhs_tmp = rhs.make_numeric ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2583
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2584 // This is easier than actually handling assignments to strings.
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2585 // An assignment to a range will normally require a conversion to a
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2586 // vector since it will normally destroy the equally-spaced property
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2587 // of the range elements.
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2588
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2589 if (type_tag == string_constant || type_tag == range_constant)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2590 force_numeric ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2591
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2592 switch (type_tag)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2593 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2594 case complex_scalar_constant:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2595 case scalar_constant:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2596 case unknown_constant:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2597 do_scalar_assignment (rhs_tmp, args, nargs);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2598 break;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2599 case complex_matrix_constant:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2600 case matrix_constant:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2601 do_matrix_assignment (rhs_tmp, args, nargs);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2602 break;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2603 case string_constant:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2604 ::error ("invalid assignment to string type");
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2605 break;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2606 case range_constant:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2607 case magic_colon:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2608 default:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2609 panic_impossible ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2610 break;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2611 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2612 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2613
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2614 /*
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2615 * Assignments to scalars. If resize_on_range_error is true,
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2616 * this can convert the left-hand size to a matrix.
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2617 */
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2618 void
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2619 tree_constant_rep::do_scalar_assignment (tree_constant& rhs,
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2620 tree_constant *args, int nargs)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2621 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2622 assert (type_tag == unknown_constant
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2623 || type_tag == scalar_constant
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2624 || type_tag == complex_scalar_constant);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2625
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2626 if ((rhs.is_scalar_type () || rhs.is_zero_by_zero ())
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2627 && valid_scalar_indices (args, nargs))
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2628 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2629 if (rhs.is_zero_by_zero ())
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2630 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2631 if (type_tag == complex_scalar_constant)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2632 delete complex_scalar;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2633
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2634 matrix = new Matrix (0, 0);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2635 type_tag = matrix_constant;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2636 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2637 else if (type_tag == unknown_constant || type_tag == scalar_constant)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2638 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2639 if (rhs.const_type () == scalar_constant)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2640 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2641 scalar = rhs.double_value ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2642 type_tag = scalar_constant;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2643 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2644 else if (rhs.const_type () == complex_scalar_constant)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2645 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2646 complex_scalar = new Complex (rhs.complex_value ());
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2647 type_tag = complex_scalar_constant;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2648 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2649 else
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2650 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2651 ::error ("invalid assignment to scalar");
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2652 return;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2653 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2654 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2655 else
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2656 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2657 if (rhs.const_type () == scalar_constant)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2658 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2659 delete complex_scalar;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2660 scalar = rhs.double_value ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2661 type_tag = scalar_constant;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2662 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2663 else if (rhs.const_type () == complex_scalar_constant)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2664 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2665 *complex_scalar = rhs.complex_value ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2666 type_tag = complex_scalar_constant;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2667 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2668 else
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2669 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2670 ::error ("invalid assignment to scalar");
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2671 return;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2672 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2673 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2674 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2675 else if (user_pref.resize_on_range_error)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2676 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2677 tree_constant_rep::constant_type old_type_tag = type_tag;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2678
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2679 if (type_tag == complex_scalar_constant)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2680 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2681 Complex *old_complex = complex_scalar;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2682 complex_matrix = new ComplexMatrix (1, 1, *complex_scalar);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2683 type_tag = complex_matrix_constant;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2684 delete old_complex;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2685 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2686 else if (type_tag == scalar_constant)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2687 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2688 matrix = new Matrix (1, 1, scalar);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2689 type_tag = matrix_constant;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2690 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2691
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2692 // If there is an error, the call to do_matrix_assignment should not
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2693 // destroy the current value. tree_constant_rep::eval(int) will take
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2694 // care of converting single element matrices back to scalars.
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2695
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2696 do_matrix_assignment (rhs, args, nargs);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2697
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2698 // I don't think there's any other way to revert back to unknown
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2699 // constant types, so here it is.
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2700
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2701 if (old_type_tag == unknown_constant && error_state)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2702 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2703 if (type_tag == matrix_constant)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2704 delete matrix;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2705 else if (type_tag == complex_matrix_constant)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2706 delete complex_matrix;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2707
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2708 type_tag = unknown_constant;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2709 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2710 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2711 else if (nargs > 3 || nargs < 2)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2712 ::error ("invalid index expression for scalar type");
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2713 else
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2714 ::error ("index invalid or out of range for scalar type");
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2715 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2716
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2717 /*
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2718 * Assignments to matrices (and vectors).
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2719 *
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2720 * For compatibility with Matlab, we allow assignment of an empty
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2721 * matrix to an expression with empty indices to do nothing.
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2722 */
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2723 void
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2724 tree_constant_rep::do_matrix_assignment (tree_constant& rhs,
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2725 tree_constant *args, int nargs)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2726 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2727 assert (type_tag == unknown_constant
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2728 || type_tag == matrix_constant
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2729 || type_tag == complex_matrix_constant);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2730
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2731 if (type_tag == matrix_constant && rhs.is_complex_type ())
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2732 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2733 Matrix *old_matrix = matrix;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2734 complex_matrix = new ComplexMatrix (*matrix);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2735 type_tag = complex_matrix_constant;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2736 delete old_matrix;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2737 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2738 else if (type_tag == unknown_constant)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2739 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2740 if (rhs.is_complex_type ())
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2741 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2742 complex_matrix = new ComplexMatrix ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2743 type_tag = complex_matrix_constant;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2744 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2745 else
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2746 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2747 matrix = new Matrix ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2748 type_tag = matrix_constant;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2749 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2750 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2751
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2752 // The do_matrix_assignment functions can't handle empty matrices, so
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2753 // don't let any pass through here.
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2754 switch (nargs)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2755 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2756 case 2:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2757 if (args == NULL_TREE_CONST)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2758 ::error ("matrix index is null");
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2759 else if (args[1].is_undefined ())
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2760 ::error ("matrix index is undefined");
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2761 else
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2762 do_matrix_assignment (rhs, args[1]);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2763 break;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2764 case 3:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2765 if (args == NULL_TREE_CONST)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2766 ::error ("matrix indices are null");
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2767 else if (args[1].is_undefined ())
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2768 ::error ("first matrix index is undefined");
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2769 else if (args[2].is_undefined ())
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2770 ::error ("second matrix index is undefined");
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2771 else if (args[1].is_empty () || args[2].is_empty ())
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2772 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2773 if (! rhs.is_empty ())
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2774 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2775 ::error ("in assignment expression, a matrix index is empty");
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2776 ::error ("but hte right hand side is not an empty matrix");
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2777 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2778 // XXX FIXME XXX -- to really be correct here, we should probably
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2779 // check to see if the assignment conforms, but that seems like more
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2780 // work than it's worth right now...
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2781 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2782 else
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2783 do_matrix_assignment (rhs, args[1], args[2]);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2784 break;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2785 default:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2786 ::error ("too many indices for matrix expression");
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2787 break;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2788 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2789 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2790
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2791 /*
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2792 * Matrix assignments indexed by a single value.
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2793 */
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2794 void
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2795 tree_constant_rep::do_matrix_assignment (tree_constant& rhs,
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2796 tree_constant& i_arg)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2797 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2798 int nr = rows ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2799 int nc = columns ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2800
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2801 if (user_pref.do_fortran_indexing || nr <= 1 || nc <= 1)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2802 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2803 if (i_arg.is_empty ())
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2804 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2805 if (! rhs.is_empty ())
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2806 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2807 ::error ("in assignment expression, matrix index is empty but");
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2808 ::error ("right hand side is not an empty matrix");
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2809 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2810 // XXX FIXME XXX -- to really be correct here, we should probably
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2811 // check to see if the assignment conforms, but that seems like more
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2812 // work than it's worth right now...
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2813
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2814 // The assignment functions can't handle empty matrices, so don't let
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2815 // any pass through here.
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2816 return;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2817 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2818
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2819 // We can't handle the case of assigning to a vector first, since even
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2820 // then, the two operations are not equivalent. For example, the
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2821 // expression V(:) = M is handled differently depending on whether the
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2822 // user specified do_fortran_indexing = "true".
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2823
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2824 if (user_pref.do_fortran_indexing)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2825 fortran_style_matrix_assignment (rhs, i_arg);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2826 else if (nr <= 1 || nc <= 1)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2827 vector_assignment (rhs, i_arg);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2828 else
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2829 panic_impossible ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2830 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2831 else
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2832 ::error ("single index only valid for row or column vector");
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2833 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2834
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2835 /*
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2836 * Fortran-style assignments. Matrices are assumed to be stored in
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2837 * column-major order and it is ok to use a single index for
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2838 * multi-dimensional matrices.
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2839 */
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2840 void
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2841 tree_constant_rep::fortran_style_matrix_assignment (tree_constant& rhs,
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2842 tree_constant& i_arg)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2843 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2844 tree_constant tmp_i = i_arg.make_numeric_or_magic ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2845
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2846 tree_constant_rep::constant_type itype = tmp_i.const_type ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2847
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2848 int nr = rows ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2849 int nc = columns ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2850
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2851 int rhs_nr = rhs.rows ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2852 int rhs_nc = rhs.columns ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2853
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2854 switch (itype)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2855 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2856 case complex_scalar_constant:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2857 case scalar_constant:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2858 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2859 int i = NINT (tmp_i.double_value ());
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2860 int idx = i - 1;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2861
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2862 if (rhs_nr == 0 && rhs_nc == 0)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2863 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2864 if (idx < nr * nc)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2865 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2866 convert_to_row_or_column_vector ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2867
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2868 nr = rows ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2869 nc = columns ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2870
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2871 if (nr == 1)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2872 delete_column (idx);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2873 else if (nc == 1)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2874 delete_row (idx);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2875 else
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2876 panic_impossible ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2877 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2878 return;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2879 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2880
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2881 if (index_check (idx, "") < 0)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2882 return;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2883
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2884 if (nr <= 1 || nc <= 1)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2885 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2886 maybe_resize (idx);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2887 if (error_state)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2888 return;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2889 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2890 else if (range_max_check (idx, nr * nc) < 0)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2891 return;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2892
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2893 nr = rows ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2894 nc = columns ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2895
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2896 if (! indexed_assign_conforms (1, 1, rhs_nr, rhs_nc))
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2897 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2898 ::error ("for A(int) = X: X must be a scalar");
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2899 return;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2900 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2901 int ii = fortran_row (i, nr) - 1;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2902 int jj = fortran_column (i, nr) - 1;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2903 do_matrix_assignment (rhs, ii, jj);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2904 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2905 break;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2906 case complex_matrix_constant:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2907 case matrix_constant:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2908 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2909 Matrix mi = tmp_i.matrix_value ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2910 int len = nr * nc;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2911 idx_vector ii (mi, 1, "", len); // Always do fortran indexing here...
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2912 if (! ii)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2913 return;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2914
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2915 if (rhs_nr == 0 && rhs_nc == 0)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2916 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2917 ii.sort_uniq ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2918 int num_to_delete = 0;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2919 for (int i = 0; i < ii.length (); i++)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2920 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2921 if (ii.elem (i) < len)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2922 num_to_delete++;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2923 else
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2924 break;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2925 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2926
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2927 if (num_to_delete > 0)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2928 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2929 if (num_to_delete != ii.length ())
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2930 ii.shorten (num_to_delete);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2931
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2932 convert_to_row_or_column_vector ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2933
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2934 nr = rows ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2935 nc = columns ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2936
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2937 if (nr == 1)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2938 delete_columns (ii);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2939 else if (nc == 1)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2940 delete_rows (ii);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2941 else
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2942 panic_impossible ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2943 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2944 return;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2945 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2946
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2947 if (nr <= 1 || nc <= 1)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2948 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2949 maybe_resize (ii.max ());
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2950 if (error_state)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2951 return;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2952 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2953 else if (range_max_check (ii.max (), len) < 0)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2954 return;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2955
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2956 int ilen = ii.capacity ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2957
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2958 if (ilen != rhs_nr * rhs_nc)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2959 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2960 ::error ("A(matrix) = X: X and matrix must have the same number");
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2961 ::error ("of elements");
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2962 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2963 else if (ilen == 1 && rhs.is_scalar_type ())
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2964 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2965 int nr = rows ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2966 int idx = ii.elem (0);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2967 int ii = fortran_row (idx + 1, nr) - 1;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2968 int jj = fortran_column (idx + 1, nr) - 1;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2969
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2970 if (rhs.const_type () == scalar_constant)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2971 matrix->elem (ii, jj) = rhs.double_value ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2972 else if (rhs.const_type () == complex_scalar_constant)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2973 complex_matrix->elem (ii, jj) = rhs.complex_value ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2974 else
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2975 panic_impossible ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2976 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2977 else
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2978 fortran_style_matrix_assignment (rhs, ii);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2979 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2980 break;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2981 case string_constant:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2982 gripe_string_invalid ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2983 break;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2984 case range_constant:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2985 gripe_range_invalid ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2986 break;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2987 case magic_colon:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2988 // a(:) = [] is equivalent to a(:,:) = foo.
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2989 if (rhs_nr == 0 && rhs_nc == 0)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2990 do_matrix_assignment (rhs, magic_colon, magic_colon);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2991 else
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2992 fortran_style_matrix_assignment (rhs, magic_colon);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2993 break;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2994 default:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2995 panic_impossible ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2996 break;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2997 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2998 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
2999
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3000 /*
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3001 * Fortran-style assignment for vector index.
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3002 */
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3003 void
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3004 tree_constant_rep::fortran_style_matrix_assignment (tree_constant& rhs,
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3005 idx_vector& i)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3006 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3007 assert (rhs.is_matrix_type ());
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3008
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3009 int ilen = i.capacity ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3010
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3011 REP_RHS_MATRIX (rhs, rhs_m, rhs_cm, rhs_nr, rhs_nc);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3012
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3013 int len = rhs_nr * rhs_nc;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3014
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3015 if (len == ilen)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3016 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3017 int nr = rows ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3018 if (rhs.const_type () == matrix_constant)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3019 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3020 double *cop_out = rhs_m.fortran_vec ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3021 for (int k = 0; k < len; k++)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3022 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3023 int ii = fortran_row (i.elem (k) + 1, nr) - 1;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3024 int jj = fortran_column (i.elem (k) + 1, nr) - 1;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3025
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3026 matrix->elem (ii, jj) = *cop_out++;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3027 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3028 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3029 else
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3030 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3031 Complex *cop_out = rhs_cm.fortran_vec ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3032 for (int k = 0; k < len; k++)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3033 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3034 int ii = fortran_row (i.elem (k) + 1, nr) - 1;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3035 int jj = fortran_column (i.elem (k) + 1, nr) - 1;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3036
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3037 complex_matrix->elem (ii, jj) = *cop_out++;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3038 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3039 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3040 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3041 else
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3042 ::error ("number of rows and columns must match for indexed assignment");
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3043 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3044
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3045 /*
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3046 * Fortran-style assignment for colon index.
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3047 */
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3048 void
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3049 tree_constant_rep::fortran_style_matrix_assignment
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3050 (tree_constant& rhs, tree_constant_rep::constant_type mci)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3051 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3052 assert (rhs.is_matrix_type () && mci == tree_constant_rep::magic_colon);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3053
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3054 int nr = rows ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3055 int nc = columns ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3056
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3057 REP_RHS_MATRIX (rhs, rhs_m, rhs_cm, rhs_nr, rhs_nc);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3058
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3059 int rhs_size = rhs_nr * rhs_nc;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3060 if (rhs_size == 0)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3061 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3062 if (rhs.const_type () == matrix_constant)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3063 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3064 delete matrix;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3065 matrix = new Matrix (0, 0);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3066 return;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3067 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3068 else
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3069 panic_impossible ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3070 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3071 else if (nr*nc != rhs_size)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3072 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3073 ::error ("A(:) = X: X and A must have the same number of elements");
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3074 return;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3075 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3076
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3077 if (rhs.const_type () == matrix_constant)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3078 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3079 double *cop_out = rhs_m.fortran_vec ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3080 for (int j = 0; j < nc; j++)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3081 for (int i = 0; i < nr; i++)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3082 matrix->elem (i, j) = *cop_out++;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3083 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3084 else
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3085 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3086 Complex *cop_out = rhs_cm.fortran_vec ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3087 for (int j = 0; j < nc; j++)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3088 for (int i = 0; i < nr; i++)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3089 complex_matrix->elem (i, j) = *cop_out++;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3090 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3091 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3092
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3093 /*
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3094 * Assignments to vectors. Hand off to other functions once we know
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3095 * what kind of index we have. For a colon, it is the same as
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3096 * assignment to a matrix indexed by two colons.
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3097 */
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3098 void
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3099 tree_constant_rep::vector_assignment (tree_constant& rhs, tree_constant& i_arg)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3100 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3101 int nr = rows ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3102 int nc = columns ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3103
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3104 assert ((nr == 1 || nc == 1 || (nr == 0 && nc == 0))
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3105 && ! user_pref.do_fortran_indexing);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3106
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3107 tree_constant tmp_i = i_arg.make_numeric_or_range_or_magic ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3108
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3109 tree_constant_rep::constant_type itype = tmp_i.const_type ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3110
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3111 switch (itype)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3112 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3113 case complex_scalar_constant:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3114 case scalar_constant:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3115 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3116 int i = tree_to_mat_idx (tmp_i.double_value ());
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3117 if (index_check (i, "") < 0)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3118 return;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3119 do_vector_assign (rhs, i);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3120 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3121 break;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3122 case complex_matrix_constant:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3123 case matrix_constant:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3124 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3125 Matrix mi = tmp_i.matrix_value ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3126 int len = nr * nc;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3127 idx_vector iv (mi, user_pref.do_fortran_indexing, "", len);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3128 if (! iv)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3129 return;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3130
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3131 do_vector_assign (rhs, iv);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3132 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3133 break;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3134 case string_constant:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3135 gripe_string_invalid ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3136 break;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3137 case range_constant:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3138 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3139 Range ri = tmp_i.range_value ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3140 int len = nr * nc;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3141 if (len == 2 && is_zero_one (ri))
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3142 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3143 do_vector_assign (rhs, 1);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3144 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3145 else if (len == 2 && is_one_zero (ri))
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3146 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3147 do_vector_assign (rhs, 0);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3148 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3149 else
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3150 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3151 if (index_check (ri, "") < 0)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3152 return;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3153 do_vector_assign (rhs, ri);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3154 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3155 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3156 break;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3157 case magic_colon:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3158 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3159 int rhs_nr = rhs.rows ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3160 int rhs_nc = rhs.columns ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3161
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3162 if (! indexed_assign_conforms (nr, nc, rhs_nr, rhs_nc))
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3163 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3164 ::error ("A(:) = X: X and A must have the same dimensions");
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3165 return;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3166 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3167 do_matrix_assignment (rhs, magic_colon, magic_colon);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3168 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3169 break;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3170 default:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3171 panic_impossible ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3172 break;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3173 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3174 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3175
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3176 /*
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3177 * Check whether an indexed assignment to a vector is valid.
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3178 */
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3179 void
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3180 tree_constant_rep::check_vector_assign (int rhs_nr, int rhs_nc,
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3181 int ilen, const char *rm)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3182 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3183 int nr = rows ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3184 int nc = columns ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3185
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3186 if ((nr == 1 && nc == 1) || nr == 0 || nc == 0) // No orientation.
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3187 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3188 if (! (ilen == rhs_nr || ilen == rhs_nc))
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3189 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3190 ::error ("A(%s) = X: X and %s must have the same number of elements",
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3191 rm, rm);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3192 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3193 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3194 else if (nr == 1) // Preserve current row orientation.
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3195 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3196 if (! (rhs_nr == 1 && rhs_nc == ilen))
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3197 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3198 ::error ("A(%s) = X: where A is a row vector, X must also be a", rm);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3199 ::error ("row vector with the same number of elements as %s", rm);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3200 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3201 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3202 else if (nc == 1) // Preserve current column orientation.
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3203 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3204 if (! (rhs_nc == 1 && rhs_nr == ilen))
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3205 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3206 ::error ("A(%s) = X: where A is a column vector, X must also be", rm);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3207 ::error ("a column vector with the same number of elements as %s", rm);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3208 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3209 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3210 else
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3211 panic_impossible ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3212 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3213
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3214 /*
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3215 * Assignment to a vector with an integer index.
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3216 */
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3217 void
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3218 tree_constant_rep::do_vector_assign (tree_constant& rhs, int i)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3219 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3220 int rhs_nr = rhs.rows ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3221 int rhs_nc = rhs.columns ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3222
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3223 if (indexed_assign_conforms (1, 1, rhs_nr, rhs_nc))
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3224 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3225 maybe_resize (i);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3226 if (error_state)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3227 return;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3228
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3229 int nr = rows ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3230 int nc = columns ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3231
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3232 if (nr == 1)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3233 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3234 REP_ELEM_ASSIGN (0, i, rhs.double_value (), rhs.complex_value (),
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3235 rhs.is_real_type ());
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3236 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3237 else if (nc == 1)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3238 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3239 REP_ELEM_ASSIGN (i, 0, rhs.double_value (), rhs.complex_value (),
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3240 rhs.is_real_type ());
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3241 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3242 else
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3243 panic_impossible ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3244 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3245 else if (rhs_nr == 0 && rhs_nc == 0)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3246 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3247 int nr = rows ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3248 int nc = columns ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3249
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3250 int len = nr > nc ? nr : nc;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3251
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3252 if (i < 0 || i >= len)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3253 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3254 ::error ("A(int) = []: index out of range");
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3255 return;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3256 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3257
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3258 if (nr == 1)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3259 delete_column (i);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3260 else if (nc == 1)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3261 delete_row (i);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3262 else
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3263 panic_impossible ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3264 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3265 else
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3266 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3267 ::error ("for A(int) = X: X must be a scalar");
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3268 return;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3269 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3270 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3271
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3272 /*
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3273 * Assignment to a vector with a vector index.
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3274 */
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3275 void
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3276 tree_constant_rep::do_vector_assign (tree_constant& rhs, idx_vector& iv)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3277 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3278 if (rhs.is_zero_by_zero ())
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3279 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3280 int nr = rows ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3281 int nc = columns ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3282
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3283 int len = nr > nc ? nr : nc;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3284
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3285 if (iv.max () >= len)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3286 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3287 ::error ("A(matrix) = []: index out of range");
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3288 return;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3289 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3290
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3291 if (nr == 1)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3292 delete_columns (iv);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3293 else if (nc == 1)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3294 delete_rows (iv);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3295 else
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3296 panic_impossible ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3297 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3298 else if (rhs.is_scalar_type ())
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3299 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3300 int nr = rows ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3301 int nc = columns ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3302
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3303 if (iv.capacity () == 1)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3304 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3305 int idx = iv.elem (0);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3306
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3307 if (nr == 1)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3308 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3309 REP_ELEM_ASSIGN (0, idx, rhs.double_value (),
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3310 rhs.complex_value (), rhs.is_real_type ());
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3311 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3312 else if (nc == 1)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3313 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3314 REP_ELEM_ASSIGN (idx, 0, rhs.double_value (),
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3315 rhs.complex_value (), rhs.is_real_type ());
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3316 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3317 else
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3318 panic_impossible ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3319 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3320 else
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3321 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3322 if (nr == 1)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3323 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3324 ::error ("A(matrix) = X: where A is a row vector, X must also be a");
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3325 ::error ("row vector with the same number of elements as matrix");
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3326 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3327 else if (nc == 1)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3328 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3329 ::error ("A(matrix) = X: where A is a column vector, X must also be a");
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3330 ::error ("column vector with the same number of elements as matrix");
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3331 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3332 else
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3333 panic_impossible ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3334 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3335 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3336 else if (rhs.is_matrix_type ())
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3337 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3338 REP_RHS_MATRIX (rhs, rhs_m, rhs_cm, rhs_nr, rhs_nc);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3339
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3340 int ilen = iv.capacity ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3341 check_vector_assign (rhs_nr, rhs_nc, ilen, "matrix");
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3342 if (error_state)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3343 return;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3344
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3345 force_orient f_orient = no_orient;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3346 if (rhs_nr == 1 && rhs_nc != 1)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3347 f_orient = row_orient;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3348 else if (rhs_nc == 1 && rhs_nr != 1)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3349 f_orient = column_orient;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3350
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3351 maybe_resize (iv.max (), f_orient);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3352 if (error_state)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3353 return;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3354
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3355 int nr = rows ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3356 int nc = columns ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3357
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3358 if (nr == 1)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3359 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3360 for (int i = 0; i < iv.capacity (); i++)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3361 REP_ELEM_ASSIGN (0, iv.elem (i), rhs_m.elem (0, i),
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3362 rhs_cm.elem (0, i), rhs.is_real_type ());
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3363 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3364 else if (nc == 1)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3365 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3366 for (int i = 0; i < iv.capacity (); i++)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3367 REP_ELEM_ASSIGN (iv.elem (i), 0, rhs_m.elem (i, 0),
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3368 rhs_cm.elem (i, 0), rhs.is_real_type ());
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3369 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3370 else
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3371 panic_impossible ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3372 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3373 else
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3374 panic_impossible ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3375 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3376
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3377 /*
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3378 * Assignment to a vector with a range index.
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3379 */
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3380 void
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3381 tree_constant_rep::do_vector_assign (tree_constant& rhs, Range& ri)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3382 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3383 if (rhs.is_zero_by_zero ())
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3384 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3385 int nr = rows ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3386 int nc = columns ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3387
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3388 int len = nr > nc ? nr : nc;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3389
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3390 int b = tree_to_mat_idx (ri.min ());
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3391 int l = tree_to_mat_idx (ri.max ());
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3392 if (b < 0 || l >= len)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3393 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3394 ::error ("A(range) = []: index out of range");
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3395 return;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3396 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3397
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3398 if (nr == 1)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3399 delete_columns (ri);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3400 else if (nc == 1)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3401 delete_rows (ri);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3402 else
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3403 panic_impossible ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3404 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3405 else if (rhs.is_scalar_type ())
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3406 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3407 int nr = rows ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3408 int nc = columns ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3409
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3410 if (nr == 1)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3411 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3412 ::error ("A(range) = X: where A is a row vector, X must also be a");
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3413 ::error ("row vector with the same number of elements as range");
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3414 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3415 else if (nc == 1)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3416 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3417 ::error ("A(range) = X: where A is a column vector, X must also be a");
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3418 ::error ("column vector with the same number of elements as range");
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3419 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3420 else
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3421 panic_impossible ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3422 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3423 else if (rhs.is_matrix_type ())
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3424 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3425 REP_RHS_MATRIX (rhs, rhs_m, rhs_cm, rhs_nr, rhs_nc);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3426
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3427 int ilen = ri.nelem ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3428 check_vector_assign (rhs_nr, rhs_nc, ilen, "range");
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3429 if (error_state)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3430 return;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3431
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3432 force_orient f_orient = no_orient;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3433 if (rhs_nr == 1 && rhs_nc != 1)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3434 f_orient = row_orient;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3435 else if (rhs_nc == 1 && rhs_nr != 1)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3436 f_orient = column_orient;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3437
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3438 maybe_resize (tree_to_mat_idx (ri.max ()), f_orient);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3439 if (error_state)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3440 return;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3441
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3442 int nr = rows ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3443 int nc = columns ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3444
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3445 double b = ri.base ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3446 double increment = ri.inc ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3447
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3448 if (nr == 1)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3449 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3450 for (int i = 0; i < ri.nelem (); i++)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3451 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3452 double tmp = b + i * increment;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3453 int col = tree_to_mat_idx (tmp);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3454 REP_ELEM_ASSIGN (0, col, rhs_m.elem (0, i), rhs_cm.elem (0, i),
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3455 rhs.is_real_type ());
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3456 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3457 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3458 else if (nc == 1)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3459 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3460 for (int i = 0; i < ri.nelem (); i++)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3461 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3462 double tmp = b + i * increment;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3463 int row = tree_to_mat_idx (tmp);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3464 REP_ELEM_ASSIGN (row, 0, rhs_m.elem (i, 0), rhs_cm.elem (i, 0),
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3465 rhs.is_real_type ());
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3466 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3467 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3468 else
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3469 panic_impossible ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3470 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3471 else
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3472 panic_impossible ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3473 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3474
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3475 /*
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3476 * Matrix assignment indexed by two values. This function determines
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3477 * the type of the first arugment, checks as much as possible, and
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3478 * then calls one of a set of functions to handle the specific cases:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3479 *
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3480 * M (integer, arg2) = RHS (MA1)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3481 * M (vector, arg2) = RHS (MA2)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3482 * M (range, arg2) = RHS (MA3)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3483 * M (colon, arg2) = RHS (MA4)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3484 *
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3485 * Each of those functions determines the type of the second argument
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3486 * and calls another function to handle the real work of doing the
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3487 * assignment.
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3488 */
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3489 void
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3490 tree_constant_rep::do_matrix_assignment (tree_constant& rhs,
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3491 tree_constant& i_arg,
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3492 tree_constant& j_arg)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3493 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3494 tree_constant tmp_i = i_arg.make_numeric_or_range_or_magic ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3495
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3496 tree_constant_rep::constant_type itype = tmp_i.const_type ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3497
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3498 switch (itype)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3499 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3500 case complex_scalar_constant:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3501 case scalar_constant:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3502 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3503 int i = tree_to_mat_idx (tmp_i.double_value ());
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3504 if (index_check (i, "row") < 0)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3505 return;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3506 do_matrix_assignment (rhs, i, j_arg);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3507 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3508 break;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3509 case complex_matrix_constant:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3510 case matrix_constant:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3511 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3512 Matrix mi = tmp_i.matrix_value ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3513 idx_vector iv (mi, user_pref.do_fortran_indexing, "row", rows ());
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3514 if (! iv)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3515 return;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3516
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3517 do_matrix_assignment (rhs, iv, j_arg);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3518 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3519 break;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3520 case string_constant:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3521 gripe_string_invalid ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3522 break;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3523 case range_constant:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3524 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3525 Range ri = tmp_i.range_value ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3526 int nr = rows ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3527 if (nr == 2 && is_zero_one (ri))
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3528 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3529 do_matrix_assignment (rhs, 1, j_arg);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3530 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3531 else if (nr == 2 && is_one_zero (ri))
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3532 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3533 do_matrix_assignment (rhs, 0, j_arg);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3534 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3535 else
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3536 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3537 if (index_check (ri, "row") < 0)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3538 return;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3539 do_matrix_assignment (rhs, ri, j_arg);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3540 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3541 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3542 break;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3543 case magic_colon:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3544 do_matrix_assignment (rhs, magic_colon, j_arg);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3545 break;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3546 default:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3547 panic_impossible ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3548 break;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3549 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3550 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3551
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3552 /* MA1 */
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3553 void
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3554 tree_constant_rep::do_matrix_assignment (tree_constant& rhs, int i,
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3555 tree_constant& j_arg)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3556 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3557 tree_constant tmp_j = j_arg.make_numeric_or_range_or_magic ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3558
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3559 tree_constant_rep::constant_type jtype = tmp_j.const_type ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3560
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3561 int rhs_nr = rhs.rows ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3562 int rhs_nc = rhs.columns ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3563
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3564 switch (jtype)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3565 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3566 case complex_scalar_constant:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3567 case scalar_constant:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3568 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3569 int j = tree_to_mat_idx (tmp_j.double_value ());
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3570 if (index_check (j, "column") < 0)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3571 return;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3572 if (! indexed_assign_conforms (1, 1, rhs_nr, rhs_nc))
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3573 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3574 ::error ("A(int,int) = X, X must be a scalar");
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3575 return;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3576 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3577 maybe_resize (i, j);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3578 if (error_state)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3579 return;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3580
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3581 do_matrix_assignment (rhs, i, j);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3582 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3583 break;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3584 case complex_matrix_constant:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3585 case matrix_constant:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3586 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3587 Matrix mj = tmp_j.matrix_value ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3588 idx_vector jv (mj, user_pref.do_fortran_indexing, "column",
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3589 columns ());
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3590 if (! jv)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3591 return;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3592
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3593 if (! indexed_assign_conforms (1, jv.capacity (), rhs_nr, rhs_nc))
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3594 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3595 ::error ("A(int,matrix) = X: X must be a row vector with the same");
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3596 ::error ("number of elements as matrix");
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3597 return;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3598 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3599 maybe_resize (i, jv.max ());
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3600 if (error_state)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3601 return;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3602
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3603 do_matrix_assignment (rhs, i, jv);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3604 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3605 break;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3606 case string_constant:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3607 gripe_string_invalid ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3608 break;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3609 case range_constant:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3610 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3611 Range rj = tmp_j.range_value ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3612 if (! indexed_assign_conforms (1, rj.nelem (), rhs_nr, rhs_nc))
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3613 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3614 ::error ("A(int,range) = X: X must be a row vector with the same");
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3615 ::error ("number of elements as range");
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3616 return;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3617 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3618
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3619 int nc = columns ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3620 if (nc == 2 && is_zero_one (rj) && rhs_nc == 1)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3621 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3622 do_matrix_assignment (rhs, i, 1);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3623 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3624 else if (nc == 2 && is_one_zero (rj) && rhs_nc == 1)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3625 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3626 do_matrix_assignment (rhs, i, 0);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3627 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3628 else
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3629 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3630 if (index_check (rj, "column") < 0)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3631 return;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3632 maybe_resize (i, tree_to_mat_idx (rj.max ()));
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3633 if (error_state)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3634 return;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3635
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3636 do_matrix_assignment (rhs, i, rj);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3637 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3638 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3639 break;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3640 case magic_colon:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3641 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3642 int nc = columns ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3643 int nr = rows ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3644 if (nc == 0 && nr == 0 && rhs_nr == 1)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3645 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3646 if (rhs.is_complex_type ())
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3647 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3648 complex_matrix = new ComplexMatrix ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3649 type_tag = complex_matrix_constant;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3650 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3651 else
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3652 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3653 matrix = new Matrix ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3654 type_tag = matrix_constant;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3655 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3656 maybe_resize (i, rhs_nc-1);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3657 if (error_state)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3658 return;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3659 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3660 else if (indexed_assign_conforms (1, nc, rhs_nr, rhs_nc))
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3661 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3662 maybe_resize (i, nc-1);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3663 if (error_state)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3664 return;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3665 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3666 else if (rhs_nr == 0 && rhs_nc == 0)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3667 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3668 if (i < 0 || i >= nr)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3669 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3670 ::error ("A(int,:) = []: row index out of range");
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3671 return;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3672 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3673 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3674 else
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3675 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3676 ::error ("A(int,:) = X: X must be a row vector with the same");
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3677 ::error ("number of columns as A");
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3678 return;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3679 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3680
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3681 do_matrix_assignment (rhs, i, magic_colon);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3682 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3683 break;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3684 default:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3685 panic_impossible ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3686 break;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3687 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3688 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3689
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3690 /* MA2 */
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3691 void
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3692 tree_constant_rep::do_matrix_assignment (tree_constant& rhs, idx_vector& iv,
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3693 tree_constant& j_arg)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3694 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3695 tree_constant tmp_j = j_arg.make_numeric_or_range_or_magic ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3696
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3697 tree_constant_rep::constant_type jtype = tmp_j.const_type ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3698
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3699 int rhs_nr = rhs.rows ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3700 int rhs_nc = rhs.columns ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3701
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3702 switch (jtype)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3703 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3704 case complex_scalar_constant:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3705 case scalar_constant:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3706 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3707 int j = tree_to_mat_idx (tmp_j.double_value ());
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3708 if (index_check (j, "column") < 0)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3709 return;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3710 if (! indexed_assign_conforms (iv.capacity (), 1, rhs_nr, rhs_nc))
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3711 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3712 ::error ("A(matrix,int) = X: X must be a column vector with the");
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3713 ::error ("same number of elements as matrix");
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3714 return;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3715 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3716 maybe_resize (iv.max (), j);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3717 if (error_state)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3718 return;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3719
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3720 do_matrix_assignment (rhs, iv, j);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3721 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3722 break;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3723 case complex_matrix_constant:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3724 case matrix_constant:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3725 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3726 Matrix mj = tmp_j.matrix_value ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3727 idx_vector jv (mj, user_pref.do_fortran_indexing, "column",
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3728 columns ());
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3729 if (! jv)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3730 return;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3731
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3732 if (! indexed_assign_conforms (iv.capacity (), jv.capacity (),
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3733 rhs_nr, rhs_nc))
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3734 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3735 ::error ("A(r_mat,c_mat) = X: the number of rows in X must match");
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3736 ::error ("the number of elements in r_mat and the number of");
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3737 ::error ("columns in X must match the number of elements in c_mat");
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3738 return;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3739 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3740 maybe_resize (iv.max (), jv.max ());
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3741 if (error_state)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3742 return;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3743
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3744 do_matrix_assignment (rhs, iv, jv);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3745 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3746 break;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3747 case string_constant:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3748 gripe_string_invalid ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3749 break;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3750 case range_constant:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3751 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3752 Range rj = tmp_j.range_value ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3753 if (! indexed_assign_conforms (iv.capacity (), rj.nelem (),
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3754 rhs_nr, rhs_nc))
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3755 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3756 ::error ("A(matrix,range) = X: the number of rows in X must match");
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3757 ::error ("the number of elements in matrix and the number of");
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3758 ::error ("columns in X must match the number of elements in range");
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3759 return;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3760 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3761
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3762 int nc = columns ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3763 if (nc == 2 && is_zero_one (rj) && rhs_nc == 1)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3764 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3765 do_matrix_assignment (rhs, iv, 1);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3766 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3767 else if (nc == 2 && is_one_zero (rj) && rhs_nc == 1)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3768 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3769 do_matrix_assignment (rhs, iv, 0);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3770 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3771 else
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3772 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3773 if (index_check (rj, "column") < 0)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3774 return;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3775 maybe_resize (iv.max (), tree_to_mat_idx (rj.max ()));
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3776 if (error_state)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3777 return;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3778
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3779 do_matrix_assignment (rhs, iv, rj);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3780 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3781 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3782 break;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3783 case magic_colon:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3784 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3785 int nc = columns ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3786 int new_nc = nc;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3787 if (nc == 0)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3788 new_nc = rhs_nc;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3789
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3790 if (indexed_assign_conforms (iv.capacity (), new_nc,
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3791 rhs_nr, rhs_nc))
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3792 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3793 maybe_resize (iv.max (), new_nc-1);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3794 if (error_state)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3795 return;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3796 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3797 else if (rhs_nr == 0 && rhs_nc == 0)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3798 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3799 if (iv.max () >= rows ())
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3800 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3801 ::error ("A(matrix,:) = []: row index out of range");
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3802 return;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3803 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3804 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3805 else
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3806 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3807 ::error ("A(matrix,:) = X: the number of rows in X must match the");
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3808 ::error ("number of elements in matrix, and the number of columns");
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3809 ::error ("in X must match the number of columns in A");
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3810 return;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3811 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3812
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3813 do_matrix_assignment (rhs, iv, magic_colon);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3814 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3815 break;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3816 default:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3817 panic_impossible ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3818 break;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3819 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3820 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3821
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3822 /* MA3 */
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3823 void
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3824 tree_constant_rep::do_matrix_assignment (tree_constant& rhs,
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3825 Range& ri, tree_constant& j_arg)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3826 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3827 tree_constant tmp_j = j_arg.make_numeric_or_range_or_magic ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3828
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3829 tree_constant_rep::constant_type jtype = tmp_j.const_type ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3830
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3831 int rhs_nr = rhs.rows ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3832 int rhs_nc = rhs.columns ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3833
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3834 switch (jtype)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3835 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3836 case complex_scalar_constant:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3837 case scalar_constant:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3838 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3839 int j = tree_to_mat_idx (tmp_j.double_value ());
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3840 if (index_check (j, "column") < 0)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3841 return;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3842 if (! indexed_assign_conforms (ri.nelem (), 1, rhs_nr, rhs_nc))
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3843 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3844 ::error ("A(range,int) = X: X must be a column vector with the");
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3845 ::error ("same number of elements as range");
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3846 return;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3847 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3848 maybe_resize (tree_to_mat_idx (ri.max ()), j);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3849 if (error_state)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3850 return;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3851
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3852 do_matrix_assignment (rhs, ri, j);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3853 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3854 break;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3855 case complex_matrix_constant:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3856 case matrix_constant:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3857 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3858 Matrix mj = tmp_j.matrix_value ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3859 idx_vector jv (mj, user_pref.do_fortran_indexing, "column",
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3860 columns ());
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3861 if (! jv)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3862 return;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3863
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3864 if (! indexed_assign_conforms (ri.nelem (), jv.capacity (),
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3865 rhs_nr, rhs_nc))
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3866 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3867 ::error ("A(range,matrix) = X: the number of rows in X must match");
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3868 ::error ("the number of elements in range and the number of");
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3869 ::error ("columns in X must match the number of elements in matrix");
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3870 return;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3871 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3872 maybe_resize (tree_to_mat_idx (ri.max ()), jv.max ());
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3873 if (error_state)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3874 return;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3875
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3876 do_matrix_assignment (rhs, ri, jv);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3877 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3878 break;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3879 case string_constant:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3880 gripe_string_invalid ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3881 break;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3882 case range_constant:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3883 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3884 Range rj = tmp_j.range_value ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3885 if (! indexed_assign_conforms (ri.nelem (), rj.nelem (),
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3886 rhs_nr, rhs_nc))
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3887 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3888 ::error ("A(r_range,c_range) = X: the number of rows in X must");
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3889 ::error ("match the number of elements in r_range and the number");
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3890 ::error ("of columns in X must match the number of elements in");
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3891 ::error ("c_range");
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3892 return;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3893 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3894
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3895 int nc = columns ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3896 if (nc == 2 && is_zero_one (rj) && rhs_nc == 1)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3897 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3898 do_matrix_assignment (rhs, ri, 1);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3899 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3900 else if (nc == 2 && is_one_zero (rj) && rhs_nc == 1)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3901 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3902 do_matrix_assignment (rhs, ri, 0);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3903 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3904 else
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3905 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3906 if (index_check (rj, "column") < 0)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3907 return;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3908
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3909 maybe_resize (tree_to_mat_idx (ri.max ()),
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3910 tree_to_mat_idx (rj.max ()));
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3911
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3912 if (error_state)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3913 return;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3914
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3915 do_matrix_assignment (rhs, ri, rj);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3916 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3917 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3918 break;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3919 case magic_colon:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3920 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3921 int nc = columns ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3922 int new_nc = nc;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3923 if (nc == 0)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3924 new_nc = rhs_nc;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3925
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3926 if (indexed_assign_conforms (ri.nelem (), new_nc, rhs_nr, rhs_nc))
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3927 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3928 maybe_resize (tree_to_mat_idx (ri.max ()), new_nc-1);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3929 if (error_state)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3930 return;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3931 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3932 else if (rhs_nr == 0 && rhs_nc == 0)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3933 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3934 int b = tree_to_mat_idx (ri.min ());
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3935 int l = tree_to_mat_idx (ri.max ());
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3936 if (b < 0 || l >= rows ())
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3937 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3938 ::error ("A(range,:) = []: row index out of range");
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3939 return;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3940 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3941 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3942 else
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3943 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3944 ::error ("A(range,:) = X: the number of rows in X must match the");
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3945 ::error ("number of elements in range, and the number of columns");
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3946 ::error ("in X must match the number of columns in A");
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3947 return;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3948 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3949
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3950 do_matrix_assignment (rhs, ri, magic_colon);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3951 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3952 break;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3953 default:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3954 panic_impossible ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3955 break;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3956 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3957 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3958
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3959 /* MA4 */
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3960 void
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3961 tree_constant_rep::do_matrix_assignment (tree_constant& rhs,
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3962 tree_constant_rep::constant_type i,
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3963 tree_constant& j_arg)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3964 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3965 tree_constant tmp_j = j_arg.make_numeric_or_range_or_magic ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3966
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3967 tree_constant_rep::constant_type jtype = tmp_j.const_type ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3968
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3969 int rhs_nr = rhs.rows ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3970 int rhs_nc = rhs.columns ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3971
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3972 switch (jtype)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3973 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3974 case complex_scalar_constant:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3975 case scalar_constant:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3976 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3977 int j = tree_to_mat_idx (tmp_j.double_value ());
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3978 if (index_check (j, "column") < 0)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3979 return;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3980 int nr = rows ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3981 int nc = columns ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3982 if (nr == 0 && nc == 0 && rhs_nc == 1)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3983 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3984 if (rhs.is_complex_type ())
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3985 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3986 complex_matrix = new ComplexMatrix ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3987 type_tag = complex_matrix_constant;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3988 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3989 else
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3990 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3991 matrix = new Matrix ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3992 type_tag = matrix_constant;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3993 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3994 maybe_resize (rhs_nr-1, j);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3995 if (error_state)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3996 return;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3997 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3998 else if (indexed_assign_conforms (nr, 1, rhs_nr, rhs_nc))
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
3999 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4000 maybe_resize (nr-1, j);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4001 if (error_state)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4002 return;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4003 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4004 else if (rhs_nr == 0 && rhs_nc == 0)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4005 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4006 if (j < 0 || j >= nc)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4007 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4008 ::error ("A(:,int) = []: column index out of range");
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4009 return;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4010 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4011 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4012 else
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4013 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4014 ::error ("A(:,int) = X: X must be a column vector with the same");
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4015 ::error ("number of rows as A");
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4016 return;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4017 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4018
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4019 do_matrix_assignment (rhs, magic_colon, j);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4020 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4021 break;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4022 case complex_matrix_constant:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4023 case matrix_constant:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4024 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4025 Matrix mj = tmp_j.matrix_value ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4026 idx_vector jv (mj, user_pref.do_fortran_indexing, "column",
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4027 columns ());
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4028 if (! jv)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4029 return;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4030
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4031 int nr = rows ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4032 int new_nr = nr;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4033 if (nr == 0)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4034 new_nr = rhs_nr;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4035
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4036 if (indexed_assign_conforms (new_nr, jv.capacity (),
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4037 rhs_nr, rhs_nc))
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4038 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4039 maybe_resize (new_nr-1, jv.max ());
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4040 if (error_state)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4041 return;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4042 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4043 else if (rhs_nr == 0 && rhs_nc == 0)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4044 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4045 if (jv.max () >= columns ())
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4046 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4047 ::error ("A(:,matrix) = []: column index out of range");
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4048 return;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4049 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4050 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4051 else
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4052 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4053 ::error ("A(:,matrix) = X: the number of rows in X must match the");
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4054 ::error ("number of rows in A, and the number of columns in X must");
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4055 ::error ("match the number of elements in matrix");
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4056 return;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4057 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4058
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4059 do_matrix_assignment (rhs, magic_colon, jv);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4060 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4061 break;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4062 case string_constant:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4063 gripe_string_invalid ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4064 break;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4065 case range_constant:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4066 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4067 Range rj = tmp_j.range_value ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4068 int nr = rows ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4069 int new_nr = nr;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4070 if (nr == 0)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4071 new_nr = rhs_nr;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4072
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4073 if (indexed_assign_conforms (new_nr, rj.nelem (), rhs_nr, rhs_nc))
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4074 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4075 int nc = columns ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4076 if (nc == 2 && is_zero_one (rj) && rhs_nc == 1)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4077 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4078 do_matrix_assignment (rhs, magic_colon, 1);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4079 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4080 else if (nc == 2 && is_one_zero (rj) && rhs_nc == 1)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4081 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4082 do_matrix_assignment (rhs, magic_colon, 0);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4083 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4084 else
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4085 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4086 if (index_check (rj, "column") < 0)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4087 return;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4088 maybe_resize (new_nr-1, tree_to_mat_idx (rj.max ()));
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4089 if (error_state)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4090 return;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4091 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4092 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4093 else if (rhs_nr == 0 && rhs_nc == 0)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4094 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4095 int b = tree_to_mat_idx (rj.min ());
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4096 int l = tree_to_mat_idx (rj.max ());
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4097 if (b < 0 || l >= columns ())
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4098 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4099 ::error ("A(:,range) = []: column index out of range");
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4100 return;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4101 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4102 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4103 else
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4104 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4105 ::error ("A(:,range) = X: the number of rows in X must match the");
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4106 ::error ("number of rows in A, and the number of columns in X");
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4107 ::error ("must match the number of elements in range");
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4108 return;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4109 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4110
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4111 do_matrix_assignment (rhs, magic_colon, rj);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4112 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4113 break;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4114 case magic_colon:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4115 // a(:,:) = foo is equivalent to a = foo.
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4116 do_matrix_assignment (rhs, magic_colon, magic_colon);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4117 break;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4118 default:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4119 panic_impossible ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4120 break;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4121 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4122 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4123
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4124 /*
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4125 * Functions that actually handle assignment to a matrix using two
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4126 * index values.
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4127 *
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4128 * idx2
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4129 * +---+---+----+----+
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4130 * idx1 | i | v | r | c |
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4131 * ---------+---+---+----+----+
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4132 * integer | 1 | 5 | 9 | 13 |
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4133 * ---------+---+---+----+----+
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4134 * vector | 2 | 6 | 10 | 14 |
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4135 * ---------+---+---+----+----+
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4136 * range | 3 | 7 | 11 | 15 |
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4137 * ---------+---+---+----+----+
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4138 * colon | 4 | 8 | 12 | 16 |
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4139 * ---------+---+---+----+----+
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4140 */
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4141
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4142 /* 1 */
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4143 void
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4144 tree_constant_rep::do_matrix_assignment (tree_constant& rhs, int i, int j)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4145 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4146 REP_ELEM_ASSIGN (i, j, rhs.double_value (), rhs.complex_value (),
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4147 rhs.is_real_type ());
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4148 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4149
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4150 /* 2 */
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4151 void
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4152 tree_constant_rep::do_matrix_assignment (tree_constant& rhs, int i,
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4153 idx_vector& jv)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4154 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4155 REP_RHS_MATRIX (rhs, rhs_m, rhs_cm, rhs_nr, rhs_nc);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4156
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4157 for (int j = 0; j < jv.capacity (); j++)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4158 REP_ELEM_ASSIGN (i, jv.elem (j), rhs_m.elem (0, j),
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4159 rhs_cm.elem (0, j), rhs.is_real_type ());
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4160 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4161
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4162 /* 3 */
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4163 void
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4164 tree_constant_rep::do_matrix_assignment (tree_constant& rhs, int i, Range& rj)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4165 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4166 REP_RHS_MATRIX (rhs, rhs_m, rhs_cm, rhs_nr, rhs_nc);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4167
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4168 double b = rj.base ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4169 double increment = rj.inc ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4170
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4171 for (int j = 0; j < rj.nelem (); j++)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4172 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4173 double tmp = b + j * increment;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4174 int col = tree_to_mat_idx (tmp);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4175 REP_ELEM_ASSIGN (i, col, rhs_m.elem (0, j), rhs_cm.elem (0, j),
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4176 rhs.is_real_type ());
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4177 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4178 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4179
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4180 /* 4 */
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4181 void
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4182 tree_constant_rep::do_matrix_assignment (tree_constant& rhs, int i,
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4183 tree_constant_rep::constant_type mcj)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4184 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4185 assert (mcj == magic_colon);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4186
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4187 int nc = columns ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4188
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4189 if (rhs.is_zero_by_zero ())
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4190 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4191 delete_row (i);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4192 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4193 else if (rhs.is_matrix_type ())
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4194 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4195 REP_RHS_MATRIX (rhs, rhs_m, rhs_cm, rhs_nr, rhs_nc);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4196
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4197 for (int j = 0; j < nc; j++)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4198 REP_ELEM_ASSIGN (i, j, rhs_m.elem (0, j), rhs_cm.elem (0, j),
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4199 rhs.is_real_type ());
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4200 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4201 else if (rhs.is_scalar_type () && nc == 1)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4202 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4203 REP_ELEM_ASSIGN (i, 0, rhs.double_value (),
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4204 rhs.complex_value (), rhs.is_real_type ());
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4205 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4206 else
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4207 panic_impossible ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4208 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4209
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4210 /* 5 */
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4211 void
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4212 tree_constant_rep::do_matrix_assignment (tree_constant& rhs,
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4213 idx_vector& iv, int j)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4214 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4215 REP_RHS_MATRIX (rhs, rhs_m, rhs_cm, rhs_nr, rhs_nc);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4216
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4217 for (int i = 0; i < iv.capacity (); i++)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4218 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4219 int row = iv.elem (i);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4220 REP_ELEM_ASSIGN (row, j, rhs_m.elem (i, 0),
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4221 rhs_cm.elem (i, 0), rhs.is_real_type ());
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4222 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4223 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4224
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4225 /* 6 */
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4226 void
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4227 tree_constant_rep::do_matrix_assignment (tree_constant& rhs,
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4228 idx_vector& iv, idx_vector& jv)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4229 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4230 REP_RHS_MATRIX (rhs, rhs_m, rhs_cm, rhs_nr, rhs_nc);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4231
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4232 for (int i = 0; i < iv.capacity (); i++)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4233 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4234 int row = iv.elem (i);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4235 for (int j = 0; j < jv.capacity (); j++)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4236 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4237 int col = jv.elem (j);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4238 REP_ELEM_ASSIGN (row, col, rhs_m.elem (i, j),
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4239 rhs_cm.elem (i, j), rhs.is_real_type ());
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4240 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4241 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4242 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4243
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4244 /* 7 */
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4245 void
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4246 tree_constant_rep::do_matrix_assignment (tree_constant& rhs,
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4247 idx_vector& iv, Range& rj)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4248 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4249 REP_RHS_MATRIX (rhs, rhs_m, rhs_cm, rhs_nr, rhs_nc);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4250
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4251 double b = rj.base ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4252 double increment = rj.inc ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4253
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4254 for (int i = 0; i < iv.capacity (); i++)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4255 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4256 int row = iv.elem (i);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4257 for (int j = 0; j < rj.nelem (); j++)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4258 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4259 double tmp = b + j * increment;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4260 int col = tree_to_mat_idx (tmp);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4261 REP_ELEM_ASSIGN (row, col, rhs_m.elem (i, j),
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4262 rhs_cm.elem (i, j), rhs.is_real_type ());
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4263 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4264 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4265 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4266
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4267 /* 8 */
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4268 void
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4269 tree_constant_rep::do_matrix_assignment (tree_constant& rhs, idx_vector& iv,
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4270 tree_constant_rep::constant_type mcj)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4271 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4272 assert (mcj == magic_colon);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4273
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4274 if (rhs.is_zero_by_zero ())
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4275 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4276 delete_rows (iv);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4277 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4278 else
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4279 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4280 REP_RHS_MATRIX (rhs, rhs_m, rhs_cm, rhs_nr, rhs_nc);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4281
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4282 int nc = columns ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4283
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4284 for (int j = 0; j < nc; j++)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4285 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4286 for (int i = 0; i < iv.capacity (); i++)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4287 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4288 int row = iv.elem (i);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4289 REP_ELEM_ASSIGN (row, j, rhs_m.elem (i, j),
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4290 rhs_cm.elem (i, j), rhs.is_real_type ());
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4291 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4292 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4293 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4294 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4295
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4296 /* 9 */
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4297 void
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4298 tree_constant_rep::do_matrix_assignment (tree_constant& rhs, Range& ri, int j)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4299 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4300 REP_RHS_MATRIX (rhs, rhs_m, rhs_cm, rhs_nr, rhs_nc);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4301
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4302 double b = ri.base ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4303 double increment = ri.inc ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4304
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4305 for (int i = 0; i < ri.nelem (); i++)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4306 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4307 double tmp = b + i * increment;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4308 int row = tree_to_mat_idx (tmp);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4309 REP_ELEM_ASSIGN (row, j, rhs_m.elem (i, 0),
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4310 rhs_cm.elem (i, 0), rhs.is_real_type ());
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4311 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4312 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4313
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4314 /* 10 */
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4315 void
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4316 tree_constant_rep::do_matrix_assignment (tree_constant& rhs, Range& ri,
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4317 idx_vector& jv)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4318 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4319 REP_RHS_MATRIX (rhs, rhs_m, rhs_cm, rhs_nr, rhs_nc);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4320
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4321 double b = ri.base ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4322 double increment = ri.inc ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4323
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4324 for (int j = 0; j < jv.capacity (); j++)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4325 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4326 int col = jv.elem (j);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4327 for (int i = 0; i < ri.nelem (); i++)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4328 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4329 double tmp = b + i * increment;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4330 int row = tree_to_mat_idx (tmp);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4331 REP_ELEM_ASSIGN (row, col, rhs_m.elem (i, j),
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4332 rhs_m.elem (i, j), rhs.is_real_type ());
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4333 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4334 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4335 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4336
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4337 /* 11 */
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4338 void
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4339 tree_constant_rep::do_matrix_assignment (tree_constant& rhs, Range& ri,
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4340 Range& rj)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4341 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4342 double ib = ri.base ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4343 double iinc = ri.inc ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4344 double jb = rj.base ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4345 double jinc = rj.inc ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4346
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4347 REP_RHS_MATRIX (rhs, rhs_m, rhs_cm, rhs_nr, rhs_nc);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4348
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4349 for (int i = 0; i < ri.nelem (); i++)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4350 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4351 double itmp = ib + i * iinc;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4352 int row = tree_to_mat_idx (itmp);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4353 for (int j = 0; j < rj.nelem (); j++)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4354 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4355 double jtmp = jb + j * jinc;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4356 int col = tree_to_mat_idx (jtmp);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4357 REP_ELEM_ASSIGN (row, col, rhs_m.elem (i, j),
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4358 rhs_cm.elem (i, j), rhs.is_real_type ());
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4359 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4360 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4361 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4362
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4363 /* 12 */
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4364 void
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4365 tree_constant_rep::do_matrix_assignment (tree_constant& rhs, Range& ri,
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4366 tree_constant_rep::constant_type mcj)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4367 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4368 assert (mcj == magic_colon);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4369
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4370 if (rhs.is_zero_by_zero ())
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4371 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4372 delete_rows (ri);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4373 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4374 else
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4375 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4376 REP_RHS_MATRIX (rhs, rhs_m, rhs_cm, rhs_nr, rhs_nc);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4377
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4378 double ib = ri.base ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4379 double iinc = ri.inc ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4380
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4381 int nc = columns ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4382
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4383 for (int i = 0; i < ri.nelem (); i++)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4384 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4385 double itmp = ib + i * iinc;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4386 int row = tree_to_mat_idx (itmp);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4387 for (int j = 0; j < nc; j++)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4388 REP_ELEM_ASSIGN (row, j, rhs_m.elem (i, j),
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4389 rhs_cm.elem (i, j), rhs.is_real_type ());
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4390 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4391 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4392 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4393
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4394 /* 13 */
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4395 void
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4396 tree_constant_rep::do_matrix_assignment (tree_constant& rhs,
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4397 tree_constant_rep::constant_type mci,
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4398 int j)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4399 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4400 assert (mci == magic_colon);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4401
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4402 int nr = rows ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4403
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4404 if (rhs.is_zero_by_zero ())
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4405 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4406 delete_column (j);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4407 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4408 else if (rhs.is_matrix_type ())
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4409 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4410 REP_RHS_MATRIX (rhs, rhs_m, rhs_cm, rhs_nr, rhs_nc);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4411
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4412 for (int i = 0; i < nr; i++)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4413 REP_ELEM_ASSIGN (i, j, rhs_m.elem (i, 0),
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4414 rhs_cm.elem (i, 0), rhs.is_real_type ());
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4415 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4416 else if (rhs.is_scalar_type () && nr == 1)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4417 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4418 REP_ELEM_ASSIGN (0, j, rhs.double_value (),
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4419 rhs.complex_value (), rhs.is_real_type ());
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4420 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4421 else
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4422 panic_impossible ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4423 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4424
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4425 /* 14 */
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4426 void
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4427 tree_constant_rep::do_matrix_assignment (tree_constant& rhs,
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4428 tree_constant_rep::constant_type mci,
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4429 idx_vector& jv)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4430 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4431 assert (mci == magic_colon);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4432
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4433 if (rhs.is_zero_by_zero ())
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4434 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4435 delete_columns (jv);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4436 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4437 else
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4438 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4439 REP_RHS_MATRIX (rhs, rhs_m, rhs_cm, rhs_nr, rhs_nc);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4440
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4441 int nr = rows ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4442
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4443 for (int i = 0; i < nr; i++)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4444 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4445 for (int j = 0; j < jv.capacity (); j++)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4446 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4447 int col = jv.elem (j);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4448 REP_ELEM_ASSIGN (i, col, rhs_m.elem (i, j),
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4449 rhs_cm.elem (i, j), rhs.is_real_type ());
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4450 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4451 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4452 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4453 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4454
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4455 /* 15 */
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4456 void
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4457 tree_constant_rep::do_matrix_assignment (tree_constant& rhs,
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4458 tree_constant_rep::constant_type mci,
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4459 Range& rj)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4460 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4461 assert (mci == magic_colon);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4462
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4463 if (rhs.is_zero_by_zero ())
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4464 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4465 delete_columns (rj);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4466 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4467 else
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4468 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4469 REP_RHS_MATRIX (rhs, rhs_m, rhs_cm, rhs_nr, rhs_nc);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4470
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4471 int nr = rows ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4472
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4473 double jb = rj.base ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4474 double jinc = rj.inc ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4475
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4476 for (int j = 0; j < rj.nelem (); j++)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4477 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4478 double jtmp = jb + j * jinc;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4479 int col = tree_to_mat_idx (jtmp);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4480 for (int i = 0; i < nr; i++)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4481 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4482 REP_ELEM_ASSIGN (i, col, rhs_m.elem (i, j),
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4483 rhs_cm.elem (i, j), rhs.is_real_type ());
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4484 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4485 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4486 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4487 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4488
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4489 /* 16 */
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4490 void
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4491 tree_constant_rep::do_matrix_assignment (tree_constant& rhs,
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4492 tree_constant_rep::constant_type mci,
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4493 tree_constant_rep::constant_type mcj)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4494 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4495 assert (mci == magic_colon && mcj == magic_colon);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4496
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4497 switch (type_tag)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4498 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4499 case scalar_constant:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4500 break;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4501 case matrix_constant:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4502 delete matrix;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4503 break;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4504 case complex_scalar_constant:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4505 delete complex_scalar;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4506 break;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4507 case complex_matrix_constant:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4508 delete complex_matrix;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4509 break;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4510 case string_constant:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4511 delete [] string;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4512 break;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4513 case range_constant:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4514 delete range;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4515 break;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4516 case magic_colon:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4517 default:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4518 panic_impossible ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4519 break;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4520 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4521
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4522 type_tag = rhs.const_type ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4523
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4524 switch (type_tag)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4525 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4526 case scalar_constant:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4527 scalar = rhs.double_value ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4528 break;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4529 case matrix_constant:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4530 matrix = new Matrix (rhs.matrix_value ());
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4531 break;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4532 case string_constant:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4533 string = strsave (rhs.string_value ());
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4534 break;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4535 case complex_matrix_constant:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4536 complex_matrix = new ComplexMatrix (rhs.complex_matrix_value ());
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4537 break;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4538 case complex_scalar_constant:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4539 complex_scalar = new Complex (rhs.complex_value ());
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4540 break;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4541 case range_constant:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4542 range = new Range (rhs.range_value ());
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4543 break;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4544 case magic_colon:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4545 default:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4546 panic_impossible ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4547 break;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4548 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4549 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4550
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4551 /*
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4552 * Functions for deleting rows or columns of a matrix. These are used
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4553 * to handle statements like
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4554 *
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4555 * M (i, j) = []
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4556 */
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4557 void
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4558 tree_constant_rep::delete_row (int idx)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4559 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4560 if (type_tag == matrix_constant)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4561 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4562 int nr = matrix->rows ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4563 int nc = matrix->columns ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4564 Matrix *new_matrix = new Matrix (nr-1, nc);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4565 int ii = 0;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4566 for (int i = 0; i < nr; i++)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4567 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4568 if (i != idx)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4569 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4570 for (int j = 0; j < nc; j++)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4571 new_matrix->elem (ii, j) = matrix->elem (i, j);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4572 ii++;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4573 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4574 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4575 delete matrix;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4576 matrix = new_matrix;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4577 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4578 else if (type_tag == complex_matrix_constant)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4579 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4580 int nr = complex_matrix->rows ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4581 int nc = complex_matrix->columns ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4582 ComplexMatrix *new_matrix = new ComplexMatrix (nr-1, nc);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4583 int ii = 0;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4584 for (int i = 0; i < nr; i++)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4585 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4586 if (i != idx)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4587 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4588 for (int j = 0; j < nc; j++)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4589 new_matrix->elem (ii, j) = complex_matrix->elem (i, j);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4590 ii++;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4591 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4592 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4593 delete complex_matrix;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4594 complex_matrix = new_matrix;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4595 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4596 else
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4597 panic_impossible ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4598 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4599
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4600 void
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4601 tree_constant_rep::delete_rows (idx_vector& iv)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4602 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4603 iv.sort_uniq ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4604 int num_to_delete = iv.length ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4605
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4606 int nr = rows ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4607 int nc = columns ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4608
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4609 // If deleting all rows of a column vector, make result 0x0.
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4610 if (nc == 1 && num_to_delete == nr)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4611 nc = 0;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4612
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4613 if (type_tag == matrix_constant)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4614 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4615 Matrix *new_matrix = new Matrix (nr-num_to_delete, nc);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4616 if (nr > num_to_delete)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4617 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4618 int ii = 0;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4619 int idx = 0;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4620 for (int i = 0; i < nr; i++)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4621 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4622 if (i == iv.elem (idx))
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4623 idx++;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4624 else
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4625 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4626 for (int j = 0; j < nc; j++)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4627 new_matrix->elem (ii, j) = matrix->elem (i, j);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4628 ii++;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4629 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4630 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4631 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4632 delete matrix;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4633 matrix = new_matrix;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4634 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4635 else if (type_tag == complex_matrix_constant)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4636 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4637 ComplexMatrix *new_matrix = new ComplexMatrix (nr-num_to_delete, nc);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4638 if (nr > num_to_delete)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4639 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4640 int ii = 0;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4641 int idx = 0;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4642 for (int i = 0; i < nr; i++)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4643 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4644 if (i == iv.elem (idx))
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4645 idx++;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4646 else
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4647 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4648 for (int j = 0; j < nc; j++)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4649 new_matrix->elem (ii, j) = complex_matrix->elem (i, j);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4650 ii++;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4651 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4652 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4653 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4654 delete complex_matrix;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4655 complex_matrix = new_matrix;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4656 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4657 else
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4658 panic_impossible ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4659 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4660
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4661 void
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4662 tree_constant_rep::delete_rows (Range& ri)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4663 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4664 ri.sort ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4665 int num_to_delete = ri.nelem ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4666
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4667 int nr = rows ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4668 int nc = columns ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4669
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4670 // If deleting all rows of a column vector, make result 0x0.
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4671 if (nc == 1 && num_to_delete == nr)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4672 nc = 0;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4673
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4674 double ib = ri.base ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4675 double iinc = ri.inc ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4676
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4677 int max_idx = tree_to_mat_idx (ri.max ());
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4678
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4679 if (type_tag == matrix_constant)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4680 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4681 Matrix *new_matrix = new Matrix (nr-num_to_delete, nc);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4682 if (nr > num_to_delete)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4683 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4684 int ii = 0;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4685 int idx = 0;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4686 for (int i = 0; i < nr; i++)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4687 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4688 double itmp = ib + idx * iinc;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4689 int row = tree_to_mat_idx (itmp);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4690
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4691 if (i == row && row <= max_idx)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4692 idx++;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4693 else
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4694 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4695 for (int j = 0; j < nc; j++)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4696 new_matrix->elem (ii, j) = matrix->elem (i, j);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4697 ii++;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4698 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4699 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4700 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4701 delete matrix;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4702 matrix = new_matrix;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4703 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4704 else if (type_tag == complex_matrix_constant)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4705 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4706 ComplexMatrix *new_matrix = new ComplexMatrix (nr-num_to_delete, nc);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4707 if (nr > num_to_delete)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4708 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4709 int ii = 0;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4710 int idx = 0;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4711 for (int i = 0; i < nr; i++)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4712 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4713 double itmp = ib + idx * iinc;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4714 int row = tree_to_mat_idx (itmp);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4715
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4716 if (i == row && row <= max_idx)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4717 idx++;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4718 else
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4719 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4720 for (int j = 0; j < nc; j++)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4721 new_matrix->elem (ii, j) = complex_matrix->elem (i, j);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4722 ii++;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4723 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4724 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4725 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4726 delete complex_matrix;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4727 complex_matrix = new_matrix;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4728 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4729 else
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4730 panic_impossible ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4731 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4732
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4733 void
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4734 tree_constant_rep::delete_column (int idx)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4735 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4736 if (type_tag == matrix_constant)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4737 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4738 int nr = matrix->rows ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4739 int nc = matrix->columns ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4740 Matrix *new_matrix = new Matrix (nr, nc-1);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4741 int jj = 0;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4742 for (int j = 0; j < nc; j++)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4743 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4744 if (j != idx)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4745 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4746 for (int i = 0; i < nr; i++)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4747 new_matrix->elem (i, jj) = matrix->elem (i, j);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4748 jj++;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4749 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4750 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4751 delete matrix;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4752 matrix = new_matrix;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4753 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4754 else if (type_tag == complex_matrix_constant)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4755 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4756 int nr = complex_matrix->rows ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4757 int nc = complex_matrix->columns ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4758 ComplexMatrix *new_matrix = new ComplexMatrix (nr, nc-1);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4759 int jj = 0;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4760 for (int j = 0; j < nc; j++)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4761 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4762 if (j != idx)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4763 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4764 for (int i = 0; i < nr; i++)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4765 new_matrix->elem (i, jj) = complex_matrix->elem (i, j);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4766 jj++;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4767 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4768 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4769 delete complex_matrix;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4770 complex_matrix = new_matrix;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4771 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4772 else
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4773 panic_impossible ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4774 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4775
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4776 void
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4777 tree_constant_rep::delete_columns (idx_vector& jv)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4778 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4779 jv.sort_uniq ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4780 int num_to_delete = jv.length ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4781
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4782 int nr = rows ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4783 int nc = columns ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4784
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4785 // If deleting all columns of a row vector, make result 0x0.
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4786 if (nr == 1 && num_to_delete == nc)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4787 nr = 0;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4788
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4789 if (type_tag == matrix_constant)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4790 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4791 Matrix *new_matrix = new Matrix (nr, nc-num_to_delete);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4792 if (nc > num_to_delete)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4793 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4794 int jj = 0;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4795 int idx = 0;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4796 for (int j = 0; j < nc; j++)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4797 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4798 if (j == jv.elem (idx))
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4799 idx++;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4800 else
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4801 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4802 for (int i = 0; i < nr; i++)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4803 new_matrix->elem (i, jj) = matrix->elem (i, j);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4804 jj++;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4805 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4806 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4807 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4808 delete matrix;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4809 matrix = new_matrix;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4810 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4811 else if (type_tag == complex_matrix_constant)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4812 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4813 ComplexMatrix *new_matrix = new ComplexMatrix (nr, nc-num_to_delete);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4814 if (nc > num_to_delete)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4815 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4816 int jj = 0;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4817 int idx = 0;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4818 for (int j = 0; j < nc; j++)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4819 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4820 if (j == jv.elem (idx))
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4821 idx++;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4822 else
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4823 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4824 for (int i = 0; i < nr; i++)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4825 new_matrix->elem (i, jj) = complex_matrix->elem (i, j);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4826 jj++;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4827 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4828 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4829 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4830 delete complex_matrix;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4831 complex_matrix = new_matrix;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4832 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4833 else
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4834 panic_impossible ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4835 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4836
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4837 void
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4838 tree_constant_rep::delete_columns (Range& rj)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4839 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4840 rj.sort ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4841 int num_to_delete = rj.nelem ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4842
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4843 int nr = rows ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4844 int nc = columns ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4845
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4846 // If deleting all columns of a row vector, make result 0x0.
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4847 if (nr == 1 && num_to_delete == nc)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4848 nr = 0;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4849
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4850 double jb = rj.base ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4851 double jinc = rj.inc ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4852
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4853 int max_idx = tree_to_mat_idx (rj.max ());
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4854
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4855 if (type_tag == matrix_constant)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4856 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4857 Matrix *new_matrix = new Matrix (nr, nc-num_to_delete);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4858 if (nc > num_to_delete)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4859 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4860 int jj = 0;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4861 int idx = 0;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4862 for (int j = 0; j < nc; j++)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4863 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4864 double jtmp = jb + idx * jinc;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4865 int col = tree_to_mat_idx (jtmp);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4866
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4867 if (j == col && col <= max_idx)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4868 idx++;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4869 else
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4870 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4871 for (int i = 0; i < nr; i++)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4872 new_matrix->elem (i, jj) = matrix->elem (i, j);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4873 jj++;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4874 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4875 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4876 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4877 delete matrix;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4878 matrix = new_matrix;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4879 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4880 else if (type_tag == complex_matrix_constant)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4881 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4882 ComplexMatrix *new_matrix = new ComplexMatrix (nr, nc-num_to_delete);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4883 if (nc > num_to_delete)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4884 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4885 int jj = 0;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4886 int idx = 0;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4887 for (int j = 0; j < nc; j++)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4888 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4889 double jtmp = jb + idx * jinc;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4890 int col = tree_to_mat_idx (jtmp);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4891
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4892 if (j == col && col <= max_idx)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4893 idx++;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4894 else
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4895 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4896 for (int i = 0; i < nr; i++)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4897 new_matrix->elem (i, jj) = complex_matrix->elem (i, j);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4898 jj++;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4899 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4900 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4901 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4902 delete complex_matrix;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4903 complex_matrix = new_matrix;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4904 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4905 else
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4906 panic_impossible ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4907 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4908
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4909
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4910 int
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4911 tree_constant_rep::valid_as_scalar_index (void) const
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4912 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4913 int valid = type_tag == magic_colon
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4914 || (type_tag == scalar_constant && NINT (scalar) == 1)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4915 || (type_tag == range_constant
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4916 && range->nelem () == 1 && NINT (range->base ()) == 1);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4917
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4918 return valid;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4919 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4920
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4921 tree_constant
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4922 tree_constant_rep::do_scalar_index (const tree_constant *args,
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4923 int nargs) const
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4924 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4925 if (valid_scalar_indices (args, nargs))
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4926 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4927 if (type_tag == scalar_constant)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4928 return tree_constant (scalar);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4929 else if (type_tag == complex_scalar_constant)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4930 return tree_constant (*complex_scalar);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4931 else
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4932 panic_impossible ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4933 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4934 else
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4935 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4936 int rows = 0;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4937 int cols = 0;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4938
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4939 switch (nargs)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4940 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4941 case 3:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4942 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4943 if (args[2].is_matrix_type ())
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4944 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4945 Matrix mj = args[2].matrix_value ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4946
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4947 idx_vector j (mj, user_pref.do_fortran_indexing, "");
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4948 if (! j)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4949 return tree_constant ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4950
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4951 int len = j.length ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4952 if (len == j.ones_count ())
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4953 cols = len;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4954 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4955 else if (args[2].const_type () == magic_colon
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4956 || (args[2].is_scalar_type ()
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4957 && NINT (args[2].double_value ()) == 1))
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4958 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4959 cols = 1;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4960 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4961 else
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4962 break;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4963 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4964 // Fall through...
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4965 case 2:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4966 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4967 if (args[1].is_matrix_type ())
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4968 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4969 Matrix mi = args[1].matrix_value ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4970
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4971 idx_vector i (mi, user_pref.do_fortran_indexing, "");
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4972 if (! i)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4973 return tree_constant ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4974
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4975 int len = i.length ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4976 if (len == i.ones_count ())
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4977 rows = len;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4978 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4979 else if (args[1].const_type () == magic_colon
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4980 || (args[1].is_scalar_type ()
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4981 && NINT (args[1].double_value ()) == 1))
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4982 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4983 rows = 1;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4984 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4985 else if (args[1].is_scalar_type ()
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4986 && NINT (args[1].double_value ()) == 0)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4987 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4988 Matrix m (0, 0);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4989 return tree_constant (m);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4990 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4991 else
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4992 break;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4993
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4994 if (cols == 0)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4995 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4996 if (user_pref.prefer_column_vectors)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4997 cols = 1;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4998 else
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
4999 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5000 cols = rows;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5001 rows = 1;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5002 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5003 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5004
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5005 if (type_tag == scalar_constant)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5006 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5007 Matrix m (rows, cols, scalar);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5008 return tree_constant (m);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5009 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5010 else if (type_tag == complex_scalar_constant)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5011 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5012 ComplexMatrix cm (rows, cols, *complex_scalar);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5013 return tree_constant (cm);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5014 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5015 else
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5016 panic_impossible ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5017 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5018 break;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5019 default:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5020 ::error ("illegal number of arguments for scalar type");
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5021 return tree_constant ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5022 break;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5023 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5024 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5025
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5026 ::error ("index invalid or out of range for scalar type");
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5027 return tree_constant ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5028 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5029
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5030 tree_constant
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5031 tree_constant_rep::do_matrix_index (const tree_constant *args,
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5032 int nargin) const
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5033 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5034 tree_constant retval;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5035
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5036 switch (nargin)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5037 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5038 case 2:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5039 if (args == NULL_TREE_CONST)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5040 ::error ("matrix index is null");
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5041 else if (args[1].is_undefined ())
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5042 ::error ("matrix index is a null expression");
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5043 else
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5044 retval = do_matrix_index (args[1]);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5045 break;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5046 case 3:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5047 if (args == NULL_TREE_CONST)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5048 ::error ("matrix indices are null");
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5049 else if (args[1].is_undefined ())
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5050 ::error ("first matrix index is a null expression");
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5051 else if (args[2].is_undefined ())
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5052 ::error ("second matrix index is a null expression");
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5053 else
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5054 retval = do_matrix_index (args[1], args[2]);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5055 break;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5056 default:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5057 ::error ("too many indices for matrix expression");
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5058 break;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5059 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5060
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5061 return retval;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5062 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5063
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5064 tree_constant
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5065 tree_constant_rep::do_matrix_index (const tree_constant& i_arg) const
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5066 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5067 tree_constant retval;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5068
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5069 int nr = rows ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5070 int nc = columns ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5071
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5072 if (user_pref.do_fortran_indexing)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5073 retval = fortran_style_matrix_index (i_arg);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5074 else if (nr <= 1 || nc <= 1)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5075 retval = do_vector_index (i_arg);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5076 else
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5077 ::error ("single index only valid for row or column vector");
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5078
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5079 return retval;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5080 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5081
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5082 tree_constant
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5083 tree_constant_rep::fortran_style_matrix_index
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5084 (const tree_constant& i_arg) const
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5085 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5086 tree_constant retval;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5087
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5088 tree_constant tmp_i = i_arg.make_numeric_or_magic ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5089
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5090 tree_constant_rep::constant_type itype = tmp_i.const_type ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5091
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5092 int nr = rows ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5093 int nc = columns ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5094
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5095 switch (itype)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5096 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5097 case complex_scalar_constant:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5098 case scalar_constant:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5099 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5100 int i = NINT (tmp_i.double_value ());
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5101 int ii = fortran_row (i, nr) - 1;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5102 int jj = fortran_column (i, nr) - 1;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5103 if (index_check (i-1, "") < 0)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5104 return tree_constant ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5105 if (range_max_check (i-1, nr * nc) < 0)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5106 return tree_constant ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5107 retval = do_matrix_index (ii, jj);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5108 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5109 break;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5110 case complex_matrix_constant:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5111 case matrix_constant:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5112 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5113 Matrix mi = tmp_i.matrix_value ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5114 if (mi.rows () == 0 || mi.columns () == 0)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5115 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5116 Matrix mtmp;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5117 retval = tree_constant (mtmp);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5118 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5119 else
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5120 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5121 // Yes, we really do want to call this with mi.
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5122 retval = fortran_style_matrix_index (mi);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5123 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5124 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5125 break;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5126 case string_constant:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5127 gripe_string_invalid ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5128 break;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5129 case range_constant:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5130 gripe_range_invalid ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5131 break;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5132 case magic_colon:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5133 retval = do_matrix_index (magic_colon);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5134 break;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5135 default:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5136 panic_impossible ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5137 break;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5138 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5139
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5140 return retval;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5141 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5142
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5143 tree_constant
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5144 tree_constant_rep::fortran_style_matrix_index (const Matrix& mi) const
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5145 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5146 assert (is_matrix_type ());
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5147
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5148 tree_constant retval;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5149
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5150 int nr = rows ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5151 int nc = columns ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5152
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5153 int len = nr * nc;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5154
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5155 int index_nr = mi.rows ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5156 int index_nc = mi.columns ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5157
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5158 if (index_nr >= 1 && index_nc >= 1)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5159 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5160 const double *cop_out = (const double *) NULL;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5161 const Complex *c_cop_out = (const Complex *) NULL;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5162 int real_type = type_tag == matrix_constant;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5163 if (real_type)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5164 cop_out = matrix->data ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5165 else
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5166 c_cop_out = complex_matrix->data ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5167
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5168 const double *cop_out_index = mi.data ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5169
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5170 idx_vector iv (mi, 1, "", len);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5171 if (! iv)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5172 return tree_constant ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5173
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5174 int result_size = iv.length ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5175
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5176 if (nc == 1 || (nr != 1 && iv.one_zero_only ()))
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5177 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5178 CRMATRIX (m, cm, result_size, 1);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5179
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5180 for (int i = 0; i < result_size; i++)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5181 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5182 int idx = iv.elem (i);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5183 CRMATRIX_ASSIGN_ELEM (m, cm, i, 0, cop_out [idx],
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5184 c_cop_out [idx], real_type);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5185 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5186
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5187 ASSIGN_CRMATRIX_TO (retval, m, cm);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5188 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5189 else if (nr == 1)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5190 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5191 CRMATRIX (m, cm, 1, result_size);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5192
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5193 for (int i = 0; i < result_size; i++)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5194 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5195 int idx = iv.elem (i);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5196 CRMATRIX_ASSIGN_ELEM (m, cm, 0, i, cop_out [idx],
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5197 c_cop_out [idx], real_type);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5198 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5199
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5200 ASSIGN_CRMATRIX_TO (retval, m, cm);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5201 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5202 else
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5203 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5204 CRMATRIX (m, cm, index_nr, index_nc);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5205
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5206 for (int j = 0; j < index_nc; j++)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5207 for (int i = 0; i < index_nr; i++)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5208 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5209 double tmp = *cop_out_index++;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5210 int idx = tree_to_mat_idx (tmp);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5211 CRMATRIX_ASSIGN_ELEM (m, cm, i, j, cop_out [idx],
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5212 c_cop_out [idx], real_type);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5213 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5214
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5215 ASSIGN_CRMATRIX_TO (retval, m, cm);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5216 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5217 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5218 else
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5219 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5220 if (index_nr == 0 || index_nc == 0)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5221 ::error ("empty matrix invalid as index");
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5222 else
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5223 ::error ("invalid matrix index");
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5224 return tree_constant ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5225 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5226
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5227 return retval;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5228 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5229
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5230 tree_constant
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5231 tree_constant_rep::do_vector_index (const tree_constant& i_arg) const
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5232 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5233 tree_constant retval;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5234
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5235 tree_constant tmp_i = i_arg.make_numeric_or_range_or_magic ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5236
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5237 tree_constant_rep::constant_type itype = tmp_i.const_type ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5238
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5239 int nr = rows ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5240 int nc = columns ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5241
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5242 int len = nr > nc ? nr : nc;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5243
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5244 if (nr == 0 || nc == 0)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5245 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5246 ::error ("attempt to index empty matrix");
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5247 return retval;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5248 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5249
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5250 assert ((nr == 1 || nc == 1) && ! user_pref.do_fortran_indexing);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5251
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5252 int swap_indices = (nr == 1);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5253
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5254 switch (itype)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5255 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5256 case complex_scalar_constant:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5257 case scalar_constant:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5258 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5259 int i = tree_to_mat_idx (tmp_i.double_value ());
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5260 if (index_check (i, "") < 0)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5261 return tree_constant ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5262 if (swap_indices)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5263 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5264 if (range_max_check (i, nc) < 0)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5265 return tree_constant ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5266 retval = do_matrix_index (0, i);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5267 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5268 else
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5269 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5270 if (range_max_check (i, nr) < 0)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5271 return tree_constant ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5272 retval = do_matrix_index (i, 0);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5273 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5274 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5275 break;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5276 case complex_matrix_constant:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5277 case matrix_constant:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5278 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5279 Matrix mi = tmp_i.matrix_value ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5280 if (mi.rows () == 0 || mi.columns () == 0)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5281 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5282 Matrix mtmp;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5283 retval = tree_constant (mtmp);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5284 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5285 else
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5286 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5287 idx_vector iv (mi, user_pref.do_fortran_indexing, "", len);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5288 if (! iv)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5289 return tree_constant ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5290
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5291 if (swap_indices)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5292 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5293 if (range_max_check (iv.max (), nc) < 0)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5294 return tree_constant ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5295 retval = do_matrix_index (0, iv);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5296 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5297 else
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5298 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5299 if (range_max_check (iv.max (), nr) < 0)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5300 return tree_constant ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5301 retval = do_matrix_index (iv, 0);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5302 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5303 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5304 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5305 break;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5306 case string_constant:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5307 gripe_string_invalid ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5308 break;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5309 case range_constant:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5310 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5311 Range ri = tmp_i.range_value ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5312 if (len == 2 && is_zero_one (ri))
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5313 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5314 if (swap_indices)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5315 retval = do_matrix_index (0, 1);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5316 else
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5317 retval = do_matrix_index (1, 0);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5318 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5319 else if (len == 2 && is_one_zero (ri))
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5320 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5321 retval = do_matrix_index (0, 0);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5322 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5323 else
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5324 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5325 if (index_check (ri, "") < 0)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5326 return tree_constant ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5327 if (swap_indices)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5328 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5329 if (range_max_check (tree_to_mat_idx (ri.max ()), nc) < 0)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5330 return tree_constant ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5331 retval = do_matrix_index (0, ri);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5332 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5333 else
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5334 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5335 if (range_max_check (tree_to_mat_idx (ri.max ()), nr) < 0)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5336 return tree_constant ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5337 retval = do_matrix_index (ri, 0);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5338 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5339 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5340 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5341 break;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5342 case magic_colon:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5343 if (swap_indices)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5344 retval = do_matrix_index (0, magic_colon);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5345 else
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5346 retval = do_matrix_index (magic_colon, 0);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5347 break;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5348 default:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5349 panic_impossible ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5350 break;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5351 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5352
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5353 return retval;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5354 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5355
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5356 tree_constant
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5357 tree_constant_rep::do_matrix_index (const tree_constant& i_arg,
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5358 const tree_constant& j_arg) const
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5359 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5360 tree_constant retval;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5361
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5362 tree_constant tmp_i = i_arg.make_numeric_or_range_or_magic ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5363
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5364 tree_constant_rep::constant_type itype = tmp_i.const_type ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5365
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5366 switch (itype)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5367 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5368 case complex_scalar_constant:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5369 case scalar_constant:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5370 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5371 int i = tree_to_mat_idx (tmp_i.double_value ());
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5372 if (index_check (i, "row") < 0)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5373 return tree_constant ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5374 retval = do_matrix_index (i, j_arg);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5375 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5376 break;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5377 case complex_matrix_constant:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5378 case matrix_constant:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5379 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5380 Matrix mi = tmp_i.matrix_value ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5381 idx_vector iv (mi, user_pref.do_fortran_indexing, "row", rows ());
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5382 if (! iv)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5383 return tree_constant ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5384
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5385 if (iv.length () == 0)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5386 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5387 Matrix mtmp;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5388 retval = tree_constant (mtmp);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5389 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5390 else
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5391 retval = do_matrix_index (iv, j_arg);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5392 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5393 break;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5394 case string_constant:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5395 gripe_string_invalid ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5396 break;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5397 case range_constant:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5398 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5399 Range ri = tmp_i.range_value ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5400 int nr = rows ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5401 if (nr == 2 && is_zero_one (ri))
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5402 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5403 retval = do_matrix_index (1, j_arg);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5404 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5405 else if (nr == 2 && is_one_zero (ri))
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5406 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5407 retval = do_matrix_index (0, j_arg);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5408 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5409 else
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5410 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5411 if (index_check (ri, "row") < 0)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5412 return tree_constant ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5413 retval = do_matrix_index (ri, j_arg);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5414 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5415 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5416 break;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5417 case magic_colon:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5418 retval = do_matrix_index (magic_colon, j_arg);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5419 break;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5420 default:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5421 panic_impossible ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5422 break;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5423 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5424
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5425 return retval;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5426 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5427
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5428 tree_constant
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5429 tree_constant_rep::do_matrix_index (int i, const tree_constant& j_arg) const
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5430 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5431 tree_constant retval;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5432
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5433 tree_constant tmp_j = j_arg.make_numeric_or_range_or_magic ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5434
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5435 tree_constant_rep::constant_type jtype = tmp_j.const_type ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5436
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5437 int nr = rows ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5438 int nc = columns ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5439
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5440 switch (jtype)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5441 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5442 case complex_scalar_constant:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5443 case scalar_constant:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5444 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5445 int j = tree_to_mat_idx (tmp_j.double_value ());
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5446 if (index_check (j, "column") < 0)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5447 return tree_constant ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5448 if (range_max_check (i, j, nr, nc) < 0)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5449 return tree_constant ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5450 retval = do_matrix_index (i, j);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5451 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5452 break;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5453 case complex_matrix_constant:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5454 case matrix_constant:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5455 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5456 Matrix mj = tmp_j.matrix_value ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5457 idx_vector jv (mj, user_pref.do_fortran_indexing, "column", nc);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5458 if (! jv)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5459 return tree_constant ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5460
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5461 if (jv.length () == 0)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5462 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5463 Matrix mtmp;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5464 retval = tree_constant (mtmp);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5465 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5466 else
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5467 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5468 if (range_max_check (i, jv.max (), nr, nc) < 0)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5469 return tree_constant ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5470 retval = do_matrix_index (i, jv);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5471 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5472 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5473 break;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5474 case string_constant:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5475 gripe_string_invalid ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5476 break;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5477 case range_constant:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5478 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5479 Range rj = tmp_j.range_value ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5480 if (nc == 2 && is_zero_one (rj))
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5481 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5482 retval = do_matrix_index (i, 1);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5483 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5484 else if (nc == 2 && is_one_zero (rj))
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5485 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5486 retval = do_matrix_index (i, 0);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5487 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5488 else
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5489 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5490 if (index_check (rj, "column") < 0)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5491 return tree_constant ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5492 if (range_max_check (i, tree_to_mat_idx (rj.max ()), nr, nc) < 0)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5493 return tree_constant ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5494 retval = do_matrix_index (i, rj);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5495 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5496 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5497 break;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5498 case magic_colon:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5499 if (range_max_check (i, 0, nr, nc) < 0)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5500 return tree_constant ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5501 retval = do_matrix_index (i, magic_colon);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5502 break;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5503 default:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5504 panic_impossible ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5505 break;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5506 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5507
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5508 return retval;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5509 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5510
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5511 tree_constant
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5512 tree_constant_rep::do_matrix_index (const idx_vector& iv,
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5513 const tree_constant& j_arg) const
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5514 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5515 tree_constant retval;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5516
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5517 tree_constant tmp_j = j_arg.make_numeric_or_range_or_magic ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5518
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5519 tree_constant_rep::constant_type jtype = tmp_j.const_type ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5520
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5521 int nr = rows ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5522 int nc = columns ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5523
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5524 switch (jtype)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5525 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5526 case complex_scalar_constant:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5527 case scalar_constant:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5528 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5529 int j = tree_to_mat_idx (tmp_j.double_value ());
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5530 if (index_check (j, "column") < 0)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5531 return tree_constant ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5532 if (range_max_check (iv.max (), j, nr, nc) < 0)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5533 return tree_constant ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5534 retval = do_matrix_index (iv, j);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5535 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5536 break;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5537 case complex_matrix_constant:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5538 case matrix_constant:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5539 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5540 Matrix mj = tmp_j.matrix_value ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5541 idx_vector jv (mj, user_pref.do_fortran_indexing, "column", nc);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5542 if (! jv)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5543 return tree_constant ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5544
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5545 if (jv.length () == 0)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5546 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5547 Matrix mtmp;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5548 retval = tree_constant (mtmp);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5549 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5550 else
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5551 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5552 if (range_max_check (iv.max (), jv.max (), nr, nc) < 0)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5553 return tree_constant ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5554 retval = do_matrix_index (iv, jv);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5555 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5556 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5557 break;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5558 case string_constant:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5559 gripe_string_invalid ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5560 break;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5561 case range_constant:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5562 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5563 Range rj = tmp_j.range_value ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5564 if (nc == 2 && is_zero_one (rj))
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5565 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5566 retval = do_matrix_index (iv, 1);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5567 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5568 else if (nc == 2 && is_one_zero (rj))
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5569 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5570 retval = do_matrix_index (iv, 0);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5571 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5572 else
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5573 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5574 if (index_check (rj, "column") < 0)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5575 return tree_constant ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5576 if (range_max_check (iv.max (), tree_to_mat_idx (rj.max ()),
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5577 nr, nc) < 0)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5578 return tree_constant ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5579 retval = do_matrix_index (iv, rj);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5580 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5581 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5582 break;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5583 case magic_colon:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5584 if (range_max_check (iv.max (), 0, nr, nc) < 0)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5585 return tree_constant ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5586 retval = do_matrix_index (iv, magic_colon);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5587 break;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5588 default:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5589 panic_impossible ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5590 break;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5591 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5592
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5593 return retval;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5594 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5595
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5596 tree_constant
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5597 tree_constant_rep::do_matrix_index (const Range& ri,
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5598 const tree_constant& j_arg) const
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5599 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5600 tree_constant retval;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5601
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5602 tree_constant tmp_j = j_arg.make_numeric_or_range_or_magic ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5603
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5604 tree_constant_rep::constant_type jtype = tmp_j.const_type ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5605
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5606 int nr = rows ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5607 int nc = columns ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5608
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5609 switch (jtype)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5610 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5611 case complex_scalar_constant:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5612 case scalar_constant:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5613 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5614 int j = tree_to_mat_idx (tmp_j.double_value ());
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5615 if (index_check (j, "column") < 0)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5616 return tree_constant ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5617 if (range_max_check (tree_to_mat_idx (ri.max ()), j, nr, nc) < 0)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5618 return tree_constant ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5619 retval = do_matrix_index (ri, j);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5620 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5621 break;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5622 case complex_matrix_constant:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5623 case matrix_constant:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5624 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5625 Matrix mj = tmp_j.matrix_value ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5626 idx_vector jv (mj, user_pref.do_fortran_indexing, "column", nc);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5627 if (! jv)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5628 return tree_constant ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5629
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5630 if (jv.length () == 0)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5631 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5632 Matrix mtmp;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5633 retval = tree_constant (mtmp);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5634 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5635 else
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5636 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5637 if (range_max_check (tree_to_mat_idx (ri.max ()),
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5638 jv.max (), nr, nc) < 0)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5639 return tree_constant ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5640 retval = do_matrix_index (ri, jv);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5641 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5642 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5643 break;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5644 case string_constant:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5645 gripe_string_invalid ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5646 break;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5647 case range_constant:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5648 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5649 Range rj = tmp_j.range_value ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5650 if (nc == 2 && is_zero_one (rj))
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5651 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5652 retval = do_matrix_index (ri, 1);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5653 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5654 else if (nc == 2 && is_one_zero (rj))
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5655 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5656 retval = do_matrix_index (ri, 0);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5657 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5658 else
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5659 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5660 if (index_check (rj, "column") < 0)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5661 return tree_constant ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5662 if (range_max_check (tree_to_mat_idx (ri.max ()),
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5663 tree_to_mat_idx (rj.max ()), nr, nc) < 0)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5664 return tree_constant ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5665 retval = do_matrix_index (ri, rj);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5666 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5667 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5668 break;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5669 case magic_colon:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5670 retval = do_matrix_index (ri, magic_colon);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5671 break;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5672 default:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5673 panic_impossible ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5674 break;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5675 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5676
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5677 return retval;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5678 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5679
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5680 tree_constant
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5681 tree_constant_rep::do_matrix_index (tree_constant_rep::constant_type mci,
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5682 const tree_constant& j_arg) const
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5683 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5684 tree_constant retval;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5685
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5686 tree_constant tmp_j = j_arg.make_numeric_or_range_or_magic ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5687
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5688 tree_constant_rep::constant_type jtype = tmp_j.const_type ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5689
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5690 int nr = rows ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5691 int nc = columns ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5692
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5693 switch (jtype)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5694 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5695 case complex_scalar_constant:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5696 case scalar_constant:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5697 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5698 int j = tree_to_mat_idx (tmp_j.double_value ());
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5699 if (index_check (j, "column") < 0)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5700 return tree_constant ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5701 if (range_max_check (0, j, nr, nc) < 0)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5702 return tree_constant ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5703 retval = do_matrix_index (magic_colon, j);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5704 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5705 break;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5706 case complex_matrix_constant:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5707 case matrix_constant:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5708 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5709 Matrix mj = tmp_j.matrix_value ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5710 idx_vector jv (mj, user_pref.do_fortran_indexing, "column", nc);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5711 if (! jv)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5712 return tree_constant ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5713
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5714 if (jv.length () == 0)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5715 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5716 Matrix mtmp;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5717 retval = tree_constant (mtmp);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5718 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5719 else
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5720 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5721 if (range_max_check (0, jv.max (), nr, nc) < 0)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5722 return tree_constant ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5723 retval = do_matrix_index (magic_colon, jv);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5724 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5725 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5726 break;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5727 case string_constant:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5728 gripe_string_invalid ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5729 break;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5730 case range_constant:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5731 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5732 Range rj = tmp_j.range_value ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5733 if (nc == 2 && is_zero_one (rj))
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5734 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5735 retval = do_matrix_index (magic_colon, 1);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5736 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5737 else if (nc == 2 && is_one_zero (rj))
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5738 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5739 retval = do_matrix_index (magic_colon, 0);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5740 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5741 else
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5742 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5743 if (index_check (rj, "column") < 0)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5744 return tree_constant ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5745 if (range_max_check (0, tree_to_mat_idx (rj.max ()), nr, nc) < 0)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5746 return tree_constant ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5747 retval = do_matrix_index (magic_colon, rj);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5748 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5749 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5750 break;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5751 case magic_colon:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5752 retval = do_matrix_index (magic_colon, magic_colon);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5753 break;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5754 default:
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5755 panic_impossible ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5756 break;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5757 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5758
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5759 return retval;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5760 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5761
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5762 tree_constant
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5763 tree_constant_rep::do_matrix_index (int i, int j) const
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5764 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5765 tree_constant retval;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5766
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5767 if (type_tag == matrix_constant)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5768 retval = tree_constant (matrix->elem (i, j));
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5769 else
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5770 retval = tree_constant (complex_matrix->elem (i, j));
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5771
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5772 return retval;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5773 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5774
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5775 tree_constant
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5776 tree_constant_rep::do_matrix_index (int i, const idx_vector& jv) const
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5777 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5778 tree_constant retval;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5779
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5780 int jlen = jv.capacity ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5781
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5782 CRMATRIX (m, cm, 1, jlen);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5783
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5784 for (int j = 0; j < jlen; j++)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5785 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5786 int col = jv.elem (j);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5787 CRMATRIX_ASSIGN_REP_ELEM (m, cm, 0, j, i, col);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5788 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5789 ASSIGN_CRMATRIX_TO (retval, m, cm);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5790
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5791 return retval;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5792 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5793
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5794 tree_constant
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5795 tree_constant_rep::do_matrix_index (int i, const Range& rj) const
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5796 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5797 tree_constant retval;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5798
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5799 int jlen = rj.nelem ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5800
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5801 CRMATRIX (m, cm, 1, jlen);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5802
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5803 double b = rj.base ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5804 double increment = rj.inc ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5805 for (int j = 0; j < jlen; j++)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5806 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5807 double tmp = b + j * increment;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5808 int col = tree_to_mat_idx (tmp);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5809 CRMATRIX_ASSIGN_REP_ELEM (m, cm, 0, j, i, col);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5810 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5811
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5812 ASSIGN_CRMATRIX_TO (retval, m, cm);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5813
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5814 return retval;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5815 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5816
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5817 tree_constant
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5818 tree_constant_rep::do_matrix_index
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5819 (int i, tree_constant_rep::constant_type mcj) const
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5820 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5821 assert (mcj == magic_colon);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5822
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5823 tree_constant retval;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5824
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5825 int nc = columns ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5826
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5827 CRMATRIX (m, cm, 1, nc);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5828
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5829 for (int j = 0; j < nc; j++)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5830 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5831 CRMATRIX_ASSIGN_REP_ELEM (m, cm, 0, j, i, j);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5832 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5833
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5834 ASSIGN_CRMATRIX_TO (retval, m, cm);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5835
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5836 return retval;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5837 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5838
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5839 tree_constant
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5840 tree_constant_rep::do_matrix_index (const idx_vector& iv, int j) const
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5841 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5842 tree_constant retval;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5843
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5844 int ilen = iv.capacity ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5845
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5846 CRMATRIX (m, cm, ilen, 1);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5847
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5848 for (int i = 0; i < ilen; i++)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5849 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5850 int row = iv.elem (i);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5851 CRMATRIX_ASSIGN_REP_ELEM (m, cm, i, 0, row, j);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5852 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5853
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5854 ASSIGN_CRMATRIX_TO (retval, m, cm);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5855
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5856 return retval;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5857 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5858
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5859 tree_constant
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5860 tree_constant_rep::do_matrix_index (const idx_vector& iv,
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5861 const idx_vector& jv) const
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5862 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5863 tree_constant retval;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5864
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5865 int ilen = iv.capacity ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5866 int jlen = jv.capacity ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5867
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5868 CRMATRIX (m, cm, ilen, jlen);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5869
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5870 for (int i = 0; i < ilen; i++)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5871 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5872 int row = iv.elem (i);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5873 for (int j = 0; j < jlen; j++)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5874 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5875 int col = jv.elem (j);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5876 CRMATRIX_ASSIGN_REP_ELEM (m, cm, i, j, row, col);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5877 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5878 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5879
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5880 ASSIGN_CRMATRIX_TO (retval, m, cm);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5881
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5882 return retval;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5883 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5884
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5885 tree_constant
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5886 tree_constant_rep::do_matrix_index (const idx_vector& iv,
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5887 const Range& rj) const
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5888 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5889 tree_constant retval;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5890
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5891 int ilen = iv.capacity ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5892 int jlen = rj.nelem ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5893
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5894 CRMATRIX (m, cm, ilen, jlen);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5895
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5896 double b = rj.base ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5897 double increment = rj.inc ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5898
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5899 for (int i = 0; i < ilen; i++)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5900 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5901 int row = iv.elem (i);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5902 for (int j = 0; j < jlen; j++)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5903 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5904 double tmp = b + j * increment;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5905 int col = tree_to_mat_idx (tmp);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5906 CRMATRIX_ASSIGN_REP_ELEM (m, cm, i, j, row, col);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5907 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5908 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5909
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5910 ASSIGN_CRMATRIX_TO (retval, m, cm);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5911
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5912 return retval;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5913 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5914
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5915 tree_constant
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5916 tree_constant_rep::do_matrix_index
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5917 (const idx_vector& iv, tree_constant_rep::constant_type mcj) const
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5918 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5919 assert (mcj == magic_colon);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5920
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5921 tree_constant retval;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5922
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5923 int nc = columns ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5924 int ilen = iv.capacity ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5925
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5926 CRMATRIX (m, cm, ilen, nc);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5927
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5928 for (int j = 0; j < nc; j++)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5929 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5930 for (int i = 0; i < ilen; i++)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5931 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5932 int row = iv.elem (i);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5933 CRMATRIX_ASSIGN_REP_ELEM (m, cm, i, j, row, j);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5934 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5935 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5936
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5937 ASSIGN_CRMATRIX_TO (retval, m, cm);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5938
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5939 return retval;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5940 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5941
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5942 tree_constant
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5943 tree_constant_rep::do_matrix_index (const Range& ri, int j) const
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5944 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5945 tree_constant retval;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5946
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5947 int ilen = ri.nelem ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5948
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5949 CRMATRIX (m, cm, ilen, 1);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5950
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5951 double b = ri.base ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5952 double increment = ri.inc ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5953 for (int i = 0; i < ilen; i++)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5954 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5955 double tmp = b + i * increment;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5956 int row = tree_to_mat_idx (tmp);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5957 CRMATRIX_ASSIGN_REP_ELEM (m, cm, i, 0, row, j);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5958 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5959
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5960 ASSIGN_CRMATRIX_TO (retval, m, cm);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5961
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5962 return retval;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5963 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5964
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5965 tree_constant
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5966 tree_constant_rep::do_matrix_index (const Range& ri,
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5967 const idx_vector& jv) const
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5968 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5969 tree_constant retval;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5970
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5971 int ilen = ri.nelem ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5972 int jlen = jv.capacity ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5973
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5974 CRMATRIX (m, cm, ilen, jlen);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5975
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5976 double b = ri.base ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5977 double increment = ri.inc ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5978 for (int i = 0; i < ilen; i++)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5979 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5980 double tmp = b + i * increment;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5981 int row = tree_to_mat_idx (tmp);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5982 for (int j = 0; j < jlen; j++)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5983 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5984 int col = jv.elem (j);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5985 CRMATRIX_ASSIGN_REP_ELEM (m, cm, i, j, row, col);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5986 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5987 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5988
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5989 ASSIGN_CRMATRIX_TO (retval, m, cm);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5990
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5991 return retval;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5992 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5993
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5994 tree_constant
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5995 tree_constant_rep::do_matrix_index (const Range& ri, const Range& rj) const
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5996 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5997 tree_constant retval;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5998
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
5999 int ilen = ri.nelem ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6000 int jlen = rj.nelem ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6001
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6002 CRMATRIX (m, cm, ilen, jlen);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6003
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6004 double ib = ri.base ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6005 double iinc = ri.inc ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6006 double jb = rj.base ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6007 double jinc = rj.inc ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6008
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6009 for (int i = 0; i < ilen; i++)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6010 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6011 double itmp = ib + i * iinc;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6012 int row = tree_to_mat_idx (itmp);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6013 for (int j = 0; j < jlen; j++)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6014 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6015 double jtmp = jb + j * jinc;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6016 int col = tree_to_mat_idx (jtmp);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6017
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6018 CRMATRIX_ASSIGN_REP_ELEM (m, cm, i, j, row, col);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6019 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6020 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6021
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6022 ASSIGN_CRMATRIX_TO (retval, m, cm);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6023
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6024 return retval;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6025 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6026
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6027 tree_constant
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6028 tree_constant_rep::do_matrix_index
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6029 (const Range& ri, tree_constant_rep::constant_type mcj) const
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6030 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6031 assert (mcj == magic_colon);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6032
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6033 tree_constant retval;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6034
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6035 int nc = columns ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6036
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6037 int ilen = ri.nelem ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6038
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6039 CRMATRIX (m, cm, ilen, nc);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6040
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6041 double ib = ri.base ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6042 double iinc = ri.inc ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6043
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6044 for (int i = 0; i < ilen; i++)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6045 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6046 double itmp = ib + i * iinc;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6047 int row = tree_to_mat_idx (itmp);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6048 for (int j = 0; j < nc; j++)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6049 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6050 CRMATRIX_ASSIGN_REP_ELEM (m, cm, i, j, row, j);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6051 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6052 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6053
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6054 ASSIGN_CRMATRIX_TO (retval, m, cm);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6055
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6056 return retval;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6057 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6058
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6059 tree_constant
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6060 tree_constant_rep::do_matrix_index (tree_constant_rep::constant_type mci,
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6061 int j) const
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6062 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6063 assert (mci == magic_colon);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6064
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6065 tree_constant retval;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6066
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6067 int nr = rows ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6068
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6069 CRMATRIX (m, cm, nr, 1);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6070
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6071 for (int i = 0; i < nr; i++)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6072 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6073 CRMATRIX_ASSIGN_REP_ELEM (m, cm, i, 0, i, j);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6074 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6075
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6076 ASSIGN_CRMATRIX_TO (retval, m, cm);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6077
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6078 return retval;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6079 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6080
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6081 tree_constant
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6082 tree_constant_rep::do_matrix_index (tree_constant_rep::constant_type mci,
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6083 const idx_vector& jv) const
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6084 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6085 assert (mci == magic_colon);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6086
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6087 tree_constant retval;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6088
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6089 int nr = rows ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6090 int jlen = jv.capacity ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6091
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6092 CRMATRIX (m, cm, nr, jlen);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6093
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6094 for (int i = 0; i < nr; i++)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6095 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6096 for (int j = 0; j < jlen; j++)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6097 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6098 int col = jv.elem (j);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6099 CRMATRIX_ASSIGN_REP_ELEM (m, cm, i, j, i, col);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6100 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6101 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6102
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6103 ASSIGN_CRMATRIX_TO (retval, m, cm);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6104
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6105 return retval;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6106 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6107
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6108 tree_constant
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6109 tree_constant_rep::do_matrix_index (tree_constant_rep::constant_type mci,
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6110 const Range& rj) const
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6111 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6112 assert (mci == magic_colon);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6113
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6114 tree_constant retval;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6115
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6116 int nr = rows ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6117 int jlen = rj.nelem ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6118
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6119 CRMATRIX (m, cm, nr, jlen);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6120
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6121 double jb = rj.base ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6122 double jinc = rj.inc ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6123
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6124 for (int j = 0; j < jlen; j++)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6125 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6126 double jtmp = jb + j * jinc;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6127 int col = tree_to_mat_idx (jtmp);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6128 for (int i = 0; i < nr; i++)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6129 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6130 CRMATRIX_ASSIGN_REP_ELEM (m, cm, i, j, i, col);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6131 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6132 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6133
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6134 ASSIGN_CRMATRIX_TO (retval, m, cm);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6135
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6136 return retval;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6137 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6138
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6139 tree_constant
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6140 tree_constant_rep::do_matrix_index (tree_constant_rep::constant_type mci,
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6141 tree_constant_rep::constant_type mcj) const
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6142 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6143 assert (mci == magic_colon && mcj == magic_colon);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6144
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6145 return tree_constant (*this);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6146 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6147
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6148 tree_constant
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6149 tree_constant_rep::do_matrix_index
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6150 (tree_constant_rep::constant_type mci) const
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6151 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6152 assert (mci == magic_colon);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6153
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6154 tree_constant retval;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6155 int nr = rows ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6156 int nc = columns ();
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6157 int size = nr * nc;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6158 if (size > 0)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6159 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6160 CRMATRIX (m, cm, size, 1);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6161 int idx = 0;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6162 for (int j = 0; j < nc; j++)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6163 for (int i = 0; i < nr; i++)
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6164 {
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6165 CRMATRIX_ASSIGN_REP_ELEM (m, cm, idx, 0, i, j);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6166 idx++;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6167 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6168 ASSIGN_CRMATRIX_TO (retval, m, cm);
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6169 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6170 return retval;
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6171 }
8c6b86564cee [project @ 1994-06-06 00:24:19 by jwe]
jwe
parents: 435
diff changeset
6172
96
36ff440553cd [project @ 1993-09-13 02:48:39 by jwe]
jwe
parents: 1
diff changeset
6173 /*
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
6174 ;;; Local Variables: ***
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
6175 ;;; mode: C++ ***
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
6176 ;;; page-delimiter: "^/\\*" ***
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
6177 ;;; End: ***
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
6178 */