annotate src/oct-obj.cc @ 1192:b6360f2d4fa6

[project @ 1995-03-30 21:38:35 by jwe]
author jwe
date Thu, 30 Mar 1995 21:38:35 +0000
parents dfe01093f657
children 12ecc2ecf0e3
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
517
be927cad4cf7 [project @ 1994-07-13 14:38:02 by jwe]
jwe
parents:
diff changeset
1 // oct-obj.cc -*- C++ -*-
be927cad4cf7 [project @ 1994-07-13 14:38:02 by jwe]
jwe
parents:
diff changeset
2 /*
be927cad4cf7 [project @ 1994-07-13 14:38:02 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) 1994, 1995 John W. Eaton
517
be927cad4cf7 [project @ 1994-07-13 14:38:02 by jwe]
jwe
parents:
diff changeset
5
be927cad4cf7 [project @ 1994-07-13 14:38:02 by jwe]
jwe
parents:
diff changeset
6 This file is part of Octave.
be927cad4cf7 [project @ 1994-07-13 14:38:02 by jwe]
jwe
parents:
diff changeset
7
be927cad4cf7 [project @ 1994-07-13 14:38:02 by jwe]
jwe
parents:
diff changeset
8 Octave is free software; you can redistribute it and/or modify it
be927cad4cf7 [project @ 1994-07-13 14:38:02 by jwe]
jwe
parents:
diff changeset
9 under the terms of the GNU General Public License as published by the
be927cad4cf7 [project @ 1994-07-13 14:38:02 by jwe]
jwe
parents:
diff changeset
10 Free Software Foundation; either version 2, or (at your option) any
be927cad4cf7 [project @ 1994-07-13 14:38:02 by jwe]
jwe
parents:
diff changeset
11 later version.
be927cad4cf7 [project @ 1994-07-13 14:38:02 by jwe]
jwe
parents:
diff changeset
12
be927cad4cf7 [project @ 1994-07-13 14:38:02 by jwe]
jwe
parents:
diff changeset
13 Octave is distributed in the hope that it will be useful, but WITHOUT
be927cad4cf7 [project @ 1994-07-13 14:38:02 by jwe]
jwe
parents:
diff changeset
14 ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
be927cad4cf7 [project @ 1994-07-13 14:38:02 by jwe]
jwe
parents:
diff changeset
15 FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
be927cad4cf7 [project @ 1994-07-13 14:38:02 by jwe]
jwe
parents:
diff changeset
16 for more details.
be927cad4cf7 [project @ 1994-07-13 14:38:02 by jwe]
jwe
parents:
diff changeset
17
be927cad4cf7 [project @ 1994-07-13 14:38:02 by jwe]
jwe
parents:
diff changeset
18 You should have received a copy of the GNU General Public License
be927cad4cf7 [project @ 1994-07-13 14:38:02 by jwe]
jwe
parents:
diff changeset
19 along with Octave; see the file COPYING. If not, write to the Free
be927cad4cf7 [project @ 1994-07-13 14:38:02 by jwe]
jwe
parents:
diff changeset
20 Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA.
be927cad4cf7 [project @ 1994-07-13 14:38:02 by jwe]
jwe
parents:
diff changeset
21
be927cad4cf7 [project @ 1994-07-13 14:38:02 by jwe]
jwe
parents:
diff changeset
22 */
be927cad4cf7 [project @ 1994-07-13 14:38:02 by jwe]
jwe
parents:
diff changeset
23
be927cad4cf7 [project @ 1994-07-13 14:38:02 by jwe]
jwe
parents:
diff changeset
24 #ifdef HAVE_CONFIG_H
1192
b6360f2d4fa6 [project @ 1995-03-30 21:38:35 by jwe]
jwe
parents: 1009
diff changeset
25 #include <config.h>
517
be927cad4cf7 [project @ 1994-07-13 14:38:02 by jwe]
jwe
parents:
diff changeset
26 #endif
be927cad4cf7 [project @ 1994-07-13 14:38:02 by jwe]
jwe
parents:
diff changeset
27
be927cad4cf7 [project @ 1994-07-13 14:38:02 by jwe]
jwe
parents:
diff changeset
28 #include "Array.h"
be927cad4cf7 [project @ 1994-07-13 14:38:02 by jwe]
jwe
parents:
diff changeset
29 #include "mx-base.h"
be927cad4cf7 [project @ 1994-07-13 14:38:02 by jwe]
jwe
parents:
diff changeset
30 #include "Range.h"
be927cad4cf7 [project @ 1994-07-13 14:38:02 by jwe]
jwe
parents:
diff changeset
31
be927cad4cf7 [project @ 1994-07-13 14:38:02 by jwe]
jwe
parents:
diff changeset
32 #include "tree-const.h"
be927cad4cf7 [project @ 1994-07-13 14:38:02 by jwe]
jwe
parents:
diff changeset
33 #include "oct-obj.h"
be927cad4cf7 [project @ 1994-07-13 14:38:02 by jwe]
jwe
parents:
diff changeset
34
be927cad4cf7 [project @ 1994-07-13 14:38:02 by jwe]
jwe
parents:
diff changeset
35 // We can't put these functions in oct-obj.h without including
be927cad4cf7 [project @ 1994-07-13 14:38:02 by jwe]
jwe
parents:
diff changeset
36 // tree-const.h there too, and that causes trouble...
be927cad4cf7 [project @ 1994-07-13 14:38:02 by jwe]
jwe
parents:
diff changeset
37
be927cad4cf7 [project @ 1994-07-13 14:38:02 by jwe]
jwe
parents:
diff changeset
38 Octave_object::Octave_object (double d)
be927cad4cf7 [project @ 1994-07-13 14:38:02 by jwe]
jwe
parents:
diff changeset
39 : Array<tree_constant> (1, tree_constant (d)) { }
be927cad4cf7 [project @ 1994-07-13 14:38:02 by jwe]
jwe
parents:
diff changeset
40
be927cad4cf7 [project @ 1994-07-13 14:38:02 by jwe]
jwe
parents:
diff changeset
41 Octave_object::Octave_object (const Matrix& m)
be927cad4cf7 [project @ 1994-07-13 14:38:02 by jwe]
jwe
parents:
diff changeset
42 : Array<tree_constant> (1, tree_constant (m)) { }
be927cad4cf7 [project @ 1994-07-13 14:38:02 by jwe]
jwe
parents:
diff changeset
43
be927cad4cf7 [project @ 1994-07-13 14:38:02 by jwe]
jwe
parents:
diff changeset
44 Octave_object::Octave_object (const DiagMatrix& d)
be927cad4cf7 [project @ 1994-07-13 14:38:02 by jwe]
jwe
parents:
diff changeset
45 : Array<tree_constant> (1, tree_constant (d)) { }
be927cad4cf7 [project @ 1994-07-13 14:38:02 by jwe]
jwe
parents:
diff changeset
46
526
a01a9db8ab69 [project @ 1994-07-20 18:46:24 by jwe]
jwe
parents: 517
diff changeset
47 Octave_object::Octave_object (const RowVector& v, int pcv)
517
be927cad4cf7 [project @ 1994-07-13 14:38:02 by jwe]
jwe
parents:
diff changeset
48 : Array<tree_constant> (1, tree_constant (v, pcv)) { }
be927cad4cf7 [project @ 1994-07-13 14:38:02 by jwe]
jwe
parents:
diff changeset
49
526
a01a9db8ab69 [project @ 1994-07-20 18:46:24 by jwe]
jwe
parents: 517
diff changeset
50 Octave_object::Octave_object (const ColumnVector& v, int pcv)
517
be927cad4cf7 [project @ 1994-07-13 14:38:02 by jwe]
jwe
parents:
diff changeset
51 : Array<tree_constant> (1, tree_constant (v, pcv)) { }
be927cad4cf7 [project @ 1994-07-13 14:38:02 by jwe]
jwe
parents:
diff changeset
52
be927cad4cf7 [project @ 1994-07-13 14:38:02 by jwe]
jwe
parents:
diff changeset
53 Octave_object::Octave_object (const Complex& c)
be927cad4cf7 [project @ 1994-07-13 14:38:02 by jwe]
jwe
parents:
diff changeset
54 : Array<tree_constant> (1, tree_constant (c)) { }
be927cad4cf7 [project @ 1994-07-13 14:38:02 by jwe]
jwe
parents:
diff changeset
55
be927cad4cf7 [project @ 1994-07-13 14:38:02 by jwe]
jwe
parents:
diff changeset
56 Octave_object::Octave_object (const ComplexMatrix& m)
be927cad4cf7 [project @ 1994-07-13 14:38:02 by jwe]
jwe
parents:
diff changeset
57 : Array<tree_constant> (1, tree_constant (m)) { }
be927cad4cf7 [project @ 1994-07-13 14:38:02 by jwe]
jwe
parents:
diff changeset
58
be927cad4cf7 [project @ 1994-07-13 14:38:02 by jwe]
jwe
parents:
diff changeset
59 Octave_object::Octave_object (const ComplexDiagMatrix& d)
be927cad4cf7 [project @ 1994-07-13 14:38:02 by jwe]
jwe
parents:
diff changeset
60 : Array<tree_constant> (1, tree_constant (d)) { }
be927cad4cf7 [project @ 1994-07-13 14:38:02 by jwe]
jwe
parents:
diff changeset
61
526
a01a9db8ab69 [project @ 1994-07-20 18:46:24 by jwe]
jwe
parents: 517
diff changeset
62 Octave_object::Octave_object (const ComplexRowVector& v, int pcv)
517
be927cad4cf7 [project @ 1994-07-13 14:38:02 by jwe]
jwe
parents:
diff changeset
63 : Array<tree_constant> (1, tree_constant (v, pcv)) { }
be927cad4cf7 [project @ 1994-07-13 14:38:02 by jwe]
jwe
parents:
diff changeset
64
526
a01a9db8ab69 [project @ 1994-07-20 18:46:24 by jwe]
jwe
parents: 517
diff changeset
65 Octave_object::Octave_object (const ComplexColumnVector& v, int pcv)
517
be927cad4cf7 [project @ 1994-07-13 14:38:02 by jwe]
jwe
parents:
diff changeset
66 : Array<tree_constant> (1, tree_constant (v, pcv)) { }
be927cad4cf7 [project @ 1994-07-13 14:38:02 by jwe]
jwe
parents:
diff changeset
67
be927cad4cf7 [project @ 1994-07-13 14:38:02 by jwe]
jwe
parents:
diff changeset
68 Octave_object::Octave_object (const char *s)
be927cad4cf7 [project @ 1994-07-13 14:38:02 by jwe]
jwe
parents:
diff changeset
69 : Array<tree_constant> (1, tree_constant (s)) { }
be927cad4cf7 [project @ 1994-07-13 14:38:02 by jwe]
jwe
parents:
diff changeset
70
be927cad4cf7 [project @ 1994-07-13 14:38:02 by jwe]
jwe
parents:
diff changeset
71 Octave_object::Octave_object (double base, double limit, double inc)
be927cad4cf7 [project @ 1994-07-13 14:38:02 by jwe]
jwe
parents:
diff changeset
72 : Array<tree_constant> (1, tree_constant (base, limit, inc)) { }
be927cad4cf7 [project @ 1994-07-13 14:38:02 by jwe]
jwe
parents:
diff changeset
73
be927cad4cf7 [project @ 1994-07-13 14:38:02 by jwe]
jwe
parents:
diff changeset
74 Octave_object::Octave_object (const Range& r)
be927cad4cf7 [project @ 1994-07-13 14:38:02 by jwe]
jwe
parents:
diff changeset
75 : Array<tree_constant> (1, tree_constant (r)) { }
be927cad4cf7 [project @ 1994-07-13 14:38:02 by jwe]
jwe
parents:
diff changeset
76
be927cad4cf7 [project @ 1994-07-13 14:38:02 by jwe]
jwe
parents:
diff changeset
77 tree_constant&
be927cad4cf7 [project @ 1994-07-13 14:38:02 by jwe]
jwe
parents:
diff changeset
78 Octave_object::operator () (int n)
be927cad4cf7 [project @ 1994-07-13 14:38:02 by jwe]
jwe
parents:
diff changeset
79 {
be927cad4cf7 [project @ 1994-07-13 14:38:02 by jwe]
jwe
parents:
diff changeset
80 maybe_resize (n);
be927cad4cf7 [project @ 1994-07-13 14:38:02 by jwe]
jwe
parents:
diff changeset
81 return Array<tree_constant>::operator () (n);
be927cad4cf7 [project @ 1994-07-13 14:38:02 by jwe]
jwe
parents:
diff changeset
82 }
be927cad4cf7 [project @ 1994-07-13 14:38:02 by jwe]
jwe
parents:
diff changeset
83
be927cad4cf7 [project @ 1994-07-13 14:38:02 by jwe]
jwe
parents:
diff changeset
84 tree_constant
be927cad4cf7 [project @ 1994-07-13 14:38:02 by jwe]
jwe
parents:
diff changeset
85 Octave_object::operator () (int n) const
be927cad4cf7 [project @ 1994-07-13 14:38:02 by jwe]
jwe
parents:
diff changeset
86 {
be927cad4cf7 [project @ 1994-07-13 14:38:02 by jwe]
jwe
parents:
diff changeset
87 return Array<tree_constant>::operator () (n);
be927cad4cf7 [project @ 1994-07-13 14:38:02 by jwe]
jwe
parents:
diff changeset
88 }
be927cad4cf7 [project @ 1994-07-13 14:38:02 by jwe]
jwe
parents:
diff changeset
89
be927cad4cf7 [project @ 1994-07-13 14:38:02 by jwe]
jwe
parents:
diff changeset
90 tree_constant&
be927cad4cf7 [project @ 1994-07-13 14:38:02 by jwe]
jwe
parents:
diff changeset
91 Octave_object::elem (int n)
be927cad4cf7 [project @ 1994-07-13 14:38:02 by jwe]
jwe
parents:
diff changeset
92 {
be927cad4cf7 [project @ 1994-07-13 14:38:02 by jwe]
jwe
parents:
diff changeset
93 maybe_resize (n);
be927cad4cf7 [project @ 1994-07-13 14:38:02 by jwe]
jwe
parents:
diff changeset
94 return Array<tree_constant>::elem (n);
be927cad4cf7 [project @ 1994-07-13 14:38:02 by jwe]
jwe
parents:
diff changeset
95 }
be927cad4cf7 [project @ 1994-07-13 14:38:02 by jwe]
jwe
parents:
diff changeset
96
be927cad4cf7 [project @ 1994-07-13 14:38:02 by jwe]
jwe
parents:
diff changeset
97 tree_constant
be927cad4cf7 [project @ 1994-07-13 14:38:02 by jwe]
jwe
parents:
diff changeset
98 Octave_object::elem (int n) const
be927cad4cf7 [project @ 1994-07-13 14:38:02 by jwe]
jwe
parents:
diff changeset
99 {
be927cad4cf7 [project @ 1994-07-13 14:38:02 by jwe]
jwe
parents:
diff changeset
100 return Array<tree_constant>::operator () (n);
be927cad4cf7 [project @ 1994-07-13 14:38:02 by jwe]
jwe
parents:
diff changeset
101 }
be927cad4cf7 [project @ 1994-07-13 14:38:02 by jwe]
jwe
parents:
diff changeset
102
be927cad4cf7 [project @ 1994-07-13 14:38:02 by jwe]
jwe
parents:
diff changeset
103 void
be927cad4cf7 [project @ 1994-07-13 14:38:02 by jwe]
jwe
parents:
diff changeset
104 Octave_object::maybe_resize (int n)
be927cad4cf7 [project @ 1994-07-13 14:38:02 by jwe]
jwe
parents:
diff changeset
105 {
be927cad4cf7 [project @ 1994-07-13 14:38:02 by jwe]
jwe
parents:
diff changeset
106 if (n >= length ())
be927cad4cf7 [project @ 1994-07-13 14:38:02 by jwe]
jwe
parents:
diff changeset
107 resize (n + 1, Matrix ());
be927cad4cf7 [project @ 1994-07-13 14:38:02 by jwe]
jwe
parents:
diff changeset
108 }
be927cad4cf7 [project @ 1994-07-13 14:38:02 by jwe]
jwe
parents:
diff changeset
109
be927cad4cf7 [project @ 1994-07-13 14:38:02 by jwe]
jwe
parents:
diff changeset
110 /*
be927cad4cf7 [project @ 1994-07-13 14:38:02 by jwe]
jwe
parents:
diff changeset
111 ;;; Local Variables: ***
be927cad4cf7 [project @ 1994-07-13 14:38:02 by jwe]
jwe
parents:
diff changeset
112 ;;; mode: C++ ***
be927cad4cf7 [project @ 1994-07-13 14:38:02 by jwe]
jwe
parents:
diff changeset
113 ;;; page-delimiter: "^/\\*" ***
be927cad4cf7 [project @ 1994-07-13 14:38:02 by jwe]
jwe
parents:
diff changeset
114 ;;; End: ***
be927cad4cf7 [project @ 1994-07-13 14:38:02 by jwe]
jwe
parents:
diff changeset
115 */