annotate liboctave/ArrayN.cc @ 5100:5a92c3177fc6 before-gnuplot-split

[project @ 2004-12-27 17:20:38 by jwe]
author jwe
date Mon, 27 Dec 2004 17:20:38 +0000
parents 19bfd295f400
children e35b034d3523
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
3665
0689afb1d001 [project @ 2000-05-11 19:07:56 by jwe]
jwe
parents:
diff changeset
1 // Template array classes
0689afb1d001 [project @ 2000-05-11 19:07:56 by jwe]
jwe
parents:
diff changeset
2 /*
0689afb1d001 [project @ 2000-05-11 19:07:56 by jwe]
jwe
parents:
diff changeset
3
0689afb1d001 [project @ 2000-05-11 19:07:56 by jwe]
jwe
parents:
diff changeset
4 Copyright (C) 2000 John W. Eaton
0689afb1d001 [project @ 2000-05-11 19:07:56 by jwe]
jwe
parents:
diff changeset
5
0689afb1d001 [project @ 2000-05-11 19:07:56 by jwe]
jwe
parents:
diff changeset
6 This file is part of Octave.
0689afb1d001 [project @ 2000-05-11 19:07:56 by jwe]
jwe
parents:
diff changeset
7
0689afb1d001 [project @ 2000-05-11 19:07:56 by jwe]
jwe
parents:
diff changeset
8 Octave is free software; you can redistribute it and/or modify it
0689afb1d001 [project @ 2000-05-11 19:07:56 by jwe]
jwe
parents:
diff changeset
9 under the terms of the GNU General Public License as published by the
0689afb1d001 [project @ 2000-05-11 19:07:56 by jwe]
jwe
parents:
diff changeset
10 Free Software Foundation; either version 2, or (at your option) any
0689afb1d001 [project @ 2000-05-11 19:07:56 by jwe]
jwe
parents:
diff changeset
11 later version.
0689afb1d001 [project @ 2000-05-11 19:07:56 by jwe]
jwe
parents:
diff changeset
12
0689afb1d001 [project @ 2000-05-11 19:07:56 by jwe]
jwe
parents:
diff changeset
13 Octave is distributed in the hope that it will be useful, but WITHOUT
0689afb1d001 [project @ 2000-05-11 19:07:56 by jwe]
jwe
parents:
diff changeset
14 ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
0689afb1d001 [project @ 2000-05-11 19:07:56 by jwe]
jwe
parents:
diff changeset
15 FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
0689afb1d001 [project @ 2000-05-11 19:07:56 by jwe]
jwe
parents:
diff changeset
16 for more details.
0689afb1d001 [project @ 2000-05-11 19:07:56 by jwe]
jwe
parents:
diff changeset
17
0689afb1d001 [project @ 2000-05-11 19:07:56 by jwe]
jwe
parents:
diff changeset
18 You should have received a copy of the GNU General Public License
0689afb1d001 [project @ 2000-05-11 19:07:56 by jwe]
jwe
parents:
diff changeset
19 along with Octave; see the file COPYING. If not, write to the Free
0689afb1d001 [project @ 2000-05-11 19:07:56 by jwe]
jwe
parents:
diff changeset
20 Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
0689afb1d001 [project @ 2000-05-11 19:07:56 by jwe]
jwe
parents:
diff changeset
21
0689afb1d001 [project @ 2000-05-11 19:07:56 by jwe]
jwe
parents:
diff changeset
22 */
0689afb1d001 [project @ 2000-05-11 19:07:56 by jwe]
jwe
parents:
diff changeset
23
4192
5719210fff4c [project @ 2002-11-20 16:56:47 by jwe]
jwe
parents: 4142
diff changeset
24 #if defined (__GNUG__) && defined (USE_PRAGMA_INTERFACE_IMPLEMENTATION)
3665
0689afb1d001 [project @ 2000-05-11 19:07:56 by jwe]
jwe
parents:
diff changeset
25 #pragma implementation
0689afb1d001 [project @ 2000-05-11 19:07:56 by jwe]
jwe
parents:
diff changeset
26 #endif
0689afb1d001 [project @ 2000-05-11 19:07:56 by jwe]
jwe
parents:
diff changeset
27
0689afb1d001 [project @ 2000-05-11 19:07:56 by jwe]
jwe
parents:
diff changeset
28 #ifdef HAVE_CONFIG_H
0689afb1d001 [project @ 2000-05-11 19:07:56 by jwe]
jwe
parents:
diff changeset
29 #include <config.h>
0689afb1d001 [project @ 2000-05-11 19:07:56 by jwe]
jwe
parents:
diff changeset
30 #endif
0689afb1d001 [project @ 2000-05-11 19:07:56 by jwe]
jwe
parents:
diff changeset
31
0689afb1d001 [project @ 2000-05-11 19:07:56 by jwe]
jwe
parents:
diff changeset
32 #include <cassert>
0689afb1d001 [project @ 2000-05-11 19:07:56 by jwe]
jwe
parents:
diff changeset
33
0689afb1d001 [project @ 2000-05-11 19:07:56 by jwe]
jwe
parents:
diff changeset
34 #include <iostream>
0689afb1d001 [project @ 2000-05-11 19:07:56 by jwe]
jwe
parents:
diff changeset
35
4588
19bfd295f400 [project @ 2003-11-10 17:18:48 by jwe]
jwe
parents: 4543
diff changeset
36 #include "Array-util.h"
3665
0689afb1d001 [project @ 2000-05-11 19:07:56 by jwe]
jwe
parents:
diff changeset
37 #include "ArrayN.h"
4513
508238e65af7 [project @ 2003-09-19 21:40:57 by jwe]
jwe
parents: 4504
diff changeset
38 #include "ArrayN-idx.h"
3665
0689afb1d001 [project @ 2000-05-11 19:07:56 by jwe]
jwe
parents:
diff changeset
39 #include "idx-vector.h"
0689afb1d001 [project @ 2000-05-11 19:07:56 by jwe]
jwe
parents:
diff changeset
40 #include "lo-error.h"
0689afb1d001 [project @ 2000-05-11 19:07:56 by jwe]
jwe
parents:
diff changeset
41
0689afb1d001 [project @ 2000-05-11 19:07:56 by jwe]
jwe
parents:
diff changeset
42 // N-dimensional array class.
0689afb1d001 [project @ 2000-05-11 19:07:56 by jwe]
jwe
parents:
diff changeset
43
0689afb1d001 [project @ 2000-05-11 19:07:56 by jwe]
jwe
parents:
diff changeset
44 template <class T>
0689afb1d001 [project @ 2000-05-11 19:07:56 by jwe]
jwe
parents:
diff changeset
45 std::ostream&
0689afb1d001 [project @ 2000-05-11 19:07:56 by jwe]
jwe
parents:
diff changeset
46 operator << (std::ostream& os, const ArrayN<T>& a)
0689afb1d001 [project @ 2000-05-11 19:07:56 by jwe]
jwe
parents:
diff changeset
47 {
4513
508238e65af7 [project @ 2003-09-19 21:40:57 by jwe]
jwe
parents: 4504
diff changeset
48 dim_vector a_dims = a.dims ();
4473
32ac2bea0185 [project @ 2003-07-29 23:05:32 by jwe]
jwe
parents: 4323
diff changeset
49
32ac2bea0185 [project @ 2003-07-29 23:05:32 by jwe]
jwe
parents: 4323
diff changeset
50 int n_dims = a_dims.length ();
32ac2bea0185 [project @ 2003-07-29 23:05:32 by jwe]
jwe
parents: 4323
diff changeset
51
32ac2bea0185 [project @ 2003-07-29 23:05:32 by jwe]
jwe
parents: 4323
diff changeset
52 os << n_dims << "-dimensional array";
32ac2bea0185 [project @ 2003-07-29 23:05:32 by jwe]
jwe
parents: 4323
diff changeset
53
32ac2bea0185 [project @ 2003-07-29 23:05:32 by jwe]
jwe
parents: 4323
diff changeset
54 if (n_dims)
4543
79df15d4470c [project @ 2003-10-18 03:53:52 by jwe]
jwe
parents: 4513
diff changeset
55 os << " (" << a_dims.str () << ")";
4473
32ac2bea0185 [project @ 2003-07-29 23:05:32 by jwe]
jwe
parents: 4323
diff changeset
56
32ac2bea0185 [project @ 2003-07-29 23:05:32 by jwe]
jwe
parents: 4323
diff changeset
57 os <<"\n\n";
3665
0689afb1d001 [project @ 2000-05-11 19:07:56 by jwe]
jwe
parents:
diff changeset
58
4473
32ac2bea0185 [project @ 2003-07-29 23:05:32 by jwe]
jwe
parents: 4323
diff changeset
59 if (n_dims)
32ac2bea0185 [project @ 2003-07-29 23:05:32 by jwe]
jwe
parents: 4323
diff changeset
60 {
32ac2bea0185 [project @ 2003-07-29 23:05:32 by jwe]
jwe
parents: 4323
diff changeset
61 os << "data:";
32ac2bea0185 [project @ 2003-07-29 23:05:32 by jwe]
jwe
parents: 4323
diff changeset
62
4513
508238e65af7 [project @ 2003-09-19 21:40:57 by jwe]
jwe
parents: 4504
diff changeset
63 Array<int> ra_idx (n_dims, 0);
4473
32ac2bea0185 [project @ 2003-07-29 23:05:32 by jwe]
jwe
parents: 4323
diff changeset
64
32ac2bea0185 [project @ 2003-07-29 23:05:32 by jwe]
jwe
parents: 4323
diff changeset
65 // Number of times the first 2d-array is to be displayed.
3665
0689afb1d001 [project @ 2000-05-11 19:07:56 by jwe]
jwe
parents:
diff changeset
66
4473
32ac2bea0185 [project @ 2003-07-29 23:05:32 by jwe]
jwe
parents: 4323
diff changeset
67 int m = 1;
32ac2bea0185 [project @ 2003-07-29 23:05:32 by jwe]
jwe
parents: 4323
diff changeset
68 for (int i = 2; i < n_dims; i++)
32ac2bea0185 [project @ 2003-07-29 23:05:32 by jwe]
jwe
parents: 4323
diff changeset
69 m *= a_dims(i);
32ac2bea0185 [project @ 2003-07-29 23:05:32 by jwe]
jwe
parents: 4323
diff changeset
70
32ac2bea0185 [project @ 2003-07-29 23:05:32 by jwe]
jwe
parents: 4323
diff changeset
71 if (m == 1)
32ac2bea0185 [project @ 2003-07-29 23:05:32 by jwe]
jwe
parents: 4323
diff changeset
72 {
32ac2bea0185 [project @ 2003-07-29 23:05:32 by jwe]
jwe
parents: 4323
diff changeset
73 int rows = 0;
32ac2bea0185 [project @ 2003-07-29 23:05:32 by jwe]
jwe
parents: 4323
diff changeset
74 int cols = 0;
32ac2bea0185 [project @ 2003-07-29 23:05:32 by jwe]
jwe
parents: 4323
diff changeset
75
32ac2bea0185 [project @ 2003-07-29 23:05:32 by jwe]
jwe
parents: 4323
diff changeset
76 switch (n_dims)
32ac2bea0185 [project @ 2003-07-29 23:05:32 by jwe]
jwe
parents: 4323
diff changeset
77 {
32ac2bea0185 [project @ 2003-07-29 23:05:32 by jwe]
jwe
parents: 4323
diff changeset
78 case 2:
32ac2bea0185 [project @ 2003-07-29 23:05:32 by jwe]
jwe
parents: 4323
diff changeset
79 rows = a_dims(0);
32ac2bea0185 [project @ 2003-07-29 23:05:32 by jwe]
jwe
parents: 4323
diff changeset
80 cols = a_dims(1);
3665
0689afb1d001 [project @ 2000-05-11 19:07:56 by jwe]
jwe
parents:
diff changeset
81
4473
32ac2bea0185 [project @ 2003-07-29 23:05:32 by jwe]
jwe
parents: 4323
diff changeset
82 for (int j = 0; j < rows; j++)
32ac2bea0185 [project @ 2003-07-29 23:05:32 by jwe]
jwe
parents: 4323
diff changeset
83 {
32ac2bea0185 [project @ 2003-07-29 23:05:32 by jwe]
jwe
parents: 4323
diff changeset
84 ra_idx(0) = j;
32ac2bea0185 [project @ 2003-07-29 23:05:32 by jwe]
jwe
parents: 4323
diff changeset
85 for (int k = 0; k < cols; k++)
32ac2bea0185 [project @ 2003-07-29 23:05:32 by jwe]
jwe
parents: 4323
diff changeset
86 {
32ac2bea0185 [project @ 2003-07-29 23:05:32 by jwe]
jwe
parents: 4323
diff changeset
87 ra_idx(1) = k;
32ac2bea0185 [project @ 2003-07-29 23:05:32 by jwe]
jwe
parents: 4323
diff changeset
88 os << " " << a.elem(ra_idx);
32ac2bea0185 [project @ 2003-07-29 23:05:32 by jwe]
jwe
parents: 4323
diff changeset
89 }
32ac2bea0185 [project @ 2003-07-29 23:05:32 by jwe]
jwe
parents: 4323
diff changeset
90 os << "\n";
32ac2bea0185 [project @ 2003-07-29 23:05:32 by jwe]
jwe
parents: 4323
diff changeset
91 }
32ac2bea0185 [project @ 2003-07-29 23:05:32 by jwe]
jwe
parents: 4323
diff changeset
92 break;
32ac2bea0185 [project @ 2003-07-29 23:05:32 by jwe]
jwe
parents: 4323
diff changeset
93
4476
b7360f8eb035 [project @ 2003-07-30 17:17:21 by jwe]
jwe
parents: 4474
diff changeset
94 default:
4473
32ac2bea0185 [project @ 2003-07-29 23:05:32 by jwe]
jwe
parents: 4323
diff changeset
95 rows = a_dims(0);
32ac2bea0185 [project @ 2003-07-29 23:05:32 by jwe]
jwe
parents: 4323
diff changeset
96
32ac2bea0185 [project @ 2003-07-29 23:05:32 by jwe]
jwe
parents: 4323
diff changeset
97 for (int k = 0; k < rows; k++)
32ac2bea0185 [project @ 2003-07-29 23:05:32 by jwe]
jwe
parents: 4323
diff changeset
98 {
32ac2bea0185 [project @ 2003-07-29 23:05:32 by jwe]
jwe
parents: 4323
diff changeset
99 ra_idx(0) = k;
32ac2bea0185 [project @ 2003-07-29 23:05:32 by jwe]
jwe
parents: 4323
diff changeset
100 os << " " << a.elem(ra_idx);
32ac2bea0185 [project @ 2003-07-29 23:05:32 by jwe]
jwe
parents: 4323
diff changeset
101 }
32ac2bea0185 [project @ 2003-07-29 23:05:32 by jwe]
jwe
parents: 4323
diff changeset
102 break;
32ac2bea0185 [project @ 2003-07-29 23:05:32 by jwe]
jwe
parents: 4323
diff changeset
103 }
3665
0689afb1d001 [project @ 2000-05-11 19:07:56 by jwe]
jwe
parents:
diff changeset
104
4473
32ac2bea0185 [project @ 2003-07-29 23:05:32 by jwe]
jwe
parents: 4323
diff changeset
105 os << "\n";
32ac2bea0185 [project @ 2003-07-29 23:05:32 by jwe]
jwe
parents: 4323
diff changeset
106 }
32ac2bea0185 [project @ 2003-07-29 23:05:32 by jwe]
jwe
parents: 4323
diff changeset
107 else
32ac2bea0185 [project @ 2003-07-29 23:05:32 by jwe]
jwe
parents: 4323
diff changeset
108 {
32ac2bea0185 [project @ 2003-07-29 23:05:32 by jwe]
jwe
parents: 4323
diff changeset
109 int rows = a_dims(0);
32ac2bea0185 [project @ 2003-07-29 23:05:32 by jwe]
jwe
parents: 4323
diff changeset
110 int cols = a_dims(1);
32ac2bea0185 [project @ 2003-07-29 23:05:32 by jwe]
jwe
parents: 4323
diff changeset
111
32ac2bea0185 [project @ 2003-07-29 23:05:32 by jwe]
jwe
parents: 4323
diff changeset
112 for (int i = 0; i < m; i++)
32ac2bea0185 [project @ 2003-07-29 23:05:32 by jwe]
jwe
parents: 4323
diff changeset
113 {
32ac2bea0185 [project @ 2003-07-29 23:05:32 by jwe]
jwe
parents: 4323
diff changeset
114 os << "\n(:,:,";
32ac2bea0185 [project @ 2003-07-29 23:05:32 by jwe]
jwe
parents: 4323
diff changeset
115
32ac2bea0185 [project @ 2003-07-29 23:05:32 by jwe]
jwe
parents: 4323
diff changeset
116 for (int j = 2; j < n_dims - 1; j++)
32ac2bea0185 [project @ 2003-07-29 23:05:32 by jwe]
jwe
parents: 4323
diff changeset
117 os << ra_idx(j) + 1 << ",";
32ac2bea0185 [project @ 2003-07-29 23:05:32 by jwe]
jwe
parents: 4323
diff changeset
118
32ac2bea0185 [project @ 2003-07-29 23:05:32 by jwe]
jwe
parents: 4323
diff changeset
119 os << ra_idx(n_dims - 1) + 1 << ") = \n";
3665
0689afb1d001 [project @ 2000-05-11 19:07:56 by jwe]
jwe
parents:
diff changeset
120
4473
32ac2bea0185 [project @ 2003-07-29 23:05:32 by jwe]
jwe
parents: 4323
diff changeset
121 for (int j = 0; j < rows; j++)
32ac2bea0185 [project @ 2003-07-29 23:05:32 by jwe]
jwe
parents: 4323
diff changeset
122 {
32ac2bea0185 [project @ 2003-07-29 23:05:32 by jwe]
jwe
parents: 4323
diff changeset
123 ra_idx(0) = j;
32ac2bea0185 [project @ 2003-07-29 23:05:32 by jwe]
jwe
parents: 4323
diff changeset
124
32ac2bea0185 [project @ 2003-07-29 23:05:32 by jwe]
jwe
parents: 4323
diff changeset
125 for (int k = 0; k < cols; k++)
32ac2bea0185 [project @ 2003-07-29 23:05:32 by jwe]
jwe
parents: 4323
diff changeset
126 {
32ac2bea0185 [project @ 2003-07-29 23:05:32 by jwe]
jwe
parents: 4323
diff changeset
127 ra_idx(1) = k;
32ac2bea0185 [project @ 2003-07-29 23:05:32 by jwe]
jwe
parents: 4323
diff changeset
128 os << " " << a.elem(ra_idx);
32ac2bea0185 [project @ 2003-07-29 23:05:32 by jwe]
jwe
parents: 4323
diff changeset
129 }
3665
0689afb1d001 [project @ 2000-05-11 19:07:56 by jwe]
jwe
parents:
diff changeset
130
4473
32ac2bea0185 [project @ 2003-07-29 23:05:32 by jwe]
jwe
parents: 4323
diff changeset
131 os << "\n";
32ac2bea0185 [project @ 2003-07-29 23:05:32 by jwe]
jwe
parents: 4323
diff changeset
132 }
32ac2bea0185 [project @ 2003-07-29 23:05:32 by jwe]
jwe
parents: 4323
diff changeset
133
32ac2bea0185 [project @ 2003-07-29 23:05:32 by jwe]
jwe
parents: 4323
diff changeset
134 os << "\n";
32ac2bea0185 [project @ 2003-07-29 23:05:32 by jwe]
jwe
parents: 4323
diff changeset
135
32ac2bea0185 [project @ 2003-07-29 23:05:32 by jwe]
jwe
parents: 4323
diff changeset
136 if (i != m - 1)
32ac2bea0185 [project @ 2003-07-29 23:05:32 by jwe]
jwe
parents: 4323
diff changeset
137 increment_index (ra_idx, a_dims, 2);
32ac2bea0185 [project @ 2003-07-29 23:05:32 by jwe]
jwe
parents: 4323
diff changeset
138 }
32ac2bea0185 [project @ 2003-07-29 23:05:32 by jwe]
jwe
parents: 4323
diff changeset
139 }
32ac2bea0185 [project @ 2003-07-29 23:05:32 by jwe]
jwe
parents: 4323
diff changeset
140 }
3665
0689afb1d001 [project @ 2000-05-11 19:07:56 by jwe]
jwe
parents:
diff changeset
141
0689afb1d001 [project @ 2000-05-11 19:07:56 by jwe]
jwe
parents:
diff changeset
142 return os;
0689afb1d001 [project @ 2000-05-11 19:07:56 by jwe]
jwe
parents:
diff changeset
143 }
0689afb1d001 [project @ 2000-05-11 19:07:56 by jwe]
jwe
parents:
diff changeset
144
0689afb1d001 [project @ 2000-05-11 19:07:56 by jwe]
jwe
parents:
diff changeset
145 /*
0689afb1d001 [project @ 2000-05-11 19:07:56 by jwe]
jwe
parents:
diff changeset
146 ;;; Local Variables: ***
0689afb1d001 [project @ 2000-05-11 19:07:56 by jwe]
jwe
parents:
diff changeset
147 ;;; mode: C++ ***
0689afb1d001 [project @ 2000-05-11 19:07:56 by jwe]
jwe
parents:
diff changeset
148 ;;; End: ***
0689afb1d001 [project @ 2000-05-11 19:07:56 by jwe]
jwe
parents:
diff changeset
149 */