Mercurial > hg > octave-lyh
annotate scripts/linear-algebra/qzhess.m @ 16385:a1690c3e93eb
move hook_function constructor to .cc file
* hook-fcn.cc: New file. Move hook_function::hook_function definition
here from hook-fcn.h.
* libinterp/interpfcn/module.mk (INTERPFCN_SRC): Include hook-fcn.cc
in the list.
author | John W. Eaton <jwe@octave.org> |
---|---|
date | Thu, 28 Mar 2013 02:52:18 -0400 |
parents | f3d52523cde1 |
children | 53eaa83e4181 |
rev | line source |
---|---|
14138
72c96de7a403
maint: update copyright notices for 2012
John W. Eaton <jwe@octave.org>
parents:
13048
diff
changeset
|
1 ## Copyright (C) 1993-2012 John W. Eaton |
2313 | 2 ## |
3 ## This file is part of Octave. | |
4 ## | |
5 ## Octave is free software; you can redistribute it and/or modify it | |
6 ## under the terms of the GNU General Public License as published by | |
7016 | 7 ## the Free Software Foundation; either version 3 of the License, or (at |
8 ## your option) any later version. | |
2313 | 9 ## |
10 ## Octave is distributed in the hope that it will be useful, but | |
11 ## WITHOUT ANY WARRANTY; without even the implied warranty of | |
12 ## MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU | |
13 ## General Public License for more details. | |
14 ## | |
15 ## You should have received a copy of the GNU General Public License | |
7016 | 16 ## along with Octave; see the file COPYING. If not, see |
17 ## <http://www.gnu.org/licenses/>. | |
245 | 18 |
3372 | 19 ## -*- texinfo -*- |
11471
994e2a93a8e2
Use uppercase 'A' to refer to matrix inputs in m-files.
Rik <octave@nomad.inbox5.com>
parents:
10821
diff
changeset
|
20 ## @deftypefn {Function File} {[@var{aa}, @var{bb}, @var{q}, @var{z}] =} qzhess (@var{A}, @var{B}) |
3372 | 21 ## Compute the Hessenberg-triangular decomposition of the matrix pencil |
11471
994e2a93a8e2
Use uppercase 'A' to refer to matrix inputs in m-files.
Rik <octave@nomad.inbox5.com>
parents:
10821
diff
changeset
|
22 ## @code{(@var{A}, @var{B})}, returning |
994e2a93a8e2
Use uppercase 'A' to refer to matrix inputs in m-files.
Rik <octave@nomad.inbox5.com>
parents:
10821
diff
changeset
|
23 ## @code{@var{aa} = @var{q} * @var{A} * @var{z}}, |
994e2a93a8e2
Use uppercase 'A' to refer to matrix inputs in m-files.
Rik <octave@nomad.inbox5.com>
parents:
10821
diff
changeset
|
24 ## @code{@var{bb} = @var{q} * @var{B} * @var{z}}, with @var{q} and @var{z} |
10821
693e22af08ae
Grammarcheck documentation of m-files
Rik <octave@nomad.inbox5.com>
parents:
7017
diff
changeset
|
25 ## orthogonal. For example: |
3426 | 26 ## |
3372 | 27 ## @example |
28 ## @group | |
29 ## [aa, bb, q, z] = qzhess ([1, 2; 3, 4], [5, 6; 7, 8]) | |
30 ## @result{} aa = [ -3.02244, -4.41741; 0.92998, 0.69749 ] | |
31 ## @result{} bb = [ -8.60233, -9.99730; 0.00000, -0.23250 ] | |
32 ## @result{} q = [ -0.58124, -0.81373; -0.81373, 0.58124 ] | |
33 ## @result{} z = [ 1, 0; 0, 1 ] | |
34 ## @end group | |
35 ## @end example | |
3426 | 36 ## |
3372 | 37 ## The Hessenberg-triangular decomposition is the first step in |
11593
1577c6f80926
Use non-breaking spaces between certain adjectives and their nouns in docstrings.
Rik <octave@nomad.inbox5.com>
parents:
11523
diff
changeset
|
38 ## Moler and Stewart's QZ@tie{}decomposition algorithm. |
3426 | 39 ## |
14327
4d917a6a858b
doc: Use Octave coding conventions in @example blocks of docstrings.
Rik <octave@nomad.inbox5.com>
parents:
14138
diff
changeset
|
40 ## Algorithm taken from Golub and Van Loan, |
4d917a6a858b
doc: Use Octave coding conventions in @example blocks of docstrings.
Rik <octave@nomad.inbox5.com>
parents:
14138
diff
changeset
|
41 ## @cite{Matrix Computations, 2nd edition}. |
3372 | 42 ## @end deftypefn |
29 | 43 |
2312 | 44 ## Author: A. S. Hodel <scotte@eng.auburn.edu> |
45 ## Created: August 1993 | |
46 ## Adapted-By: jwe | |
29 | 47 |
11471
994e2a93a8e2
Use uppercase 'A' to refer to matrix inputs in m-files.
Rik <octave@nomad.inbox5.com>
parents:
10821
diff
changeset
|
48 function [aa, bb, q, z] = qzhess (A, B) |
72 | 49 |
54 | 50 if (nargin != 2) |
6046 | 51 print_usage (); |
54 | 52 endif |
53 | |
11471
994e2a93a8e2
Use uppercase 'A' to refer to matrix inputs in m-files.
Rik <octave@nomad.inbox5.com>
parents:
10821
diff
changeset
|
54 [na, ma] = size (A); |
994e2a93a8e2
Use uppercase 'A' to refer to matrix inputs in m-files.
Rik <octave@nomad.inbox5.com>
parents:
10821
diff
changeset
|
55 [nb, mb] = size (B); |
54 | 56 if (na != ma || na != nb || nb != mb) |
57 error ("qzhess: incompatible dimensions"); | |
58 endif | |
59 | |
2303 | 60 ## Reduce to hessenberg-triangular form. |
29 | 61 |
11471
994e2a93a8e2
Use uppercase 'A' to refer to matrix inputs in m-files.
Rik <octave@nomad.inbox5.com>
parents:
10821
diff
changeset
|
62 [q, bb] = qr (B); |
994e2a93a8e2
Use uppercase 'A' to refer to matrix inputs in m-files.
Rik <octave@nomad.inbox5.com>
parents:
10821
diff
changeset
|
63 aa = q' * A; |
54 | 64 q = q'; |
65 z = eye (na); | |
66 for j = 1:(na-2) | |
67 for i = na:-1:(j+2) | |
68 | |
2303 | 69 ## disp (["zero out aa(", num2str(i), ",", num2str(j), ")"]) |
54 | 70 |
71 rot = givens (aa (i-1, j), aa (i, j)); | |
72 aa ((i-1):i, :) = rot *aa ((i-1):i, :); | |
73 bb ((i-1):i, :) = rot *bb ((i-1):i, :); | |
74 q ((i-1):i, :) = rot *q ((i-1):i, :); | |
75 | |
2303 | 76 ## disp (["now zero out bb(", num2str(i), ",", num2str(i-1), ")"]) |
54 | 77 |
78 rot = givens (bb (i, i), bb (i, i-1))'; | |
79 bb (:, (i-1):i) = bb (:, (i-1):i) * rot'; | |
80 aa (:, (i-1):i) = aa (:, (i-1):i) * rot'; | |
81 z (:, (i-1):i) = z (:, (i-1):i) * rot'; | |
82 | |
83 endfor | |
29 | 84 endfor |
85 | |
54 | 86 bb (2, 1) = 0.0; |
87 for i = 3:na | |
88 bb (i, 1:(i-1)) = zeros (1, i-1); | |
89 aa (i, 1:(i-2)) = zeros (1, i-2); | |
90 endfor | |
91 | |
29 | 92 endfunction |
13048
c5c94b63931f
codesprint: linear algebra tests: cross, housh, planerot, qzhess, rref
Roman Belov <romblv@gmail.com>
parents:
11593
diff
changeset
|
93 |
14363
f3d52523cde1
Use Octave coding conventions in all m-file %!test blocks
Rik <octave@nomad.inbox5.com>
parents:
14327
diff
changeset
|
94 |
13048
c5c94b63931f
codesprint: linear algebra tests: cross, housh, planerot, qzhess, rref
Roman Belov <romblv@gmail.com>
parents:
11593
diff
changeset
|
95 %!test |
c5c94b63931f
codesprint: linear algebra tests: cross, housh, planerot, qzhess, rref
Roman Belov <romblv@gmail.com>
parents:
11593
diff
changeset
|
96 %! a = [1 2 1 3; |
c5c94b63931f
codesprint: linear algebra tests: cross, housh, planerot, qzhess, rref
Roman Belov <romblv@gmail.com>
parents:
11593
diff
changeset
|
97 %! 2 5 3 2; |
c5c94b63931f
codesprint: linear algebra tests: cross, housh, planerot, qzhess, rref
Roman Belov <romblv@gmail.com>
parents:
11593
diff
changeset
|
98 %! 5 5 1 0; |
c5c94b63931f
codesprint: linear algebra tests: cross, housh, planerot, qzhess, rref
Roman Belov <romblv@gmail.com>
parents:
11593
diff
changeset
|
99 %! 4 0 3 2]; |
c5c94b63931f
codesprint: linear algebra tests: cross, housh, planerot, qzhess, rref
Roman Belov <romblv@gmail.com>
parents:
11593
diff
changeset
|
100 %! b = [0 4 2 1; |
c5c94b63931f
codesprint: linear algebra tests: cross, housh, planerot, qzhess, rref
Roman Belov <romblv@gmail.com>
parents:
11593
diff
changeset
|
101 %! 2 3 1 1; |
c5c94b63931f
codesprint: linear algebra tests: cross, housh, planerot, qzhess, rref
Roman Belov <romblv@gmail.com>
parents:
11593
diff
changeset
|
102 %! 1 0 2 1; |
c5c94b63931f
codesprint: linear algebra tests: cross, housh, planerot, qzhess, rref
Roman Belov <romblv@gmail.com>
parents:
11593
diff
changeset
|
103 %! 2 5 3 2]; |
c5c94b63931f
codesprint: linear algebra tests: cross, housh, planerot, qzhess, rref
Roman Belov <romblv@gmail.com>
parents:
11593
diff
changeset
|
104 %! mask = [0 0 0 0; |
c5c94b63931f
codesprint: linear algebra tests: cross, housh, planerot, qzhess, rref
Roman Belov <romblv@gmail.com>
parents:
11593
diff
changeset
|
105 %! 0 0 0 0; |
c5c94b63931f
codesprint: linear algebra tests: cross, housh, planerot, qzhess, rref
Roman Belov <romblv@gmail.com>
parents:
11593
diff
changeset
|
106 %! 1 0 0 0; |
c5c94b63931f
codesprint: linear algebra tests: cross, housh, planerot, qzhess, rref
Roman Belov <romblv@gmail.com>
parents:
11593
diff
changeset
|
107 %! 1 1 0 0]; |
14363
f3d52523cde1
Use Octave coding conventions in all m-file %!test blocks
Rik <octave@nomad.inbox5.com>
parents:
14327
diff
changeset
|
108 %! [aa, bb, q, z] = qzhess (a, b); |
f3d52523cde1
Use Octave coding conventions in all m-file %!test blocks
Rik <octave@nomad.inbox5.com>
parents:
14327
diff
changeset
|
109 %! assert (inv (q) - q', zeros (4), 2e-8); |
f3d52523cde1
Use Octave coding conventions in all m-file %!test blocks
Rik <octave@nomad.inbox5.com>
parents:
14327
diff
changeset
|
110 %! assert (inv (z) - z', zeros (4), 2e-8); |
f3d52523cde1
Use Octave coding conventions in all m-file %!test blocks
Rik <octave@nomad.inbox5.com>
parents:
14327
diff
changeset
|
111 %! assert (q * a * z, aa, 2e-8); |
f3d52523cde1
Use Octave coding conventions in all m-file %!test blocks
Rik <octave@nomad.inbox5.com>
parents:
14327
diff
changeset
|
112 %! assert (aa .* mask, zeros (4), 2e-8); |
f3d52523cde1
Use Octave coding conventions in all m-file %!test blocks
Rik <octave@nomad.inbox5.com>
parents:
14327
diff
changeset
|
113 %! assert (q * b * z, bb, 2e-8); |
f3d52523cde1
Use Octave coding conventions in all m-file %!test blocks
Rik <octave@nomad.inbox5.com>
parents:
14327
diff
changeset
|
114 %! assert (bb .* mask, zeros (4), 2e-8); |
13048
c5c94b63931f
codesprint: linear algebra tests: cross, housh, planerot, qzhess, rref
Roman Belov <romblv@gmail.com>
parents:
11593
diff
changeset
|
115 |
c5c94b63931f
codesprint: linear algebra tests: cross, housh, planerot, qzhess, rref
Roman Belov <romblv@gmail.com>
parents:
11593
diff
changeset
|
116 %!test |
c5c94b63931f
codesprint: linear algebra tests: cross, housh, planerot, qzhess, rref
Roman Belov <romblv@gmail.com>
parents:
11593
diff
changeset
|
117 %! a = [1 2 3 4 5; |
c5c94b63931f
codesprint: linear algebra tests: cross, housh, planerot, qzhess, rref
Roman Belov <romblv@gmail.com>
parents:
11593
diff
changeset
|
118 %! 3 2 3 1 0; |
c5c94b63931f
codesprint: linear algebra tests: cross, housh, planerot, qzhess, rref
Roman Belov <romblv@gmail.com>
parents:
11593
diff
changeset
|
119 %! 4 3 2 1 1; |
c5c94b63931f
codesprint: linear algebra tests: cross, housh, planerot, qzhess, rref
Roman Belov <romblv@gmail.com>
parents:
11593
diff
changeset
|
120 %! 0 1 0 1 0; |
c5c94b63931f
codesprint: linear algebra tests: cross, housh, planerot, qzhess, rref
Roman Belov <romblv@gmail.com>
parents:
11593
diff
changeset
|
121 %! 3 2 1 0 5]; |
c5c94b63931f
codesprint: linear algebra tests: cross, housh, planerot, qzhess, rref
Roman Belov <romblv@gmail.com>
parents:
11593
diff
changeset
|
122 %! b = [5 0 4 0 1; |
c5c94b63931f
codesprint: linear algebra tests: cross, housh, planerot, qzhess, rref
Roman Belov <romblv@gmail.com>
parents:
11593
diff
changeset
|
123 %! 1 1 1 2 5; |
c5c94b63931f
codesprint: linear algebra tests: cross, housh, planerot, qzhess, rref
Roman Belov <romblv@gmail.com>
parents:
11593
diff
changeset
|
124 %! 0 3 2 1 0; |
c5c94b63931f
codesprint: linear algebra tests: cross, housh, planerot, qzhess, rref
Roman Belov <romblv@gmail.com>
parents:
11593
diff
changeset
|
125 %! 4 3 0 3 5; |
c5c94b63931f
codesprint: linear algebra tests: cross, housh, planerot, qzhess, rref
Roman Belov <romblv@gmail.com>
parents:
11593
diff
changeset
|
126 %! 2 1 2 1 3]; |
c5c94b63931f
codesprint: linear algebra tests: cross, housh, planerot, qzhess, rref
Roman Belov <romblv@gmail.com>
parents:
11593
diff
changeset
|
127 %! mask = [0 0 0 0 0; |
c5c94b63931f
codesprint: linear algebra tests: cross, housh, planerot, qzhess, rref
Roman Belov <romblv@gmail.com>
parents:
11593
diff
changeset
|
128 %! 0 0 0 0 0; |
c5c94b63931f
codesprint: linear algebra tests: cross, housh, planerot, qzhess, rref
Roman Belov <romblv@gmail.com>
parents:
11593
diff
changeset
|
129 %! 1 0 0 0 0; |
c5c94b63931f
codesprint: linear algebra tests: cross, housh, planerot, qzhess, rref
Roman Belov <romblv@gmail.com>
parents:
11593
diff
changeset
|
130 %! 1 1 0 0 0; |
c5c94b63931f
codesprint: linear algebra tests: cross, housh, planerot, qzhess, rref
Roman Belov <romblv@gmail.com>
parents:
11593
diff
changeset
|
131 %! 1 1 1 0 0]; |
14363
f3d52523cde1
Use Octave coding conventions in all m-file %!test blocks
Rik <octave@nomad.inbox5.com>
parents:
14327
diff
changeset
|
132 %! [aa, bb, q, z] = qzhess (a, b); |
f3d52523cde1
Use Octave coding conventions in all m-file %!test blocks
Rik <octave@nomad.inbox5.com>
parents:
14327
diff
changeset
|
133 %! assert (inv (q) - q', zeros (5), 2e-8); |
f3d52523cde1
Use Octave coding conventions in all m-file %!test blocks
Rik <octave@nomad.inbox5.com>
parents:
14327
diff
changeset
|
134 %! assert (inv (z) - z', zeros (5), 2e-8); |
f3d52523cde1
Use Octave coding conventions in all m-file %!test blocks
Rik <octave@nomad.inbox5.com>
parents:
14327
diff
changeset
|
135 %! assert (q * a * z, aa, 2e-8); |
f3d52523cde1
Use Octave coding conventions in all m-file %!test blocks
Rik <octave@nomad.inbox5.com>
parents:
14327
diff
changeset
|
136 %! assert (aa .* mask, zeros (5), 2e-8); |
f3d52523cde1
Use Octave coding conventions in all m-file %!test blocks
Rik <octave@nomad.inbox5.com>
parents:
14327
diff
changeset
|
137 %! assert (q * b * z, bb, 2e-8); |
f3d52523cde1
Use Octave coding conventions in all m-file %!test blocks
Rik <octave@nomad.inbox5.com>
parents:
14327
diff
changeset
|
138 %! assert (bb .* mask, zeros (5), 2e-8); |
13048
c5c94b63931f
codesprint: linear algebra tests: cross, housh, planerot, qzhess, rref
Roman Belov <romblv@gmail.com>
parents:
11593
diff
changeset
|
139 |
14363
f3d52523cde1
Use Octave coding conventions in all m-file %!test blocks
Rik <octave@nomad.inbox5.com>
parents:
14327
diff
changeset
|
140 %!error qzhess ([0]) |
f3d52523cde1
Use Octave coding conventions in all m-file %!test blocks
Rik <octave@nomad.inbox5.com>
parents:
14327
diff
changeset
|
141 %!error qzhess () |
13048
c5c94b63931f
codesprint: linear algebra tests: cross, housh, planerot, qzhess, rref
Roman Belov <romblv@gmail.com>
parents:
11593
diff
changeset
|
142 |