annotate src/syl.cc @ 1404:2bab346e3012

[project @ 1995-09-15 05:34:08 by jwe]
author jwe
date Fri, 15 Sep 1995 05:34:08 +0000
parents 749071f48336
children 89c587478067
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
519
b9284136189a [project @ 1994-07-19 14:40:20 by jwe]
jwe
parents: 516
diff changeset
1 // f-syl.cc -*- C++ -*-
37
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
2 /*
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
3
1009
dfe01093f657 [project @ 1995-01-04 04:05:12 by jwe]
jwe
parents: 718
diff changeset
4 Copyright (C) 1993, 1994, 1995 John W. Eaton
37
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
5
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
6 This file is part of Octave.
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
7
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
8 Octave is free software; you can redistribute it and/or modify it
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
9 under the terms of the GNU General Public License as published by the
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
10 Free Software Foundation; either version 2, or (at your option) any
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
11 later version.
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
12
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
13 Octave is distributed in the hope that it will be useful, but WITHOUT
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
14 ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
15 FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
16 for more details.
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
17
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
18 You should have received a copy of the GNU General Public License
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 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: 1255
diff changeset
20 Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
37
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
21
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
22 */
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
23
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
24 // Written by A. S. Hodel <scotte@eng.auburn.edu>
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
25
240
a99f28f5e351 [project @ 1993-11-30 20:24:36 by jwe]
jwe
parents: 234
diff changeset
26 #ifdef HAVE_CONFIG_H
1192
b6360f2d4fa6 [project @ 1995-03-30 21:38:35 by jwe]
jwe
parents: 1009
diff changeset
27 #include <config.h>
37
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
28 #endif
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
29
1352
19c10b8657d5 [project @ 1995-09-05 08:11:57 by jwe]
jwe
parents: 1315
diff changeset
30 #include "CMatrix.h"
19c10b8657d5 [project @ 1995-09-05 08:11:57 by jwe]
jwe
parents: 1315
diff changeset
31 #include "CmplxSCHUR.h"
453
393e95f46b51 [project @ 1994-06-06 00:05:20 by jwe]
jwe
parents: 240
diff changeset
32 #include "dMatrix.h"
393e95f46b51 [project @ 1994-06-06 00:05:20 by jwe]
jwe
parents: 240
diff changeset
33 #include "dbleSCHUR.h"
234
a366eb563bf2 [project @ 1993-11-16 11:10:08 by jwe]
jwe
parents: 162
diff changeset
34 #include "f77-uscore.h"
37
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
35
1352
19c10b8657d5 [project @ 1995-09-05 08:11:57 by jwe]
jwe
parents: 1315
diff changeset
36 #include "defun-dld.h"
19c10b8657d5 [project @ 1995-09-05 08:11:57 by jwe]
jwe
parents: 1315
diff changeset
37 #include "error.h"
19c10b8657d5 [project @ 1995-09-05 08:11:57 by jwe]
jwe
parents: 1315
diff changeset
38 #include "gripes.h"
19c10b8657d5 [project @ 1995-09-05 08:11:57 by jwe]
jwe
parents: 1315
diff changeset
39 #include "help.h"
37
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
40 #include "tree-const.h"
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
41 #include "user-prefs.h"
636
fae2bd91c027 [project @ 1994-08-23 18:39:50 by jwe]
jwe
parents: 628
diff changeset
42 #include "utils.h"
37
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
43
47
ed620db95182 [project @ 1993-08-10 23:02:53 by jwe]
jwe
parents: 46
diff changeset
44 extern "C"
ed620db95182 [project @ 1993-08-10 23:02:53 by jwe]
jwe
parents: 46
diff changeset
45 {
1255
fa24599e3d2c [project @ 1995-04-11 17:49:27 by jwe]
jwe
parents: 1245
diff changeset
46 int F77_FCN (dtrsyl, DTRSYL) (const char*, const char*, const int&,
fa24599e3d2c [project @ 1995-04-11 17:49:27 by jwe]
jwe
parents: 1245
diff changeset
47 const int&, const int&, const double*,
fa24599e3d2c [project @ 1995-04-11 17:49:27 by jwe]
jwe
parents: 1245
diff changeset
48 const int&, const double*, const int&,
fa24599e3d2c [project @ 1995-04-11 17:49:27 by jwe]
jwe
parents: 1245
diff changeset
49 const double*, const int&, double&,
fa24599e3d2c [project @ 1995-04-11 17:49:27 by jwe]
jwe
parents: 1245
diff changeset
50 int&, long, long);
37
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
51
1255
fa24599e3d2c [project @ 1995-04-11 17:49:27 by jwe]
jwe
parents: 1245
diff changeset
52 int F77_FCN (ztrsyl, ZTRSYL) (const char*, const char*, const int&,
fa24599e3d2c [project @ 1995-04-11 17:49:27 by jwe]
jwe
parents: 1245
diff changeset
53 const int&, const int&,
fa24599e3d2c [project @ 1995-04-11 17:49:27 by jwe]
jwe
parents: 1245
diff changeset
54 const Complex*, const int&,
fa24599e3d2c [project @ 1995-04-11 17:49:27 by jwe]
jwe
parents: 1245
diff changeset
55 const Complex*, const int&,
fa24599e3d2c [project @ 1995-04-11 17:49:27 by jwe]
jwe
parents: 1245
diff changeset
56 const Complex*, const int&, double&,
fa24599e3d2c [project @ 1995-04-11 17:49:27 by jwe]
jwe
parents: 1245
diff changeset
57 int&, long, long);
47
ed620db95182 [project @ 1993-08-10 23:02:53 by jwe]
jwe
parents: 46
diff changeset
58 }
37
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
59
701
0a81458ef677 [project @ 1994-09-15 02:23:24 by jwe]
jwe
parents: 636
diff changeset
60 DEFUN_DLD_BUILTIN ("syl", Fsyl, Ssyl, 4, 1,
519
b9284136189a [project @ 1994-07-19 14:40:20 by jwe]
jwe
parents: 516
diff changeset
61 "X = syl (A, B, C): solve the Sylvester equation A X + X B + C = 0")
37
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
62 {
497
88614b380d6e [project @ 1994-07-08 02:00:57 by jwe]
jwe
parents: 453
diff changeset
63 Octave_object retval;
37
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
64
712
36ba0576bd1b [project @ 1994-09-19 14:18:15 by jwe]
jwe
parents: 701
diff changeset
65 int nargin = args.length ();
36ba0576bd1b [project @ 1994-09-19 14:18:15 by jwe]
jwe
parents: 701
diff changeset
66
36ba0576bd1b [project @ 1994-09-19 14:18:15 by jwe]
jwe
parents: 701
diff changeset
67 if (nargin != 3 || nargout > 1)
519
b9284136189a [project @ 1994-07-19 14:40:20 by jwe]
jwe
parents: 516
diff changeset
68 {
b9284136189a [project @ 1994-07-19 14:40:20 by jwe]
jwe
parents: 516
diff changeset
69 print_usage ("syl");
b9284136189a [project @ 1994-07-19 14:40:20 by jwe]
jwe
parents: 516
diff changeset
70 return retval;
b9284136189a [project @ 1994-07-19 14:40:20 by jwe]
jwe
parents: 516
diff changeset
71 }
b9284136189a [project @ 1994-07-19 14:40:20 by jwe]
jwe
parents: 516
diff changeset
72
712
36ba0576bd1b [project @ 1994-09-19 14:18:15 by jwe]
jwe
parents: 701
diff changeset
73 tree_constant arg_a = args(0);
36ba0576bd1b [project @ 1994-09-19 14:18:15 by jwe]
jwe
parents: 701
diff changeset
74 tree_constant arg_b = args(1);
36ba0576bd1b [project @ 1994-09-19 14:18:15 by jwe]
jwe
parents: 701
diff changeset
75 tree_constant arg_c = args(2);
636
fae2bd91c027 [project @ 1994-08-23 18:39:50 by jwe]
jwe
parents: 628
diff changeset
76
fae2bd91c027 [project @ 1994-08-23 18:39:50 by jwe]
jwe
parents: 628
diff changeset
77 int a_nr = arg_a.rows ();
fae2bd91c027 [project @ 1994-08-23 18:39:50 by jwe]
jwe
parents: 628
diff changeset
78 int a_nc = arg_a.columns ();
37
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
79
636
fae2bd91c027 [project @ 1994-08-23 18:39:50 by jwe]
jwe
parents: 628
diff changeset
80 int b_nr = arg_b.rows ();
fae2bd91c027 [project @ 1994-08-23 18:39:50 by jwe]
jwe
parents: 628
diff changeset
81 int b_nc = arg_b.columns ();
fae2bd91c027 [project @ 1994-08-23 18:39:50 by jwe]
jwe
parents: 628
diff changeset
82
fae2bd91c027 [project @ 1994-08-23 18:39:50 by jwe]
jwe
parents: 628
diff changeset
83 int c_nr = arg_c.rows ();
fae2bd91c027 [project @ 1994-08-23 18:39:50 by jwe]
jwe
parents: 628
diff changeset
84 int c_nc = arg_c.columns ();
718
e81d3a66725e [project @ 1994-09-21 14:58:18 by jwe]
jwe
parents: 712
diff changeset
85
e81d3a66725e [project @ 1994-09-21 14:58:18 by jwe]
jwe
parents: 712
diff changeset
86 int arg_a_is_empty = empty_arg ("syl", a_nr, a_nc);
e81d3a66725e [project @ 1994-09-21 14:58:18 by jwe]
jwe
parents: 712
diff changeset
87 int arg_b_is_empty = empty_arg ("syl", b_nr, b_nc);
e81d3a66725e [project @ 1994-09-21 14:58:18 by jwe]
jwe
parents: 712
diff changeset
88 int arg_c_is_empty = empty_arg ("syl", c_nr, c_nc);
e81d3a66725e [project @ 1994-09-21 14:58:18 by jwe]
jwe
parents: 712
diff changeset
89
e81d3a66725e [project @ 1994-09-21 14:58:18 by jwe]
jwe
parents: 712
diff changeset
90 if (arg_a_is_empty > 0 && arg_b_is_empty > 0 && arg_c_is_empty > 0)
e81d3a66725e [project @ 1994-09-21 14:58:18 by jwe]
jwe
parents: 712
diff changeset
91 return Matrix ();
e81d3a66725e [project @ 1994-09-21 14:58:18 by jwe]
jwe
parents: 712
diff changeset
92 else if (arg_a_is_empty || arg_b_is_empty || arg_c_is_empty)
636
fae2bd91c027 [project @ 1994-08-23 18:39:50 by jwe]
jwe
parents: 628
diff changeset
93 return retval;
37
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
94
1357
749071f48336 [project @ 1995-09-05 20:28:59 by jwe]
jwe
parents: 1352
diff changeset
95 // Arguments are not empty, so check for correct dimensions.
37
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
96
636
fae2bd91c027 [project @ 1994-08-23 18:39:50 by jwe]
jwe
parents: 628
diff changeset
97 if (a_nr != a_nc || b_nr != b_nc)
fae2bd91c027 [project @ 1994-08-23 18:39:50 by jwe]
jwe
parents: 628
diff changeset
98 {
fae2bd91c027 [project @ 1994-08-23 18:39:50 by jwe]
jwe
parents: 628
diff changeset
99 gripe_square_matrix_required ("syl: first two parameters:");
fae2bd91c027 [project @ 1994-08-23 18:39:50 by jwe]
jwe
parents: 628
diff changeset
100 return retval;
fae2bd91c027 [project @ 1994-08-23 18:39:50 by jwe]
jwe
parents: 628
diff changeset
101 }
fae2bd91c027 [project @ 1994-08-23 18:39:50 by jwe]
jwe
parents: 628
diff changeset
102 else if (a_nr != c_nr || b_nr != c_nc)
fae2bd91c027 [project @ 1994-08-23 18:39:50 by jwe]
jwe
parents: 628
diff changeset
103 {
fae2bd91c027 [project @ 1994-08-23 18:39:50 by jwe]
jwe
parents: 628
diff changeset
104 gripe_nonconformant ();
fae2bd91c027 [project @ 1994-08-23 18:39:50 by jwe]
jwe
parents: 628
diff changeset
105 return retval;
fae2bd91c027 [project @ 1994-08-23 18:39:50 by jwe]
jwe
parents: 628
diff changeset
106 }
37
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
107
1357
749071f48336 [project @ 1995-09-05 20:28:59 by jwe]
jwe
parents: 1352
diff changeset
108 // Dimensions look o.k., let's solve the problem.
37
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
109
636
fae2bd91c027 [project @ 1994-08-23 18:39:50 by jwe]
jwe
parents: 628
diff changeset
110 if (arg_a.is_complex_type ()
fae2bd91c027 [project @ 1994-08-23 18:39:50 by jwe]
jwe
parents: 628
diff changeset
111 || arg_b.is_complex_type ()
fae2bd91c027 [project @ 1994-08-23 18:39:50 by jwe]
jwe
parents: 628
diff changeset
112 || arg_c.is_complex_type ())
37
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
113 {
1357
749071f48336 [project @ 1995-09-05 20:28:59 by jwe]
jwe
parents: 1352
diff changeset
114 // Do everything in complex arithmetic;
37
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
115
636
fae2bd91c027 [project @ 1994-08-23 18:39:50 by jwe]
jwe
parents: 628
diff changeset
116 ComplexMatrix ca = arg_a.complex_matrix_value ();
fae2bd91c027 [project @ 1994-08-23 18:39:50 by jwe]
jwe
parents: 628
diff changeset
117
fae2bd91c027 [project @ 1994-08-23 18:39:50 by jwe]
jwe
parents: 628
diff changeset
118 if (error_state)
fae2bd91c027 [project @ 1994-08-23 18:39:50 by jwe]
jwe
parents: 628
diff changeset
119 return retval;
fae2bd91c027 [project @ 1994-08-23 18:39:50 by jwe]
jwe
parents: 628
diff changeset
120
fae2bd91c027 [project @ 1994-08-23 18:39:50 by jwe]
jwe
parents: 628
diff changeset
121 ComplexMatrix cb = arg_b.complex_matrix_value ();
fae2bd91c027 [project @ 1994-08-23 18:39:50 by jwe]
jwe
parents: 628
diff changeset
122
fae2bd91c027 [project @ 1994-08-23 18:39:50 by jwe]
jwe
parents: 628
diff changeset
123 if (error_state)
fae2bd91c027 [project @ 1994-08-23 18:39:50 by jwe]
jwe
parents: 628
diff changeset
124 return retval;
fae2bd91c027 [project @ 1994-08-23 18:39:50 by jwe]
jwe
parents: 628
diff changeset
125
fae2bd91c027 [project @ 1994-08-23 18:39:50 by jwe]
jwe
parents: 628
diff changeset
126 ComplexMatrix cc = arg_c.complex_matrix_value ();
fae2bd91c027 [project @ 1994-08-23 18:39:50 by jwe]
jwe
parents: 628
diff changeset
127
fae2bd91c027 [project @ 1994-08-23 18:39:50 by jwe]
jwe
parents: 628
diff changeset
128 if (error_state)
fae2bd91c027 [project @ 1994-08-23 18:39:50 by jwe]
jwe
parents: 628
diff changeset
129 return retval;
fae2bd91c027 [project @ 1994-08-23 18:39:50 by jwe]
jwe
parents: 628
diff changeset
130
1357
749071f48336 [project @ 1995-09-05 20:28:59 by jwe]
jwe
parents: 1352
diff changeset
131 // Compute Schur decompositions
37
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
132
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
133 ComplexSCHUR as (ca, "U");
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
134 ComplexSCHUR bs (cb, "U");
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
135
1357
749071f48336 [project @ 1995-09-05 20:28:59 by jwe]
jwe
parents: 1352
diff changeset
136 // Transform cc to new coordinates.
37
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
137
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
138 ComplexMatrix ua = as.unitary_matrix ();
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
139 ComplexMatrix sch_a = as.schur_matrix ();
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
140 ComplexMatrix ub = bs.unitary_matrix ();
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
141 ComplexMatrix sch_b = bs.schur_matrix ();
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
142
46
80ea39e3c917 [project @ 1993-08-10 22:58:17 by jwe]
jwe
parents: 43
diff changeset
143 ComplexMatrix cx = ua.hermitian () * cc * ub;
37
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
144
1357
749071f48336 [project @ 1995-09-05 20:28:59 by jwe]
jwe
parents: 1352
diff changeset
145 // Solve the sylvester equation, back-transform, and return
749071f48336 [project @ 1995-09-05 20:28:59 by jwe]
jwe
parents: 1352
diff changeset
146 // the solution.
37
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
147
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
148 double scale;
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
149 int info;
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
150
1255
fa24599e3d2c [project @ 1995-04-11 17:49:27 by jwe]
jwe
parents: 1245
diff changeset
151 F77_FCN (ztrsyl, ZTRSYL) ("N", "N", 1, a_nr, b_nr,
fa24599e3d2c [project @ 1995-04-11 17:49:27 by jwe]
jwe
parents: 1245
diff changeset
152 sch_a.fortran_vec (), a_nr,
fa24599e3d2c [project @ 1995-04-11 17:49:27 by jwe]
jwe
parents: 1245
diff changeset
153 sch_b.fortran_vec (), b_nr,
fa24599e3d2c [project @ 1995-04-11 17:49:27 by jwe]
jwe
parents: 1245
diff changeset
154 cx.fortran_vec (), a_nr, scale,
fa24599e3d2c [project @ 1995-04-11 17:49:27 by jwe]
jwe
parents: 1245
diff changeset
155 info, 1L, 1L);
37
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
156
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
157 cx = -ua * cx * ub.hermitian ();
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
158
636
fae2bd91c027 [project @ 1994-08-23 18:39:50 by jwe]
jwe
parents: 628
diff changeset
159 retval = cx;
37
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
160 }
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
161 else
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
162 {
1357
749071f48336 [project @ 1995-09-05 20:28:59 by jwe]
jwe
parents: 1352
diff changeset
163 // Do everything in real arithmetic.
37
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
164
636
fae2bd91c027 [project @ 1994-08-23 18:39:50 by jwe]
jwe
parents: 628
diff changeset
165 Matrix ca = arg_a.matrix_value ();
fae2bd91c027 [project @ 1994-08-23 18:39:50 by jwe]
jwe
parents: 628
diff changeset
166
fae2bd91c027 [project @ 1994-08-23 18:39:50 by jwe]
jwe
parents: 628
diff changeset
167 if (error_state)
fae2bd91c027 [project @ 1994-08-23 18:39:50 by jwe]
jwe
parents: 628
diff changeset
168 return retval;
fae2bd91c027 [project @ 1994-08-23 18:39:50 by jwe]
jwe
parents: 628
diff changeset
169
fae2bd91c027 [project @ 1994-08-23 18:39:50 by jwe]
jwe
parents: 628
diff changeset
170 Matrix cb = arg_b.matrix_value ();
fae2bd91c027 [project @ 1994-08-23 18:39:50 by jwe]
jwe
parents: 628
diff changeset
171
fae2bd91c027 [project @ 1994-08-23 18:39:50 by jwe]
jwe
parents: 628
diff changeset
172 if (error_state)
fae2bd91c027 [project @ 1994-08-23 18:39:50 by jwe]
jwe
parents: 628
diff changeset
173 return retval;
fae2bd91c027 [project @ 1994-08-23 18:39:50 by jwe]
jwe
parents: 628
diff changeset
174
fae2bd91c027 [project @ 1994-08-23 18:39:50 by jwe]
jwe
parents: 628
diff changeset
175 Matrix cc = arg_c.matrix_value ();
fae2bd91c027 [project @ 1994-08-23 18:39:50 by jwe]
jwe
parents: 628
diff changeset
176
fae2bd91c027 [project @ 1994-08-23 18:39:50 by jwe]
jwe
parents: 628
diff changeset
177 if (error_state)
fae2bd91c027 [project @ 1994-08-23 18:39:50 by jwe]
jwe
parents: 628
diff changeset
178 return retval;
fae2bd91c027 [project @ 1994-08-23 18:39:50 by jwe]
jwe
parents: 628
diff changeset
179
1357
749071f48336 [project @ 1995-09-05 20:28:59 by jwe]
jwe
parents: 1352
diff changeset
180 // Compute Schur decompositions.
37
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
181
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
182 SCHUR as (ca, "U");
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
183 SCHUR bs (cb, "U");
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
184
1357
749071f48336 [project @ 1995-09-05 20:28:59 by jwe]
jwe
parents: 1352
diff changeset
185 // Transform cc to new coordinates.
37
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
186
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
187 Matrix ua = as.unitary_matrix ();
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
188 Matrix sch_a = as.schur_matrix ();
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
189 Matrix ub = bs.unitary_matrix ();
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
190 Matrix sch_b = bs.schur_matrix ();
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
191
46
80ea39e3c917 [project @ 1993-08-10 22:58:17 by jwe]
jwe
parents: 43
diff changeset
192 Matrix cx = ua.transpose () * cc * ub;
37
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
193
1357
749071f48336 [project @ 1995-09-05 20:28:59 by jwe]
jwe
parents: 1352
diff changeset
194 // Solve the sylvester equation, back-transform, and return
749071f48336 [project @ 1995-09-05 20:28:59 by jwe]
jwe
parents: 1352
diff changeset
195 // the solution.
37
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
196
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
197 double scale;
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
198 int info;
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
199
1255
fa24599e3d2c [project @ 1995-04-11 17:49:27 by jwe]
jwe
parents: 1245
diff changeset
200 F77_FCN (dtrsyl, DTRSYL) ("N", "N", 1, a_nr, b_nr,
fa24599e3d2c [project @ 1995-04-11 17:49:27 by jwe]
jwe
parents: 1245
diff changeset
201 sch_a.fortran_vec (), a_nr,
fa24599e3d2c [project @ 1995-04-11 17:49:27 by jwe]
jwe
parents: 1245
diff changeset
202 sch_b.fortran_vec (), b_nr,
fa24599e3d2c [project @ 1995-04-11 17:49:27 by jwe]
jwe
parents: 1245
diff changeset
203 cx.fortran_vec (), a_nr, scale,
fa24599e3d2c [project @ 1995-04-11 17:49:27 by jwe]
jwe
parents: 1245
diff changeset
204 info, 1L, 1L);
37
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
205
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
206 if (info)
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
207 error ("syl: trouble in dtrsyl info = %d", info);
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
208
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
209 cx = -ua*cx*ub.transpose ();
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
210
636
fae2bd91c027 [project @ 1994-08-23 18:39:50 by jwe]
jwe
parents: 628
diff changeset
211 retval = cx;
37
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
212 }
636
fae2bd91c027 [project @ 1994-08-23 18:39:50 by jwe]
jwe
parents: 628
diff changeset
213
37
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
214 return retval;
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
215 }
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
216
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
217 /*
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
218 ;;; Local Variables: ***
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
219 ;;; mode: C++ ***
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
220 ;;; page-delimiter: "^/\\*" ***
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
221 ;;; End: ***
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
222 */