annotate src/pt-const.cc @ 1490:4d6c168ff235

[project @ 1995-09-29 03:59:46 by jwe]
author jwe
date Fri, 29 Sep 1995 03:59:46 +0000
parents 89c587478067
children 297e084c3857
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
529
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 513
diff changeset
1 // tree-const.cc -*- C++ -*-
1
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
1009
dfe01093f657 [project @ 1995-01-04 04:05:12 by jwe]
jwe
parents: 877
diff changeset
4 Copyright (C) 1992, 1993, 1994, 1995 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
1315
611d403c7f3d [project @ 1995-06-25 19:56:32 by jwe]
jwe
parents: 1299
diff changeset
20 Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
1
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
1299
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
24 #if defined (__GNUG__)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
25 #pragma implementation
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
26 #endif
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
27
240
a99f28f5e351 [project @ 1993-11-30 20:24:36 by jwe]
jwe
parents: 217
diff changeset
28 #ifdef HAVE_CONFIG_H
1192
b6360f2d4fa6 [project @ 1995-03-30 21:38:35 by jwe]
jwe
parents: 1170
diff changeset
29 #include <config.h>
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
30 #endif
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
31
1355
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
32 #include <cstring>
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
33
581
bc813f5eb025 [project @ 1994-08-07 01:02:15 by jwe]
jwe
parents: 531
diff changeset
34 #include <iostream.h>
1199
4f1bfa351b99 [project @ 1995-03-31 22:16:54 by jwe]
jwe
parents: 1192
diff changeset
35 #include <strstream.h>
581
bc813f5eb025 [project @ 1994-08-07 01:02:15 by jwe]
jwe
parents: 531
diff changeset
36
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
37 #include "error.h"
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
38 #include "gripes.h"
747
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
39 #include "oct-map.h"
1355
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
40 #include "oct-str.h"
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
41 #include "pager.h"
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
42 #include "tree-const.h"
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
43 #include "user-prefs.h"
1430
045e70a15a8f [project @ 1995-09-19 07:05:37 by jwe]
jwe
parents: 1358
diff changeset
44 #include "utils.h"
747
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
45
1168
e2036dce97ea [project @ 1995-03-10 18:49:55 by jwe]
jwe
parents: 1009
diff changeset
46 // The following three variables could be made static members of the
e2036dce97ea [project @ 1995-03-10 18:49:55 by jwe]
jwe
parents: 1009
diff changeset
47 // tree_constant class.
e2036dce97ea [project @ 1995-03-10 18:49:55 by jwe]
jwe
parents: 1009
diff changeset
48
e2036dce97ea [project @ 1995-03-10 18:49:55 by jwe]
jwe
parents: 1009
diff changeset
49 // Pointer to the blocks of memory we manage.
1299
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
50 static tree_constant *tc_newlist = 0;
1168
e2036dce97ea [project @ 1995-03-10 18:49:55 by jwe]
jwe
parents: 1009
diff changeset
51
e2036dce97ea [project @ 1995-03-10 18:49:55 by jwe]
jwe
parents: 1009
diff changeset
52 // Multiplier for allocating new blocks.
1299
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
53 static const int tc_newlist_grow_size = 128;
1168
e2036dce97ea [project @ 1995-03-10 18:49:55 by jwe]
jwe
parents: 1009
diff changeset
54
747
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
55 Octave_map
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
56 tree_constant::map_value (void) const
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
57 {
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
58 return rep->map_value ();
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
59 }
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
60
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
61 tree_constant::~tree_constant (void)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
62 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
63 #if defined (MDEBUG)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
64 cerr << "~tree_constant: rep: " << rep
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
65 << " rep->count: " << rep->count << "\n";
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
66 #endif
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
67
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
68 if (--rep->count <= 0)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
69 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
70 delete rep;
531
1be78be437c7 [project @ 1994-07-20 19:44:13 by jwe]
jwe
parents: 529
diff changeset
71 rep = 0;
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
72 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
73 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
74
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
75 void *
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
76 tree_constant::operator new (size_t size)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
77 {
1168
e2036dce97ea [project @ 1995-03-10 18:49:55 by jwe]
jwe
parents: 1009
diff changeset
78 assert (size == sizeof (tree_constant));
e2036dce97ea [project @ 1995-03-10 18:49:55 by jwe]
jwe
parents: 1009
diff changeset
79
1299
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
80 if (! tc_newlist)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
81 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
82 int block_size = tc_newlist_grow_size * sizeof (tree_constant);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
83 tc_newlist = (tree_constant *) new char [block_size];
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
84
1321
64819a909ed7 [project @ 1995-08-22 05:39:43 by jwe]
jwe
parents: 1320
diff changeset
85 int i = 0;
64819a909ed7 [project @ 1995-08-22 05:39:43 by jwe]
jwe
parents: 1320
diff changeset
86
64819a909ed7 [project @ 1995-08-22 05:39:43 by jwe]
jwe
parents: 1320
diff changeset
87 for (i = 0; i < tc_newlist_grow_size - 1; i++)
1299
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
88 tc_newlist[i].freeptr = &tc_newlist[i+1];
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
89
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
90 tc_newlist[i].freeptr = 0;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
91 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
92
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
93 tree_constant *tmp = tc_newlist;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
94 tc_newlist = tc_newlist->freeptr;
1168
e2036dce97ea [project @ 1995-03-10 18:49:55 by jwe]
jwe
parents: 1009
diff changeset
95 return tmp;
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
96 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
97
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
98 void
1488
89c587478067 [project @ 1995-09-26 22:49:48 by jwe]
jwe
parents: 1430
diff changeset
99 tree_constant::operator delete (void *p, size_t /* size */)
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
100 {
1168
e2036dce97ea [project @ 1995-03-10 18:49:55 by jwe]
jwe
parents: 1009
diff changeset
101 tree_constant *tmp = (tree_constant *) p;
1299
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
102 tmp->freeptr = tc_newlist;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
103 tc_newlist = tmp;
1
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
747
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
106 // Simple assignment.
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
107
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
108 tree_constant
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
109 tree_constant::operator = (const tree_constant& a)
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
110 {
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
111 if (rep != a.rep)
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
112 {
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
113 if (--rep->count <= 0)
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
114 delete rep;
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
115 rep = a.rep;
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
116 rep->count++;
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
117 }
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
118 return *this;
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
119 }
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
120
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
121 tree_constant
1277
db4f4009d6e8 [project @ 1995-04-24 20:35:06 by jwe]
jwe
parents: 1199
diff changeset
122 tree_constant::lookup_map_element (const char *ref, int insert,
db4f4009d6e8 [project @ 1995-04-24 20:35:06 by jwe]
jwe
parents: 1199
diff changeset
123 int silent)
db4f4009d6e8 [project @ 1995-04-24 20:35:06 by jwe]
jwe
parents: 1199
diff changeset
124 {
db4f4009d6e8 [project @ 1995-04-24 20:35:06 by jwe]
jwe
parents: 1199
diff changeset
125 tree_constant retval;
db4f4009d6e8 [project @ 1995-04-24 20:35:06 by jwe]
jwe
parents: 1199
diff changeset
126
db4f4009d6e8 [project @ 1995-04-24 20:35:06 by jwe]
jwe
parents: 1199
diff changeset
127 if (ref)
db4f4009d6e8 [project @ 1995-04-24 20:35:06 by jwe]
jwe
parents: 1199
diff changeset
128 {
db4f4009d6e8 [project @ 1995-04-24 20:35:06 by jwe]
jwe
parents: 1199
diff changeset
129 char *tmp = strsave (ref);
db4f4009d6e8 [project @ 1995-04-24 20:35:06 by jwe]
jwe
parents: 1199
diff changeset
130
db4f4009d6e8 [project @ 1995-04-24 20:35:06 by jwe]
jwe
parents: 1199
diff changeset
131 SLList<char *> list;
db4f4009d6e8 [project @ 1995-04-24 20:35:06 by jwe]
jwe
parents: 1199
diff changeset
132
db4f4009d6e8 [project @ 1995-04-24 20:35:06 by jwe]
jwe
parents: 1199
diff changeset
133 char *beg = tmp;
db4f4009d6e8 [project @ 1995-04-24 20:35:06 by jwe]
jwe
parents: 1199
diff changeset
134 char *end = 0;
db4f4009d6e8 [project @ 1995-04-24 20:35:06 by jwe]
jwe
parents: 1199
diff changeset
135 do
db4f4009d6e8 [project @ 1995-04-24 20:35:06 by jwe]
jwe
parents: 1199
diff changeset
136 {
db4f4009d6e8 [project @ 1995-04-24 20:35:06 by jwe]
jwe
parents: 1199
diff changeset
137 end = strchr (beg, '.');
db4f4009d6e8 [project @ 1995-04-24 20:35:06 by jwe]
jwe
parents: 1199
diff changeset
138 if (end)
db4f4009d6e8 [project @ 1995-04-24 20:35:06 by jwe]
jwe
parents: 1199
diff changeset
139 *end = '\0';
db4f4009d6e8 [project @ 1995-04-24 20:35:06 by jwe]
jwe
parents: 1199
diff changeset
140
db4f4009d6e8 [project @ 1995-04-24 20:35:06 by jwe]
jwe
parents: 1199
diff changeset
141 list.append (strsave (beg));
db4f4009d6e8 [project @ 1995-04-24 20:35:06 by jwe]
jwe
parents: 1199
diff changeset
142 }
db4f4009d6e8 [project @ 1995-04-24 20:35:06 by jwe]
jwe
parents: 1199
diff changeset
143 while (end && (beg = end + 1));
db4f4009d6e8 [project @ 1995-04-24 20:35:06 by jwe]
jwe
parents: 1199
diff changeset
144
db4f4009d6e8 [project @ 1995-04-24 20:35:06 by jwe]
jwe
parents: 1199
diff changeset
145 retval = lookup_map_element (list, insert, silent);
db4f4009d6e8 [project @ 1995-04-24 20:35:06 by jwe]
jwe
parents: 1199
diff changeset
146
db4f4009d6e8 [project @ 1995-04-24 20:35:06 by jwe]
jwe
parents: 1199
diff changeset
147 delete [] tmp;
db4f4009d6e8 [project @ 1995-04-24 20:35:06 by jwe]
jwe
parents: 1199
diff changeset
148 }
db4f4009d6e8 [project @ 1995-04-24 20:35:06 by jwe]
jwe
parents: 1199
diff changeset
149
db4f4009d6e8 [project @ 1995-04-24 20:35:06 by jwe]
jwe
parents: 1199
diff changeset
150 return retval;
db4f4009d6e8 [project @ 1995-04-24 20:35:06 by jwe]
jwe
parents: 1199
diff changeset
151 }
db4f4009d6e8 [project @ 1995-04-24 20:35:06 by jwe]
jwe
parents: 1199
diff changeset
152
db4f4009d6e8 [project @ 1995-04-24 20:35:06 by jwe]
jwe
parents: 1199
diff changeset
153 tree_constant
db4f4009d6e8 [project @ 1995-04-24 20:35:06 by jwe]
jwe
parents: 1199
diff changeset
154 tree_constant::lookup_map_element (SLList<char*>& list, int insert,
db4f4009d6e8 [project @ 1995-04-24 20:35:06 by jwe]
jwe
parents: 1199
diff changeset
155 int silent)
747
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
156 {
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
157 tree_constant retval;
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
158
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
159 tree_constant_rep *tmp_rep = rep;
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
160
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
161 Pix p = list.first ();
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
162 while (p)
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
163 {
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
164 char *elt = list (p);
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
165
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
166 list.next (p);
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
167
1277
db4f4009d6e8 [project @ 1995-04-24 20:35:06 by jwe]
jwe
parents: 1199
diff changeset
168 tree_constant tmp;
db4f4009d6e8 [project @ 1995-04-24 20:35:06 by jwe]
jwe
parents: 1199
diff changeset
169
db4f4009d6e8 [project @ 1995-04-24 20:35:06 by jwe]
jwe
parents: 1199
diff changeset
170 tmp = tmp_rep->lookup_map_element (elt, insert, silent);
747
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
171
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
172 if (error_state)
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
173 break;
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
174
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
175 tmp_rep = tmp.rep;
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
176
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
177 if (! p)
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
178 retval = tmp;
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
179 }
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
180
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
181 return retval;
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
182 }
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
183
1199
4f1bfa351b99 [project @ 1995-03-31 22:16:54 by jwe]
jwe
parents: 1192
diff changeset
184 void
4f1bfa351b99 [project @ 1995-03-31 22:16:54 by jwe]
jwe
parents: 1192
diff changeset
185 tree_constant::print (void)
4f1bfa351b99 [project @ 1995-03-31 22:16:54 by jwe]
jwe
parents: 1192
diff changeset
186 {
4f1bfa351b99 [project @ 1995-03-31 22:16:54 by jwe]
jwe
parents: 1192
diff changeset
187 ostrstream output_buf;
4f1bfa351b99 [project @ 1995-03-31 22:16:54 by jwe]
jwe
parents: 1192
diff changeset
188 print (output_buf);
4f1bfa351b99 [project @ 1995-03-31 22:16:54 by jwe]
jwe
parents: 1192
diff changeset
189 output_buf << ends;
4f1bfa351b99 [project @ 1995-03-31 22:16:54 by jwe]
jwe
parents: 1192
diff changeset
190 maybe_page_output (output_buf);
4f1bfa351b99 [project @ 1995-03-31 22:16:54 by jwe]
jwe
parents: 1192
diff changeset
191 }
4f1bfa351b99 [project @ 1995-03-31 22:16:54 by jwe]
jwe
parents: 1192
diff changeset
192
747
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
193 // Simple structure assignment.
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
194
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
195 void
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
196 tree_constant::make_unique (void)
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
197 {
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
198 if (rep->count > 1)
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
199 {
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
200 --rep->count;
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
201 rep = new tree_constant_rep (*rep);
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
202 rep->count = 1;
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
203 }
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
204
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
205 if (rep->is_map ())
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
206 {
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
207 for (Pix p = rep->a_map->first (); p != 0; rep->a_map->next (p))
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
208 {
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
209 rep->a_map->contents (p) . make_unique ();
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
210 }
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
211 }
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
212 }
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
213
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
214 tree_constant::tree_constant_rep *
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
215 tree_constant::make_unique_map (void)
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
216 {
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
217 if (! rep->is_map ())
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
218 {
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
219 if (--rep->count <= 0)
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
220 delete rep;
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
221
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
222 Octave_map m;
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
223 rep = new tree_constant_rep (m);
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
224 rep->count = 1;
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
225 }
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
226
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
227 make_unique ();
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
228
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
229 return rep;
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
230 }
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
231
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
232 tree_constant
780
81a661c0368b [project @ 1994-10-07 17:26:04 by jwe]
jwe
parents: 777
diff changeset
233 tree_constant::assign_map_element (SLList<char*>& list,
782
ffe18d3d64a6 [project @ 1994-10-07 19:01:20 by jwe]
jwe
parents: 780
diff changeset
234 tree_constant& rhs)
747
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
235 {
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
236 tree_constant_rep *tmp_rep = make_unique_map ();
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
237
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
238 if (rhs.is_map ())
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
239 rhs.make_unique ();
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
240
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
241 Pix p = list.first ();
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
242 while (p)
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
243 {
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
244 char *elt = list (p);
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
245
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
246 list.next (p);
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
247
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
248 tree_constant& tmp = tmp_rep->lookup_map_element (elt, 1);
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
249
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
250 if (! p)
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
251 {
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
252 tmp = rhs;
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
253 return tmp;
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
254 }
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
255
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
256 tmp_rep = tmp.make_unique_map ();
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
257 }
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
258
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
259 return tree_constant ();
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
260 }
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
261
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
262 // Indexed structure assignment.
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
263
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
264 tree_constant
780
81a661c0368b [project @ 1994-10-07 17:26:04 by jwe]
jwe
parents: 777
diff changeset
265 tree_constant::assign_map_element (SLList<char*>& list,
782
ffe18d3d64a6 [project @ 1994-10-07 19:01:20 by jwe]
jwe
parents: 780
diff changeset
266 tree_constant& rhs,
747
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
267 const Octave_object& args)
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
268 {
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
269 tree_constant_rep *tmp_rep = make_unique_map ();
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
270
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
271 if (rhs.is_map ())
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
272 rhs.make_unique ();
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
273
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
274 Pix p = list.first ();
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
275 while (p)
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
276 {
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
277 char *elt = list (p);
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
278
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
279 list.next (p);
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
280
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
281 tree_constant& tmp = tmp_rep->lookup_map_element (elt, 1);
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
282
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
283 if (! p)
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
284 {
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
285 tmp.assign (rhs, args);
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
286 return tmp;
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
287 }
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
288
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
289 tmp_rep = tmp.make_unique_map ();
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
290 }
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
291
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
292 return tree_constant ();
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
293 }
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
294
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
295 void
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
296 tree_constant::print_code (ostream& os)
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
297 {
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
298 print_code_indent (os);
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
299
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
300 if (in_parens)
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
301 os << "(";
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
302
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
303 if (rep)
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
304 rep->print_code (os);
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
305
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
306 if (in_parens)
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
307 os << ")";
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
308 }
6182de8cb3b7 [project @ 1994-09-30 15:09:36 by jwe]
jwe
parents: 629
diff changeset
309
1199
4f1bfa351b99 [project @ 1995-03-31 22:16:54 by jwe]
jwe
parents: 1192
diff changeset
310 int
4f1bfa351b99 [project @ 1995-03-31 22:16:54 by jwe]
jwe
parents: 1192
diff changeset
311 print_as_scalar (const tree_constant& val)
4f1bfa351b99 [project @ 1995-03-31 22:16:54 by jwe]
jwe
parents: 1192
diff changeset
312 {
4f1bfa351b99 [project @ 1995-03-31 22:16:54 by jwe]
jwe
parents: 1192
diff changeset
313 int nr = val.rows ();
4f1bfa351b99 [project @ 1995-03-31 22:16:54 by jwe]
jwe
parents: 1192
diff changeset
314 int nc = val.columns ();
4f1bfa351b99 [project @ 1995-03-31 22:16:54 by jwe]
jwe
parents: 1192
diff changeset
315 return (val.is_scalar_type ()
1355
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
316 || (val.is_string () && nr <= 1)
1199
4f1bfa351b99 [project @ 1995-03-31 22:16:54 by jwe]
jwe
parents: 1192
diff changeset
317 || (val.is_matrix_type ()
4f1bfa351b99 [project @ 1995-03-31 22:16:54 by jwe]
jwe
parents: 1192
diff changeset
318 && ((nr == 1 && nc == 1)
4f1bfa351b99 [project @ 1995-03-31 22:16:54 by jwe]
jwe
parents: 1192
diff changeset
319 || nr == 0
4f1bfa351b99 [project @ 1995-03-31 22:16:54 by jwe]
jwe
parents: 1192
diff changeset
320 || nc == 0)));
4f1bfa351b99 [project @ 1995-03-31 22:16:54 by jwe]
jwe
parents: 1192
diff changeset
321 }
4f1bfa351b99 [project @ 1995-03-31 22:16:54 by jwe]
jwe
parents: 1192
diff changeset
322
4f1bfa351b99 [project @ 1995-03-31 22:16:54 by jwe]
jwe
parents: 1192
diff changeset
323 int
4f1bfa351b99 [project @ 1995-03-31 22:16:54 by jwe]
jwe
parents: 1192
diff changeset
324 print_as_structure (const tree_constant& val)
4f1bfa351b99 [project @ 1995-03-31 22:16:54 by jwe]
jwe
parents: 1192
diff changeset
325 {
4f1bfa351b99 [project @ 1995-03-31 22:16:54 by jwe]
jwe
parents: 1192
diff changeset
326 return val.is_map ();
4f1bfa351b99 [project @ 1995-03-31 22:16:54 by jwe]
jwe
parents: 1192
diff changeset
327 }
4f1bfa351b99 [project @ 1995-03-31 22:16:54 by jwe]
jwe
parents: 1192
diff changeset
328
581
bc813f5eb025 [project @ 1994-08-07 01:02:15 by jwe]
jwe
parents: 531
diff changeset
329 // Construct return vector of empty matrices. Return empty matrices
bc813f5eb025 [project @ 1994-08-07 01:02:15 by jwe]
jwe
parents: 531
diff changeset
330 // and/or gripe when appropriate.
bc813f5eb025 [project @ 1994-08-07 01:02:15 by jwe]
jwe
parents: 531
diff changeset
331
500
5f91088cb98e [project @ 1994-07-08 02:16:02 by jwe]
jwe
parents: 493
diff changeset
332 Octave_object
164
e2c950dd96d2 [project @ 1993-10-18 19:32:00 by jwe]
jwe
parents: 161
diff changeset
333 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
334 {
500
5f91088cb98e [project @ 1994-07-08 02:16:02 by jwe]
jwe
parents: 493
diff changeset
335 Octave_object retval;
96
36ff440553cd [project @ 1993-09-13 02:48:39 by jwe]
jwe
parents: 1
diff changeset
336
1358
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1355
diff changeset
337 // Got an empty argument, check if should gripe/return empty
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1355
diff changeset
338 // values.
96
36ff440553cd [project @ 1993-09-13 02:48:39 by jwe]
jwe
parents: 1
diff changeset
339
36ff440553cd [project @ 1993-09-13 02:48:39 by jwe]
jwe
parents: 1
diff changeset
340 int flag = user_pref.propagate_empty_matrices;
36ff440553cd [project @ 1993-09-13 02:48:39 by jwe]
jwe
parents: 1
diff changeset
341 if (flag != 0)
36ff440553cd [project @ 1993-09-13 02:48:39 by jwe]
jwe
parents: 1
diff changeset
342 {
36ff440553cd [project @ 1993-09-13 02:48:39 by jwe]
jwe
parents: 1
diff changeset
343 if (flag < 0)
36ff440553cd [project @ 1993-09-13 02:48:39 by jwe]
jwe
parents: 1
diff changeset
344 gripe_empty_arg (fcn_name, 0);
36ff440553cd [project @ 1993-09-13 02:48:39 by jwe]
jwe
parents: 1
diff changeset
345
36ff440553cd [project @ 1993-09-13 02:48:39 by jwe]
jwe
parents: 1
diff changeset
346 Matrix m;
500
5f91088cb98e [project @ 1994-07-08 02:16:02 by jwe]
jwe
parents: 493
diff changeset
347 retval.resize (nargout ? nargout : 1);
96
36ff440553cd [project @ 1993-09-13 02:48:39 by jwe]
jwe
parents: 1
diff changeset
348 for (int i = 0; i < nargout; i++)
529
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 513
diff changeset
349 retval(i) = m;
96
36ff440553cd [project @ 1993-09-13 02:48:39 by jwe]
jwe
parents: 1
diff changeset
350 }
36ff440553cd [project @ 1993-09-13 02:48:39 by jwe]
jwe
parents: 1
diff changeset
351 else
36ff440553cd [project @ 1993-09-13 02:48:39 by jwe]
jwe
parents: 1
diff changeset
352 gripe_empty_arg (fcn_name, 1);
36ff440553cd [project @ 1993-09-13 02:48:39 by jwe]
jwe
parents: 1
diff changeset
353
36ff440553cd [project @ 1993-09-13 02:48:39 by jwe]
jwe
parents: 1
diff changeset
354 return retval;
36ff440553cd [project @ 1993-09-13 02:48:39 by jwe]
jwe
parents: 1
diff changeset
355 }
36ff440553cd [project @ 1993-09-13 02:48:39 by jwe]
jwe
parents: 1
diff changeset
356
1299
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
357 // -------------------------------------------------------------------
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
358 //
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
359 // Basic stuff for the tree-constant representation class.
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
360 //
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
361 // Leave the commented #includes below to make it easy to split this
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
362 // out again, should we want to do that.
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
363 //
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
364 // -------------------------------------------------------------------
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
365
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
366 // #ifdef HAVE_CONFIG_H
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
367 // #include <config.h>
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
368 // #endif
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
369
1355
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
370 #include <cctype>
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
371 // #include <cstring>
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
372
1299
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
373 #include <fstream.h>
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
374 // #include <iostream.h>
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
375
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
376 #include "mx-base.h"
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
377 #include "Range.h"
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
378
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
379 #include "arith-ops.h"
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
380 #include "variables.h"
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
381 #include "sysdep.h"
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
382 // #include "error.h"
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
383 // #include "gripes.h"
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
384 // #include "user-prefs.h"
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
385 #include "utils.h"
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
386 #include "pr-output.h"
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
387 // #include "tree-const.h"
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
388 #include "idx-vector.h"
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
389 #include "unwind-prot.h"
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
390 // #include "oct-map.h"
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
391
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
392 #include "tc-inlines.h"
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
393
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
394 // The following three variables could be made static members of the
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
395 // TC_REP class.
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
396
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
397 // Pointer to the blocks of memory we manage.
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
398 static TC_REP *tc_rep_newlist = 0;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
399
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
400 // Multiplier for allocating new blocks.
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
401 static const int tc_rep_newlist_grow_size = 128;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
402
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
403 // Indentation level for structures.
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
404 static int structure_indent_level = 0;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
405
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
406 static void
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
407 increment_structure_indent_level (void)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
408 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
409 structure_indent_level += 2;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
410 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
411
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
412 static void
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
413 decrement_structure_indent_level (void)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
414 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
415 structure_indent_level -= 2;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
416 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
417
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
418 static int
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
419 any_element_is_complex (const ComplexMatrix& a)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
420 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
421 int nr = a.rows ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
422 int nc = a.columns ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
423 for (int j = 0; j < nc; j++)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
424 for (int i = 0; i < nr; i++)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
425 if (imag (a.elem (i, j)) != 0.0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
426 return 1;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
427 return 0;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
428 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
429
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
430 // The real representation of constants.
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
431
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
432 TC_REP::tree_constant_rep (void)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
433 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
434 type_tag = unknown_constant;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
435 orig_text = 0;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
436 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
437
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
438 TC_REP::tree_constant_rep (double d)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
439 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
440 scalar = d;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
441 type_tag = scalar_constant;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
442 orig_text = 0;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
443 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
444
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
445 TC_REP::tree_constant_rep (const Matrix& m)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
446 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
447 if (m.rows () == 1 && m.columns () == 1)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
448 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
449 scalar = m.elem (0, 0);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
450 type_tag = scalar_constant;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
451 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
452 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
453 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
454 matrix = new Matrix (m);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
455 type_tag = matrix_constant;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
456 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
457 orig_text = 0;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
458 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
459
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
460 TC_REP::tree_constant_rep (const DiagMatrix& d)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
461 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
462 if (d.rows () == 1 && d.columns () == 1)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
463 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
464 scalar = d.elem (0, 0);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
465 type_tag = scalar_constant;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
466 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
467 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
468 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
469 matrix = new Matrix (d);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
470 type_tag = matrix_constant;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
471 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
472 orig_text = 0;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
473 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
474
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
475 TC_REP::tree_constant_rep (const RowVector& v, int prefer_column_vector)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
476 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
477 int len = v.capacity ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
478 if (len == 1)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
479 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
480 scalar = v.elem (0);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
481 type_tag = scalar_constant;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
482 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
483 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
484 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
485 int pcv = (prefer_column_vector < 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
486 ? user_pref.prefer_column_vectors
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
487 : prefer_column_vector;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
488
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
489 if (pcv)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
490 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
491 Matrix m (len, 1);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
492 for (int i = 0; i < len; i++)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
493 m.elem (i, 0) = v.elem (i);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
494 matrix = new Matrix (m);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
495 type_tag = matrix_constant;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
496 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
497 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
498 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
499 Matrix m (1, len);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
500 for (int i = 0; i < len; i++)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
501 m.elem (0, i) = v.elem (i);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
502 matrix = new Matrix (m);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
503 type_tag = matrix_constant;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
504 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
505 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
506 orig_text = 0;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
507 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
508
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
509 TC_REP::tree_constant_rep (const ColumnVector& v, int prefer_column_vector)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
510 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
511 int len = v.capacity ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
512 if (len == 1)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
513 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
514 scalar = v.elem (0);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
515 type_tag = scalar_constant;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
516 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
517 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
518 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
519 int pcv = (prefer_column_vector < 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
520 ? user_pref.prefer_column_vectors
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
521 : prefer_column_vector;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
522
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
523 if (pcv)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
524 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
525 Matrix m (len, 1);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
526 for (int i = 0; i < len; i++)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
527 m.elem (i, 0) = v.elem (i);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
528 matrix = new Matrix (m);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
529 type_tag = matrix_constant;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
530 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
531 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
532 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
533 Matrix m (1, len);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
534 for (int i = 0; i < len; i++)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
535 m.elem (0, i) = v.elem (i);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
536 matrix = new Matrix (m);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
537 type_tag = matrix_constant;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
538 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
539 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
540 orig_text = 0;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
541 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
542
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
543 TC_REP::tree_constant_rep (const Complex& c)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
544 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
545 complex_scalar = new Complex (c);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
546 type_tag = complex_scalar_constant;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
547 orig_text = 0;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
548 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
549
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
550 TC_REP::tree_constant_rep (const ComplexMatrix& m)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
551 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
552 if (m.rows () == 1 && m.columns () == 1)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
553 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
554 complex_scalar = new Complex (m.elem (0, 0));
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
555 type_tag = complex_scalar_constant;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
556 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
557 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
558 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
559 complex_matrix = new ComplexMatrix (m);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
560 type_tag = complex_matrix_constant;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
561 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
562 orig_text = 0;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
563 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
564
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
565 TC_REP::tree_constant_rep (const ComplexDiagMatrix& d)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
566 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
567 if (d.rows () == 1 && d.columns () == 1)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
568 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
569 complex_scalar = new Complex (d.elem (0, 0));
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
570 type_tag = complex_scalar_constant;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
571 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
572 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
573 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
574 complex_matrix = new ComplexMatrix (d);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
575 type_tag = complex_matrix_constant;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
576 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
577 orig_text = 0;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
578 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
579
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
580 TC_REP::tree_constant_rep (const ComplexRowVector& v,
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
581 int prefer_column_vector)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
582 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
583 int len = v.capacity ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
584 if (len == 1)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
585 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
586 complex_scalar = new Complex (v.elem (0));
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
587 type_tag = complex_scalar_constant;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
588 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
589 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
590 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
591 int pcv = (prefer_column_vector < 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
592 ? user_pref.prefer_column_vectors
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
593 : prefer_column_vector;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
594
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
595 if (pcv)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
596 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
597 ComplexMatrix m (len, 1);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
598 for (int i = 0; i < len; i++)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
599 m.elem (i, 0) = v.elem (i);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
600 complex_matrix = new ComplexMatrix (m);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
601 type_tag = complex_matrix_constant;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
602 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
603 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
604 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
605 ComplexMatrix m (1, len);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
606 for (int i = 0; i < len; i++)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
607 m.elem (0, i) = v.elem (i);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
608 complex_matrix = new ComplexMatrix (m);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
609 type_tag = complex_matrix_constant;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
610 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
611 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
612 orig_text = 0;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
613 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
614
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
615 TC_REP::tree_constant_rep (const ComplexColumnVector& v, int
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
616 prefer_column_vector)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
617 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
618 int len = v.capacity ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
619 if (len == 1)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
620 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
621 complex_scalar = new Complex (v.elem (0));
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
622 type_tag = complex_scalar_constant;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
623 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
624 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
625 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
626 int pcv = (prefer_column_vector < 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
627 ? user_pref.prefer_column_vectors
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
628 : prefer_column_vector;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
629
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
630 if (pcv)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
631 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
632 ComplexMatrix m (len, 1);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
633 for (int i = 0; i < len; i++)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
634 m.elem (i, 0) = v.elem (i);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
635 complex_matrix = new ComplexMatrix (m);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
636 type_tag = complex_matrix_constant;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
637 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
638 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
639 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
640 ComplexMatrix m (1, len);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
641 for (int i = 0; i < len; i++)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
642 m.elem (0, i) = v.elem (i);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
643 complex_matrix = new ComplexMatrix (m);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
644 type_tag = complex_matrix_constant;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
645 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
646 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
647 orig_text = 0;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
648 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
649
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
650 TC_REP::tree_constant_rep (const char *s)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
651 {
1355
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
652 str_obj = new Octave_str_obj (s);
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
653 type_tag = string_constant;
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
654 orig_text = 0;
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
655 }
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
656
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
657 TC_REP::tree_constant_rep (const Octave_str_obj& s)
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
658 {
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
659 str_obj = new Octave_str_obj (s);
1299
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
660 type_tag = string_constant;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
661 orig_text = 0;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
662 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
663
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
664 TC_REP::tree_constant_rep (double b, double l, double i)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
665 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
666 range = new Range (b, l, i);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
667 int nel = range->nelem ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
668 if (nel > 1)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
669 type_tag = range_constant;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
670 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
671 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
672 delete range;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
673 if (nel == 1)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
674 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
675 scalar = b;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
676 type_tag = scalar_constant;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
677 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
678 else if (nel == 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
679 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
680 matrix = new Matrix ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
681 type_tag = matrix_constant;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
682 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
683 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
684 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
685 type_tag = unknown_constant;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
686 if (nel == -1)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
687 ::error ("number of elements in range exceeds INT_MAX");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
688 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
689 ::error ("invalid range");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
690 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
691 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
692 orig_text = 0;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
693 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
694
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
695 TC_REP::tree_constant_rep (const Range& r)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
696 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
697 int nel = r.nelem ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
698 if (nel > 1)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
699 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
700 range = new Range (r);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
701 type_tag = range_constant;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
702 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
703 else if (nel == 1)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
704 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
705 scalar = r.base ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
706 type_tag = scalar_constant;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
707 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
708 else if (nel == 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
709 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
710 matrix = new Matrix ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
711 type_tag = matrix_constant;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
712 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
713 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
714 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
715 type_tag = unknown_constant;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
716 if (nel == -1)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
717 ::error ("number of elements in range exceeds INT_MAX");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
718 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
719 ::error ("invalid range");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
720 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
721
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
722 orig_text = 0;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
723 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
724
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
725 TC_REP::tree_constant_rep (const Octave_map& m)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
726 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
727 a_map = new Octave_map (m);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
728 type_tag = map_constant;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
729 orig_text = 0;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
730 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
731
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
732 TC_REP::tree_constant_rep (TC_REP::constant_type t)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
733 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
734 assert (t == magic_colon || t == all_va_args);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
735 type_tag = t;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
736 orig_text = 0;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
737 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
738
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
739 TC_REP::tree_constant_rep (const tree_constant_rep& t)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
740 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
741 type_tag = t.type_tag;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
742
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
743 switch (t.type_tag)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
744 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
745 case unknown_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
746 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
747
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
748 case scalar_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
749 scalar = t.scalar;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
750 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
751
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
752 case matrix_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
753 matrix = new Matrix (*(t.matrix));
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
754 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
755
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
756 case string_constant:
1355
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
757 str_obj = new Octave_str_obj (*(t.str_obj));
1299
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
758 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
759
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
760 case complex_matrix_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
761 complex_matrix = new ComplexMatrix (*(t.complex_matrix));
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
762 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
763
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
764 case complex_scalar_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
765 complex_scalar = new Complex (*(t.complex_scalar));
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
766 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
767
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
768 case range_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
769 range = new Range (*(t.range));
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
770 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
771
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
772 case map_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
773 a_map = new Octave_map (*(t.a_map));
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
774 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
775
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
776 case magic_colon:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
777 case all_va_args:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
778 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
779 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
780
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
781 orig_text = strsave (t.orig_text);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
782 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
783
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
784 TC_REP::~tree_constant_rep (void)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
785 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
786 switch (type_tag)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
787 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
788 case matrix_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
789 delete matrix;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
790 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
791
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
792 case complex_scalar_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
793 delete complex_scalar;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
794 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
795
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
796 case complex_matrix_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
797 delete complex_matrix;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
798 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
799
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
800 case string_constant:
1355
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
801 delete str_obj;
1299
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
802 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
803
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
804 case range_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
805 delete range;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
806 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
807
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
808 case map_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
809 delete a_map;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
810 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
811
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
812 case unknown_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
813 case scalar_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
814 case magic_colon:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
815 case all_va_args:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
816 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
817 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
818
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
819 delete [] orig_text;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
820 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
821
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
822 void *
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
823 TC_REP::operator new (size_t size)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
824 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
825 assert (size == sizeof (TC_REP));
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
826
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
827 if (! tc_rep_newlist)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
828 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
829 int block_size = tc_rep_newlist_grow_size * sizeof (TC_REP);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
830 tc_rep_newlist = (TC_REP *) new char [block_size];
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
831
1321
64819a909ed7 [project @ 1995-08-22 05:39:43 by jwe]
jwe
parents: 1320
diff changeset
832 int i = 0;
64819a909ed7 [project @ 1995-08-22 05:39:43 by jwe]
jwe
parents: 1320
diff changeset
833
64819a909ed7 [project @ 1995-08-22 05:39:43 by jwe]
jwe
parents: 1320
diff changeset
834 for (i = 0; i < tc_rep_newlist_grow_size - 1; i++)
1299
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
835 tc_rep_newlist[i].freeptr = &tc_rep_newlist[i+1];
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
836
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
837 tc_rep_newlist[i].freeptr = 0;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
838 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
839
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
840 TC_REP *tmp = tc_rep_newlist;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
841 tc_rep_newlist = tc_rep_newlist->freeptr;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
842 return tmp;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
843 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
844
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
845 void
1488
89c587478067 [project @ 1995-09-26 22:49:48 by jwe]
jwe
parents: 1430
diff changeset
846 TC_REP::operator delete (void *p, size_t /* size */)
1299
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
847 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
848 TC_REP *tmp = (TC_REP *) p;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
849 tmp->freeptr = tc_rep_newlist;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
850 tc_rep_newlist = tmp;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
851 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
852
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
853 int
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
854 TC_REP::rows (void) const
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
855 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
856 int retval = -1;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
857
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
858 switch (type_tag)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
859 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
860 case scalar_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
861 case complex_scalar_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
862 retval = 1;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
863 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
864
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
865 case string_constant:
1355
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
866 retval = str_obj->num_strings ();
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
867 break;
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
868
1299
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
869 case range_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
870 retval = (columns () > 0);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
871 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
872
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
873 case matrix_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
874 retval = matrix->rows ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
875 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
876
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
877 case complex_matrix_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
878 retval = complex_matrix->rows ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
879 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
880
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
881 default:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
882 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
883 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
884
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
885 return retval;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
886 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
887
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
888 int
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
889 TC_REP::columns (void) const
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
890 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
891 int retval = -1;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
892
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
893 switch (type_tag)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
894 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
895 case scalar_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
896 case complex_scalar_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
897 retval = 1;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
898 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
899
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
900 case matrix_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
901 retval = matrix->columns ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
902 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
903
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
904 case complex_matrix_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
905 retval = complex_matrix->columns ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
906 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
907
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
908 case string_constant:
1355
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
909 retval = str_obj->max_length ();
1299
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
910 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
911
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
912 case range_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
913 retval = range->nelem ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
914 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
915
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
916 default:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
917 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
918 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
919
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
920 return retval;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
921 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
922
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
923 tree_constant
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
924 TC_REP::all (void) const
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
925 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
926 tree_constant retval;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
927
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
928 if (error_state)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
929 return retval;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
930
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
931 if (! is_numeric_type ())
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
932 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
933 tree_constant tmp = make_numeric ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
934
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
935 if (error_state)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
936 return retval;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
937
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
938 return tmp.all ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
939 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
940
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
941 switch (type_tag)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
942 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
943 case scalar_constant:
1355
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
944 retval = (double) (scalar != 0.0);
1299
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
945 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
946
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
947 case matrix_constant:
1355
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
948 retval = matrix->all ();
1299
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
949 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
950
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
951 case complex_scalar_constant:
1355
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
952 retval = (double) (*complex_scalar != 0.0);
1299
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
953 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
954
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
955 case complex_matrix_constant:
1355
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
956 retval = complex_matrix->all ();
1299
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
957 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
958
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
959 default:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
960 gripe_wrong_type_arg ("all", *this);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
961 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
962 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
963
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
964 return retval;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
965 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
966
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
967 tree_constant
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
968 TC_REP::any (void) const
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
969 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
970 tree_constant retval;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
971
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
972 if (error_state)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
973 return retval;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
974
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
975 if (! is_numeric_type ())
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
976 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
977 tree_constant tmp = make_numeric ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
978
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
979 if (error_state)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
980 return retval;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
981
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
982 return tmp.any ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
983 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
984
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
985 switch (type_tag)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
986 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
987 case scalar_constant:
1355
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
988 retval = (double) (scalar != 0.0);
1299
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
989 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
990
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
991 case matrix_constant:
1355
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
992 retval = matrix->any ();
1299
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
993 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
994
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
995 case complex_scalar_constant:
1355
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
996 retval = (double) (*complex_scalar != 0.0);
1299
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
997 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
998
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
999 case complex_matrix_constant:
1355
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
1000 retval = complex_matrix->any ();
1299
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1001 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1002
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1003 default:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1004 gripe_wrong_type_arg ("any", *this);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1005 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1006 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1007
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1008 return retval;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1009 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1010
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1011 int
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1012 TC_REP::valid_as_scalar_index (void) const
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1013 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1014 return (type_tag == magic_colon
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1015 || (type_tag == scalar_constant
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1016 && ! xisnan (scalar)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1017 && NINT (scalar) == 1)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1018 || (type_tag == range_constant
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1019 && range->nelem () == 1
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1020 && ! xisnan (range->base ())
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1021 && NINT (range->base ()) == 1));
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1022 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1023
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1024 int
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1025 TC_REP::valid_as_zero_index (void) const
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1026 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1027 return ((type_tag == scalar_constant
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1028 && ! xisnan (scalar)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1029 && NINT (scalar) == 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1030 || (type_tag == matrix_constant
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1031 && matrix->rows () == 0
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1032 && matrix->columns () == 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1033 || (type_tag == range_constant
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1034 && range->nelem () == 1
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1035 && ! xisnan (range->base ())
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1036 && NINT (range->base ()) == 0));
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1037 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1038
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1039 int
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1040 TC_REP::is_true (void) const
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1041 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1042 int retval = 0;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1043
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1044 if (error_state)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1045 return retval;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1046
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1047 if (! is_numeric_type ())
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1048 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1049 tree_constant tmp = make_numeric ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1050
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1051 if (error_state)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1052 return retval;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1053
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1054 return tmp.is_true ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1055 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1056
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1057 switch (type_tag)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1058 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1059 case scalar_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1060 retval = (scalar != 0.0);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1061 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1062
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1063 case matrix_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1064 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1065 Matrix m = (matrix->all ()) . all ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1066 retval = (m.rows () == 1
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1067 && m.columns () == 1
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1068 && m.elem (0, 0) != 0.0);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1069 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1070 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1071
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1072 case complex_scalar_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1073 retval = (*complex_scalar != 0.0);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1074 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1075
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1076 case complex_matrix_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1077 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1078 Matrix m = (complex_matrix->all ()) . all ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1079 retval = (m.rows () == 1
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1080 && m.columns () == 1
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1081 && m.elem (0, 0) != 0.0);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1082 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1083 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1084
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1085 default:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1086 gripe_wrong_type_arg (0, *this);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1087 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1088 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1089
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1090 return retval;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1091 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1092
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1093 static void
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1094 warn_implicit_conversion (const char *from, const char *to)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1095 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1096 warning ("implicit conversion from %s to %s", from, to);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1097 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1098
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1099 double
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1100 TC_REP::double_value (int force_string_conversion) const
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1101 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1102 double retval = octave_NaN;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1103
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1104 switch (type_tag)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1105 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1106 case scalar_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1107 retval = scalar;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1108 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1109
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1110 case matrix_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1111 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1112 if (user_pref.do_fortran_indexing && rows () > 0 && columns () > 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1113 retval = matrix->elem (0, 0);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1114 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1115 gripe_invalid_conversion ("real matrix", "real scalar");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1116 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1117 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1118
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1119 case complex_matrix_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1120 case complex_scalar_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1121 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1122 int flag = user_pref.ok_to_lose_imaginary_part;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1123
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1124 if (flag < 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1125 warn_implicit_conversion ("complex scalar", "real scalar");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1126
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1127 if (flag)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1128 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1129 if (type_tag == complex_scalar_constant)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1130 retval = ::real (*complex_scalar);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1131 else if (type_tag == complex_matrix_constant)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1132 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1133 if (user_pref.do_fortran_indexing
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1134 && rows () > 0 && columns () > 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1135 retval = ::real (complex_matrix->elem (0, 0));
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1136 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1137 gripe_invalid_conversion ("complex matrix", "real scalar");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1138 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1139 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1140 panic_impossible ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1141 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1142 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1143 gripe_invalid_conversion ("complex scalar", "real scalar");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1144 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1145 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1146
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1147 case string_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1148 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1149 int flag = force_string_conversion;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1150 if (! flag)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1151 flag = user_pref.implicit_str_to_num_ok;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1152
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1153 if (flag < 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1154 warn_implicit_conversion ("string", "real scalar");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1155
1355
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
1156 int len = str_obj->max_length ();
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
1157 if (flag
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
1158 && ((str_obj->num_strings () == 1 && len == 1)
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
1159 || (len > 1 && user_pref.do_fortran_indexing)))
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
1160 retval = toascii ((int) str_obj->elem (0, 0));
1299
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1161 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1162 gripe_invalid_conversion ("string", "real scalar");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1163 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1164 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1165
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1166 case range_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1167 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1168 int nel = range->nelem ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1169 if (nel == 1 || (nel > 1 && user_pref.do_fortran_indexing))
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1170 retval = range->base ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1171 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1172 gripe_invalid_conversion ("range", "real scalar");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1173 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1174 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1175
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1176 default:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1177 gripe_invalid_conversion (type_as_string (), "real scalar");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1178 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1179 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1180
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1181 return retval;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1182 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1183
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1184 Matrix
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1185 TC_REP::matrix_value (int force_string_conversion) const
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1186 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1187 Matrix retval;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1188
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1189 switch (type_tag)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1190 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1191 case scalar_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1192 retval = Matrix (1, 1, scalar);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1193 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1194
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1195 case matrix_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1196 retval = *matrix;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1197 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1198
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1199 case complex_scalar_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1200 case complex_matrix_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1201 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1202 int flag = user_pref.ok_to_lose_imaginary_part;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1203 if (flag < 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1204 warn_implicit_conversion ("complex matrix", "real matrix");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1205
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1206 if (flag)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1207 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1208 if (type_tag == complex_scalar_constant)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1209 retval = Matrix (1, 1, ::real (*complex_scalar));
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1210 else if (type_tag == complex_matrix_constant)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1211 retval = ::real (*complex_matrix);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1212 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1213 panic_impossible ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1214 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1215 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1216 gripe_invalid_conversion ("complex matrix", "real matrix");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1217 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1218 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1219
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1220 case string_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1221 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1222 int flag = force_string_conversion;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1223 if (! flag)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1224 flag = user_pref.implicit_str_to_num_ok;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1225
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1226 if (flag < 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1227 warn_implicit_conversion ("string", "real matrix");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1228
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1229 if (flag)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1230 {
1355
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
1231 int nr = str_obj->num_strings ();
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
1232 int nc = str_obj->max_length ();
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
1233
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
1234 if (nr > 0 && nc > 0)
1299
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1235 {
1355
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
1236 retval.resize (nr, nc);
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
1237
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
1238 for (int i = 0; i < nr; i++)
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
1239 {
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
1240 for (int j = 0; j < nc; j++)
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
1241 {
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
1242 int c = (int) str_obj->elem (i, j);
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
1243 retval.elem (i, j) = toascii (c);
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
1244 }
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
1245 }
1299
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1246 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1247 else
1355
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
1248 retval = Matrix (); // XXX FIXME XXX -- is this correct?
1299
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1249 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1250 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1251 gripe_invalid_conversion ("string", "real matrix");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1252 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1253 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1254
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1255 case range_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1256 retval = range->matrix_value ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1257 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1258
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1259 default:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1260 gripe_invalid_conversion (type_as_string (), "real matrix");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1261 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1262 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1263
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1264 return retval;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1265 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1266
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1267 Complex
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1268 TC_REP::complex_value (int force_string_conversion) const
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1269 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1270 Complex retval (octave_NaN, octave_NaN);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1271
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1272 switch (type_tag)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1273 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1274 case complex_scalar_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1275 retval = *complex_scalar;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1276 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1277
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1278 case scalar_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1279 retval = scalar;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1280 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1281
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1282 case complex_matrix_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1283 case matrix_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1284 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1285 if (user_pref.do_fortran_indexing && rows () > 0 && columns () > 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1286 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1287 if (type_tag == complex_matrix_constant)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1288 retval = complex_matrix->elem (0, 0);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1289 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1290 retval = matrix->elem (0, 0);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1291 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1292 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1293 gripe_invalid_conversion ("real matrix", "real scalar");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1294 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1295 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1296
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1297 case string_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1298 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1299 int flag = force_string_conversion;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1300 if (! flag)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1301 flag = user_pref.implicit_str_to_num_ok;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1302
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1303 if (flag < 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1304 warn_implicit_conversion ("string", "complex scalar");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1305
1355
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
1306 int len = str_obj->max_length ();
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
1307 if (flag
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
1308 && ((str_obj->num_strings () == 1 && len == 1)
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
1309 || (len > 1 && user_pref.do_fortran_indexing)))
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
1310 retval = toascii ((int) str_obj->elem (0, 0));
1299
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1311 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1312 gripe_invalid_conversion ("string", "complex scalar");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1313 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1314 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1315
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1316 case range_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1317 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1318 int nel = range->nelem ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1319 if (nel == 1 || (nel > 1 && user_pref.do_fortran_indexing))
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1320 retval = range->base ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1321 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1322 gripe_invalid_conversion ("range", "complex scalar");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1323 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1324 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1325
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1326 default:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1327 gripe_invalid_conversion (type_as_string (), "complex scalar");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1328 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1329 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1330
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1331 return retval;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1332 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1333
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1334 ComplexMatrix
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1335 TC_REP::complex_matrix_value (int force_string_conversion) const
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1336 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1337 ComplexMatrix retval;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1338
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1339 switch (type_tag)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1340 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1341 case scalar_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1342 retval = ComplexMatrix (1, 1, Complex (scalar));
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1343 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1344
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1345 case complex_scalar_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1346 retval = ComplexMatrix (1, 1, *complex_scalar);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1347 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1348
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1349 case matrix_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1350 retval = ComplexMatrix (*matrix);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1351 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1352
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1353 case complex_matrix_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1354 retval = *complex_matrix;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1355 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1356
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1357 case string_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1358 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1359 int flag = force_string_conversion;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1360 if (! flag)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1361 flag = user_pref.implicit_str_to_num_ok;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1362
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1363 if (flag < 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1364 warn_implicit_conversion ("string", "complex matrix");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1365
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1366 if (flag)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1367 {
1355
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
1368 int nr = str_obj->num_strings ();
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
1369 int nc = str_obj->max_length ();
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
1370
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
1371 if (nr > 0 && nc > 0)
1299
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1372 {
1355
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
1373 retval.resize (nr, nc);
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
1374
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
1375 for (int i = 0; i < nr; i++)
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
1376 {
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
1377 for (int j = 0; j < nc; j++)
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
1378 {
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
1379 int c = (int) str_obj->elem (i, j);
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
1380 retval.elem (i, j) = toascii (c);
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
1381 }
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
1382 }
1299
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1383 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1384 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1385 panic_impossible ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1386 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1387 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1388 gripe_invalid_conversion ("string", "real matrix");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1389 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1390 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1391
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1392 case range_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1393 retval = range->matrix_value ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1394 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1395
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1396 default:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1397 gripe_invalid_conversion (type_as_string (), "complex matrix");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1398 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1399 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1400
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1401 return retval;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1402 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1403
1355
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
1404 Octave_str_obj
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
1405 TC_REP::all_strings (void) const
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
1406 {
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
1407 if (type_tag == string_constant)
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
1408 return *str_obj;
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
1409 else
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
1410 {
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
1411 gripe_invalid_conversion (type_as_string (), "string");
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
1412 return 0;
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
1413 }
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
1414 }
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
1415
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
1416 const char *
1299
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1417 TC_REP::string_value (void) const
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1418 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1419 if (type_tag == string_constant)
1355
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
1420 return str_obj->elem (0).c_str (); // XXX FIXME??? XXX
1299
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1421 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1422 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1423 gripe_invalid_conversion (type_as_string (), "string");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1424 return 0;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1425 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1426 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1427
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1428 Range
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1429 TC_REP::range_value (void) const
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1430 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1431 assert (type_tag == range_constant);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1432 return *range;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1433 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1434
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1435 Octave_map
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1436 TC_REP::map_value (void) const
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1437 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1438 assert (type_tag == map_constant);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1439 return *a_map;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1440 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1441
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1442 tree_constant&
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1443 TC_REP::lookup_map_element (const char *name, int insert, int silent)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1444 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1445 static tree_constant retval;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1446
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1447 if (type_tag == map_constant)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1448 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1449 Pix idx = a_map->seek (name);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1450
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1451 if (idx)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1452 return a_map->contents (idx);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1453 else if (insert)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1454 return (*a_map) [name];
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1455 else if (! silent)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1456 error ("structure has no member `%s'", name);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1457 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1458 else if (! silent)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1459 error ("invalid structure access attempted");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1460
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1461 return retval;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1462 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1463
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1464 // This could be made more efficient by doing all the work here rather
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1465 // than relying on matrix_value() to do any possible type conversions.
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1466
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1467 ColumnVector
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1468 TC_REP::vector_value (int force_string_conversion,
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1469 int force_vector_conversion) const
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1470 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1471 ColumnVector retval;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1472
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1473 Matrix m = matrix_value (force_string_conversion);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1474
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1475 if (error_state)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1476 return retval;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1477
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1478 int nr = m.rows ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1479 int nc = m.columns ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1480 if (nr == 1)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1481 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1482 retval.resize (nc);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1483 for (int i = 0; i < nc; i++)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1484 retval.elem (i) = m (0, i);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1485 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1486 else if (nc == 1)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1487 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1488 retval.resize (nr);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1489 for (int i = 0; i < nr; i++)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1490 retval.elem (i) = m.elem (i, 0);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1491 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1492 else if (nr > 0 && nc > 0
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1493 && (user_pref.do_fortran_indexing || force_vector_conversion))
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1494 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1495 retval.resize (nr * nc);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1496 int k = 0;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1497 for (int j = 0; j < nc; j++)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1498 for (int i = 0; i < nr; i++)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1499 retval.elem (k++) = m.elem (i, j);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1500 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1501 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1502 gripe_invalid_conversion ("real matrix", "real vector");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1503
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1504 return retval;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1505 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1506
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1507 // This could be made more efficient by doing all the work here rather
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1508 // than relying on complex_matrix_value() to do any possible type
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1509 // conversions.
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1510
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1511 ComplexColumnVector
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1512 TC_REP::complex_vector_value (int force_string_conversion,
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1513 int force_vector_conversion) const
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1514 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1515 ComplexColumnVector retval;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1516
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1517 ComplexMatrix m = complex_matrix_value (force_string_conversion);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1518
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1519 if (error_state)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1520 return retval;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1521
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1522 int nr = m.rows ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1523 int nc = m.columns ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1524 if (nr == 1)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1525 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1526 retval.resize (nc);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1527 for (int i = 0; i < nc; i++)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1528 retval.elem (i) = m (0, i);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1529 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1530 else if (nc == 1)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1531 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1532 retval.resize (nr);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1533 for (int i = 0; i < nr; i++)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1534 retval.elem (i) = m.elem (i, 0);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1535 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1536 else if (nr > 0 && nc > 0
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1537 && (user_pref.do_fortran_indexing || force_vector_conversion))
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1538 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1539 retval.resize (nr * nc);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1540 int k = 0;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1541 for (int j = 0; j < nc; j++)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1542 for (int i = 0; i < nr; i++)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1543 retval.elem (k++) = m.elem (i, j);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1544 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1545 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1546 gripe_invalid_conversion ("complex matrix", "complex vector");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1547
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1548 return retval;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1549 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1550
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1551 tree_constant
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1552 TC_REP::convert_to_str (void) const
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1553 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1554 tree_constant retval;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1555
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1556 switch (type_tag)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1557 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1558 case complex_scalar_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1559 case scalar_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1560 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1561 double d = double_value ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1562
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1563 if (xisnan (d))
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1564 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1565 ::error ("invalid conversion from NaN to character");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1566 return retval;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1567 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1568 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1569 {
1358
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1355
diff changeset
1570 // XXX FIXME XXX -- warn about out of range conversions?
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1355
diff changeset
1571
1299
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1572 int i = NINT (d);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1573 char s[2];
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1574 s[0] = (char) i;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1575 s[1] = '\0';
1355
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
1576 retval = s;
1299
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1577 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1578 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1579 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1580
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1581 case complex_matrix_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1582 case matrix_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1583 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1584 if (rows () == 0 && columns () == 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1585 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1586 char s = '\0';
1355
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
1587 retval = &s;
1299
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1588 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1589 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1590 {
1355
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
1591 Matrix m = matrix_value ();
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
1592
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
1593 int nr = m.rows ();
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
1594 int nc = m.columns ();
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
1595
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
1596 if (nr == 0 || nc == 0)
1299
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1597 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1598 char s = '\0';
1355
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
1599 retval = &s;
1299
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1600 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1601 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1602 {
1355
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
1603 Octave_str_obj s (nr);
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
1604
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
1605 for (int i = 0; i < nr; i++)
1299
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1606 {
1355
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
1607 char buf[nc+1];
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
1608 buf[nc] = '\0';
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
1609
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
1610 for (int j = 0; j < nc; j++)
1299
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1611 {
1355
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
1612 double d = m.elem (i, j);
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
1613
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
1614 if (xisnan (d))
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
1615 {
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
1616 ::error ("invalid conversion from NaN to character");
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
1617 return retval;
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
1618 }
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
1619 else
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
1620 {
1358
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1355
diff changeset
1621 // XXX FIXME XXX -- warn about out of
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1355
diff changeset
1622 // range conversions?
1355
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
1623
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
1624 int ival = NINT (d);
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
1625 buf[j] = (char) ival;
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
1626 }
1299
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1627 }
1355
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
1628
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
1629 s.elem (i).assign (buf, nc);
1299
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1630 }
1355
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
1631
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
1632 retval = s;
1299
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1633 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1634 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1635 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1636 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1637
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1638 case range_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1639 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1640 Range r = range_value ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1641 double b = r.base ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1642 double incr = r.inc ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1643 int nel = r.nelem ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1644 char *s = new char [nel+1];
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1645 s[nel] = '\0';
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1646 for (int i = 0; i < nel; i++)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1647 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1648 double d = b + i * incr;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1649
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1650 if (xisnan (d))
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1651 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1652 ::error ("invalid conversion from NaN to character");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1653 delete [] s;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1654 return retval;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1655 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1656 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1657 {
1358
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1355
diff changeset
1658 // XXX FIXME XXX -- warn about out of range
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1355
diff changeset
1659 // conversions?
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1355
diff changeset
1660
1299
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1661 int ival = NINT (d);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1662 s[i] = (char) ival;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1663 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1664 }
1355
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
1665 retval = s;
1299
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1666 delete [] s;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1667 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1668 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1669
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1670 case string_constant:
1355
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
1671 retval = *str_obj;
1299
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1672 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1673
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1674 default:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1675 gripe_invalid_conversion (type_as_string (), "string");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1676 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1677 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1678
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1679 return retval;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1680 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1681
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1682 void
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1683 TC_REP::convert_to_row_or_column_vector (void)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1684 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1685 assert (type_tag == matrix_constant || type_tag == complex_matrix_constant);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1686
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1687 int nr = rows ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1688 int nc = columns ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1689
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1690 if (nr == 1 || nc == 1)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1691 return;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1692
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1693 int len = nr * nc;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1694
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1695 assert (len > 0);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1696
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1697 int new_nr = 1;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1698 int new_nc = 1;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1699
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1700 if (user_pref.prefer_column_vectors)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1701 new_nr = len;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1702 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1703 new_nc = len;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1704
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1705 if (type_tag == matrix_constant)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1706 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1707 Matrix *m = new Matrix (new_nr, new_nc);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1708
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1709 double *cop_out = matrix->fortran_vec ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1710
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1711 for (int i = 0; i < len; i++)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1712 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1713 if (new_nr == 1)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1714 m->elem (0, i) = *cop_out++;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1715 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1716 m->elem (i, 0) = *cop_out++;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1717 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1718
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1719 delete matrix;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1720 matrix = m;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1721 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1722 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1723 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1724 ComplexMatrix *cm = new ComplexMatrix (new_nr, new_nc);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1725
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1726 Complex *cop_out = complex_matrix->fortran_vec ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1727
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1728 for (int i = 0; i < len; i++)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1729 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1730 if (new_nr == 1)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1731 cm->elem (0, i) = *cop_out++;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1732 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1733 cm->elem (i, 0) = *cop_out++;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1734 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1735
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1736 delete complex_matrix;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1737 complex_matrix = cm;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1738 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1739 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1740
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1741 void
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1742 TC_REP::force_numeric (int force_str_conv)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1743 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1744 switch (type_tag)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1745 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1746 case scalar_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1747 case matrix_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1748 case complex_scalar_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1749 case complex_matrix_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1750 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1751
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1752 case string_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1753 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1754 if (! force_str_conv && ! user_pref.implicit_str_to_num_ok)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1755 {
1490
4d6c168ff235 [project @ 1995-09-29 03:59:46 by jwe]
jwe
parents: 1488
diff changeset
1756 ::error ("string to numeric conversion failed --\
4d6c168ff235 [project @ 1995-09-29 03:59:46 by jwe]
jwe
parents: 1488
diff changeset
1757 default conversion turned off");
1299
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1758 return;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1759 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1760
1355
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
1761 int nr = str_obj->num_strings ();
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
1762 int nc = str_obj->max_length ();
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
1763
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
1764 if (nr == 1 && nc == 1)
1299
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1765 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1766 type_tag = scalar_constant;
1355
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
1767 scalar = toascii ((int) str_obj->elem (0, 0));
1299
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1768 }
1355
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
1769 else if (nr == 0 || nc == 0)
1299
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1770 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1771 type_tag = matrix_constant;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1772 matrix = new Matrix (0, 0);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1773 }
1355
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
1774 else if (nr > 0 && nc > 0)
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
1775 {
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
1776 type_tag = matrix_constant;
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
1777
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
1778 Matrix *tm = new Matrix (nr, nc);
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
1779
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
1780 for (int i = 0; i < nr; i++)
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
1781 {
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
1782 for (int j = 0; j < nc; j++)
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
1783 {
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
1784 int c = (int) str_obj->elem (i, j);
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
1785 tm->elem (i, j) = toascii (c);
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
1786 }
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
1787 }
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
1788 matrix = tm;
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
1789 }
1299
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1790 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1791 panic_impossible ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1792 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1793 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1794
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1795 case range_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1796 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1797 int len = range->nelem ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1798 if (len > 1)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1799 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1800 type_tag = matrix_constant;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1801 Matrix *tm = new Matrix (1, len);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1802 double b = range->base ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1803 double increment = range->inc ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1804 for (int i = 0; i < len; i++)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1805 tm->elem (0, i) = b + i * increment;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1806 matrix = tm;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1807 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1808 else if (len == 1)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1809 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1810 type_tag = scalar_constant;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1811 scalar = range->base ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1812 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1813 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1814 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1815
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1816 default:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1817 gripe_invalid_conversion (type_as_string (), "numeric type");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1818 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1819 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1820 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1821
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1822 tree_constant
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1823 TC_REP::make_numeric (int force_str_conv) const
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1824 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1825 tree_constant retval;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1826
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1827 switch (type_tag)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1828 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1829 case scalar_constant:
1355
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
1830 retval = scalar;
1299
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1831 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1832
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1833 case matrix_constant:
1355
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
1834 retval = *matrix;
1299
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1835 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1836
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1837 case complex_scalar_constant:
1355
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
1838 retval = *complex_scalar;
1299
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1839 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1840
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1841 case complex_matrix_constant:
1355
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
1842 retval = *complex_matrix;
1299
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1843 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1844
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1845 case string_constant:
1355
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
1846 retval = *str_obj;
1299
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1847 retval.force_numeric (force_str_conv);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1848 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1849
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1850 case range_constant:
1355
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
1851 retval = *range;
1299
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1852 retval.force_numeric (force_str_conv);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1853 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1854
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1855 default:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1856 gripe_invalid_conversion (type_as_string (), "numeric value");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1857 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1858 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1859
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1860 return retval;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1861 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1862
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1863 void
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1864 TC_REP::bump_value (tree_expression::type etype)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1865 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1866 switch (etype)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1867 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1868 case tree_expression::increment:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1869 switch (type_tag)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1870 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1871 case scalar_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1872 scalar++;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1873 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1874
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1875 case matrix_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1876 *matrix = *matrix + 1.0;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1877 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1878
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1879 case complex_scalar_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1880 *complex_scalar = *complex_scalar + 1.0;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1881 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1882
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1883 case complex_matrix_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1884 *complex_matrix = *complex_matrix + 1.0;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1885 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1886
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1887 case range_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1888 range->set_base (range->base () + 1.0);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1889 range->set_limit (range->limit () + 1.0);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1890 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1891
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1892 default:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1893 gripe_wrong_type_arg ("operator ++", type_as_string ());
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1894 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1895 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1896 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1897
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1898 case tree_expression::decrement:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1899 switch (type_tag)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1900 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1901 case scalar_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1902 scalar--;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1903 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1904
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1905 case matrix_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1906 *matrix = *matrix - 1.0;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1907 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1908
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1909 case range_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1910 range->set_base (range->base () - 1.0);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1911 range->set_limit (range->limit () - 1.0);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1912 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1913
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1914 default:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1915 gripe_wrong_type_arg ("operator --", type_as_string ());
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1916 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1917 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1918 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1919
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1920 default:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1921 panic_impossible ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1922 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1923 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1924 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1925
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1926 void
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1927 TC_REP::resize (int i, int j)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1928 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1929 switch (type_tag)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1930 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1931 case matrix_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1932 matrix->resize (i, j);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1933 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1934
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1935 case complex_matrix_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1936 complex_matrix->resize (i, j);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1937 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1938
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1939 default:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1940 gripe_wrong_type_arg ("resize", type_as_string ());
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1941 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1942 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1943 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1944
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1945 void
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1946 TC_REP::resize (int i, int j, double val)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1947 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1948 switch (type_tag)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1949 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1950 case matrix_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1951 matrix->resize (i, j, val);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1952 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1953
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1954 case complex_matrix_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1955 complex_matrix->resize (i, j, val);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1956 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1957
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1958 default:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1959 gripe_wrong_type_arg ("resize", type_as_string ());
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1960 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1961 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1962 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1963
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1964 void
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1965 TC_REP::maybe_resize (int i, int j)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1966 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1967 int nr = rows ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1968 int nc = columns ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1969
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1970 i++;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1971 j++;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1972
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1973 assert (i > 0 && j > 0);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1974
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1975 if (i > nr || j > nc)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1976 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1977 if (user_pref.resize_on_range_error)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1978 resize (MAX (i, nr), MAX (j, nc), 0.0);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1979 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1980 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1981 if (i > nr)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1982 ::error ("row index = %d exceeds max row dimension = %d", i, nr);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1983
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1984 if (j > nc)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1985 ::error ("column index = %d exceeds max column dimension = %d",
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1986 j, nc);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1987 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1988 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1989 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1990
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1991 void
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1992 TC_REP::maybe_resize (int i, force_orient f_orient)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1993 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1994 int nr = rows ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1995 int nc = columns ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1996
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1997 i++;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1998
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
1999 assert (i >= 0 && (nr <= 1 || nc <= 1));
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2000
1358
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1355
diff changeset
2001 // This function never reduces the size of a vector, and all vectors
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1355
diff changeset
2002 // have dimensions of at least 0x0. If i is 0, it is either because
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1355
diff changeset
2003 // a vector has been indexed with a vector of all zeros (in which
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1355
diff changeset
2004 // case the index vector is empty and nothing will happen) or a
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1355
diff changeset
2005 // vector has been indexed with 0 (an error which will be caught
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1355
diff changeset
2006 // elsewhere).
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1355
diff changeset
2007
1299
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2008 if (i == 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2009 return;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2010
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2011 if (nr <= 1 && nc <= 1 && i >= 1)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2012 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2013 if (user_pref.resize_on_range_error)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2014 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2015 if (f_orient == row_orient)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2016 resize (1, i, 0.0);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2017 else if (f_orient == column_orient)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2018 resize (i, 1, 0.0);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2019 else if (user_pref.prefer_column_vectors)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2020 resize (i, 1, 0.0);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2021 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2022 resize (1, i, 0.0);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2023 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2024 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2025 ::error ("matrix index = %d exceeds max dimension = %d", i, nc);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2026 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2027 else if (nr == 1 && i > nc)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2028 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2029 if (user_pref.resize_on_range_error)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2030 resize (1, i, 0.0);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2031 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2032 ::error ("matrix index = %d exceeds max dimension = %d", i, nc);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2033 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2034 else if (nc == 1 && i > nr)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2035 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2036 if (user_pref.resize_on_range_error)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2037 resize (i, 1, 0.0);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2038 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2039 ::error ("matrix index = %d exceeds max dimension = ", i, nc);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2040 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2041 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2042
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2043 void
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2044 TC_REP::stash_original_text (char *s)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2045 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2046 orig_text = strsave (s);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2047 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2048
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2049 void
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2050 TC_REP::maybe_mutate (void)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2051 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2052 if (error_state)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2053 return;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2054
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2055 switch (type_tag)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2056 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2057 case complex_scalar_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2058 if (::imag (*complex_scalar) == 0.0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2059 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2060 double d = ::real (*complex_scalar);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2061 delete complex_scalar;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2062 scalar = d;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2063 type_tag = scalar_constant;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2064 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2065 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2066
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2067 case complex_matrix_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2068 if (! any_element_is_complex (*complex_matrix))
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2069 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2070 Matrix *m = new Matrix (::real (*complex_matrix));
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2071 delete complex_matrix;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2072 matrix = m;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2073 type_tag = matrix_constant;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2074 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2075 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2076
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2077 default:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2078 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2079 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2080
1358
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1355
diff changeset
2081 // Avoid calling rows() and columns() for things like magic_colon.
1299
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2082
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2083 int nr = 1;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2084 int nc = 1;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2085 if (type_tag == matrix_constant
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2086 || type_tag == complex_matrix_constant
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2087 || type_tag == range_constant)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2088 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2089 nr = rows ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2090 nc = columns ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2091 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2092
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2093 switch (type_tag)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2094 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2095 case matrix_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2096 if (nr == 1 && nc == 1)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2097 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2098 double d = matrix->elem (0, 0);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2099 delete matrix;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2100 scalar = d;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2101 type_tag = scalar_constant;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2102 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2103 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2104
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2105 case complex_matrix_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2106 if (nr == 1 && nc == 1)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2107 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2108 Complex c = complex_matrix->elem (0, 0);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2109 delete complex_matrix;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2110 complex_scalar = new Complex (c);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2111 type_tag = complex_scalar_constant;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2112 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2113 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2114
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2115 case range_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2116 if (nr == 1 && nc == 1)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2117 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2118 double d = range->base ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2119 delete range;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2120 scalar = d;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2121 type_tag = scalar_constant;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2122 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2123 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2124
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2125 default:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2126 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2127 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2128 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2129
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2130 void
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2131 TC_REP::print (ostream& output_buf)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2132 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2133 if (error_state)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2134 return;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2135
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2136 switch (type_tag)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2137 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2138 case scalar_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2139 octave_print_internal (output_buf, scalar);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2140 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2141
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2142 case matrix_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2143 octave_print_internal (output_buf, *matrix);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2144 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2145
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2146 case complex_scalar_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2147 octave_print_internal (output_buf, *complex_scalar);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2148 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2149
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2150 case complex_matrix_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2151 octave_print_internal (output_buf, *complex_matrix);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2152 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2153
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2154 case string_constant:
1355
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
2155 octave_print_internal (output_buf, *str_obj);
1299
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2156 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2157
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2158 case range_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2159 octave_print_internal (output_buf, *range);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2160 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2161
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2162 case map_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2163 {
1358
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1355
diff changeset
2164 // XXX FIXME XXX -- would be nice to print the output in some
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1355
diff changeset
2165 // standard order. Maybe all substructures first, maybe
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1355
diff changeset
2166 // alphabetize entries, etc.
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1355
diff changeset
2167
1299
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2168 begin_unwind_frame ("TC_REP_print");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2169
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2170 unwind_protect_int (structure_indent_level);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2171 unwind_protect_int (user_pref.struct_levels_to_print);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2172
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2173 if (user_pref.struct_levels_to_print-- > 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2174 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2175 output_buf << "{\n";
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2176
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2177 increment_structure_indent_level ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2178
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2179 for (Pix p = a_map->first (); p != 0; a_map->next (p))
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2180 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2181 const char *key = a_map->key (p);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2182 tree_constant val = a_map->contents (p);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2183
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2184 output_buf.form ("%*s%s = ", structure_indent_level,
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2185 "", key);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2186
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2187 if (! (print_as_scalar (val) || print_as_structure (val)))
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2188 output_buf << "\n";
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2189
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2190 val.print (output_buf);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2191 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2192
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2193 decrement_structure_indent_level ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2194
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2195 output_buf.form ("%*s%s", structure_indent_level, "", "}\n");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2196 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2197 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2198 output_buf << "<structure>\n";
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2199
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2200 run_unwind_frame ("TC_REP_print");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2201 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2202 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2203
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2204 case unknown_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2205 case magic_colon:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2206 case all_va_args:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2207 panic_impossible ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2208 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2209 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2210 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2211
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2212 void
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2213 TC_REP::print_code (ostream& os)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2214 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2215 switch (type_tag)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2216 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2217 case scalar_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2218 if (orig_text)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2219 os << orig_text;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2220 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2221 octave_print_internal (os, scalar, 1);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2222 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2223
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2224 case matrix_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2225 octave_print_internal (os, *matrix, 1);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2226 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2227
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2228 case complex_scalar_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2229 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2230 double re = complex_scalar->real ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2231 double im = complex_scalar->imag ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2232
1358
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1355
diff changeset
2233 // If we have the original text and a pure imaginary, just
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1355
diff changeset
2234 // print the original text, because this must be a constant
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1355
diff changeset
2235 // that was parsed as part of a function.
1299
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2236
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2237 if (orig_text && re == 0.0 && im > 0.0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2238 os << orig_text;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2239 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2240 octave_print_internal (os, *complex_scalar, 1);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2241 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2242 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2243
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2244 case complex_matrix_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2245 octave_print_internal (os, *complex_matrix, 1);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2246 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2247
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2248 case string_constant:
1355
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
2249 octave_print_internal (os, *str_obj, 1);
1299
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2250 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2251
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2252 case range_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2253 octave_print_internal (os, *range, 1);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2254 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2255
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2256 case magic_colon:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2257 os << ":";
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2258 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2259
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2260 case all_va_args:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2261 os << "all_va_args";
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2262 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2263
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2264 case map_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2265 case unknown_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2266 panic_impossible ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2267 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2268 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2269 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2270
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2271 void
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2272 TC_REP::gripe_wrong_type_arg (const char *name,
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2273 const tree_constant_rep& tcr) const
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2274 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2275 if (name)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2276 ::error ("%s: wrong type argument `%s'", name, tcr.type_as_string ());
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2277 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2278 ::error ("wrong type argument `%s'", name, tcr.type_as_string ());
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2279 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2280
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2281 char *
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2282 TC_REP::type_as_string (void) const
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2283 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2284 switch (type_tag)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2285 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2286 case scalar_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2287 return "real scalar";
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2288
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2289 case matrix_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2290 return "real matrix";
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2291
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2292 case complex_scalar_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2293 return "complex scalar";
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2294
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2295 case complex_matrix_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2296 return "complex matrix";
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2297
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2298 case string_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2299 return "string";
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2300
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2301 case range_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2302 return "range";
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2303
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2304 case map_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2305 return "structure";
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2306
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2307 default:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2308 return "<unknown type>";
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2309 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2310 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2311
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2312 tree_constant
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2313 do_binary_op (tree_constant& a, tree_constant& b, tree_expression::type t)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2314 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2315 tree_constant retval;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2316
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2317 int first_empty = (a.rows () == 0 || a.columns () == 0);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2318 int second_empty = (b.rows () == 0 || b.columns () == 0);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2319
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2320 if (first_empty || second_empty)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2321 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2322 int flag = user_pref.propagate_empty_matrices;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2323 if (flag < 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2324 warning ("binary operation on empty matrix");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2325 else if (flag == 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2326 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2327 ::error ("invalid binary operation on empty matrix");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2328 return retval;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2329 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2330 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2331
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2332 tree_constant tmp_a = a.make_numeric ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2333
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2334 if (error_state)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2335 return retval;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2336
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2337 tree_constant tmp_b = b.make_numeric ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2338
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2339 if (error_state)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2340 return retval;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2341
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2342 TC_REP::constant_type a_type = tmp_a.const_type ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2343 TC_REP::constant_type b_type = tmp_b.const_type ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2344
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2345 double d1, d2;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2346 Matrix m1, m2;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2347 Complex c1, c2;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2348 ComplexMatrix cm1, cm2;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2349
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2350 switch (a_type)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2351 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2352 case TC_REP::scalar_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2353
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2354 d1 = tmp_a.double_value ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2355
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2356 switch (b_type)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2357 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2358 case TC_REP::scalar_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2359 d2 = tmp_b.double_value ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2360 retval = do_binary_op (d1, d2, t);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2361 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2362
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2363 case TC_REP::matrix_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2364 m2 = tmp_b.matrix_value ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2365 retval = do_binary_op (d1, m2, t);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2366 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2367
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2368 case TC_REP::complex_scalar_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2369 c2 = tmp_b.complex_value ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2370 retval = do_binary_op (d1, c2, t);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2371 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2372
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2373 case TC_REP::complex_matrix_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2374 cm2 = tmp_b.complex_matrix_value ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2375 retval = do_binary_op (d1, cm2, t);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2376 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2377
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2378 default:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2379 gripe_wrong_type_arg_for_binary_op (tmp_b);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2380 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2381 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2382 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2383
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2384 case TC_REP::matrix_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2385
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2386 m1 = tmp_a.matrix_value ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2387
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2388 switch (b_type)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2389 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2390 case TC_REP::scalar_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2391 d2 = tmp_b.double_value ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2392 retval = do_binary_op (m1, d2, t);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2393 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2394
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2395 case TC_REP::matrix_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2396 m2 = tmp_b.matrix_value ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2397 retval = do_binary_op (m1, m2, t);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2398 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2399
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2400 case TC_REP::complex_scalar_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2401 c2 = tmp_b.complex_value ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2402 retval = do_binary_op (m1, c2, t);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2403 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2404
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2405 case TC_REP::complex_matrix_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2406 cm2 = tmp_b.complex_matrix_value ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2407 retval = do_binary_op (m1, cm2, t);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2408 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2409
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2410 default:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2411 gripe_wrong_type_arg_for_binary_op (tmp_b);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2412 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2413 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2414 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2415
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2416 case TC_REP::complex_scalar_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2417
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2418 c1 = tmp_a.complex_value ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2419
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2420 switch (b_type)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2421 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2422 case TC_REP::scalar_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2423 d2 = tmp_b.double_value ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2424 retval = do_binary_op (c1, d2, t);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2425 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2426
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2427 case TC_REP::matrix_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2428 m2 = tmp_b.matrix_value ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2429 retval = do_binary_op (c1, m2, t);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2430 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2431
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2432 case TC_REP::complex_scalar_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2433 c2 = tmp_b.complex_value ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2434 retval = do_binary_op (c1, c2, t);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2435 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2436
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2437 case TC_REP::complex_matrix_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2438 cm2 = tmp_b.complex_matrix_value ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2439 retval = do_binary_op (c1, cm2, t);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2440 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2441
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2442 default:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2443 gripe_wrong_type_arg_for_binary_op (tmp_b);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2444 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2445 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2446 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2447
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2448 case TC_REP::complex_matrix_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2449
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2450 cm1 = tmp_a.complex_matrix_value ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2451
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2452 switch (b_type)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2453 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2454 case TC_REP::scalar_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2455 d2 = tmp_b.double_value ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2456 retval = do_binary_op (cm1, d2, t);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2457 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2458
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2459 case TC_REP::matrix_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2460 m2 = tmp_b.matrix_value ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2461 retval = do_binary_op (cm1, m2, t);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2462 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2463
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2464 case TC_REP::complex_scalar_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2465 c2 = tmp_b.complex_value ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2466 retval = do_binary_op (cm1, c2, t);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2467 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2468
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2469 case TC_REP::complex_matrix_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2470 cm2 = tmp_b.complex_matrix_value ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2471 retval = do_binary_op (cm1, cm2, t);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2472 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2473
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2474 default:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2475 gripe_wrong_type_arg_for_binary_op (tmp_b);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2476 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2477 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2478 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2479
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2480 default:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2481 gripe_wrong_type_arg_for_binary_op (tmp_a);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2482 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2483 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2484
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2485 return retval;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2486 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2487
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2488 tree_constant
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2489 do_unary_op (tree_constant& a, tree_expression::type t)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2490 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2491 tree_constant retval;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2492
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2493 if (a.rows () == 0 || a.columns () == 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2494 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2495 int flag = user_pref.propagate_empty_matrices;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2496 if (flag < 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2497 warning ("unary operation on empty matrix");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2498 else if (flag == 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2499 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2500 ::error ("invalid unary operation on empty matrix");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2501 return retval;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2502 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2503 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2504
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2505 tree_constant tmp_a = a.make_numeric ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2506
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2507 if (error_state)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2508 return retval;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2509
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2510 switch (tmp_a.const_type ())
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2511 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2512 case TC_REP::scalar_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2513 retval = do_unary_op (tmp_a.double_value (), t);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2514 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2515
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2516 case TC_REP::matrix_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2517 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2518 Matrix m = tmp_a.matrix_value ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2519 retval = do_unary_op (m, t);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2520 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2521 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2522
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2523 case TC_REP::complex_scalar_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2524 retval = do_unary_op (tmp_a.complex_value (), t);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2525 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2526
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2527 case TC_REP::complex_matrix_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2528 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2529 ComplexMatrix m = tmp_a.complex_matrix_value ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2530 retval = do_unary_op (m, t);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2531 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2532 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2533
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2534 default:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2535 gripe_wrong_type_arg_for_unary_op (tmp_a);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2536 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2537 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2538
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2539 return retval;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2540 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2541
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2542 // -------------------------------------------------------------------
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2543 //
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2544 // Indexing operations for the tree-constant representation class.
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2545 //
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2546 // Leave the commented #includes below to make it easy to split this
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2547 // out again, should we want to do that.
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2548 //
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2549 // -------------------------------------------------------------------
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2550
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2551 // #ifdef HAVE_CONFIG_H
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2552 // #include <config.h>
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2553 // #endif
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2554
1355
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
2555 // #include <cctype>
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
2556 // #include <cstring>
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
2557
1299
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2558 // #include <fstream.h>
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2559 // #include <iostream.h>
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2560 // #include <strstream.h>
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2561
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2562 // #include "mx-base.h"
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2563 // #include "Range.h"
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2564
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2565 // #include "arith-ops.h"
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2566 // #include "variables.h"
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2567 // #include "sysdep.h"
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2568 // #include "error.h"
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2569 // #include "gripes.h"
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2570 // #include "user-prefs.h"
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2571 // #include "utils.h"
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2572 // #include "pager.h"
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2573 // #include "pr-output.h"
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2574 // #include "tree-const.h"
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2575 // #include "idx-vector.h"
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2576 // #include "oct-map.h"
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2577
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2578 // #include "tc-inlines.h"
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2579
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2580 // Indexing functions.
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2581
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2582 // This is the top-level indexing function.
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2583
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2584 tree_constant
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2585 TC_REP::do_index (const Octave_object& args)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2586 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2587 tree_constant retval;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2588
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2589 if (error_state)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2590 return retval;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2591
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2592 if (rows () == 0 || columns () == 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2593 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2594 switch (args.length ())
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2595 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2596 case 2:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2597 if (! args(1).is_magic_colon ()
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2598 && args(1).rows () != 0 && args(1).columns () != 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2599 goto index_error;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2600
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2601 case 1:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2602 if (! args(0).is_magic_colon ()
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2603 && args(0).rows () != 0 && args(0).columns () != 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2604 goto index_error;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2605
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2606 return Matrix ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2607
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2608 default:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2609 index_error:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2610 ::error ("attempt to index empty matrix");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2611 return retval;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2612 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2613 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2614
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2615 switch (type_tag)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2616 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2617 case complex_scalar_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2618 case scalar_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2619 retval = do_scalar_index (args);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2620 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2621
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2622 case complex_matrix_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2623 case matrix_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2624 retval = do_matrix_index (args);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2625 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2626
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2627 case string_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2628 gripe_string_invalid ();
1358
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1355
diff changeset
2629 // retval = do_string_index (args);
1299
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2630 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2631
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2632 default:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2633
1358
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1355
diff changeset
2634 // This isn't great, but it's easier than implementing a lot
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1355
diff changeset
2635 // of other special indexing functions.
1299
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2636
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2637 force_numeric ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2638
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2639 if (! error_state && is_numeric_type ())
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2640 retval = do_index (args);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2641
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2642 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2643 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2644
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2645 return retval;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2646 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2647
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2648 tree_constant
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2649 TC_REP::do_scalar_index (const Octave_object& args) const
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2650 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2651 tree_constant retval;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2652
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2653 if (valid_scalar_indices (args))
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2654 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2655 if (type_tag == scalar_constant)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2656 retval = scalar;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2657 else if (type_tag == complex_scalar_constant)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2658 retval = *complex_scalar;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2659 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2660 panic_impossible ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2661
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2662 return retval;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2663 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2664 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2665 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2666 int rows = -1;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2667 int cols = -1;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2668
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2669 int nargin = args.length ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2670
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2671 switch (nargin)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2672 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2673 case 2:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2674 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2675 tree_constant arg = args(1);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2676
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2677 if (arg.is_matrix_type ())
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2678 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2679 Matrix mj = arg.matrix_value ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2680
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2681 idx_vector j (mj, user_pref.do_fortran_indexing, "", 1);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2682 if (! j)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2683 return retval;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2684
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2685 int jmax = j.max ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2686 int len = j.length ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2687 if (len == j.ones_count ())
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2688 cols = len;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2689 else if (jmax > 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2690 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2691 error ("invalid scalar index = %d", jmax+1);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2692 return retval;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2693 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2694 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2695 else if (arg.const_type () == magic_colon)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2696 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2697 cols = 1;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2698 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2699 else if (arg.is_scalar_type ())
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2700 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2701 double dval = arg.double_value ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2702 if (! xisnan (dval))
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2703 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2704 int ival = NINT (dval);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2705 if (ival == 1)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2706 cols = 1;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2707 else if (ival == 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2708 cols = 0;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2709 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2710 break;;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2711 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2712 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2713 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2714 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2715 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2716 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2717 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2718
1358
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1355
diff changeset
2719 // Fall through...
1299
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2720
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2721 case 1:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2722 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2723 tree_constant arg = args(0);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2724
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2725 if (arg.is_matrix_type ())
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2726 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2727 Matrix mi = arg.matrix_value ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2728
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2729 idx_vector i (mi, user_pref.do_fortran_indexing, "", 1);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2730 if (! i)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2731 return retval;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2732
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2733 int imax = i.max ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2734 int len = i.length ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2735 if (len == i.ones_count ())
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2736 rows = len;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2737 else if (imax > 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2738 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2739 error ("invalid scalar index = %d", imax+1);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2740 return retval;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2741 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2742 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2743 else if (arg.const_type () == magic_colon)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2744 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2745 rows = 1;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2746 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2747 else if (arg.is_scalar_type ())
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2748 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2749 double dval = arg.double_value ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2750
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2751 if (! xisnan (dval))
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2752 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2753 int ival = NINT (dval);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2754 if (ival == 1)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2755 rows = 1;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2756 else if (ival == 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2757 rows = 0;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2758 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2759 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2760 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2761 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2762 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2763 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2764 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2765 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2766
1358
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1355
diff changeset
2767 // If only one index, cols will not be set, so we set it.
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1355
diff changeset
2768 // If single index is [], rows will be zero, and we should
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1355
diff changeset
2769 // set cols to zero too.
1299
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2770
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2771 if (cols < 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2772 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2773 if (rows == 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2774 cols = 0;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2775 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2776 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2777 if (user_pref.prefer_column_vectors)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2778 cols = 1;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2779 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2780 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2781 cols = rows;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2782 rows = 1;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2783 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2784 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2785 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2786
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2787 if (type_tag == scalar_constant)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2788 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2789 return Matrix (rows, cols, scalar);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2790 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2791 else if (type_tag == complex_scalar_constant)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2792 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2793 return ComplexMatrix (rows, cols, *complex_scalar);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2794 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2795 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2796 panic_impossible ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2797 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2798 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2799
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2800 default:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2801 ::error ("invalid number of arguments for scalar type");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2802 return tree_constant ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2803 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2804 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2805 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2806
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2807 ::error ("index invalid or out of range for scalar type");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2808 return tree_constant ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2809 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2810
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2811 tree_constant
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2812 TC_REP::do_matrix_index (const Octave_object& args) const
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2813 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2814 tree_constant retval;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2815
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2816 int nargin = args.length ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2817
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2818 switch (nargin)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2819 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2820 case 1:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2821 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2822 tree_constant arg = args(0);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2823
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2824 if (arg.is_undefined ())
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2825 ::error ("matrix index is a null expression");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2826 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2827 retval = do_matrix_index (arg);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2828 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2829 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2830
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2831 case 2:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2832 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2833 tree_constant arg_a = args(0);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2834 tree_constant arg_b = args(1);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2835
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2836 if (arg_a.is_undefined ())
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2837 ::error ("first matrix index is a null expression");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2838 else if (arg_b.is_undefined ())
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2839 ::error ("second matrix index is a null expression");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2840 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2841 retval = do_matrix_index (arg_a, arg_b);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2842 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2843 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2844
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2845 default:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2846 if (nargin == 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2847 ::error ("matrix indices expected, but none provided");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2848 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2849 ::error ("too many indices for matrix expression");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2850 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2851 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2852
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2853 return retval;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2854 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2855
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2856 tree_constant
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2857 TC_REP::do_matrix_index (const tree_constant& i_arg) const
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2858 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2859 tree_constant retval;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2860
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2861 int nr = rows ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2862 int nc = columns ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2863
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2864 if (user_pref.do_fortran_indexing)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2865 retval = fortran_style_matrix_index (i_arg);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2866 else if (nr <= 1 || nc <= 1)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2867 retval = do_vector_index (i_arg);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2868 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2869 ::error ("single index only valid for row or column vector");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2870
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2871 return retval;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2872 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2873
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2874 tree_constant
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2875 TC_REP::do_matrix_index (const tree_constant& i_arg,
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2876 const tree_constant& j_arg) const
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2877 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2878 tree_constant retval;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2879
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2880 tree_constant tmp_i = i_arg.make_numeric_or_range_or_magic ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2881
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2882 if (error_state)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2883 return retval;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2884
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2885 TC_REP::constant_type itype = tmp_i.const_type ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2886
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2887 switch (itype)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2888 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2889 case complex_scalar_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2890 case scalar_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2891 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2892 int i = tree_to_mat_idx (tmp_i.double_value ());
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2893 retval = do_matrix_index (i, j_arg);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2894 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2895 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2896
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2897 case complex_matrix_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2898 case matrix_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2899 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2900 Matrix mi = tmp_i.matrix_value ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2901 idx_vector iv (mi, user_pref.do_fortran_indexing, "row", rows ());
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2902 if (! iv)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2903 return tree_constant ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2904
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2905 if (iv.length () == 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2906 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2907 Matrix mtmp;
1355
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
2908 retval = mtmp;
1299
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2909 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2910 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2911 retval = do_matrix_index (iv, j_arg);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2912 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2913 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2914
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2915 case string_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2916 gripe_string_invalid ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2917 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2918
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2919 case range_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2920 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2921 Range ri = tmp_i.range_value ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2922 int nr = rows ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2923 if (nr == 2 && is_zero_one (ri))
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2924 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2925 retval = do_matrix_index (1, j_arg);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2926 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2927 else if (nr == 2 && is_one_zero (ri))
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2928 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2929 retval = do_matrix_index (0, j_arg);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2930 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2931 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2932 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2933 if (index_check (ri, "row") < 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2934 return tree_constant ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2935 retval = do_matrix_index (ri, j_arg);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2936 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2937 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2938 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2939
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2940 case magic_colon:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2941 retval = do_matrix_index (magic_colon, j_arg);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2942 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2943
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2944 default:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2945 panic_impossible ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2946 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2947 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2948
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2949 return retval;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2950 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2951
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2952 tree_constant
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2953 TC_REP::do_matrix_index (TC_REP::constant_type mci) const
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2954 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2955 assert (mci == magic_colon);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2956
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2957 tree_constant retval;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2958 int nr = rows ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2959 int nc = columns ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2960 int size = nr * nc;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2961 if (size > 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2962 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2963 CRMATRIX (m, cm, size, 1);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2964 int idx = 0;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2965 for (int j = 0; j < nc; j++)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2966 for (int i = 0; i < nr; i++)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2967 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2968 CRMATRIX_ASSIGN_REP_ELEM (m, cm, idx, 0, i, j);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2969 idx++;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2970 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2971 ASSIGN_CRMATRIX_TO (retval, m, cm);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2972 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2973 return retval;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2974 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2975
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2976 tree_constant
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2977 TC_REP::fortran_style_matrix_index (const tree_constant& i_arg) const
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2978 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2979 tree_constant retval;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2980
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2981 tree_constant tmp_i = i_arg.make_numeric_or_magic ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2982
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2983 if (error_state)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2984 return retval;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2985
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2986 TC_REP::constant_type itype = tmp_i.const_type ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2987
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2988 int nr = rows ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2989 int nc = columns ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2990
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2991 switch (itype)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2992 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2993 case complex_scalar_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2994 case scalar_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2995 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2996 double dval = tmp_i.double_value ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2997
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2998 if (xisnan (dval))
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
2999 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3000 ::error ("NaN is invalid as a matrix index");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3001 return tree_constant ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3002 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3003 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3004 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3005 int i = NINT (dval);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3006 int ii = fortran_row (i, nr) - 1;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3007 int jj = fortran_column (i, nr) - 1;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3008 if (index_check (i-1, "") < 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3009 return tree_constant ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3010 if (range_max_check (i-1, nr * nc) < 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3011 return tree_constant ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3012 retval = do_matrix_index (ii, jj);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3013 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3014 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3015 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3016
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3017 case complex_matrix_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3018 case matrix_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3019 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3020 Matrix mi = tmp_i.matrix_value ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3021 if (mi.rows () == 0 || mi.columns () == 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3022 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3023 Matrix mtmp;
1355
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
3024 retval = mtmp;
1299
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3025 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3026 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3027 {
1358
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1355
diff changeset
3028 // Yes, we really do want to call this with mi.
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1355
diff changeset
3029
1299
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3030 retval = fortran_style_matrix_index (mi);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3031 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3032 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3033 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3034
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3035 case string_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3036 gripe_string_invalid ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3037 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3038
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3039 case range_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3040 gripe_range_invalid ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3041 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3042
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3043 case magic_colon:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3044 retval = do_matrix_index (magic_colon);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3045 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3046
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3047 default:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3048 panic_impossible ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3049 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3050 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3051
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3052 return retval;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3053 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3054
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3055 tree_constant
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3056 TC_REP::fortran_style_matrix_index (const Matrix& mi) const
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3057 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3058 assert (is_matrix_type ());
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3059
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3060 tree_constant retval;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3061
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3062 int nr = rows ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3063 int nc = columns ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3064
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3065 int len = nr * nc;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3066
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3067 int index_nr = mi.rows ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3068 int index_nc = mi.columns ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3069
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3070 if (index_nr >= 1 && index_nc >= 1)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3071 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3072 const double *cop_out = 0;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3073 const Complex *c_cop_out = 0;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3074 int real_type = type_tag == matrix_constant;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3075 if (real_type)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3076 cop_out = matrix->data ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3077 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3078 c_cop_out = complex_matrix->data ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3079
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3080 const double *cop_out_index = mi.data ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3081
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3082 idx_vector iv (mi, 1, "", len);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3083 if (! iv || range_max_check (iv.max (), len) < 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3084 return retval;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3085
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3086 int result_size = iv.length ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3087
1358
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1355
diff changeset
3088 // XXX FIXME XXX -- there is way too much duplicate code
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1355
diff changeset
3089 // here...
1299
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3090
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3091 if (iv.one_zero_only ())
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3092 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3093 if (iv.ones_count () == 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3094 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3095 retval = Matrix ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3096 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3097 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3098 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3099 if (nr == 1)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3100 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3101 CRMATRIX (m, cm, 1, result_size);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3102
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3103 for (int i = 0; i < result_size; i++)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3104 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3105 int idx = iv.elem (i);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3106 CRMATRIX_ASSIGN_ELEM (m, cm, 0, i, cop_out [idx],
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3107 c_cop_out [idx], real_type);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3108 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3109
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3110 ASSIGN_CRMATRIX_TO (retval, m, cm);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3111 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3112 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3113 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3114 CRMATRIX (m, cm, result_size, 1);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3115
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3116 for (int i = 0; i < result_size; i++)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3117 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3118 int idx = iv.elem (i);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3119 CRMATRIX_ASSIGN_ELEM (m, cm, i, 0, cop_out [idx],
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3120 c_cop_out [idx], real_type);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3121 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3122
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3123 ASSIGN_CRMATRIX_TO (retval, m, cm);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3124 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3125 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3126 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3127 else if (nc == 1)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3128 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3129 CRMATRIX (m, cm, result_size, 1);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3130
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3131 for (int i = 0; i < result_size; i++)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3132 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3133 int idx = iv.elem (i);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3134 CRMATRIX_ASSIGN_ELEM (m, cm, i, 0, cop_out [idx],
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3135 c_cop_out [idx], real_type);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3136 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3137
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3138 ASSIGN_CRMATRIX_TO (retval, m, cm);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3139 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3140 else if (nr == 1)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3141 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3142 CRMATRIX (m, cm, 1, result_size);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3143
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3144 for (int i = 0; i < result_size; i++)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3145 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3146 int idx = iv.elem (i);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3147 CRMATRIX_ASSIGN_ELEM (m, cm, 0, i, cop_out [idx],
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3148 c_cop_out [idx], real_type);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3149 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3150
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3151 ASSIGN_CRMATRIX_TO (retval, m, cm);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3152 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3153 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3154 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3155 CRMATRIX (m, cm, index_nr, index_nc);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3156
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3157 for (int j = 0; j < index_nc; j++)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3158 for (int i = 0; i < index_nr; i++)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3159 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3160 double tmp = *cop_out_index++;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3161 int idx = tree_to_mat_idx (tmp);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3162 CRMATRIX_ASSIGN_ELEM (m, cm, i, j, cop_out [idx],
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3163 c_cop_out [idx], real_type);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3164 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3165
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3166 ASSIGN_CRMATRIX_TO (retval, m, cm);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3167 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3168 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3169 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3170 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3171 if (index_nr == 0 || index_nc == 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3172 ::error ("empty matrix invalid as index");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3173 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3174 ::error ("invalid matrix index");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3175 return tree_constant ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3176 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3177
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3178 return retval;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3179 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3180
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3181 tree_constant
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3182 TC_REP::do_vector_index (const tree_constant& i_arg) const
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3183 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3184 tree_constant retval;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3185
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3186 tree_constant tmp_i = i_arg.make_numeric_or_range_or_magic ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3187
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3188 if (error_state)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3189 return retval;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3190
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3191 TC_REP::constant_type itype = tmp_i.const_type ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3192
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3193 int nr = rows ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3194 int nc = columns ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3195
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3196 int len = MAX (nr, nc);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3197
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3198 assert ((nr == 1 || nc == 1) && ! user_pref.do_fortran_indexing);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3199
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3200 int swap_indices = (nr == 1);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3201
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3202 switch (itype)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3203 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3204 case complex_scalar_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3205 case scalar_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3206 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3207 int i = tree_to_mat_idx (tmp_i.double_value ());
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3208 if (index_check (i, "") < 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3209 return tree_constant ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3210 if (swap_indices)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3211 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3212 if (range_max_check (i, nc) < 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3213 return tree_constant ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3214 retval = do_matrix_index (0, i);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3215 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3216 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3217 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3218 if (range_max_check (i, nr) < 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3219 return tree_constant ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3220 retval = do_matrix_index (i, 0);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3221 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3222 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3223 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3224
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3225 case complex_matrix_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3226 case matrix_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3227 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3228 Matrix mi = tmp_i.matrix_value ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3229 if (mi.rows () == 0 || mi.columns () == 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3230 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3231 Matrix mtmp;
1355
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
3232 retval = mtmp;
1299
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3233 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3234 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3235 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3236 idx_vector iv (mi, user_pref.do_fortran_indexing, "", len);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3237 if (! iv)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3238 return tree_constant ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3239
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3240 if (swap_indices)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3241 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3242 if (range_max_check (iv.max (), nc) < 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3243 return tree_constant ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3244 retval = do_matrix_index (0, iv);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3245 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3246 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3247 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3248 if (range_max_check (iv.max (), nr) < 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3249 return tree_constant ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3250 retval = do_matrix_index (iv, 0);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3251 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3252 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3253 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3254 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3255
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3256 case string_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3257 gripe_string_invalid ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3258 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3259
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3260 case range_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3261 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3262 Range ri = tmp_i.range_value ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3263 if (len == 2 && is_zero_one (ri))
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3264 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3265 if (swap_indices)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3266 retval = do_matrix_index (0, 1);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3267 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3268 retval = do_matrix_index (1, 0);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3269 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3270 else if (len == 2 && is_one_zero (ri))
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3271 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3272 retval = do_matrix_index (0, 0);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3273 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3274 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3275 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3276 if (index_check (ri, "") < 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3277 return tree_constant ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3278 if (swap_indices)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3279 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3280 if (range_max_check (tree_to_mat_idx (ri.max ()), nc) < 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3281 return tree_constant ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3282 retval = do_matrix_index (0, ri);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3283 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3284 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3285 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3286 if (range_max_check (tree_to_mat_idx (ri.max ()), nr) < 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3287 return tree_constant ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3288 retval = do_matrix_index (ri, 0);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3289 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3290 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3291 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3292 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3293
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3294 case magic_colon:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3295 if (swap_indices)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3296 retval = do_matrix_index (0, magic_colon);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3297 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3298 retval = do_matrix_index (magic_colon, 0);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3299 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3300
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3301 default:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3302 panic_impossible ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3303 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3304 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3305
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3306 return retval;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3307 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3308
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3309 tree_constant
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3310 TC_REP::do_matrix_index (int i, const tree_constant& j_arg) const
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3311 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3312 tree_constant retval;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3313
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3314 tree_constant tmp_j = j_arg.make_numeric_or_range_or_magic ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3315
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3316 if (error_state)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3317 return retval;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3318
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3319 TC_REP::constant_type jtype = tmp_j.const_type ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3320
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3321 int nr = rows ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3322 int nc = columns ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3323
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3324 switch (jtype)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3325 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3326 case complex_scalar_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3327 case scalar_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3328 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3329 if (index_check (i, "row") < 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3330 return tree_constant ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3331 int j = tree_to_mat_idx (tmp_j.double_value ());
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3332 if (index_check (j, "column") < 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3333 return tree_constant ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3334 if (range_max_check (i, j, nr, nc) < 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3335 return tree_constant ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3336 retval = do_matrix_index (i, j);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3337 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3338 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3339
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3340 case complex_matrix_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3341 case matrix_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3342 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3343 if (index_check (i, "row") < 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3344 return tree_constant ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3345 Matrix mj = tmp_j.matrix_value ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3346 idx_vector jv (mj, user_pref.do_fortran_indexing, "column", nc);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3347 if (! jv)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3348 return tree_constant ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3349
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3350 if (jv.length () == 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3351 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3352 Matrix mtmp;
1355
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
3353 retval = mtmp;
1299
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3354 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3355 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3356 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3357 if (range_max_check (i, jv.max (), nr, nc) < 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3358 return tree_constant ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3359 retval = do_matrix_index (i, jv);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3360 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3361 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3362 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3363
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3364 case string_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3365 gripe_string_invalid ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3366 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3367
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3368 case range_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3369 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3370 if (index_check (i, "row") < 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3371 return tree_constant ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3372 Range rj = tmp_j.range_value ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3373 if (nc == 2 && is_zero_one (rj))
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3374 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3375 retval = do_matrix_index (i, 1);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3376 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3377 else if (nc == 2 && is_one_zero (rj))
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3378 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3379 retval = do_matrix_index (i, 0);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3380 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3381 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3382 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3383 if (index_check (rj, "column") < 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3384 return tree_constant ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3385 if (range_max_check (i, tree_to_mat_idx (rj.max ()), nr, nc) < 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3386 return tree_constant ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3387 retval = do_matrix_index (i, rj);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3388 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3389 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3390 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3391
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3392 case magic_colon:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3393 if (i == -1 && nr == 1)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3394 return Matrix ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3395 if (index_check (i, "row") < 0
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3396 || range_max_check (i, 0, nr, nc) < 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3397 return tree_constant ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3398 retval = do_matrix_index (i, magic_colon);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3399 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3400
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3401 default:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3402 panic_impossible ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3403 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3404 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3405
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3406 return retval;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3407 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3408
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3409 tree_constant
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3410 TC_REP::do_matrix_index (const idx_vector& iv,
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3411 const tree_constant& j_arg) const
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3412 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3413 tree_constant retval;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3414
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3415 tree_constant tmp_j = j_arg.make_numeric_or_range_or_magic ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3416
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3417 if (error_state)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3418 return retval;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3419
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3420 TC_REP::constant_type jtype = tmp_j.const_type ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3421
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3422 int nr = rows ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3423 int nc = columns ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3424
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3425 switch (jtype)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3426 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3427 case complex_scalar_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3428 case scalar_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3429 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3430 int j = tree_to_mat_idx (tmp_j.double_value ());
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3431 if (index_check (j, "column") < 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3432 return tree_constant ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3433 if (range_max_check (iv.max (), j, nr, nc) < 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3434 return tree_constant ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3435 retval = do_matrix_index (iv, j);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3436 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3437 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3438
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3439 case complex_matrix_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3440 case matrix_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3441 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3442 Matrix mj = tmp_j.matrix_value ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3443 idx_vector jv (mj, user_pref.do_fortran_indexing, "column", nc);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3444 if (! jv)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3445 return tree_constant ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3446
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3447 if (jv.length () == 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3448 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3449 Matrix mtmp;
1355
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
3450 retval = mtmp;
1299
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3451 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3452 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3453 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3454 if (range_max_check (iv.max (), jv.max (), nr, nc) < 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3455 return tree_constant ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3456 retval = do_matrix_index (iv, jv);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3457 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3458 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3459 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3460
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3461 case string_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3462 gripe_string_invalid ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3463 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3464
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3465 case range_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3466 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3467 Range rj = tmp_j.range_value ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3468 if (nc == 2 && is_zero_one (rj))
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3469 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3470 retval = do_matrix_index (iv, 1);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3471 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3472 else if (nc == 2 && is_one_zero (rj))
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3473 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3474 retval = do_matrix_index (iv, 0);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3475 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3476 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3477 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3478 if (index_check (rj, "column") < 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3479 return tree_constant ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3480 if (range_max_check (iv.max (), tree_to_mat_idx (rj.max ()),
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3481 nr, nc) < 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3482 return tree_constant ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3483 retval = do_matrix_index (iv, rj);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3484 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3485 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3486 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3487
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3488 case magic_colon:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3489 if (range_max_check (iv.max (), 0, nr, nc) < 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3490 return tree_constant ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3491 retval = do_matrix_index (iv, magic_colon);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3492 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3493
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3494 default:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3495 panic_impossible ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3496 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3497 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3498
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3499 return retval;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3500 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3501
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3502 tree_constant
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3503 TC_REP::do_matrix_index (const Range& ri,
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3504 const tree_constant& j_arg) const
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3505 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3506 tree_constant retval;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3507
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3508 tree_constant tmp_j = j_arg.make_numeric_or_range_or_magic ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3509
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3510 if (error_state)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3511 return retval;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3512
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3513 TC_REP::constant_type jtype = tmp_j.const_type ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3514
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3515 int nr = rows ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3516 int nc = columns ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3517
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3518 switch (jtype)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3519 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3520 case complex_scalar_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3521 case scalar_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3522 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3523 int j = tree_to_mat_idx (tmp_j.double_value ());
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3524 if (index_check (j, "column") < 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3525 return tree_constant ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3526 if (range_max_check (tree_to_mat_idx (ri.max ()), j, nr, nc) < 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3527 return tree_constant ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3528 retval = do_matrix_index (ri, j);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3529 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3530 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3531
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3532 case complex_matrix_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3533 case matrix_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3534 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3535 Matrix mj = tmp_j.matrix_value ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3536 idx_vector jv (mj, user_pref.do_fortran_indexing, "column", nc);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3537 if (! jv)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3538 return tree_constant ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3539
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3540 if (jv.length () == 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3541 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3542 Matrix mtmp;
1355
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
3543 retval = mtmp;
1299
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3544 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3545 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3546 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3547 if (range_max_check (tree_to_mat_idx (ri.max ()),
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3548 jv.max (), nr, nc) < 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3549 return tree_constant ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3550 retval = do_matrix_index (ri, jv);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3551 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3552 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3553 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3554
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3555 case string_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3556 gripe_string_invalid ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3557 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3558
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3559 case range_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3560 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3561 Range rj = tmp_j.range_value ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3562 if (nc == 2 && is_zero_one (rj))
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3563 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3564 retval = do_matrix_index (ri, 1);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3565 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3566 else if (nc == 2 && is_one_zero (rj))
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3567 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3568 retval = do_matrix_index (ri, 0);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3569 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3570 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3571 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3572 if (index_check (rj, "column") < 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3573 return tree_constant ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3574 if (range_max_check (tree_to_mat_idx (ri.max ()),
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3575 tree_to_mat_idx (rj.max ()), nr, nc) < 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3576 return tree_constant ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3577 retval = do_matrix_index (ri, rj);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3578 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3579 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3580 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3581
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3582 case magic_colon:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3583 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3584 if (index_check (ri, "row") < 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3585 return tree_constant ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3586 if (range_max_check (tree_to_mat_idx (ri.max ()), 0, nr, nc) < 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3587 return tree_constant ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3588 retval = do_matrix_index (ri, magic_colon);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3589 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3590 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3591
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3592 default:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3593 panic_impossible ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3594 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3595 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3596
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3597 return retval;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3598 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3599
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3600 tree_constant
1488
89c587478067 [project @ 1995-09-26 22:49:48 by jwe]
jwe
parents: 1430
diff changeset
3601 TC_REP::do_matrix_index (TC_REP::constant_type /* mci */,
1299
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3602 const tree_constant& j_arg) const
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3603 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3604 tree_constant retval;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3605
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3606 tree_constant tmp_j = j_arg.make_numeric_or_range_or_magic ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3607
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3608 if (error_state)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3609 return retval;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3610
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3611 TC_REP::constant_type jtype = tmp_j.const_type ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3612
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3613 int nr = rows ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3614 int nc = columns ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3615
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3616 switch (jtype)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3617 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3618 case complex_scalar_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3619 case scalar_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3620 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3621 int j = tree_to_mat_idx (tmp_j.double_value ());
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3622 if (j == -1 && nc == 1)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3623 return Matrix ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3624 if (index_check (j, "column") < 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3625 return tree_constant ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3626 if (range_max_check (0, j, nr, nc) < 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3627 return tree_constant ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3628 retval = do_matrix_index (magic_colon, j);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3629 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3630 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3631
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3632 case complex_matrix_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3633 case matrix_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3634 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3635 Matrix mj = tmp_j.matrix_value ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3636 idx_vector jv (mj, user_pref.do_fortran_indexing, "column", nc);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3637 if (! jv)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3638 return tree_constant ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3639
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3640 if (jv.length () == 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3641 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3642 Matrix mtmp;
1355
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
3643 retval = mtmp;
1299
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3644 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3645 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3646 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3647 if (range_max_check (0, jv.max (), nr, nc) < 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3648 return tree_constant ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3649 retval = do_matrix_index (magic_colon, jv);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3650 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3651 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3652 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3653
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3654 case string_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3655 gripe_string_invalid ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3656 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3657
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3658 case range_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3659 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3660 Range rj = tmp_j.range_value ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3661 if (nc == 2 && is_zero_one (rj))
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3662 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3663 retval = do_matrix_index (magic_colon, 1);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3664 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3665 else if (nc == 2 && is_one_zero (rj))
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3666 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3667 retval = do_matrix_index (magic_colon, 0);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3668 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3669 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3670 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3671 if (index_check (rj, "column") < 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3672 return tree_constant ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3673 if (range_max_check (0, tree_to_mat_idx (rj.max ()), nr, nc) < 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3674 return tree_constant ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3675 retval = do_matrix_index (magic_colon, rj);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3676 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3677 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3678 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3679
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3680 case magic_colon:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3681 retval = do_matrix_index (magic_colon, magic_colon);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3682 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3683
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3684 default:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3685 panic_impossible ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3686 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3687 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3688
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3689 return retval;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3690 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3691
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3692 tree_constant
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3693 TC_REP::do_matrix_index (int i, int j) const
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3694 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3695 tree_constant retval;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3696
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3697 if (type_tag == matrix_constant)
1355
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
3698 retval = matrix->elem (i, j);
1299
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3699 else
1355
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
3700 retval = complex_matrix->elem (i, j);
1299
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3701
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3702 return retval;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3703 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3704
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3705 tree_constant
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3706 TC_REP::do_matrix_index (int i, const idx_vector& jv) const
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3707 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3708 tree_constant retval;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3709
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3710 int jlen = jv.capacity ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3711
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3712 CRMATRIX (m, cm, 1, jlen);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3713
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3714 for (int j = 0; j < jlen; j++)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3715 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3716 int col = jv.elem (j);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3717 CRMATRIX_ASSIGN_REP_ELEM (m, cm, 0, j, i, col);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3718 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3719 ASSIGN_CRMATRIX_TO (retval, m, cm);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3720
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3721 return retval;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3722 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3723
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3724 tree_constant
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3725 TC_REP::do_matrix_index (int i, const Range& rj) const
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3726 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3727 tree_constant retval;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3728
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3729 int jlen = rj.nelem ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3730
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3731 CRMATRIX (m, cm, 1, jlen);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3732
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3733 double b = rj.base ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3734 double increment = rj.inc ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3735 for (int j = 0; j < jlen; j++)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3736 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3737 double tmp = b + j * increment;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3738 int col = tree_to_mat_idx (tmp);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3739 CRMATRIX_ASSIGN_REP_ELEM (m, cm, 0, j, i, col);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3740 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3741
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3742 ASSIGN_CRMATRIX_TO (retval, m, cm);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3743
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3744 return retval;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3745 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3746
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3747 tree_constant
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3748 TC_REP::do_matrix_index (int i, TC_REP::constant_type mcj) const
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3749 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3750 assert (mcj == magic_colon);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3751
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3752 tree_constant retval;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3753
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3754 int nc = columns ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3755
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3756 CRMATRIX (m, cm, 1, nc);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3757
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3758 for (int j = 0; j < nc; j++)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3759 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3760 CRMATRIX_ASSIGN_REP_ELEM (m, cm, 0, j, i, j);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3761 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3762
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3763 ASSIGN_CRMATRIX_TO (retval, m, cm);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3764
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3765 return retval;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3766 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3767
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3768 tree_constant
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3769 TC_REP::do_matrix_index (const idx_vector& iv, int j) const
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3770 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3771 tree_constant retval;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3772
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3773 int ilen = iv.capacity ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3774
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3775 CRMATRIX (m, cm, ilen, 1);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3776
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3777 for (int i = 0; i < ilen; i++)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3778 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3779 int row = iv.elem (i);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3780 CRMATRIX_ASSIGN_REP_ELEM (m, cm, i, 0, row, j);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3781 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3782
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3783 ASSIGN_CRMATRIX_TO (retval, m, cm);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3784
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3785 return retval;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3786 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3787
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3788 tree_constant
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3789 TC_REP::do_matrix_index (const idx_vector& iv, const idx_vector& jv) const
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3790 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3791 tree_constant retval;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3792
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3793 int ilen = iv.capacity ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3794 int jlen = jv.capacity ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3795
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3796 CRMATRIX (m, cm, ilen, jlen);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3797
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3798 for (int i = 0; i < ilen; i++)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3799 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3800 int row = iv.elem (i);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3801 for (int j = 0; j < jlen; j++)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3802 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3803 int col = jv.elem (j);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3804 CRMATRIX_ASSIGN_REP_ELEM (m, cm, i, j, row, col);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3805 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3806 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3807
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3808 ASSIGN_CRMATRIX_TO (retval, m, cm);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3809
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3810 return retval;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3811 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3812
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3813 tree_constant
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3814 TC_REP::do_matrix_index (const idx_vector& iv, const Range& rj) const
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3815 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3816 tree_constant retval;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3817
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3818 int ilen = iv.capacity ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3819 int jlen = rj.nelem ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3820
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3821 CRMATRIX (m, cm, ilen, jlen);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3822
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3823 double b = rj.base ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3824 double increment = rj.inc ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3825
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3826 for (int i = 0; i < ilen; i++)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3827 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3828 int row = iv.elem (i);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3829 for (int j = 0; j < jlen; j++)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3830 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3831 double tmp = b + j * increment;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3832 int col = tree_to_mat_idx (tmp);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3833 CRMATRIX_ASSIGN_REP_ELEM (m, cm, i, j, row, col);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3834 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3835 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3836
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3837 ASSIGN_CRMATRIX_TO (retval, m, cm);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3838
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3839 return retval;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3840 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3841
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3842 tree_constant
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3843 TC_REP::do_matrix_index (const idx_vector& iv,
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3844 TC_REP::constant_type mcj) const
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3845 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3846 assert (mcj == magic_colon);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3847
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3848 tree_constant retval;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3849
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3850 int nc = columns ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3851 int ilen = iv.capacity ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3852
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3853 CRMATRIX (m, cm, ilen, nc);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3854
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3855 for (int j = 0; j < nc; j++)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3856 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3857 for (int i = 0; i < ilen; i++)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3858 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3859 int row = iv.elem (i);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3860 CRMATRIX_ASSIGN_REP_ELEM (m, cm, i, j, row, j);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3861 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3862 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3863
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3864 ASSIGN_CRMATRIX_TO (retval, m, cm);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3865
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3866 return retval;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3867 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3868
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3869 tree_constant
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3870 TC_REP::do_matrix_index (const Range& ri, int j) const
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3871 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3872 tree_constant retval;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3873
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3874 int ilen = ri.nelem ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3875
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3876 CRMATRIX (m, cm, ilen, 1);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3877
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3878 double b = ri.base ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3879 double increment = ri.inc ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3880 for (int i = 0; i < ilen; i++)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3881 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3882 double tmp = b + i * increment;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3883 int row = tree_to_mat_idx (tmp);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3884 CRMATRIX_ASSIGN_REP_ELEM (m, cm, i, 0, row, j);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3885 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3886
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3887 ASSIGN_CRMATRIX_TO (retval, m, cm);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3888
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3889 return retval;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3890 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3891
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3892 tree_constant
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3893 TC_REP::do_matrix_index (const Range& ri,
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3894 const idx_vector& jv) const
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3895 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3896 tree_constant retval;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3897
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3898 int ilen = ri.nelem ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3899 int jlen = jv.capacity ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3900
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3901 CRMATRIX (m, cm, ilen, jlen);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3902
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3903 double b = ri.base ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3904 double increment = ri.inc ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3905 for (int i = 0; i < ilen; i++)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3906 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3907 double tmp = b + i * increment;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3908 int row = tree_to_mat_idx (tmp);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3909 for (int j = 0; j < jlen; j++)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3910 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3911 int col = jv.elem (j);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3912 CRMATRIX_ASSIGN_REP_ELEM (m, cm, i, j, row, col);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3913 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3914 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3915
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3916 ASSIGN_CRMATRIX_TO (retval, m, cm);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3917
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3918 return retval;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3919 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3920
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3921 tree_constant
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3922 TC_REP::do_matrix_index (const Range& ri, const Range& rj) const
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3923 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3924 tree_constant retval;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3925
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3926 int ilen = ri.nelem ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3927 int jlen = rj.nelem ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3928
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3929 CRMATRIX (m, cm, ilen, jlen);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3930
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3931 double ib = ri.base ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3932 double iinc = ri.inc ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3933 double jb = rj.base ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3934 double jinc = rj.inc ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3935
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3936 for (int i = 0; i < ilen; i++)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3937 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3938 double itmp = ib + i * iinc;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3939 int row = tree_to_mat_idx (itmp);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3940 for (int j = 0; j < jlen; j++)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3941 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3942 double jtmp = jb + j * jinc;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3943 int col = tree_to_mat_idx (jtmp);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3944
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3945 CRMATRIX_ASSIGN_REP_ELEM (m, cm, i, j, row, col);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3946 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3947 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3948
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3949 ASSIGN_CRMATRIX_TO (retval, m, cm);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3950
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3951 return retval;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3952 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3953
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3954 tree_constant
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3955 TC_REP::do_matrix_index (const Range& ri, TC_REP::constant_type mcj) const
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3956 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3957 assert (mcj == magic_colon);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3958
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3959 tree_constant retval;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3960
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3961 int nc = columns ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3962
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3963 int ilen = ri.nelem ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3964
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3965 CRMATRIX (m, cm, ilen, nc);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3966
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3967 double ib = ri.base ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3968 double iinc = ri.inc ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3969
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3970 for (int i = 0; i < ilen; i++)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3971 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3972 double itmp = ib + i * iinc;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3973 int row = tree_to_mat_idx (itmp);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3974 for (int j = 0; j < nc; j++)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3975 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3976 CRMATRIX_ASSIGN_REP_ELEM (m, cm, i, j, row, j);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3977 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3978 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3979
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3980 ASSIGN_CRMATRIX_TO (retval, m, cm);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3981
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3982 return retval;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3983 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3984
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3985 tree_constant
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3986 TC_REP::do_matrix_index (TC_REP::constant_type mci, int j) const
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3987 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3988 assert (mci == magic_colon);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3989
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3990 tree_constant retval;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3991
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3992 int nr = rows ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3993
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3994 CRMATRIX (m, cm, nr, 1);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3995
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3996 for (int i = 0; i < nr; i++)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3997 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3998 CRMATRIX_ASSIGN_REP_ELEM (m, cm, i, 0, i, j);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
3999 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4000
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4001 ASSIGN_CRMATRIX_TO (retval, m, cm);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4002
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4003 return retval;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4004 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4005
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4006 tree_constant
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4007 TC_REP::do_matrix_index (TC_REP::constant_type mci,
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4008 const idx_vector& jv) const
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4009 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4010 assert (mci == magic_colon);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4011
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4012 tree_constant retval;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4013
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4014 int nr = rows ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4015 int jlen = jv.capacity ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4016
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4017 CRMATRIX (m, cm, nr, jlen);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4018
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4019 for (int i = 0; i < nr; i++)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4020 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4021 for (int j = 0; j < jlen; j++)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4022 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4023 int col = jv.elem (j);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4024 CRMATRIX_ASSIGN_REP_ELEM (m, cm, i, j, i, col);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4025 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4026 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4027
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4028 ASSIGN_CRMATRIX_TO (retval, m, cm);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4029
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4030 return retval;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4031 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4032
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4033 tree_constant
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4034 TC_REP::do_matrix_index (TC_REP::constant_type mci, const Range& rj) const
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4035 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4036 assert (mci == magic_colon);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4037
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4038 tree_constant retval;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4039
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4040 int nr = rows ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4041 int jlen = rj.nelem ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4042
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4043 CRMATRIX (m, cm, nr, jlen);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4044
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4045 double jb = rj.base ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4046 double jinc = rj.inc ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4047
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4048 for (int j = 0; j < jlen; j++)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4049 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4050 double jtmp = jb + j * jinc;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4051 int col = tree_to_mat_idx (jtmp);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4052 for (int i = 0; i < nr; i++)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4053 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4054 CRMATRIX_ASSIGN_REP_ELEM (m, cm, i, j, i, col);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4055 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4056 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4057
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4058 ASSIGN_CRMATRIX_TO (retval, m, cm);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4059
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4060 return retval;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4061 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4062
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4063 tree_constant
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4064 TC_REP::do_matrix_index (TC_REP::constant_type mci,
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4065 TC_REP::constant_type mcj) const
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4066 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4067 tree_constant retval;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4068
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4069 assert (mci == magic_colon && mcj == magic_colon);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4070
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4071 switch (type_tag)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4072 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4073 case complex_scalar_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4074 retval = *complex_scalar;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4075 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4076
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4077 case scalar_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4078 retval = scalar;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4079 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4080
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4081 case complex_matrix_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4082 retval = *complex_matrix;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4083 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4084
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4085 case matrix_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4086 retval = *matrix;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4087 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4088
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4089 case range_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4090 retval = *range;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4091 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4092
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4093 case string_constant:
1355
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
4094 retval = *str_obj;
1299
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4095 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4096
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4097 case magic_colon:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4098 default:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4099 panic_impossible ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4100 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4101 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4102
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4103 return retval;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4104 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4105
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4106 // -------------------------------------------------------------------
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4107 //
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4108 // Assignment operations for the tree-constant representation class.
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4109 //
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4110 // Leave the commented #includes below to make it easy to split this
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4111 // out again, should we want to do that.
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4112 //
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4113 // -------------------------------------------------------------------
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4114
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4115 // #ifdef HAVE_CONFIG_H
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4116 // #include <config.h>
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4117 // #endif
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4118
1355
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
4119 // #include <cctype>
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
4120 // #include <cstring>
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
4121
1299
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4122 // #include <fstream.h>
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4123 // #include <iostream.h>
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4124 // #include <strstream.h>
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4125
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4126 // #include "mx-base.h"
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4127 // #include "Range.h"
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4128
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4129 // #include "arith-ops.h"
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4130 // #include "variables.h"
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4131 // #include "sysdep.h"
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4132 // #include "error.h"
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4133 // #include "gripes.h"
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4134 // #include "user-prefs.h"
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4135 // #include "utils.h"
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4136 // #include "pager.h"
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4137 // #include "pr-output.h"
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4138 // #include "tree-const.h"
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4139 // #include "idx-vector.h"
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4140 // #include "oct-map.h"
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4141
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4142 // #include "tc-inlines.h"
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4143
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4144 // Top-level tree-constant function that handles assignments. Only
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4145 // decide if the left-hand side is currently a scalar or a matrix and
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4146 // hand off to other functions to do the real work.
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4147
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4148 void
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4149 TC_REP::assign (tree_constant& rhs, const Octave_object& args)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4150 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4151 tree_constant rhs_tmp = rhs.make_numeric ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4152
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4153 if (error_state)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4154 return;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4155
1358
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1355
diff changeset
4156 // This is easier than actually handling assignments to strings. An
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1355
diff changeset
4157 // assignment to a range will normally require a conversion to a
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1355
diff changeset
4158 // vector since it will normally destroy the equally-spaced property
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1355
diff changeset
4159 // of the range elements.
1299
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4160
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4161 if (is_defined () && ! is_numeric_type ())
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4162 force_numeric ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4163
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4164 if (error_state)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4165 return;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4166
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4167 switch (type_tag)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4168 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4169 case complex_scalar_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4170 case scalar_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4171 case unknown_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4172 do_scalar_assignment (rhs_tmp, args);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4173 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4174
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4175 case complex_matrix_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4176 case matrix_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4177 do_matrix_assignment (rhs_tmp, args);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4178 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4179
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4180 default:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4181 ::error ("invalid assignment to %s", type_as_string ());
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4182 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4183 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4184 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4185
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4186 // Assignments to scalars. If resize_on_range_error is true,
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4187 // this can convert the left-hand side to a matrix.
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4188
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4189 void
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4190 TC_REP::do_scalar_assignment (const tree_constant& rhs,
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4191 const Octave_object& args)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4192 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4193 assert (type_tag == unknown_constant
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4194 || type_tag == scalar_constant
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4195 || type_tag == complex_scalar_constant);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4196
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4197 int nargin = args.length ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4198
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4199 if (rhs.is_zero_by_zero ())
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4200 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4201 if (valid_scalar_indices (args))
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4202 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4203 if (type_tag == complex_scalar_constant)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4204 delete complex_scalar;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4205
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4206 matrix = new Matrix (0, 0);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4207 type_tag = matrix_constant;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4208 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4209 else if (! valid_zero_index (args))
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4210 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4211 ::error ("invalid assigment of empty matrix to scalar");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4212 return;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4213 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4214 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4215 else if (rhs.is_scalar_type () && valid_scalar_indices (args))
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4216 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4217 if (type_tag == unknown_constant || type_tag == scalar_constant)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4218 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4219 if (rhs.const_type () == scalar_constant)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4220 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4221 scalar = rhs.double_value ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4222 type_tag = scalar_constant;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4223 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4224 else if (rhs.const_type () == complex_scalar_constant)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4225 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4226 complex_scalar = new Complex (rhs.complex_value ());
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4227 type_tag = complex_scalar_constant;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4228 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4229 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4230 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4231 ::error ("invalid assignment to scalar");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4232 return;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4233 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4234 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4235 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4236 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4237 if (rhs.const_type () == scalar_constant)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4238 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4239 delete complex_scalar;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4240 scalar = rhs.double_value ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4241 type_tag = scalar_constant;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4242 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4243 else if (rhs.const_type () == complex_scalar_constant)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4244 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4245 *complex_scalar = rhs.complex_value ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4246 type_tag = complex_scalar_constant;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4247 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4248 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4249 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4250 ::error ("invalid assignment to scalar");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4251 return;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4252 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4253 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4254 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4255 else if (user_pref.resize_on_range_error)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4256 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4257 TC_REP::constant_type old_type_tag = type_tag;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4258
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4259 if (type_tag == complex_scalar_constant)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4260 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4261 Complex *old_complex = complex_scalar;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4262 complex_matrix = new ComplexMatrix (1, 1, *complex_scalar);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4263 type_tag = complex_matrix_constant;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4264 delete old_complex;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4265 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4266 else if (type_tag == scalar_constant)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4267 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4268 matrix = new Matrix (1, 1, scalar);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4269 type_tag = matrix_constant;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4270 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4271
1358
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1355
diff changeset
4272 // If there is an error, the call to do_matrix_assignment should
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1355
diff changeset
4273 // not destroy the current value. TC_REP::eval(int) will take
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1355
diff changeset
4274 // care of converting single element matrices back to scalars.
1299
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4275
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4276 do_matrix_assignment (rhs, args);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4277
1358
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1355
diff changeset
4278 // I don't think there's any other way to revert back to unknown
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1355
diff changeset
4279 // constant types, so here it is.
1299
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4280
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4281 if (old_type_tag == unknown_constant && error_state)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4282 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4283 if (type_tag == matrix_constant)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4284 delete matrix;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4285 else if (type_tag == complex_matrix_constant)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4286 delete complex_matrix;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4287
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4288 type_tag = unknown_constant;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4289 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4290 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4291 else if (nargin > 2 || nargin < 1)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4292 ::error ("invalid index expression for scalar type");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4293 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4294 ::error ("index invalid or out of range for scalar type");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4295 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4296
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4297 // Assignments to matrices (and vectors).
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4298 //
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4299 // For compatibility with Matlab, we allow assignment of an empty
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4300 // matrix to an expression with empty indices to do nothing.
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4301
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4302 void
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4303 TC_REP::do_matrix_assignment (const tree_constant& rhs,
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4304 const Octave_object& args)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4305 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4306 assert (type_tag == unknown_constant
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4307 || type_tag == matrix_constant
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4308 || type_tag == complex_matrix_constant);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4309
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4310 if (type_tag == matrix_constant && rhs.is_complex_type ())
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4311 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4312 Matrix *old_matrix = matrix;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4313 complex_matrix = new ComplexMatrix (*matrix);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4314 type_tag = complex_matrix_constant;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4315 delete old_matrix;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4316 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4317 else if (type_tag == unknown_constant)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4318 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4319 if (rhs.is_complex_type ())
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4320 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4321 complex_matrix = new ComplexMatrix ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4322 type_tag = complex_matrix_constant;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4323 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4324 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4325 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4326 matrix = new Matrix ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4327 type_tag = matrix_constant;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4328 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4329 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4330
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4331 int nargin = args.length ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4332
1358
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1355
diff changeset
4333 // The do_matrix_assignment functions can't handle empty matrices,
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1355
diff changeset
4334 // so don't let any pass through here.
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1355
diff changeset
4335
1299
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4336 switch (nargin)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4337 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4338 case 1:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4339 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4340 tree_constant arg = args(0);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4341
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4342 if (arg.is_undefined ())
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4343 ::error ("matrix index is undefined");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4344 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4345 do_matrix_assignment (rhs, arg);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4346 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4347 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4348
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4349 case 2:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4350 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4351 tree_constant arg_a = args(0);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4352 tree_constant arg_b = args(1);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4353
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4354 if (arg_a.is_undefined ())
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4355 ::error ("first matrix index is undefined");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4356 else if (arg_b.is_undefined ())
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4357 ::error ("second matrix index is undefined");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4358 else if (arg_a.is_empty () || arg_b.is_empty ())
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4359 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4360 if (! rhs.is_empty ())
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4361 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4362 ::error ("in assignment expression, a matrix index is empty");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4363 ::error ("but the right hand side is not an empty matrix");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4364 }
1358
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1355
diff changeset
4365
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1355
diff changeset
4366 // XXX FIXME XXX -- to really be correct here, we should
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1355
diff changeset
4367 // probably check to see if the assignment conforms, but
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1355
diff changeset
4368 // that seems like more work than it's worth right now...
1299
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4369 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4370 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4371 do_matrix_assignment (rhs, arg_a, arg_b);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4372 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4373 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4374
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4375 default:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4376 if (nargin == 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4377 ::error ("matrix indices expected, but none provided");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4378 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4379 ::error ("too many indices for matrix expression");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4380 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4381 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4382 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4383
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4384 // Matrix assignments indexed by a single value.
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4385
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4386 void
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4387 TC_REP::do_matrix_assignment (const tree_constant& rhs,
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4388 const tree_constant& i_arg)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4389 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4390 int nr = rows ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4391 int nc = columns ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4392
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4393 if (user_pref.do_fortran_indexing || nr <= 1 || nc <= 1)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4394 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4395 if (i_arg.is_empty ())
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4396 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4397 if (! rhs.is_empty ())
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4398 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4399 ::error ("in assignment expression, matrix index is empty but");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4400 ::error ("right hand side is not an empty matrix");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4401 }
1358
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1355
diff changeset
4402
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1355
diff changeset
4403 // XXX FIXME XXX -- to really be correct here, we should
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1355
diff changeset
4404 // probably check to see if the assignment conforms, but
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1355
diff changeset
4405 // that seems like more work than it's worth right now...
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1355
diff changeset
4406
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1355
diff changeset
4407 // The assignment functions can't handle empty matrices, so
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1355
diff changeset
4408 // don't let any pass through here.
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1355
diff changeset
4409
1299
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4410 return;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4411 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4412
1358
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1355
diff changeset
4413 // We can't handle the case of assigning to a vector first,
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1355
diff changeset
4414 // since even then, the two operations are not equivalent. For
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1355
diff changeset
4415 // example, the expression V(:) = M is handled differently
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1355
diff changeset
4416 // depending on whether the user specified do_fortran_indexing =
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1355
diff changeset
4417 // "true".
1299
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4418
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4419 if (user_pref.do_fortran_indexing)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4420 fortran_style_matrix_assignment (rhs, i_arg);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4421 else if (nr <= 1 || nc <= 1)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4422 vector_assignment (rhs, i_arg);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4423 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4424 panic_impossible ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4425 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4426 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4427 ::error ("single index only valid for row or column vector");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4428 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4429
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4430 // Fortran-style assignments. Matrices are assumed to be stored in
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4431 // column-major order and it is ok to use a single index for
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4432 // multi-dimensional matrices.
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4433
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4434 void
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4435 TC_REP::fortran_style_matrix_assignment (const tree_constant& rhs,
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4436 const tree_constant& i_arg)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4437 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4438 tree_constant tmp_i = i_arg.make_numeric_or_magic ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4439
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4440 if (error_state)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4441 return;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4442
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4443 TC_REP::constant_type itype = tmp_i.const_type ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4444
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4445 int nr = rows ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4446 int nc = columns ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4447
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4448 int rhs_nr = rhs.rows ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4449 int rhs_nc = rhs.columns ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4450
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4451 switch (itype)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4452 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4453 case complex_scalar_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4454 case scalar_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4455 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4456 double dval = tmp_i.double_value ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4457
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4458 if (xisnan (dval))
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4459 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4460 error ("NaN is invalid as a matrix index");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4461 return;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4462 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4463
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4464 int i = NINT (dval);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4465 int idx = i - 1;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4466
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4467 if (rhs_nr == 0 && rhs_nc == 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4468 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4469 int len = nr * nc;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4470
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4471 if (idx < len && len > 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4472 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4473 convert_to_row_or_column_vector ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4474
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4475 nr = rows ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4476 nc = columns ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4477
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4478 if (nr == 1)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4479 delete_column (idx);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4480 else if (nc == 1)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4481 delete_row (idx);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4482 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4483 panic_impossible ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4484 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4485 else if (idx < 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4486 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4487 error ("invalid index = %d", idx+1);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4488 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4489
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4490 return;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4491 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4492
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4493 if (index_check (idx, "") < 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4494 return;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4495
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4496 if (nr <= 1 || nc <= 1)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4497 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4498 maybe_resize (idx);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4499 if (error_state)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4500 return;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4501 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4502 else if (range_max_check (idx, nr * nc) < 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4503 return;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4504
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4505 nr = rows ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4506 nc = columns ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4507
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4508 if (! indexed_assign_conforms (1, 1, rhs_nr, rhs_nc))
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4509 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4510 ::error ("for A(int) = X: X must be a scalar");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4511 return;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4512 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4513 int ii = fortran_row (i, nr) - 1;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4514 int jj = fortran_column (i, nr) - 1;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4515 do_matrix_assignment (rhs, ii, jj);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4516 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4517 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4518
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4519 case complex_matrix_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4520 case matrix_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4521 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4522 Matrix mi = tmp_i.matrix_value ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4523 int len = nr * nc;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4524 idx_vector ii (mi, 1, "", len); // Always do fortran indexing here...
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4525 if (! ii)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4526 return;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4527
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4528 if (rhs_nr == 0 && rhs_nc == 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4529 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4530 ii.sort_uniq ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4531 int num_to_delete = 0;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4532 for (int i = 0; i < ii.length (); i++)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4533 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4534 if (ii.elem (i) < len)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4535 num_to_delete++;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4536 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4537 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4538 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4539
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4540 if (num_to_delete > 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4541 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4542 if (num_to_delete != ii.length ())
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4543 ii.shorten (num_to_delete);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4544
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4545 convert_to_row_or_column_vector ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4546
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4547 nr = rows ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4548 nc = columns ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4549
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4550 if (nr == 1)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4551 delete_columns (ii);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4552 else if (nc == 1)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4553 delete_rows (ii);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4554 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4555 panic_impossible ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4556 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4557 return;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4558 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4559
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4560 if (nr <= 1 || nc <= 1)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4561 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4562 maybe_resize (ii.max ());
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4563 if (error_state)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4564 return;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4565 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4566 else if (range_max_check (ii.max (), len) < 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4567 return;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4568
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4569 int ilen = ii.capacity ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4570
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4571 if (ilen != rhs_nr * rhs_nc)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4572 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4573 ::error ("A(matrix) = X: X and matrix must have the same number");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4574 ::error ("of elements");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4575 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4576 else if (ilen == 1 && rhs.is_scalar_type ())
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4577 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4578 int nr = rows ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4579 int idx = ii.elem (0);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4580 int ii = fortran_row (idx + 1, nr) - 1;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4581 int jj = fortran_column (idx + 1, nr) - 1;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4582
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4583 if (rhs.const_type () == scalar_constant)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4584 matrix->elem (ii, jj) = rhs.double_value ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4585 else if (rhs.const_type () == complex_scalar_constant)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4586 complex_matrix->elem (ii, jj) = rhs.complex_value ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4587 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4588 panic_impossible ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4589 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4590 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4591 fortran_style_matrix_assignment (rhs, ii);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4592 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4593 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4594
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4595 case string_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4596 gripe_string_invalid ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4597 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4598
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4599 case range_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4600 gripe_range_invalid ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4601 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4602
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4603 case magic_colon:
1358
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1355
diff changeset
4604
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1355
diff changeset
4605 // a(:) = [] is equivalent to a(:,:) = [].
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1355
diff changeset
4606
1299
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4607 if (rhs_nr == 0 && rhs_nc == 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4608 do_matrix_assignment (rhs, magic_colon, magic_colon);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4609 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4610 fortran_style_matrix_assignment (rhs, magic_colon);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4611 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4612
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4613 default:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4614 panic_impossible ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4615 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4616 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4617 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4618
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4619 // Fortran-style assignment for vector index.
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4620
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4621 void
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4622 TC_REP::fortran_style_matrix_assignment (const tree_constant& rhs,
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4623 idx_vector& i)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4624 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4625 assert (rhs.is_matrix_type ());
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4626
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4627 int ilen = i.capacity ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4628
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4629 REP_RHS_MATRIX (rhs, rhs_m, rhs_cm, rhs_nr, rhs_nc);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4630
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4631 int len = rhs_nr * rhs_nc;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4632
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4633 if (len == ilen)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4634 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4635 int nr = rows ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4636 if (rhs.const_type () == matrix_constant)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4637 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4638 double *cop_out = rhs_m.fortran_vec ();
1320
c9aecc02c6d4 [project @ 1995-08-22 04:10:01 by jwe]
jwe
parents: 1315
diff changeset
4639
c9aecc02c6d4 [project @ 1995-08-22 04:10:01 by jwe]
jwe
parents: 1315
diff changeset
4640 if (type_tag == matrix_constant)
1299
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4641 {
1320
c9aecc02c6d4 [project @ 1995-08-22 04:10:01 by jwe]
jwe
parents: 1315
diff changeset
4642 for (int k = 0; k < len; k++)
c9aecc02c6d4 [project @ 1995-08-22 04:10:01 by jwe]
jwe
parents: 1315
diff changeset
4643 {
c9aecc02c6d4 [project @ 1995-08-22 04:10:01 by jwe]
jwe
parents: 1315
diff changeset
4644 int ii = fortran_row (i.elem (k) + 1, nr) - 1;
c9aecc02c6d4 [project @ 1995-08-22 04:10:01 by jwe]
jwe
parents: 1315
diff changeset
4645 int jj = fortran_column (i.elem (k) + 1, nr) - 1;
c9aecc02c6d4 [project @ 1995-08-22 04:10:01 by jwe]
jwe
parents: 1315
diff changeset
4646
c9aecc02c6d4 [project @ 1995-08-22 04:10:01 by jwe]
jwe
parents: 1315
diff changeset
4647 matrix->elem (ii, jj) = *cop_out++;
c9aecc02c6d4 [project @ 1995-08-22 04:10:01 by jwe]
jwe
parents: 1315
diff changeset
4648 }
1299
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4649 }
1320
c9aecc02c6d4 [project @ 1995-08-22 04:10:01 by jwe]
jwe
parents: 1315
diff changeset
4650 else if (type_tag == complex_matrix_constant)
c9aecc02c6d4 [project @ 1995-08-22 04:10:01 by jwe]
jwe
parents: 1315
diff changeset
4651 {
c9aecc02c6d4 [project @ 1995-08-22 04:10:01 by jwe]
jwe
parents: 1315
diff changeset
4652 for (int k = 0; k < len; k++)
c9aecc02c6d4 [project @ 1995-08-22 04:10:01 by jwe]
jwe
parents: 1315
diff changeset
4653 {
c9aecc02c6d4 [project @ 1995-08-22 04:10:01 by jwe]
jwe
parents: 1315
diff changeset
4654 int ii = fortran_row (i.elem (k) + 1, nr) - 1;
c9aecc02c6d4 [project @ 1995-08-22 04:10:01 by jwe]
jwe
parents: 1315
diff changeset
4655 int jj = fortran_column (i.elem (k) + 1, nr) - 1;
c9aecc02c6d4 [project @ 1995-08-22 04:10:01 by jwe]
jwe
parents: 1315
diff changeset
4656
c9aecc02c6d4 [project @ 1995-08-22 04:10:01 by jwe]
jwe
parents: 1315
diff changeset
4657 complex_matrix->elem (ii, jj) = *cop_out++;
c9aecc02c6d4 [project @ 1995-08-22 04:10:01 by jwe]
jwe
parents: 1315
diff changeset
4658 }
c9aecc02c6d4 [project @ 1995-08-22 04:10:01 by jwe]
jwe
parents: 1315
diff changeset
4659 }
c9aecc02c6d4 [project @ 1995-08-22 04:10:01 by jwe]
jwe
parents: 1315
diff changeset
4660 else
c9aecc02c6d4 [project @ 1995-08-22 04:10:01 by jwe]
jwe
parents: 1315
diff changeset
4661 panic_impossible ();
1299
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4662 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4663 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4664 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4665 Complex *cop_out = rhs_cm.fortran_vec ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4666 for (int k = 0; k < len; k++)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4667 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4668 int ii = fortran_row (i.elem (k) + 1, nr) - 1;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4669 int jj = fortran_column (i.elem (k) + 1, nr) - 1;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4670
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4671 complex_matrix->elem (ii, jj) = *cop_out++;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4672 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4673 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4674 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4675 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4676 ::error ("number of rows and columns must match for indexed assignment");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4677 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4678
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4679 // Fortran-style assignment for colon index.
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4680
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4681 void
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4682 TC_REP::fortran_style_matrix_assignment (const tree_constant& rhs,
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4683 TC_REP::constant_type mci)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4684 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4685 assert (rhs.is_matrix_type () && mci == TC_REP::magic_colon);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4686
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4687 int nr = rows ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4688 int nc = columns ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4689
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4690 REP_RHS_MATRIX (rhs, rhs_m, rhs_cm, rhs_nr, rhs_nc);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4691
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4692 int rhs_size = rhs_nr * rhs_nc;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4693 if (rhs_size == 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4694 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4695 if (rhs.const_type () == matrix_constant)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4696 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4697 delete matrix;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4698 matrix = new Matrix (0, 0);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4699 return;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4700 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4701 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4702 panic_impossible ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4703 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4704 else if (nr*nc != rhs_size)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4705 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4706 ::error ("A(:) = X: X and A must have the same number of elements");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4707 return;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4708 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4709
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4710 if (rhs.const_type () == matrix_constant)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4711 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4712 double *cop_out = rhs_m.fortran_vec ();
1320
c9aecc02c6d4 [project @ 1995-08-22 04:10:01 by jwe]
jwe
parents: 1315
diff changeset
4713 if (type_tag == matrix_constant)
c9aecc02c6d4 [project @ 1995-08-22 04:10:01 by jwe]
jwe
parents: 1315
diff changeset
4714 {
c9aecc02c6d4 [project @ 1995-08-22 04:10:01 by jwe]
jwe
parents: 1315
diff changeset
4715 for (int j = 0; j < nc; j++)
c9aecc02c6d4 [project @ 1995-08-22 04:10:01 by jwe]
jwe
parents: 1315
diff changeset
4716 for (int i = 0; i < nr; i++)
c9aecc02c6d4 [project @ 1995-08-22 04:10:01 by jwe]
jwe
parents: 1315
diff changeset
4717 matrix->elem (i, j) = *cop_out++;
c9aecc02c6d4 [project @ 1995-08-22 04:10:01 by jwe]
jwe
parents: 1315
diff changeset
4718 }
c9aecc02c6d4 [project @ 1995-08-22 04:10:01 by jwe]
jwe
parents: 1315
diff changeset
4719 else if (type_tag == complex_matrix_constant)
c9aecc02c6d4 [project @ 1995-08-22 04:10:01 by jwe]
jwe
parents: 1315
diff changeset
4720 {
c9aecc02c6d4 [project @ 1995-08-22 04:10:01 by jwe]
jwe
parents: 1315
diff changeset
4721 for (int j = 0; j < nc; j++)
c9aecc02c6d4 [project @ 1995-08-22 04:10:01 by jwe]
jwe
parents: 1315
diff changeset
4722 for (int i = 0; i < nr; i++)
c9aecc02c6d4 [project @ 1995-08-22 04:10:01 by jwe]
jwe
parents: 1315
diff changeset
4723 complex_matrix->elem (i, j) = *cop_out++;
c9aecc02c6d4 [project @ 1995-08-22 04:10:01 by jwe]
jwe
parents: 1315
diff changeset
4724 }
c9aecc02c6d4 [project @ 1995-08-22 04:10:01 by jwe]
jwe
parents: 1315
diff changeset
4725 else
c9aecc02c6d4 [project @ 1995-08-22 04:10:01 by jwe]
jwe
parents: 1315
diff changeset
4726 panic_impossible ();
1299
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4727 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4728 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4729 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4730 Complex *cop_out = rhs_cm.fortran_vec ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4731 for (int j = 0; j < nc; j++)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4732 for (int i = 0; i < nr; i++)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4733 complex_matrix->elem (i, j) = *cop_out++;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4734 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4735 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4736
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4737 // Assignments to vectors. Hand off to other functions once we know
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4738 // what kind of index we have. For a colon, it is the same as
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4739 // assignment to a matrix indexed by two colons.
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4740
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4741 void
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4742 TC_REP::vector_assignment (const tree_constant& rhs,
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4743 const tree_constant& i_arg)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4744 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4745 int nr = rows ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4746 int nc = columns ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4747
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4748 assert ((nr <= 1 || nc <= 1) && ! user_pref.do_fortran_indexing);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4749
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4750 tree_constant tmp_i = i_arg.make_numeric_or_range_or_magic ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4751
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4752 if (error_state)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4753 return;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4754
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4755 TC_REP::constant_type itype = tmp_i.const_type ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4756
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4757 switch (itype)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4758 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4759 case complex_scalar_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4760 case scalar_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4761 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4762 int i = tree_to_mat_idx (tmp_i.double_value ());
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4763 if (index_check (i, "") < 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4764 return;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4765 do_vector_assign (rhs, i);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4766 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4767 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4768
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4769 case complex_matrix_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4770 case matrix_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4771 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4772 Matrix mi = tmp_i.matrix_value ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4773 int len = nr * nc;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4774 idx_vector iv (mi, user_pref.do_fortran_indexing, "", len);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4775 if (! iv)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4776 return;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4777
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4778 do_vector_assign (rhs, iv);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4779 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4780 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4781
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4782 case string_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4783 gripe_string_invalid ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4784 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4785
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4786 case range_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4787 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4788 Range ri = tmp_i.range_value ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4789 int len = nr * nc;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4790 if (len == 2 && is_zero_one (ri))
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4791 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4792 do_vector_assign (rhs, 1);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4793 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4794 else if (len == 2 && is_one_zero (ri))
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4795 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4796 do_vector_assign (rhs, 0);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4797 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4798 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4799 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4800 if (index_check (ri, "") < 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4801 return;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4802 do_vector_assign (rhs, ri);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4803 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4804 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4805 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4806
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4807 case magic_colon:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4808 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4809 int rhs_nr = rhs.rows ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4810 int rhs_nc = rhs.columns ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4811
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4812 if (! indexed_assign_conforms (nr, nc, rhs_nr, rhs_nc))
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4813 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4814 ::error ("A(:) = X: X and A must have the same dimensions");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4815 return;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4816 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4817 do_matrix_assignment (rhs, magic_colon, magic_colon);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4818 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4819 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4820
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4821 default:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4822 panic_impossible ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4823 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4824 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4825 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4826
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4827 // Check whether an indexed assignment to a vector is valid.
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4828
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4829 void
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4830 TC_REP::check_vector_assign (int rhs_nr, int rhs_nc, int ilen, const char *rm)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4831 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4832 int nr = rows ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4833 int nc = columns ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4834
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4835 if ((nr == 1 && nc == 1) || nr == 0 || nc == 0) // No orientation.
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4836 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4837 if (! (ilen == rhs_nr || ilen == rhs_nc))
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4838 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4839 ::error ("A(%s) = X: X and %s must have the same number of elements",
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4840 rm, rm);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4841 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4842 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4843 else if (nr == 1) // Preserve current row orientation.
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4844 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4845 if (! (rhs_nr == 1 && rhs_nc == ilen))
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4846 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4847 ::error ("A(%s) = X: where A is a row vector, X must also be a", rm);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4848 ::error ("row vector with the same number of elements as %s", rm);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4849 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4850 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4851 else if (nc == 1) // Preserve current column orientation.
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4852 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4853 if (! (rhs_nc == 1 && rhs_nr == ilen))
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4854 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4855 ::error ("A(%s) = X: where A is a column vector, X must also be", rm);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4856 ::error ("a column vector with the same number of elements as %s", rm);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4857 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4858 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4859 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4860 panic_impossible ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4861 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4862
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4863 // Assignment to a vector with an integer index.
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4864
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4865 void
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4866 TC_REP::do_vector_assign (const tree_constant& rhs, int i)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4867 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4868 int rhs_nr = rhs.rows ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4869 int rhs_nc = rhs.columns ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4870
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4871 if (indexed_assign_conforms (1, 1, rhs_nr, rhs_nc))
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4872 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4873 maybe_resize (i);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4874 if (error_state)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4875 return;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4876
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4877 int nr = rows ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4878 int nc = columns ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4879
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4880 if (nr == 1)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4881 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4882 REP_ELEM_ASSIGN (0, i, rhs.double_value (), rhs.complex_value (),
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4883 rhs.is_real_type ());
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4884 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4885 else if (nc == 1)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4886 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4887 REP_ELEM_ASSIGN (i, 0, rhs.double_value (), rhs.complex_value (),
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4888 rhs.is_real_type ());
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4889 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4890 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4891 panic_impossible ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4892 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4893 else if (rhs_nr == 0 && rhs_nc == 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4894 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4895 int nr = rows ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4896 int nc = columns ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4897
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4898 int len = MAX (nr, nc);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4899
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4900 if (i < 0 || i >= len || (nr == 0 && nc == 0))
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4901 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4902 ::error ("A(int) = []: index out of range");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4903 return;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4904 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4905
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4906 if (nr == 0 && nc > 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4907 resize (0, nc - 1);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4908 else if (nc == 0 && nr > 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4909 resize (nr - 1, 0);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4910 else if (nr == 1)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4911 delete_column (i);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4912 else if (nc == 1)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4913 delete_row (i);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4914 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4915 panic_impossible ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4916 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4917 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4918 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4919 ::error ("for A(int) = X: X must be a scalar");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4920 return;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4921 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4922 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4923
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4924 // Assignment to a vector with a vector index.
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4925
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4926 void
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4927 TC_REP::do_vector_assign (const tree_constant& rhs, idx_vector& iv)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4928 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4929 if (rhs.is_zero_by_zero ())
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4930 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4931 int nr = rows ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4932 int nc = columns ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4933
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4934 int len = MAX (nr, nc);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4935
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4936 if (iv.max () >= len)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4937 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4938 ::error ("A(matrix) = []: index out of range");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4939 return;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4940 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4941
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4942 if (nr == 1)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4943 delete_columns (iv);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4944 else if (nc == 1)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4945 delete_rows (iv);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4946 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4947 panic_impossible ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4948 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4949 else if (rhs.is_scalar_type ())
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4950 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4951 int nr = rows ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4952 int nc = columns ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4953
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4954 if (iv.capacity () == 1)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4955 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4956 int idx = iv.elem (0);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4957
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4958 if (nr == 1)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4959 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4960 REP_ELEM_ASSIGN (0, idx, rhs.double_value (),
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4961 rhs.complex_value (), rhs.is_real_type ());
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4962 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4963 else if (nc == 1)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4964 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4965 REP_ELEM_ASSIGN (idx, 0, rhs.double_value (),
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4966 rhs.complex_value (), rhs.is_real_type ());
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4967 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4968 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4969 panic_impossible ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4970 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4971 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4972 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4973 if (nr == 1)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4974 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4975 ::error ("A(matrix) = X: where A is a row vector, X must also be a");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4976 ::error ("row vector with the same number of elements as matrix");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4977 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4978 else if (nc == 1)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4979 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4980 ::error ("A(matrix) = X: where A is a column vector, X must also be a");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4981 ::error ("column vector with the same number of elements as matrix");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4982 }
1331
c04c2a6849e8 [project @ 1995-08-24 01:35:58 by jwe]
jwe
parents: 1321
diff changeset
4983 else if (nr == 0 || nc == 0)
c04c2a6849e8 [project @ 1995-08-24 01:35:58 by jwe]
jwe
parents: 1321
diff changeset
4984 {
c04c2a6849e8 [project @ 1995-08-24 01:35:58 by jwe]
jwe
parents: 1321
diff changeset
4985 ::error ("A(matrix) = X: X must be a vector with the same");
c04c2a6849e8 [project @ 1995-08-24 01:35:58 by jwe]
jwe
parents: 1321
diff changeset
4986 ::error ("number of elements as matrix");
c04c2a6849e8 [project @ 1995-08-24 01:35:58 by jwe]
jwe
parents: 1321
diff changeset
4987 }
1299
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4988 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4989 panic_impossible ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4990 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4991 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4992 else if (rhs.is_matrix_type ())
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4993 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4994 REP_RHS_MATRIX (rhs, rhs_m, rhs_cm, rhs_nr, rhs_nc);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4995
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4996 int ilen = iv.capacity ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4997 check_vector_assign (rhs_nr, rhs_nc, ilen, "matrix");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4998 if (error_state)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
4999 return;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5000
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5001 force_orient f_orient = no_orient;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5002 if (rhs_nr == 1 && rhs_nc != 1)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5003 f_orient = row_orient;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5004 else if (rhs_nc == 1 && rhs_nr != 1)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5005 f_orient = column_orient;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5006
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5007 maybe_resize (iv.max (), f_orient);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5008 if (error_state)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5009 return;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5010
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5011 int nr = rows ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5012 int nc = columns ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5013
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5014 if (nr == 1 && rhs_nr == 1)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5015 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5016 for (int i = 0; i < iv.capacity (); i++)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5017 REP_ELEM_ASSIGN (0, iv.elem (i), rhs_m.elem (0, i),
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5018 rhs_cm.elem (0, i), rhs.is_real_type ());
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5019 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5020 else if (nc == 1 && rhs_nc == 1)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5021 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5022 for (int i = 0; i < iv.capacity (); i++)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5023 REP_ELEM_ASSIGN (iv.elem (i), 0, rhs_m.elem (i, 0),
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5024 rhs_cm.elem (i, 0), rhs.is_real_type ());
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5025 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5026 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5027 ::error ("A(vector) = X: X must be the same size as vector");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5028 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5029 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5030 panic_impossible ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5031 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5032
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5033 // Assignment to a vector with a range index.
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5034
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5035 void
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5036 TC_REP::do_vector_assign (const tree_constant& rhs, Range& ri)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5037 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5038 if (rhs.is_zero_by_zero ())
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5039 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5040 int nr = rows ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5041 int nc = columns ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5042
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5043 int len = MAX (nr, nc);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5044
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5045 int b = tree_to_mat_idx (ri.min ());
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5046 int l = tree_to_mat_idx (ri.max ());
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5047 if (b < 0 || l >= len)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5048 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5049 ::error ("A(range) = []: index out of range");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5050 return;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5051 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5052
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5053 if (nr == 1)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5054 delete_columns (ri);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5055 else if (nc == 1)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5056 delete_rows (ri);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5057 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5058 panic_impossible ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5059 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5060 else if (rhs.is_scalar_type ())
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5061 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5062 int nr = rows ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5063 int nc = columns ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5064
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5065 if (nr == 1)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5066 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5067 ::error ("A(range) = X: where A is a row vector, X must also be a");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5068 ::error ("row vector with the same number of elements as range");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5069 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5070 else if (nc == 1)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5071 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5072 ::error ("A(range) = X: where A is a column vector, X must also be a");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5073 ::error ("column vector with the same number of elements as range");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5074 }
1331
c04c2a6849e8 [project @ 1995-08-24 01:35:58 by jwe]
jwe
parents: 1321
diff changeset
5075 else if (nr == 0 || nc == 0)
c04c2a6849e8 [project @ 1995-08-24 01:35:58 by jwe]
jwe
parents: 1321
diff changeset
5076 {
c04c2a6849e8 [project @ 1995-08-24 01:35:58 by jwe]
jwe
parents: 1321
diff changeset
5077 ::error ("A(range) = X: X must be a vector with the same");
c04c2a6849e8 [project @ 1995-08-24 01:35:58 by jwe]
jwe
parents: 1321
diff changeset
5078 ::error ("number of elements as range");
c04c2a6849e8 [project @ 1995-08-24 01:35:58 by jwe]
jwe
parents: 1321
diff changeset
5079 }
1299
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5080 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5081 panic_impossible ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5082 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5083 else if (rhs.is_matrix_type ())
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5084 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5085 REP_RHS_MATRIX (rhs, rhs_m, rhs_cm, rhs_nr, rhs_nc);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5086
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5087 int ilen = ri.nelem ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5088 check_vector_assign (rhs_nr, rhs_nc, ilen, "range");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5089 if (error_state)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5090 return;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5091
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5092 force_orient f_orient = no_orient;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5093 if (rhs_nr == 1 && rhs_nc != 1)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5094 f_orient = row_orient;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5095 else if (rhs_nc == 1 && rhs_nr != 1)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5096 f_orient = column_orient;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5097
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5098 maybe_resize (tree_to_mat_idx (ri.max ()), f_orient);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5099 if (error_state)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5100 return;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5101
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5102 int nr = rows ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5103 int nc = columns ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5104
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5105 double b = ri.base ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5106 double increment = ri.inc ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5107
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5108 if (nr == 1)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5109 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5110 for (int i = 0; i < ri.nelem (); i++)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5111 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5112 double tmp = b + i * increment;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5113 int col = tree_to_mat_idx (tmp);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5114 REP_ELEM_ASSIGN (0, col, rhs_m.elem (0, i), rhs_cm.elem (0, i),
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5115 rhs.is_real_type ());
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5116 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5117 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5118 else if (nc == 1)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5119 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5120 for (int i = 0; i < ri.nelem (); i++)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5121 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5122 double tmp = b + i * increment;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5123 int row = tree_to_mat_idx (tmp);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5124 REP_ELEM_ASSIGN (row, 0, rhs_m.elem (i, 0), rhs_cm.elem (i, 0),
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5125 rhs.is_real_type ());
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5126 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5127 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5128 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5129 panic_impossible ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5130 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5131 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5132 panic_impossible ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5133 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5134
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5135 // Matrix assignment indexed by two values. This function determines
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5136 // the type of the first arugment, checks as much as possible, and
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5137 // then calls one of a set of functions to handle the specific cases:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5138 //
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5139 // M (integer, arg2) = RHS (MA1)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5140 // M (vector, arg2) = RHS (MA2)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5141 // M (range, arg2) = RHS (MA3)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5142 // M (colon, arg2) = RHS (MA4)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5143 //
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5144 // Each of those functions determines the type of the second argument
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5145 // and calls another function to handle the real work of doing the
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5146 // assignment.
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5147
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5148 void
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5149 TC_REP::do_matrix_assignment (const tree_constant& rhs,
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5150 const tree_constant& i_arg,
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5151 const tree_constant& j_arg)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5152 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5153 tree_constant tmp_i = i_arg.make_numeric_or_range_or_magic ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5154
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5155 if (error_state)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5156 return;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5157
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5158 TC_REP::constant_type itype = tmp_i.const_type ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5159
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5160 switch (itype)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5161 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5162 case complex_scalar_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5163 case scalar_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5164 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5165 int i = tree_to_mat_idx (tmp_i.double_value ());
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5166 do_matrix_assignment (rhs, i, j_arg);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5167 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5168 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5169
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5170 case complex_matrix_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5171 case matrix_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5172 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5173 Matrix mi = tmp_i.matrix_value ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5174 idx_vector iv (mi, user_pref.do_fortran_indexing, "row", rows ());
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5175 if (! iv)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5176 return;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5177
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5178 do_matrix_assignment (rhs, iv, j_arg);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5179 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5180 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5181
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5182 case string_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5183 gripe_string_invalid ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5184 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5185
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5186 case range_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5187 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5188 Range ri = tmp_i.range_value ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5189 int nr = rows ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5190 if (nr == 2 && is_zero_one (ri))
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5191 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5192 do_matrix_assignment (rhs, 1, j_arg);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5193 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5194 else if (nr == 2 && is_one_zero (ri))
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5195 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5196 do_matrix_assignment (rhs, 0, j_arg);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5197 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5198 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5199 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5200 if (index_check (ri, "row") < 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5201 return;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5202 do_matrix_assignment (rhs, ri, j_arg);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5203 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5204 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5205 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5206
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5207 case magic_colon:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5208 do_matrix_assignment (rhs, magic_colon, j_arg);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5209 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5210
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5211 default:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5212 panic_impossible ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5213 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5214 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5215 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5216
1358
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1355
diff changeset
5217 // -*- MA1 -*-
1299
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5218 void
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5219 TC_REP::do_matrix_assignment (const tree_constant& rhs, int i,
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5220 const tree_constant& j_arg)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5221 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5222 tree_constant tmp_j = j_arg.make_numeric_or_range_or_magic ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5223
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5224 if (error_state)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5225 return;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5226
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5227 TC_REP::constant_type jtype = tmp_j.const_type ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5228
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5229 int rhs_nr = rhs.rows ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5230 int rhs_nc = rhs.columns ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5231
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5232 switch (jtype)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5233 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5234 case complex_scalar_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5235 case scalar_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5236 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5237 if (index_check (i, "row") < 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5238 return;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5239 int j = tree_to_mat_idx (tmp_j.double_value ());
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5240 if (index_check (j, "column") < 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5241 return;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5242 if (! indexed_assign_conforms (1, 1, rhs_nr, rhs_nc))
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5243 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5244 ::error ("A(int,int) = X, X must be a scalar");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5245 return;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5246 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5247 maybe_resize (i, j);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5248 if (error_state)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5249 return;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5250
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5251 do_matrix_assignment (rhs, i, j);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5252 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5253 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5254
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5255 case complex_matrix_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5256 case matrix_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5257 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5258 if (index_check (i, "row") < 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5259 return;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5260 Matrix mj = tmp_j.matrix_value ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5261 idx_vector jv (mj, user_pref.do_fortran_indexing, "column",
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5262 columns ());
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5263 if (! jv)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5264 return;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5265
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5266 if (! indexed_assign_conforms (1, jv.capacity (), rhs_nr, rhs_nc))
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5267 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5268 ::error ("A(int,matrix) = X: X must be a row vector with the same");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5269 ::error ("number of elements as matrix");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5270 return;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5271 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5272 maybe_resize (i, jv.max ());
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5273 if (error_state)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5274 return;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5275
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5276 do_matrix_assignment (rhs, i, jv);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5277 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5278 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5279
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5280 case string_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5281 gripe_string_invalid ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5282 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5283
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5284 case range_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5285 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5286 if (index_check (i, "row") < 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5287 return;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5288 Range rj = tmp_j.range_value ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5289 if (! indexed_assign_conforms (1, rj.nelem (), rhs_nr, rhs_nc))
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5290 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5291 ::error ("A(int,range) = X: X must be a row vector with the same");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5292 ::error ("number of elements as range");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5293 return;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5294 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5295
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5296 int nc = columns ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5297 if (nc == 2 && is_zero_one (rj) && rhs_nc == 1)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5298 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5299 do_matrix_assignment (rhs, i, 1);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5300 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5301 else if (nc == 2 && is_one_zero (rj) && rhs_nc == 1)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5302 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5303 do_matrix_assignment (rhs, i, 0);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5304 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5305 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5306 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5307 if (index_check (rj, "column") < 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5308 return;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5309 maybe_resize (i, tree_to_mat_idx (rj.max ()));
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5310 if (error_state)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5311 return;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5312
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5313 do_matrix_assignment (rhs, i, rj);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5314 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5315 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5316 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5317
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5318 case magic_colon:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5319 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5320 int nc = columns ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5321 int nr = rows ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5322 if (i == -1 && nr == 1 && rhs_nr == 0 && rhs_nc == 0
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5323 || index_check (i, "row") < 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5324 return;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5325 else if (nc == 0 && nr == 0 && rhs_nr == 1)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5326 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5327 if (rhs.is_complex_type ())
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5328 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5329 complex_matrix = new ComplexMatrix ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5330 type_tag = complex_matrix_constant;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5331 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5332 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5333 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5334 matrix = new Matrix ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5335 type_tag = matrix_constant;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5336 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5337 maybe_resize (i, rhs_nc-1);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5338 if (error_state)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5339 return;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5340 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5341 else if (indexed_assign_conforms (1, nc, rhs_nr, rhs_nc))
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5342 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5343 maybe_resize (i, nc-1);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5344 if (error_state)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5345 return;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5346 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5347 else if (rhs_nr == 0 && rhs_nc == 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5348 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5349 if (i < 0 || i >= nr)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5350 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5351 ::error ("A(int,:) = []: row index out of range");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5352 return;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5353 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5354 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5355 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5356 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5357 ::error ("A(int,:) = X: X must be a row vector with the same");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5358 ::error ("number of columns as A");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5359 return;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5360 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5361
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5362 do_matrix_assignment (rhs, i, magic_colon);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5363 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5364 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5365
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5366 default:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5367 panic_impossible ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5368 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5369 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5370 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5371
1358
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1355
diff changeset
5372 // -*- MA2 -*-
1299
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5373 void
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5374 TC_REP::do_matrix_assignment (const tree_constant& rhs,
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5375 idx_vector& iv, const tree_constant& j_arg)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5376 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5377 tree_constant tmp_j = j_arg.make_numeric_or_range_or_magic ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5378
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5379 if (error_state)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5380 return;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5381
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5382 TC_REP::constant_type jtype = tmp_j.const_type ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5383
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5384 int rhs_nr = rhs.rows ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5385 int rhs_nc = rhs.columns ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5386
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5387 switch (jtype)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5388 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5389 case complex_scalar_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5390 case scalar_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5391 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5392 int j = tree_to_mat_idx (tmp_j.double_value ());
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5393 if (index_check (j, "column") < 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5394 return;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5395 if (! indexed_assign_conforms (iv.capacity (), 1, rhs_nr, rhs_nc))
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5396 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5397 ::error ("A(matrix,int) = X: X must be a column vector with the");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5398 ::error ("same number of elements as matrix");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5399 return;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5400 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5401 maybe_resize (iv.max (), j);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5402 if (error_state)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5403 return;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5404
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5405 do_matrix_assignment (rhs, iv, j);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5406 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5407 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5408
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5409 case complex_matrix_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5410 case matrix_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5411 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5412 Matrix mj = tmp_j.matrix_value ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5413 idx_vector jv (mj, user_pref.do_fortran_indexing, "column",
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5414 columns ());
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5415 if (! jv)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5416 return;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5417
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5418 if (! indexed_assign_conforms (iv.capacity (), jv.capacity (),
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5419 rhs_nr, rhs_nc))
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5420 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5421 ::error ("A(r_mat,c_mat) = X: the number of rows in X must match");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5422 ::error ("the number of elements in r_mat and the number of");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5423 ::error ("columns in X must match the number of elements in c_mat");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5424 return;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5425 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5426 maybe_resize (iv.max (), jv.max ());
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5427 if (error_state)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5428 return;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5429
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5430 do_matrix_assignment (rhs, iv, jv);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5431 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5432 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5433
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5434 case string_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5435 gripe_string_invalid ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5436 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5437
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5438 case range_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5439 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5440 Range rj = tmp_j.range_value ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5441 if (! indexed_assign_conforms (iv.capacity (), rj.nelem (),
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5442 rhs_nr, rhs_nc))
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5443 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5444 ::error ("A(matrix,range) = X: the number of rows in X must match");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5445 ::error ("the number of elements in matrix and the number of");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5446 ::error ("columns in X must match the number of elements in range");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5447 return;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5448 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5449
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5450 int nc = columns ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5451 if (nc == 2 && is_zero_one (rj) && rhs_nc == 1)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5452 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5453 do_matrix_assignment (rhs, iv, 1);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5454 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5455 else if (nc == 2 && is_one_zero (rj) && rhs_nc == 1)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5456 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5457 do_matrix_assignment (rhs, iv, 0);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5458 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5459 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5460 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5461 if (index_check (rj, "column") < 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5462 return;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5463 maybe_resize (iv.max (), tree_to_mat_idx (rj.max ()));
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5464 if (error_state)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5465 return;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5466
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5467 do_matrix_assignment (rhs, iv, rj);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5468 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5469 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5470 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5471
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5472 case magic_colon:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5473 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5474 int nc = columns ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5475 int new_nc = nc;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5476 if (nc == 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5477 new_nc = rhs_nc;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5478
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5479 if (indexed_assign_conforms (iv.capacity (), new_nc,
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5480 rhs_nr, rhs_nc))
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5481 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5482 maybe_resize (iv.max (), new_nc-1);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5483 if (error_state)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5484 return;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5485 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5486 else if (rhs_nr == 0 && rhs_nc == 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5487 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5488 if (iv.max () >= rows ())
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5489 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5490 ::error ("A(matrix,:) = []: row index out of range");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5491 return;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5492 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5493 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5494 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5495 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5496 ::error ("A(matrix,:) = X: the number of rows in X must match the");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5497 ::error ("number of elements in matrix, and the number of columns");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5498 ::error ("in X must match the number of columns in A");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5499 return;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5500 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5501
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5502 do_matrix_assignment (rhs, iv, magic_colon);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5503 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5504 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5505
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5506 default:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5507 panic_impossible ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5508 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5509 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5510 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5511
1358
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1355
diff changeset
5512 // -*- MA3 -*-
1299
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5513 void
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5514 TC_REP::do_matrix_assignment (const tree_constant& rhs, Range& ri,
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5515 const tree_constant& j_arg)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5516 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5517 tree_constant tmp_j = j_arg.make_numeric_or_range_or_magic ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5518
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5519 if (error_state)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5520 return;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5521
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5522 TC_REP::constant_type jtype = tmp_j.const_type ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5523
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5524 int rhs_nr = rhs.rows ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5525 int rhs_nc = rhs.columns ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5526
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5527 switch (jtype)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5528 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5529 case complex_scalar_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5530 case scalar_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5531 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5532 int j = tree_to_mat_idx (tmp_j.double_value ());
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5533 if (index_check (j, "column") < 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5534 return;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5535 if (! indexed_assign_conforms (ri.nelem (), 1, rhs_nr, rhs_nc))
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5536 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5537 ::error ("A(range,int) = X: X must be a column vector with the");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5538 ::error ("same number of elements as range");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5539 return;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5540 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5541 maybe_resize (tree_to_mat_idx (ri.max ()), j);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5542 if (error_state)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5543 return;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5544
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5545 do_matrix_assignment (rhs, ri, j);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5546 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5547 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5548
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5549 case complex_matrix_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5550 case matrix_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5551 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5552 Matrix mj = tmp_j.matrix_value ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5553 idx_vector jv (mj, user_pref.do_fortran_indexing, "column",
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5554 columns ());
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5555 if (! jv)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5556 return;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5557
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5558 if (! indexed_assign_conforms (ri.nelem (), jv.capacity (),
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5559 rhs_nr, rhs_nc))
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5560 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5561 ::error ("A(range,matrix) = X: the number of rows in X must match");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5562 ::error ("the number of elements in range and the number of");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5563 ::error ("columns in X must match the number of elements in matrix");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5564 return;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5565 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5566 maybe_resize (tree_to_mat_idx (ri.max ()), jv.max ());
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5567 if (error_state)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5568 return;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5569
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5570 do_matrix_assignment (rhs, ri, jv);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5571 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5572 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5573
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5574 case string_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5575 gripe_string_invalid ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5576 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5577
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5578 case range_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5579 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5580 Range rj = tmp_j.range_value ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5581 if (! indexed_assign_conforms (ri.nelem (), rj.nelem (),
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5582 rhs_nr, rhs_nc))
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5583 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5584 ::error ("A(r_range,c_range) = X: the number of rows in X must");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5585 ::error ("match the number of elements in r_range and the number");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5586 ::error ("of columns in X must match the number of elements in");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5587 ::error ("c_range");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5588 return;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5589 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5590
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5591 int nc = columns ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5592 if (nc == 2 && is_zero_one (rj) && rhs_nc == 1)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5593 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5594 do_matrix_assignment (rhs, ri, 1);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5595 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5596 else if (nc == 2 && is_one_zero (rj) && rhs_nc == 1)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5597 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5598 do_matrix_assignment (rhs, ri, 0);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5599 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5600 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5601 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5602 if (index_check (rj, "column") < 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5603 return;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5604
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5605 maybe_resize (tree_to_mat_idx (ri.max ()),
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5606 tree_to_mat_idx (rj.max ()));
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5607
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5608 if (error_state)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5609 return;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5610
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5611 do_matrix_assignment (rhs, ri, rj);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5612 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5613 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5614 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5615
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5616 case magic_colon:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5617 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5618 int nc = columns ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5619 int new_nc = nc;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5620 if (nc == 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5621 new_nc = rhs_nc;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5622
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5623 if (indexed_assign_conforms (ri.nelem (), new_nc, rhs_nr, rhs_nc))
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5624 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5625 maybe_resize (tree_to_mat_idx (ri.max ()), new_nc-1);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5626 if (error_state)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5627 return;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5628 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5629 else if (rhs_nr == 0 && rhs_nc == 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5630 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5631 int b = tree_to_mat_idx (ri.min ());
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5632 int l = tree_to_mat_idx (ri.max ());
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5633 if (b < 0 || l >= rows ())
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5634 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5635 ::error ("A(range,:) = []: row index out of range");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5636 return;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5637 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5638 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5639 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5640 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5641 ::error ("A(range,:) = X: the number of rows in X must match the");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5642 ::error ("number of elements in range, and the number of columns");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5643 ::error ("in X must match the number of columns in A");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5644 return;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5645 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5646
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5647 do_matrix_assignment (rhs, ri, magic_colon);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5648 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5649 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5650
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5651 default:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5652 panic_impossible ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5653 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5654 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5655 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5656
1358
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1355
diff changeset
5657 // -*- MA4 -*-
1299
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5658 void
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5659 TC_REP::do_matrix_assignment (const tree_constant& rhs,
1488
89c587478067 [project @ 1995-09-26 22:49:48 by jwe]
jwe
parents: 1430
diff changeset
5660 TC_REP::constant_type /* i */,
1299
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5661 const tree_constant& j_arg)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5662 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5663 tree_constant tmp_j = j_arg.make_numeric_or_range_or_magic ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5664
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5665 if (error_state)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5666 return;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5667
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5668 TC_REP::constant_type jtype = tmp_j.const_type ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5669
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5670 int rhs_nr = rhs.rows ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5671 int rhs_nc = rhs.columns ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5672
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5673 switch (jtype)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5674 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5675 case complex_scalar_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5676 case scalar_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5677 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5678 int j = tree_to_mat_idx (tmp_j.double_value ());
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5679 int nr = rows ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5680 int nc = columns ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5681 if (j == -1 && nc == 1 && rhs_nr == 0 && rhs_nc == 0
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5682 || index_check (j, "column") < 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5683 return;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5684 if (nr == 0 && nc == 0 && rhs_nc == 1)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5685 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5686 if (rhs.is_complex_type ())
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5687 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5688 complex_matrix = new ComplexMatrix ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5689 type_tag = complex_matrix_constant;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5690 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5691 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5692 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5693 matrix = new Matrix ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5694 type_tag = matrix_constant;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5695 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5696 maybe_resize (rhs_nr-1, j);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5697 if (error_state)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5698 return;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5699 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5700 else if (indexed_assign_conforms (nr, 1, rhs_nr, rhs_nc))
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5701 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5702 maybe_resize (nr-1, j);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5703 if (error_state)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5704 return;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5705 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5706 else if (rhs_nr == 0 && rhs_nc == 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5707 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5708 if (j < 0 || j >= nc)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5709 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5710 ::error ("A(:,int) = []: column index out of range");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5711 return;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5712 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5713 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5714 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5715 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5716 ::error ("A(:,int) = X: X must be a column vector with the same");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5717 ::error ("number of rows as A");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5718 return;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5719 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5720
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5721 do_matrix_assignment (rhs, magic_colon, j);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5722 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5723 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5724
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5725 case complex_matrix_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5726 case matrix_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5727 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5728 Matrix mj = tmp_j.matrix_value ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5729 idx_vector jv (mj, user_pref.do_fortran_indexing, "column",
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5730 columns ());
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5731 if (! jv)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5732 return;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5733
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5734 int nr = rows ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5735 int new_nr = nr;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5736 if (nr == 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5737 new_nr = rhs_nr;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5738
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5739 if (indexed_assign_conforms (new_nr, jv.capacity (),
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5740 rhs_nr, rhs_nc))
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5741 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5742 maybe_resize (new_nr-1, jv.max ());
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5743 if (error_state)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5744 return;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5745 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5746 else if (rhs_nr == 0 && rhs_nc == 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5747 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5748 if (jv.max () >= columns ())
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5749 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5750 ::error ("A(:,matrix) = []: column index out of range");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5751 return;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5752 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5753 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5754 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5755 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5756 ::error ("A(:,matrix) = X: the number of rows in X must match the");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5757 ::error ("number of rows in A, and the number of columns in X must");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5758 ::error ("match the number of elements in matrix");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5759 return;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5760 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5761
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5762 do_matrix_assignment (rhs, magic_colon, jv);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5763 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5764 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5765
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5766 case string_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5767 gripe_string_invalid ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5768 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5769
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5770 case range_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5771 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5772 Range rj = tmp_j.range_value ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5773 int nr = rows ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5774 int new_nr = nr;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5775 if (nr == 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5776 new_nr = rhs_nr;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5777
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5778 if (indexed_assign_conforms (new_nr, rj.nelem (), rhs_nr, rhs_nc))
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5779 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5780 int nc = columns ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5781 if (nc == 2 && is_zero_one (rj) && rhs_nc == 1)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5782 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5783 do_matrix_assignment (rhs, magic_colon, 1);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5784 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5785 else if (nc == 2 && is_one_zero (rj) && rhs_nc == 1)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5786 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5787 do_matrix_assignment (rhs, magic_colon, 0);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5788 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5789 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5790 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5791 if (index_check (rj, "column") < 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5792 return;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5793 maybe_resize (new_nr-1, tree_to_mat_idx (rj.max ()));
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5794 if (error_state)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5795 return;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5796 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5797 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5798 else if (rhs_nr == 0 && rhs_nc == 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5799 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5800 int b = tree_to_mat_idx (rj.min ());
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5801 int l = tree_to_mat_idx (rj.max ());
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5802 if (b < 0 || l >= columns ())
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5803 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5804 ::error ("A(:,range) = []: column index out of range");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5805 return;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5806 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5807 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5808 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5809 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5810 ::error ("A(:,range) = X: the number of rows in X must match the");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5811 ::error ("number of rows in A, and the number of columns in X");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5812 ::error ("must match the number of elements in range");
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5813 return;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5814 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5815
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5816 do_matrix_assignment (rhs, magic_colon, rj);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5817 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5818 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5819
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5820 case magic_colon:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5821 // a(:,:) = foo is equivalent to a = foo.
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5822 do_matrix_assignment (rhs, magic_colon, magic_colon);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5823 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5824
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5825 default:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5826 panic_impossible ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5827 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5828 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5829 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5830
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5831 // Functions that actually handle assignment to a matrix using two
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5832 // index values.
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5833 //
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5834 // idx2
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5835 // +---+---+----+----+
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5836 // idx1 | i | v | r | c |
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5837 // ---------+---+---+----+----+
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5838 // integer | 1 | 5 | 9 | 13 |
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5839 // ---------+---+---+----+----+
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5840 // vector | 2 | 6 | 10 | 14 |
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5841 // ---------+---+---+----+----+
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5842 // range | 3 | 7 | 11 | 15 |
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5843 // ---------+---+---+----+----+
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5844 // colon | 4 | 8 | 12 | 16 |
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5845 // ---------+---+---+----+----+
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5846
1358
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1355
diff changeset
5847 // -*- 1 -*-
1299
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5848 void
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5849 TC_REP::do_matrix_assignment (const tree_constant& rhs, int i, int j)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5850 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5851 REP_ELEM_ASSIGN (i, j, rhs.double_value (), rhs.complex_value (),
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5852 rhs.is_real_type ());
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5853 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5854
1358
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1355
diff changeset
5855 // -*- 2 -*-
1299
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5856 void
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5857 TC_REP::do_matrix_assignment (const tree_constant& rhs, int i, idx_vector& jv)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5858 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5859 REP_RHS_MATRIX (rhs, rhs_m, rhs_cm, rhs_nr, rhs_nc);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5860
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5861 for (int j = 0; j < jv.capacity (); j++)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5862 REP_ELEM_ASSIGN (i, jv.elem (j), rhs_m.elem (0, j),
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5863 rhs_cm.elem (0, j), rhs.is_real_type ());
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5864 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5865
1358
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1355
diff changeset
5866 // -*- 3 -*-
1299
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5867 void
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5868 TC_REP::do_matrix_assignment (const tree_constant& rhs, int i, Range& rj)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5869 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5870 REP_RHS_MATRIX (rhs, rhs_m, rhs_cm, rhs_nr, rhs_nc);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5871
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5872 double b = rj.base ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5873 double increment = rj.inc ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5874
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5875 for (int j = 0; j < rj.nelem (); j++)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5876 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5877 double tmp = b + j * increment;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5878 int col = tree_to_mat_idx (tmp);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5879 REP_ELEM_ASSIGN (i, col, rhs_m.elem (0, j), rhs_cm.elem (0, j),
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5880 rhs.is_real_type ());
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5881 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5882 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5883
1358
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1355
diff changeset
5884 // -*- 4 -*-
1299
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5885 void
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5886 TC_REP::do_matrix_assignment (const tree_constant& rhs, int i,
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5887 TC_REP::constant_type mcj)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5888 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5889 assert (mcj == magic_colon);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5890
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5891 int nc = columns ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5892
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5893 if (rhs.is_zero_by_zero ())
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5894 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5895 delete_row (i);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5896 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5897 else if (rhs.is_matrix_type ())
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5898 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5899 REP_RHS_MATRIX (rhs, rhs_m, rhs_cm, rhs_nr, rhs_nc);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5900
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5901 for (int j = 0; j < nc; j++)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5902 REP_ELEM_ASSIGN (i, j, rhs_m.elem (0, j), rhs_cm.elem (0, j),
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5903 rhs.is_real_type ());
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5904 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5905 else if (rhs.is_scalar_type () && nc == 1)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5906 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5907 REP_ELEM_ASSIGN (i, 0, rhs.double_value (),
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5908 rhs.complex_value (), rhs.is_real_type ());
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5909 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5910 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5911 panic_impossible ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5912 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5913
1358
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1355
diff changeset
5914 // -*- 5 -*-
1299
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5915 void
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5916 TC_REP::do_matrix_assignment (const tree_constant& rhs,
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5917 idx_vector& iv, int j)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5918 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5919 REP_RHS_MATRIX (rhs, rhs_m, rhs_cm, rhs_nr, rhs_nc);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5920
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5921 for (int i = 0; i < iv.capacity (); i++)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5922 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5923 int row = iv.elem (i);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5924 REP_ELEM_ASSIGN (row, j, rhs_m.elem (i, 0),
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5925 rhs_cm.elem (i, 0), rhs.is_real_type ());
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5926 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5927 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5928
1358
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1355
diff changeset
5929 // -*- 6 -*-
1299
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5930 void
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5931 TC_REP::do_matrix_assignment (const tree_constant& rhs,
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5932 idx_vector& iv, idx_vector& jv)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5933 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5934 REP_RHS_MATRIX (rhs, rhs_m, rhs_cm, rhs_nr, rhs_nc);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5935
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5936 for (int i = 0; i < iv.capacity (); i++)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5937 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5938 int row = iv.elem (i);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5939 for (int j = 0; j < jv.capacity (); j++)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5940 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5941 int col = jv.elem (j);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5942 REP_ELEM_ASSIGN (row, col, rhs_m.elem (i, j),
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5943 rhs_cm.elem (i, j), rhs.is_real_type ());
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5944 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5945 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5946 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5947
1358
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1355
diff changeset
5948 // -*- 7 -*-
1299
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5949 void
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5950 TC_REP::do_matrix_assignment (const tree_constant& rhs,
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5951 idx_vector& iv, Range& rj)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5952 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5953 REP_RHS_MATRIX (rhs, rhs_m, rhs_cm, rhs_nr, rhs_nc);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5954
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5955 double b = rj.base ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5956 double increment = rj.inc ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5957
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5958 for (int i = 0; i < iv.capacity (); i++)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5959 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5960 int row = iv.elem (i);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5961 for (int j = 0; j < rj.nelem (); j++)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5962 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5963 double tmp = b + j * increment;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5964 int col = tree_to_mat_idx (tmp);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5965 REP_ELEM_ASSIGN (row, col, rhs_m.elem (i, j),
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5966 rhs_cm.elem (i, j), rhs.is_real_type ());
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5967 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5968 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5969 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5970
1358
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1355
diff changeset
5971 // -*- 8 -*-
1299
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5972 void
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5973 TC_REP::do_matrix_assignment (const tree_constant& rhs,
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5974 idx_vector& iv, TC_REP::constant_type mcj)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5975 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5976 assert (mcj == magic_colon);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5977
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5978 if (rhs.is_zero_by_zero ())
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5979 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5980 delete_rows (iv);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5981 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5982 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5983 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5984 REP_RHS_MATRIX (rhs, rhs_m, rhs_cm, rhs_nr, rhs_nc);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5985
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5986 int nc = columns ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5987
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5988 for (int j = 0; j < nc; j++)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5989 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5990 for (int i = 0; i < iv.capacity (); i++)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5991 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5992 int row = iv.elem (i);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5993 REP_ELEM_ASSIGN (row, j, rhs_m.elem (i, j),
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5994 rhs_cm.elem (i, j), rhs.is_real_type ());
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5995 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5996 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5997 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5998 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
5999
1358
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1355
diff changeset
6000 // -*- 9 -*-
1299
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6001 void
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6002 TC_REP::do_matrix_assignment (const tree_constant& rhs, Range& ri, int j)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6003 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6004 REP_RHS_MATRIX (rhs, rhs_m, rhs_cm, rhs_nr, rhs_nc);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6005
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6006 double b = ri.base ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6007 double increment = ri.inc ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6008
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6009 for (int i = 0; i < ri.nelem (); i++)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6010 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6011 double tmp = b + i * increment;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6012 int row = tree_to_mat_idx (tmp);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6013 REP_ELEM_ASSIGN (row, j, rhs_m.elem (i, 0),
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6014 rhs_cm.elem (i, 0), rhs.is_real_type ());
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6015 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6016 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6017
1358
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1355
diff changeset
6018 // -*- 10 -*-
1299
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6019 void
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6020 TC_REP::do_matrix_assignment (const tree_constant& rhs,
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6021 Range& ri, idx_vector& jv)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6022 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6023 REP_RHS_MATRIX (rhs, rhs_m, rhs_cm, rhs_nr, rhs_nc);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6024
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6025 double b = ri.base ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6026 double increment = ri.inc ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6027
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6028 for (int j = 0; j < jv.capacity (); j++)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6029 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6030 int col = jv.elem (j);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6031 for (int i = 0; i < ri.nelem (); i++)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6032 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6033 double tmp = b + i * increment;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6034 int row = tree_to_mat_idx (tmp);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6035 REP_ELEM_ASSIGN (row, col, rhs_m.elem (i, j),
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6036 rhs_m.elem (i, j), rhs.is_real_type ());
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6037 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6038 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6039 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6040
1358
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1355
diff changeset
6041 // -*- 11 -*-
1299
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6042 void
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6043 TC_REP::do_matrix_assignment (const tree_constant& rhs,
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6044 Range& ri, Range& rj)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6045 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6046 double ib = ri.base ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6047 double iinc = ri.inc ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6048 double jb = rj.base ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6049 double jinc = rj.inc ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6050
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6051 REP_RHS_MATRIX (rhs, rhs_m, rhs_cm, rhs_nr, rhs_nc);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6052
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6053 for (int i = 0; i < ri.nelem (); i++)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6054 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6055 double itmp = ib + i * iinc;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6056 int row = tree_to_mat_idx (itmp);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6057 for (int j = 0; j < rj.nelem (); j++)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6058 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6059 double jtmp = jb + j * jinc;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6060 int col = tree_to_mat_idx (jtmp);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6061 REP_ELEM_ASSIGN (row, col, rhs_m.elem (i, j),
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6062 rhs_cm.elem (i, j), rhs.is_real_type ());
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6063 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6064 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6065 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6066
1358
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1355
diff changeset
6067 // -*- 12 -*-
1299
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6068 void
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6069 TC_REP::do_matrix_assignment (const tree_constant& rhs,
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6070 Range& ri, TC_REP::constant_type mcj)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6071 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6072 assert (mcj == magic_colon);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6073
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6074 if (rhs.is_zero_by_zero ())
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6075 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6076 delete_rows (ri);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6077 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6078 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6079 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6080 REP_RHS_MATRIX (rhs, rhs_m, rhs_cm, rhs_nr, rhs_nc);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6081
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6082 double ib = ri.base ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6083 double iinc = ri.inc ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6084
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6085 int nc = columns ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6086
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6087 for (int i = 0; i < ri.nelem (); i++)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6088 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6089 double itmp = ib + i * iinc;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6090 int row = tree_to_mat_idx (itmp);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6091 for (int j = 0; j < nc; j++)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6092 REP_ELEM_ASSIGN (row, j, rhs_m.elem (i, j),
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6093 rhs_cm.elem (i, j), rhs.is_real_type ());
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6094 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6095 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6096 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6097
1358
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1355
diff changeset
6098 // -*- 13 -*-
1299
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6099 void
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6100 TC_REP::do_matrix_assignment (const tree_constant& rhs,
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6101 TC_REP::constant_type mci, int j)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6102 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6103 assert (mci == magic_colon);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6104
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6105 int nr = rows ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6106
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6107 if (rhs.is_zero_by_zero ())
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6108 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6109 delete_column (j);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6110 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6111 else if (rhs.is_matrix_type ())
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6112 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6113 REP_RHS_MATRIX (rhs, rhs_m, rhs_cm, rhs_nr, rhs_nc);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6114
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6115 for (int i = 0; i < nr; i++)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6116 REP_ELEM_ASSIGN (i, j, rhs_m.elem (i, 0),
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6117 rhs_cm.elem (i, 0), rhs.is_real_type ());
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6118 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6119 else if (rhs.is_scalar_type () && nr == 1)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6120 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6121 REP_ELEM_ASSIGN (0, j, rhs.double_value (),
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6122 rhs.complex_value (), rhs.is_real_type ());
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6123 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6124 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6125 panic_impossible ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6126 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6127
1358
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1355
diff changeset
6128 // -*- 14 -*-
1299
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6129 void
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6130 TC_REP::do_matrix_assignment (const tree_constant& rhs,
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6131 TC_REP::constant_type mci, idx_vector& jv)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6132 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6133 assert (mci == magic_colon);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6134
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6135 if (rhs.is_zero_by_zero ())
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6136 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6137 delete_columns (jv);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6138 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6139 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6140 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6141 REP_RHS_MATRIX (rhs, rhs_m, rhs_cm, rhs_nr, rhs_nc);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6142
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6143 int nr = rows ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6144
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6145 for (int i = 0; i < nr; i++)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6146 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6147 for (int j = 0; j < jv.capacity (); j++)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6148 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6149 int col = jv.elem (j);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6150 REP_ELEM_ASSIGN (i, col, rhs_m.elem (i, j),
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6151 rhs_cm.elem (i, j), rhs.is_real_type ());
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6152 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6153 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6154 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6155 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6156
1358
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1355
diff changeset
6157 // -*- 15 -*-
1299
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6158 void
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6159 TC_REP::do_matrix_assignment (const tree_constant& rhs,
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6160 TC_REP::constant_type mci, Range& rj)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6161 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6162 assert (mci == magic_colon);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6163
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6164 if (rhs.is_zero_by_zero ())
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6165 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6166 delete_columns (rj);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6167 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6168 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6169 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6170 REP_RHS_MATRIX (rhs, rhs_m, rhs_cm, rhs_nr, rhs_nc);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6171
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6172 int nr = rows ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6173
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6174 double jb = rj.base ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6175 double jinc = rj.inc ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6176
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6177 for (int j = 0; j < rj.nelem (); j++)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6178 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6179 double jtmp = jb + j * jinc;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6180 int col = tree_to_mat_idx (jtmp);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6181 for (int i = 0; i < nr; i++)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6182 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6183 REP_ELEM_ASSIGN (i, col, rhs_m.elem (i, j),
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6184 rhs_cm.elem (i, j), rhs.is_real_type ());
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6185 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6186 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6187 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6188 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6189
1358
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1355
diff changeset
6190 // -*- 16 -*-
1299
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6191 void
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6192 TC_REP::do_matrix_assignment (const tree_constant& rhs,
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6193 TC_REP::constant_type mci,
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6194 TC_REP::constant_type mcj)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6195 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6196 assert (mci == magic_colon && mcj == magic_colon);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6197
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6198 switch (type_tag)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6199 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6200 case scalar_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6201 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6202
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6203 case matrix_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6204 delete matrix;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6205 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6206
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6207 case complex_scalar_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6208 delete complex_scalar;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6209 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6210
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6211 case complex_matrix_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6212 delete complex_matrix;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6213 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6214
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6215 case string_constant:
1355
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
6216 delete str_obj;
1299
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6217 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6218
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6219 case range_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6220 delete range;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6221 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6222
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6223 case magic_colon:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6224 default:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6225 panic_impossible ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6226 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6227 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6228
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6229 type_tag = rhs.const_type ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6230
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6231 switch (type_tag)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6232 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6233 case scalar_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6234 scalar = rhs.double_value ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6235 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6236
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6237 case matrix_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6238 matrix = new Matrix (rhs.matrix_value ());
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6239 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6240
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6241 case string_constant:
1355
94697d007075 [project @ 1995-09-05 20:04:15 by jwe]
jwe
parents: 1331
diff changeset
6242 str_obj = new Octave_str_obj (rhs.string_value ());
1299
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6243 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6244
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6245 case complex_matrix_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6246 complex_matrix = new ComplexMatrix (rhs.complex_matrix_value ());
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6247 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6248
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6249 case complex_scalar_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6250 complex_scalar = new Complex (rhs.complex_value ());
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6251 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6252
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6253 case range_constant:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6254 range = new Range (rhs.range_value ());
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6255 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6256
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6257 case magic_colon:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6258 default:
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6259 panic_impossible ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6260 break;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6261 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6262 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6263
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6264 // Functions for deleting rows or columns of a matrix. These are used
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6265 // to handle statements like
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6266 //
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6267 // M (i, j) = []
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6268
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6269 void
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6270 TC_REP::delete_row (int idx)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6271 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6272 if (type_tag == matrix_constant)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6273 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6274 int nr = matrix->rows ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6275 int nc = matrix->columns ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6276 Matrix *new_matrix = new Matrix (nr-1, nc);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6277 int ii = 0;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6278 for (int i = 0; i < nr; i++)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6279 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6280 if (i != idx)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6281 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6282 for (int j = 0; j < nc; j++)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6283 new_matrix->elem (ii, j) = matrix->elem (i, j);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6284 ii++;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6285 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6286 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6287 delete matrix;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6288 matrix = new_matrix;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6289 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6290 else if (type_tag == complex_matrix_constant)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6291 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6292 int nr = complex_matrix->rows ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6293 int nc = complex_matrix->columns ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6294 ComplexMatrix *new_matrix = new ComplexMatrix (nr-1, nc);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6295 int ii = 0;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6296 for (int i = 0; i < nr; i++)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6297 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6298 if (i != idx)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6299 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6300 for (int j = 0; j < nc; j++)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6301 new_matrix->elem (ii, j) = complex_matrix->elem (i, j);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6302 ii++;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6303 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6304 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6305 delete complex_matrix;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6306 complex_matrix = new_matrix;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6307 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6308 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6309 panic_impossible ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6310 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6311
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6312 void
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6313 TC_REP::delete_rows (idx_vector& iv)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6314 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6315 iv.sort_uniq ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6316 int num_to_delete = iv.length ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6317
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6318 if (num_to_delete == 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6319 return;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6320
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6321 int nr = rows ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6322 int nc = columns ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6323
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6324 // If deleting all rows of a column vector, make result 0x0.
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6325 if (nc == 1 && num_to_delete == nr)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6326 nc = 0;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6327
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6328 if (type_tag == matrix_constant)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6329 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6330 Matrix *new_matrix = new Matrix (nr-num_to_delete, nc);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6331 if (nr > num_to_delete)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6332 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6333 int ii = 0;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6334 int idx = 0;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6335 for (int i = 0; i < nr; i++)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6336 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6337 if (i == iv.elem (idx))
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6338 idx++;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6339 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6340 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6341 for (int j = 0; j < nc; j++)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6342 new_matrix->elem (ii, j) = matrix->elem (i, j);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6343 ii++;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6344 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6345 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6346 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6347 delete matrix;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6348 matrix = new_matrix;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6349 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6350 else if (type_tag == complex_matrix_constant)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6351 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6352 ComplexMatrix *new_matrix = new ComplexMatrix (nr-num_to_delete, nc);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6353 if (nr > num_to_delete)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6354 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6355 int ii = 0;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6356 int idx = 0;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6357 for (int i = 0; i < nr; i++)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6358 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6359 if (i == iv.elem (idx))
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6360 idx++;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6361 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6362 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6363 for (int j = 0; j < nc; j++)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6364 new_matrix->elem (ii, j) = complex_matrix->elem (i, j);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6365 ii++;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6366 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6367 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6368 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6369 delete complex_matrix;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6370 complex_matrix = new_matrix;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6371 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6372 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6373 panic_impossible ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6374 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6375
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6376 void
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6377 TC_REP::delete_rows (Range& ri)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6378 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6379 ri.sort ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6380 int num_to_delete = ri.nelem ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6381
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6382 if (num_to_delete == 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6383 return;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6384
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6385 int nr = rows ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6386 int nc = columns ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6387
1358
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1355
diff changeset
6388 // If deleting all rows of a column vector, make result 0x0.
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1355
diff changeset
6389
1299
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6390 if (nc == 1 && num_to_delete == nr)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6391 nc = 0;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6392
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6393 double ib = ri.base ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6394 double iinc = ri.inc ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6395
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6396 int max_idx = tree_to_mat_idx (ri.max ());
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6397
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6398 if (type_tag == matrix_constant)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6399 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6400 Matrix *new_matrix = new Matrix (nr-num_to_delete, nc);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6401 if (nr > num_to_delete)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6402 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6403 int ii = 0;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6404 int idx = 0;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6405 for (int i = 0; i < nr; i++)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6406 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6407 double itmp = ib + idx * iinc;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6408 int row = tree_to_mat_idx (itmp);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6409
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6410 if (i == row && row <= max_idx)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6411 idx++;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6412 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6413 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6414 for (int j = 0; j < nc; j++)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6415 new_matrix->elem (ii, j) = matrix->elem (i, j);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6416 ii++;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6417 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6418 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6419 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6420 delete matrix;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6421 matrix = new_matrix;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6422 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6423 else if (type_tag == complex_matrix_constant)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6424 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6425 ComplexMatrix *new_matrix = new ComplexMatrix (nr-num_to_delete, nc);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6426 if (nr > num_to_delete)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6427 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6428 int ii = 0;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6429 int idx = 0;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6430 for (int i = 0; i < nr; i++)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6431 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6432 double itmp = ib + idx * iinc;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6433 int row = tree_to_mat_idx (itmp);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6434
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6435 if (i == row && row <= max_idx)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6436 idx++;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6437 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6438 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6439 for (int j = 0; j < nc; j++)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6440 new_matrix->elem (ii, j) = complex_matrix->elem (i, j);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6441 ii++;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6442 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6443 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6444 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6445 delete complex_matrix;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6446 complex_matrix = new_matrix;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6447 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6448 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6449 panic_impossible ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6450 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6451
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6452 void
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6453 TC_REP::delete_column (int idx)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6454 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6455 if (type_tag == matrix_constant)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6456 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6457 int nr = matrix->rows ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6458 int nc = matrix->columns ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6459 Matrix *new_matrix = new Matrix (nr, nc-1);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6460 int jj = 0;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6461 for (int j = 0; j < nc; j++)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6462 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6463 if (j != idx)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6464 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6465 for (int i = 0; i < nr; i++)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6466 new_matrix->elem (i, jj) = matrix->elem (i, j);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6467 jj++;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6468 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6469 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6470 delete matrix;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6471 matrix = new_matrix;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6472 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6473 else if (type_tag == complex_matrix_constant)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6474 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6475 int nr = complex_matrix->rows ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6476 int nc = complex_matrix->columns ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6477 ComplexMatrix *new_matrix = new ComplexMatrix (nr, nc-1);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6478 int jj = 0;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6479 for (int j = 0; j < nc; j++)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6480 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6481 if (j != idx)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6482 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6483 for (int i = 0; i < nr; i++)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6484 new_matrix->elem (i, jj) = complex_matrix->elem (i, j);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6485 jj++;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6486 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6487 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6488 delete complex_matrix;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6489 complex_matrix = new_matrix;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6490 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6491 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6492 panic_impossible ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6493 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6494
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6495 void
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6496 TC_REP::delete_columns (idx_vector& jv)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6497 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6498 jv.sort_uniq ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6499 int num_to_delete = jv.length ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6500
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6501 if (num_to_delete == 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6502 return;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6503
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6504 int nr = rows ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6505 int nc = columns ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6506
1358
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1355
diff changeset
6507 // If deleting all columns of a row vector, make result 0x0.
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1355
diff changeset
6508
1299
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6509 if (nr == 1 && num_to_delete == nc)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6510 nr = 0;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6511
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6512 if (type_tag == matrix_constant)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6513 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6514 Matrix *new_matrix = new Matrix (nr, nc-num_to_delete);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6515 if (nc > num_to_delete)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6516 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6517 int jj = 0;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6518 int idx = 0;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6519 for (int j = 0; j < nc; j++)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6520 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6521 if (j == jv.elem (idx))
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6522 idx++;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6523 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6524 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6525 for (int i = 0; i < nr; i++)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6526 new_matrix->elem (i, jj) = matrix->elem (i, j);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6527 jj++;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6528 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6529 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6530 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6531 delete matrix;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6532 matrix = new_matrix;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6533 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6534 else if (type_tag == complex_matrix_constant)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6535 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6536 ComplexMatrix *new_matrix = new ComplexMatrix (nr, nc-num_to_delete);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6537 if (nc > num_to_delete)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6538 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6539 int jj = 0;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6540 int idx = 0;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6541 for (int j = 0; j < nc; j++)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6542 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6543 if (j == jv.elem (idx))
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6544 idx++;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6545 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6546 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6547 for (int i = 0; i < nr; i++)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6548 new_matrix->elem (i, jj) = complex_matrix->elem (i, j);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6549 jj++;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6550 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6551 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6552 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6553 delete complex_matrix;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6554 complex_matrix = new_matrix;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6555 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6556 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6557 panic_impossible ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6558 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6559
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6560 void
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6561 TC_REP::delete_columns (Range& rj)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6562 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6563 rj.sort ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6564 int num_to_delete = rj.nelem ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6565
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6566 if (num_to_delete == 0)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6567 return;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6568
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6569 int nr = rows ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6570 int nc = columns ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6571
1358
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1355
diff changeset
6572 // If deleting all columns of a row vector, make result 0x0.
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1355
diff changeset
6573
1299
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6574 if (nr == 1 && num_to_delete == nc)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6575 nr = 0;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6576
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6577 double jb = rj.base ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6578 double jinc = rj.inc ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6579
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6580 int max_idx = tree_to_mat_idx (rj.max ());
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6581
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6582 if (type_tag == matrix_constant)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6583 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6584 Matrix *new_matrix = new Matrix (nr, nc-num_to_delete);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6585 if (nc > num_to_delete)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6586 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6587 int jj = 0;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6588 int idx = 0;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6589 for (int j = 0; j < nc; j++)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6590 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6591 double jtmp = jb + idx * jinc;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6592 int col = tree_to_mat_idx (jtmp);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6593
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6594 if (j == col && col <= max_idx)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6595 idx++;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6596 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6597 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6598 for (int i = 0; i < nr; i++)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6599 new_matrix->elem (i, jj) = matrix->elem (i, j);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6600 jj++;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6601 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6602 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6603 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6604 delete matrix;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6605 matrix = new_matrix;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6606 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6607 else if (type_tag == complex_matrix_constant)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6608 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6609 ComplexMatrix *new_matrix = new ComplexMatrix (nr, nc-num_to_delete);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6610 if (nc > num_to_delete)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6611 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6612 int jj = 0;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6613 int idx = 0;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6614 for (int j = 0; j < nc; j++)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6615 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6616 double jtmp = jb + idx * jinc;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6617 int col = tree_to_mat_idx (jtmp);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6618
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6619 if (j == col && col <= max_idx)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6620 idx++;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6621 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6622 {
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6623 for (int i = 0; i < nr; i++)
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6624 new_matrix->elem (i, jj) = complex_matrix->elem (i, j);
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6625 jj++;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6626 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6627 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6628 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6629 delete complex_matrix;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6630 complex_matrix = new_matrix;
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6631 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6632 else
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6633 panic_impossible ();
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6634 }
484e94579182 [project @ 1995-05-01 18:50:20 by jwe]
jwe
parents: 1277
diff changeset
6635
96
36ff440553cd [project @ 1993-09-13 02:48:39 by jwe]
jwe
parents: 1
diff changeset
6636 /*
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
6637 ;;; Local Variables: ***
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
6638 ;;; mode: C++ ***
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
6639 ;;; page-delimiter: "^/\\*" ***
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
6640 ;;; End: ***
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
6641 */