annotate src/syl.cc @ 1245:85d1899047e1

[project @ 1995-04-11 00:45:35 by jwe]
author jwe
date Tue, 11 Apr 1995 00:45:35 +0000
parents b6360f2d4fa6
children fa24599e3d2c
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
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
20 Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA.
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
453
393e95f46b51 [project @ 1994-06-06 00:05:20 by jwe]
jwe
parents: 240
diff changeset
30 #include "dMatrix.h"
393e95f46b51 [project @ 1994-06-06 00:05:20 by jwe]
jwe
parents: 240
diff changeset
31 #include "CMatrix.h"
393e95f46b51 [project @ 1994-06-06 00:05:20 by jwe]
jwe
parents: 240
diff changeset
32 #include "dbleSCHUR.h"
393e95f46b51 [project @ 1994-06-06 00:05:20 by jwe]
jwe
parents: 240
diff changeset
33 #include "CmplxSCHUR.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
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
36 #include "tree-const.h"
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
37 #include "user-prefs.h"
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
38 #include "gripes.h"
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
39 #include "error.h"
636
fae2bd91c027 [project @ 1994-08-23 18:39:50 by jwe]
jwe
parents: 628
diff changeset
40 #include "utils.h"
544
20fbad23ae51 [project @ 1994-07-22 05:04:44 by jwe]
jwe
parents: 519
diff changeset
41 #include "help.h"
519
b9284136189a [project @ 1994-07-19 14:40:20 by jwe]
jwe
parents: 516
diff changeset
42 #include "defun-dld.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 {
1245
85d1899047e1 [project @ 1995-04-11 00:45:35 by jwe]
jwe
parents: 1192
diff changeset
46 int F77_FCN (dtrsyl) (const char*, const char*, const int&,
85d1899047e1 [project @ 1995-04-11 00:45:35 by jwe]
jwe
parents: 1192
diff changeset
47 const int&, const int&, const double*,
85d1899047e1 [project @ 1995-04-11 00:45:35 by jwe]
jwe
parents: 1192
diff changeset
48 const int&, const double*, const int&,
85d1899047e1 [project @ 1995-04-11 00:45:35 by jwe]
jwe
parents: 1192
diff changeset
49 const double*, const int&, double&, int&,
47
ed620db95182 [project @ 1993-08-10 23:02:53 by jwe]
jwe
parents: 46
diff changeset
50 long, long);
37
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
51
1245
85d1899047e1 [project @ 1995-04-11 00:45:35 by jwe]
jwe
parents: 1192
diff changeset
52 int F77_FCN (ztrsyl) (const char*, const char*, const int&,
85d1899047e1 [project @ 1995-04-11 00:45:35 by jwe]
jwe
parents: 1192
diff changeset
53 const int&, const int&, const Complex*,
85d1899047e1 [project @ 1995-04-11 00:45:35 by jwe]
jwe
parents: 1192
diff changeset
54 const int&, const Complex*, const int&,
85d1899047e1 [project @ 1995-04-11 00:45:35 by jwe]
jwe
parents: 1192
diff changeset
55 const Complex*, const int&, double&, int&,
47
ed620db95182 [project @ 1993-08-10 23:02:53 by jwe]
jwe
parents: 46
diff changeset
56 long, long);
ed620db95182 [project @ 1993-08-10 23:02:53 by jwe]
jwe
parents: 46
diff changeset
57 }
37
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
58
701
0a81458ef677 [project @ 1994-09-15 02:23:24 by jwe]
jwe
parents: 636
diff changeset
59 DEFUN_DLD_BUILTIN ("syl", Fsyl, Ssyl, 4, 1,
519
b9284136189a [project @ 1994-07-19 14:40:20 by jwe]
jwe
parents: 516
diff changeset
60 "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
61 {
497
88614b380d6e [project @ 1994-07-08 02:00:57 by jwe]
jwe
parents: 453
diff changeset
62 Octave_object retval;
37
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
63
712
36ba0576bd1b [project @ 1994-09-19 14:18:15 by jwe]
jwe
parents: 701
diff changeset
64 int nargin = args.length ();
36ba0576bd1b [project @ 1994-09-19 14:18:15 by jwe]
jwe
parents: 701
diff changeset
65
36ba0576bd1b [project @ 1994-09-19 14:18:15 by jwe]
jwe
parents: 701
diff changeset
66 if (nargin != 3 || nargout > 1)
519
b9284136189a [project @ 1994-07-19 14:40:20 by jwe]
jwe
parents: 516
diff changeset
67 {
b9284136189a [project @ 1994-07-19 14:40:20 by jwe]
jwe
parents: 516
diff changeset
68 print_usage ("syl");
b9284136189a [project @ 1994-07-19 14:40:20 by jwe]
jwe
parents: 516
diff changeset
69 return retval;
b9284136189a [project @ 1994-07-19 14:40:20 by jwe]
jwe
parents: 516
diff changeset
70 }
b9284136189a [project @ 1994-07-19 14:40:20 by jwe]
jwe
parents: 516
diff changeset
71
712
36ba0576bd1b [project @ 1994-09-19 14:18:15 by jwe]
jwe
parents: 701
diff changeset
72 tree_constant arg_a = args(0);
36ba0576bd1b [project @ 1994-09-19 14:18:15 by jwe]
jwe
parents: 701
diff changeset
73 tree_constant arg_b = args(1);
36ba0576bd1b [project @ 1994-09-19 14:18:15 by jwe]
jwe
parents: 701
diff changeset
74 tree_constant arg_c = args(2);
636
fae2bd91c027 [project @ 1994-08-23 18:39:50 by jwe]
jwe
parents: 628
diff changeset
75
fae2bd91c027 [project @ 1994-08-23 18:39:50 by jwe]
jwe
parents: 628
diff changeset
76 int a_nr = arg_a.rows ();
fae2bd91c027 [project @ 1994-08-23 18:39:50 by jwe]
jwe
parents: 628
diff changeset
77 int a_nc = arg_a.columns ();
37
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
78
636
fae2bd91c027 [project @ 1994-08-23 18:39:50 by jwe]
jwe
parents: 628
diff changeset
79 int b_nr = arg_b.rows ();
fae2bd91c027 [project @ 1994-08-23 18:39:50 by jwe]
jwe
parents: 628
diff changeset
80 int b_nc = arg_b.columns ();
fae2bd91c027 [project @ 1994-08-23 18:39:50 by jwe]
jwe
parents: 628
diff changeset
81
fae2bd91c027 [project @ 1994-08-23 18:39:50 by jwe]
jwe
parents: 628
diff changeset
82 int c_nr = arg_c.rows ();
fae2bd91c027 [project @ 1994-08-23 18:39:50 by jwe]
jwe
parents: 628
diff changeset
83 int c_nc = arg_c.columns ();
718
e81d3a66725e [project @ 1994-09-21 14:58:18 by jwe]
jwe
parents: 712
diff changeset
84
e81d3a66725e [project @ 1994-09-21 14:58:18 by jwe]
jwe
parents: 712
diff changeset
85 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
86 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
87 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
88
e81d3a66725e [project @ 1994-09-21 14:58:18 by jwe]
jwe
parents: 712
diff changeset
89 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
90 return Matrix ();
e81d3a66725e [project @ 1994-09-21 14:58:18 by jwe]
jwe
parents: 712
diff changeset
91 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
92 return retval;
37
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
93
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
94 // Arguments are not empty, so check for correct dimensions.
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
95
636
fae2bd91c027 [project @ 1994-08-23 18:39:50 by jwe]
jwe
parents: 628
diff changeset
96 if (a_nr != a_nc || b_nr != b_nc)
fae2bd91c027 [project @ 1994-08-23 18:39:50 by jwe]
jwe
parents: 628
diff changeset
97 {
fae2bd91c027 [project @ 1994-08-23 18:39:50 by jwe]
jwe
parents: 628
diff changeset
98 gripe_square_matrix_required ("syl: first two parameters:");
fae2bd91c027 [project @ 1994-08-23 18:39:50 by jwe]
jwe
parents: 628
diff changeset
99 return retval;
fae2bd91c027 [project @ 1994-08-23 18:39:50 by jwe]
jwe
parents: 628
diff changeset
100 }
fae2bd91c027 [project @ 1994-08-23 18:39:50 by jwe]
jwe
parents: 628
diff changeset
101 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
102 {
fae2bd91c027 [project @ 1994-08-23 18:39:50 by jwe]
jwe
parents: 628
diff changeset
103 gripe_nonconformant ();
fae2bd91c027 [project @ 1994-08-23 18:39:50 by jwe]
jwe
parents: 628
diff changeset
104 return retval;
fae2bd91c027 [project @ 1994-08-23 18:39:50 by jwe]
jwe
parents: 628
diff changeset
105 }
37
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
106
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
107 // Dimensions look o.k., let's solve the problem.
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
108
636
fae2bd91c027 [project @ 1994-08-23 18:39:50 by jwe]
jwe
parents: 628
diff changeset
109 if (arg_a.is_complex_type ()
fae2bd91c027 [project @ 1994-08-23 18:39:50 by jwe]
jwe
parents: 628
diff changeset
110 || arg_b.is_complex_type ()
fae2bd91c027 [project @ 1994-08-23 18:39:50 by jwe]
jwe
parents: 628
diff changeset
111 || arg_c.is_complex_type ())
37
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
112 {
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
113
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
114 // Do everything in complex arithmetic;
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
37
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
131 // Compute Schur decompositions
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
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
136 // Transform cc to new coordinates.
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
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
145 // Solve the sylvester equation, back-transform, and return the solution.
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
146
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
147 double scale;
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
148 int info;
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
149
1245
85d1899047e1 [project @ 1995-04-11 00:45:35 by jwe]
jwe
parents: 1192
diff changeset
150 F77_FCN (ztrsyl) ("N", "N", 1, a_nr, b_nr,
85d1899047e1 [project @ 1995-04-11 00:45:35 by jwe]
jwe
parents: 1192
diff changeset
151 sch_a.fortran_vec (), a_nr,
85d1899047e1 [project @ 1995-04-11 00:45:35 by jwe]
jwe
parents: 1192
diff changeset
152 sch_b.fortran_vec (), b_nr,
85d1899047e1 [project @ 1995-04-11 00:45:35 by jwe]
jwe
parents: 1192
diff changeset
153 cx.fortran_vec (), a_nr, scale, info,
37
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
154 1L, 1L);
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
155
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
156 cx = -ua * cx * ub.hermitian ();
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
157
636
fae2bd91c027 [project @ 1994-08-23 18:39:50 by jwe]
jwe
parents: 628
diff changeset
158 retval = cx;
37
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
159 }
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
160 else
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
161 {
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
162
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
163 // Do everything in real arithmetic;
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
37
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
180 // Compute Schur decompositions.
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
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
185 // Transform cc to new coordinates.
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
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
194 // Solve the sylvester equation, back-transform, and return the solution.
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
195
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
196 double scale;
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
197 int info;
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
198
1245
85d1899047e1 [project @ 1995-04-11 00:45:35 by jwe]
jwe
parents: 1192
diff changeset
199 F77_FCN (dtrsyl) ("N", "N", 1, a_nr, b_nr,
85d1899047e1 [project @ 1995-04-11 00:45:35 by jwe]
jwe
parents: 1192
diff changeset
200 sch_a.fortran_vec (), a_nr,
85d1899047e1 [project @ 1995-04-11 00:45:35 by jwe]
jwe
parents: 1192
diff changeset
201 sch_b.fortran_vec (), b_nr,
85d1899047e1 [project @ 1995-04-11 00:45:35 by jwe]
jwe
parents: 1192
diff changeset
202 cx.fortran_vec (), a_nr, scale, info,
37
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
203 1L, 1L);
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
204
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
205 if (info)
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
206 error ("syl: trouble in dtrsyl info = %d", info);
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
207
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
208 cx = -ua*cx*ub.transpose ();
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
209
636
fae2bd91c027 [project @ 1994-08-23 18:39:50 by jwe]
jwe
parents: 628
diff changeset
210 retval = cx;
37
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
211 }
636
fae2bd91c027 [project @ 1994-08-23 18:39:50 by jwe]
jwe
parents: 628
diff changeset
212
37
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
213 return retval;
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
214 }
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 ;;; Local Variables: ***
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
218 ;;; mode: C++ ***
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
219 ;;; page-delimiter: "^/\\*" ***
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
220 ;;; End: ***
2947a1ad8ca3 [project @ 1993-08-10 22:12:50 by jwe]
jwe
parents:
diff changeset
221 */