|
kusano |
7d535a |
/* -- translated by f2c (version 19940927).
|
|
kusano |
7d535a |
You must link the resulting object file with the libraries:
|
|
kusano |
7d535a |
-lf2c -lm (in that order)
|
|
kusano |
7d535a |
*/
|
|
kusano |
7d535a |
|
|
kusano |
7d535a |
#include "f2c.h"
|
|
kusano |
7d535a |
|
|
kusano |
7d535a |
/* Table of constant values */
|
|
kusano |
7d535a |
|
|
kusano |
7d535a |
static integer c__4 = 4;
|
|
kusano |
7d535a |
static integer c__8 = 8;
|
|
kusano |
7d535a |
|
|
kusano |
7d535a |
/* Subroutine */ int clarot_(logical *lrows, logical *lleft, logical *lright,
|
|
kusano |
7d535a |
integer *nl, complex *c, complex *s, complex *a, integer *lda,
|
|
kusano |
7d535a |
complex *xleft, complex *xright)
|
|
kusano |
7d535a |
{
|
|
kusano |
7d535a |
/* System generated locals */
|
|
kusano |
7d535a |
integer i__1, i__2, i__3, i__4;
|
|
kusano |
7d535a |
complex q__1, q__2, q__3, q__4, q__5, q__6;
|
|
kusano |
7d535a |
|
|
kusano |
7d535a |
/* Builtin functions */
|
|
kusano |
7d535a |
void r_cnjg(complex *, complex *);
|
|
kusano |
7d535a |
|
|
kusano |
7d535a |
/* Local variables */
|
|
kusano |
7d535a |
static integer iinc, j, inext;
|
|
kusano |
7d535a |
static complex tempx;
|
|
kusano |
7d535a |
static integer ix, iy, nt;
|
|
kusano |
7d535a |
static complex xt[2], yt[2];
|
|
kusano |
7d535a |
extern /* Subroutine */ int xerbla_(char *, integer *);
|
|
kusano |
7d535a |
static integer iyt;
|
|
kusano |
7d535a |
|
|
kusano |
7d535a |
|
|
kusano |
7d535a |
/* -- LAPACK auxiliary test routine (version 2.0) --
|
|
kusano |
7d535a |
Univ. of Tennessee, Univ. of California Berkeley, NAG Ltd.,
|
|
kusano |
7d535a |
Courant Institute, Argonne National Lab, and Rice University
|
|
kusano |
7d535a |
February 29, 1992
|
|
kusano |
7d535a |
|
|
kusano |
7d535a |
|
|
kusano |
7d535a |
Purpose
|
|
kusano |
7d535a |
=======
|
|
kusano |
7d535a |
|
|
kusano |
7d535a |
CLAROT applies a (Givens) rotation to two adjacent rows or
|
|
kusano |
7d535a |
columns, where one element of the first and/or last column/row
|
|
kusano |
7d535a |
may be a separate variable. This is specifically indended
|
|
kusano |
7d535a |
for use on matrices stored in some format other than GE, so
|
|
kusano |
7d535a |
that elements of the matrix may be used or modified for which
|
|
kusano |
7d535a |
no array element is provided.
|
|
kusano |
7d535a |
|
|
kusano |
7d535a |
One example is a symmetric matrix in SB format (bandwidth=4), for
|
|
kusano |
7d535a |
|
|
kusano |
7d535a |
which UPLO='L': Two adjacent rows will have the format:
|
|
kusano |
7d535a |
|
|
kusano |
7d535a |
row j: * * * * * . . . .
|
|
kusano |
7d535a |
row j+1: * * * * * . . . .
|
|
kusano |
7d535a |
|
|
kusano |
7d535a |
'*' indicates elements for which storage is provided,
|
|
kusano |
7d535a |
'.' indicates elements for which no storage is provided, but
|
|
kusano |
7d535a |
are not necessarily zero; their values are determined by
|
|
kusano |
7d535a |
symmetry. ' ' indicates elements which are necessarily zero,
|
|
kusano |
7d535a |
and have no storage provided.
|
|
kusano |
7d535a |
|
|
kusano |
7d535a |
Those columns which have two '*'s can be handled by SROT.
|
|
kusano |
7d535a |
Those columns which have no '*'s can be ignored, since as long
|
|
kusano |
7d535a |
as the Givens rotations are carefully applied to preserve
|
|
kusano |
7d535a |
symmetry, their values are determined.
|
|
kusano |
7d535a |
Those columns which have one '*' have to be handled separately,
|
|
kusano |
7d535a |
by using separate variables "p" and "q":
|
|
kusano |
7d535a |
|
|
kusano |
7d535a |
row j: * * * * * p . . .
|
|
kusano |
7d535a |
row j+1: q * * * * * . . . .
|
|
kusano |
7d535a |
|
|
kusano |
7d535a |
The element p would have to be set correctly, then that column
|
|
kusano |
7d535a |
is rotated, setting p to its new value. The next call to
|
|
kusano |
7d535a |
CLAROT would rotate columns j and j+1, using p, and restore
|
|
kusano |
7d535a |
symmetry. The element q would start out being zero, and be
|
|
kusano |
7d535a |
made non-zero by the rotation. Later, rotations would presumably
|
|
kusano |
7d535a |
|
|
kusano |
7d535a |
be chosen to zero q out.
|
|
kusano |
7d535a |
|
|
kusano |
7d535a |
Typical Calling Sequences: rotating the i-th and (i+1)-st rows.
|
|
kusano |
7d535a |
------- ------- ---------
|
|
kusano |
7d535a |
|
|
kusano |
7d535a |
General dense matrix:
|
|
kusano |
7d535a |
|
|
kusano |
7d535a |
CALL CLAROT(.TRUE.,.FALSE.,.FALSE., N, C,S,
|
|
kusano |
7d535a |
A(i,1),LDA, DUMMY, DUMMY)
|
|
kusano |
7d535a |
|
|
kusano |
7d535a |
General banded matrix in GB format:
|
|
kusano |
7d535a |
|
|
kusano |
7d535a |
j = MAX(1, i-KL )
|
|
kusano |
7d535a |
NL = MIN( N, i+KU+1 ) + 1-j
|
|
kusano |
7d535a |
CALL CLAROT( .TRUE., i-KL.GE.1, i+KU.LT.N, NL, C,S,
|
|
kusano |
7d535a |
A(KU+i+1-j,j),LDA-1, XLEFT, XRIGHT )
|
|
kusano |
7d535a |
|
|
kusano |
7d535a |
[ note that i+1-j is just MIN(i,KL+1) ]
|
|
kusano |
7d535a |
|
|
kusano |
7d535a |
Symmetric banded matrix in SY format, bandwidth K,
|
|
kusano |
7d535a |
lower triangle only:
|
|
kusano |
7d535a |
|
|
kusano |
7d535a |
j = MAX(1, i-K )
|
|
kusano |
7d535a |
NL = MIN( K+1, i ) + 1
|
|
kusano |
7d535a |
CALL CLAROT( .TRUE., i-K.GE.1, .TRUE., NL, C,S,
|
|
kusano |
7d535a |
A(i,j), LDA, XLEFT, XRIGHT )
|
|
kusano |
7d535a |
|
|
kusano |
7d535a |
Same, but upper triangle only:
|
|
kusano |
7d535a |
|
|
kusano |
7d535a |
NL = MIN( K+1, N-i ) + 1
|
|
kusano |
7d535a |
CALL CLAROT( .TRUE., .TRUE., i+K.LT.N, NL, C,S,
|
|
kusano |
7d535a |
A(i,i), LDA, XLEFT, XRIGHT )
|
|
kusano |
7d535a |
|
|
kusano |
7d535a |
Symmetric banded matrix in SB format, bandwidth K,
|
|
kusano |
7d535a |
lower triangle only:
|
|
kusano |
7d535a |
|
|
kusano |
7d535a |
[ same as for SY, except:]
|
|
kusano |
7d535a |
. . . .
|
|
kusano |
7d535a |
A(i+1-j,j), LDA-1, XLEFT, XRIGHT )
|
|
kusano |
7d535a |
|
|
kusano |
7d535a |
[ note that i+1-j is just MIN(i,K+1) ]
|
|
kusano |
7d535a |
|
|
kusano |
7d535a |
Same, but upper triangle only:
|
|
kusano |
7d535a |
. . .
|
|
kusano |
7d535a |
A(K+1,i), LDA-1, XLEFT, XRIGHT )
|
|
kusano |
7d535a |
|
|
kusano |
7d535a |
Rotating columns is just the transpose of rotating rows, except
|
|
kusano |
7d535a |
|
|
kusano |
7d535a |
for GB and SB: (rotating columns i and i+1)
|
|
kusano |
7d535a |
|
|
kusano |
7d535a |
GB:
|
|
kusano |
7d535a |
j = MAX(1, i-KU )
|
|
kusano |
7d535a |
NL = MIN( N, i+KL+1 ) + 1-j
|
|
kusano |
7d535a |
CALL CLAROT( .TRUE., i-KU.GE.1, i+KL.LT.N, NL, C,S,
|
|
kusano |
7d535a |
A(KU+j+1-i,i),LDA-1, XTOP, XBOTTM )
|
|
kusano |
7d535a |
|
|
kusano |
7d535a |
[note that KU+j+1-i is just MAX(1,KU+2-i)]
|
|
kusano |
7d535a |
|
|
kusano |
7d535a |
SB: (upper triangle)
|
|
kusano |
7d535a |
|
|
kusano |
7d535a |
. . . . . .
|
|
kusano |
7d535a |
A(K+j+1-i,i),LDA-1, XTOP, XBOTTM )
|
|
kusano |
7d535a |
|
|
kusano |
7d535a |
SB: (lower triangle)
|
|
kusano |
7d535a |
|
|
kusano |
7d535a |
. . . . . .
|
|
kusano |
7d535a |
A(1,i),LDA-1, XTOP, XBOTTM )
|
|
kusano |
7d535a |
|
|
kusano |
7d535a |
Arguments
|
|
kusano |
7d535a |
=========
|
|
kusano |
7d535a |
|
|
kusano |
7d535a |
LROWS - LOGICAL
|
|
kusano |
7d535a |
If .TRUE., then CLAROT will rotate two rows. If .FALSE.,
|
|
kusano |
7d535a |
then it will rotate two columns.
|
|
kusano |
7d535a |
Not modified.
|
|
kusano |
7d535a |
|
|
kusano |
7d535a |
LLEFT - LOGICAL
|
|
kusano |
7d535a |
If .TRUE., then XLEFT will be used instead of the
|
|
kusano |
7d535a |
corresponding element of A for the first element in the
|
|
kusano |
7d535a |
second row (if LROWS=.FALSE.) or column (if LROWS=.TRUE.)
|
|
kusano |
7d535a |
If .FALSE., then the corresponding element of A will be
|
|
kusano |
7d535a |
used.
|
|
kusano |
7d535a |
Not modified.
|
|
kusano |
7d535a |
|
|
kusano |
7d535a |
LRIGHT - LOGICAL
|
|
kusano |
7d535a |
If .TRUE., then XRIGHT will be used instead of the
|
|
kusano |
7d535a |
corresponding element of A for the last element in the
|
|
kusano |
7d535a |
first row (if LROWS=.FALSE.) or column (if LROWS=.TRUE.) If
|
|
kusano |
7d535a |
|
|
kusano |
7d535a |
.FALSE., then the corresponding element of A will be used.
|
|
kusano |
7d535a |
Not modified.
|
|
kusano |
7d535a |
|
|
kusano |
7d535a |
NL - INTEGER
|
|
kusano |
7d535a |
The length of the rows (if LROWS=.TRUE.) or columns (if
|
|
kusano |
7d535a |
LROWS=.FALSE.) to be rotated. If XLEFT and/or XRIGHT are
|
|
kusano |
7d535a |
used, the columns/rows they are in should be included in
|
|
kusano |
7d535a |
NL, e.g., if LLEFT = LRIGHT = .TRUE., then NL must be at
|
|
kusano |
7d535a |
least 2. The number of rows/columns to be rotated
|
|
kusano |
7d535a |
exclusive of those involving XLEFT and/or XRIGHT may
|
|
kusano |
7d535a |
not be negative, i.e., NL minus how many of LLEFT and
|
|
kusano |
7d535a |
LRIGHT are .TRUE. must be at least zero; if not, XERBLA
|
|
kusano |
7d535a |
will be called.
|
|
kusano |
7d535a |
Not modified.
|
|
kusano |
7d535a |
|
|
kusano |
7d535a |
C, S - COMPLEX
|
|
kusano |
7d535a |
Specify the Givens rotation to be applied. If LROWS is
|
|
kusano |
7d535a |
true, then the matrix ( c s )
|
|
kusano |
7d535a |
( _ _ )
|
|
kusano |
7d535a |
(-s c ) is applied from the left;
|
|
kusano |
7d535a |
if false, then the transpose (not conjugated) thereof is
|
|
kusano |
7d535a |
applied from the right. Note that in contrast to the
|
|
kusano |
7d535a |
output of CROTG or to most versions of CROT, both C and S
|
|
kusano |
7d535a |
are complex. For a Givens rotation, |C|**2 + |S|**2 should
|
|
kusano |
7d535a |
|
|
kusano |
7d535a |
be 1, but this is not checked.
|
|
kusano |
7d535a |
Not modified.
|
|
kusano |
7d535a |
|
|
kusano |
7d535a |
A - COMPLEX array.
|
|
kusano |
7d535a |
The array containing the rows/columns to be rotated. The
|
|
kusano |
7d535a |
first element of A should be the upper left element to
|
|
kusano |
7d535a |
be rotated.
|
|
kusano |
7d535a |
Read and modified.
|
|
kusano |
7d535a |
|
|
kusano |
7d535a |
LDA - INTEGER
|
|
kusano |
7d535a |
The "effective" leading dimension of A. If A contains
|
|
kusano |
7d535a |
a matrix stored in GE, HE, or SY format, then this is just
|
|
kusano |
7d535a |
the leading dimension of A as dimensioned in the calling
|
|
kusano |
7d535a |
routine. If A contains a matrix stored in band (GB, HB, or
|
|
kusano |
7d535a |
|
|
kusano |
7d535a |
SB) format, then this should be *one less* than the leading
|
|
kusano |
7d535a |
|
|
kusano |
7d535a |
dimension used in the calling routine. Thus, if A were
|
|
kusano |
7d535a |
dimensioned A(LDA,*) in CLAROT, then A(1,j) would be the
|
|
kusano |
7d535a |
j-th element in the first of the two rows to be rotated,
|
|
kusano |
7d535a |
and A(2,j) would be the j-th in the second, regardless of
|
|
kusano |
7d535a |
how the array may be stored in the calling routine. [A
|
|
kusano |
7d535a |
cannot, however, actually be dimensioned thus, since for
|
|
kusano |
7d535a |
band format, the row number may exceed LDA, which is not
|
|
kusano |
7d535a |
legal FORTRAN.]
|
|
kusano |
7d535a |
If LROWS=.TRUE., then LDA must be at least 1, otherwise
|
|
kusano |
7d535a |
it must be at least NL minus the number of .TRUE. values
|
|
kusano |
7d535a |
in XLEFT and XRIGHT.
|
|
kusano |
7d535a |
Not modified.
|
|
kusano |
7d535a |
|
|
kusano |
7d535a |
XLEFT - COMPLEX
|
|
kusano |
7d535a |
If LLEFT is .TRUE., then XLEFT will be used and modified
|
|
kusano |
7d535a |
instead of A(2,1) (if LROWS=.TRUE.) or A(1,2)
|
|
kusano |
7d535a |
(if LROWS=.FALSE.).
|
|
kusano |
7d535a |
Read and modified.
|
|
kusano |
7d535a |
|
|
kusano |
7d535a |
XRIGHT - COMPLEX
|
|
kusano |
7d535a |
If LRIGHT is .TRUE., then XRIGHT will be used and modified
|
|
kusano |
7d535a |
instead of A(1,NL) (if LROWS=.TRUE.) or A(NL,1)
|
|
kusano |
7d535a |
(if LROWS=.FALSE.).
|
|
kusano |
7d535a |
Read and modified.
|
|
kusano |
7d535a |
|
|
kusano |
7d535a |
=====================================================================
|
|
kusano |
7d535a |
|
|
kusano |
7d535a |
|
|
kusano |
7d535a |
|
|
kusano |
7d535a |
Set up indices, arrays for ends
|
|
kusano |
7d535a |
|
|
kusano |
7d535a |
Parameter adjustments */
|
|
kusano |
7d535a |
--a;
|
|
kusano |
7d535a |
|
|
kusano |
7d535a |
/* Function Body */
|
|
kusano |
7d535a |
if (*lrows) {
|
|
kusano |
7d535a |
iinc = *lda;
|
|
kusano |
7d535a |
inext = 1;
|
|
kusano |
7d535a |
} else {
|
|
kusano |
7d535a |
iinc = 1;
|
|
kusano |
7d535a |
inext = *lda;
|
|
kusano |
7d535a |
}
|
|
kusano |
7d535a |
|
|
kusano |
7d535a |
if (*lleft) {
|
|
kusano |
7d535a |
nt = 1;
|
|
kusano |
7d535a |
ix = iinc + 1;
|
|
kusano |
7d535a |
iy = *lda + 2;
|
|
kusano |
7d535a |
xt[0].r = a[1].r, xt[0].i = a[1].i;
|
|
kusano |
7d535a |
yt[0].r = xleft->r, yt[0].i = xleft->i;
|
|
kusano |
7d535a |
} else {
|
|
kusano |
7d535a |
nt = 0;
|
|
kusano |
7d535a |
ix = 1;
|
|
kusano |
7d535a |
iy = inext + 1;
|
|
kusano |
7d535a |
}
|
|
kusano |
7d535a |
|
|
kusano |
7d535a |
if (*lright) {
|
|
kusano |
7d535a |
iyt = inext + 1 + (*nl - 1) * iinc;
|
|
kusano |
7d535a |
++nt;
|
|
kusano |
7d535a |
i__1 = nt - 1;
|
|
kusano |
7d535a |
xt[i__1].r = xright->r, xt[i__1].i = xright->i;
|
|
kusano |
7d535a |
i__1 = nt - 1;
|
|
kusano |
7d535a |
i__2 = iyt;
|
|
kusano |
7d535a |
yt[i__1].r = a[i__2].r, yt[i__1].i = a[i__2].i;
|
|
kusano |
7d535a |
}
|
|
kusano |
7d535a |
|
|
kusano |
7d535a |
/* Check for errors */
|
|
kusano |
7d535a |
|
|
kusano |
7d535a |
if (*nl < nt) {
|
|
kusano |
7d535a |
xerbla_("CLAROT", &c__4);
|
|
kusano |
7d535a |
return 0;
|
|
kusano |
7d535a |
}
|
|
kusano |
7d535a |
if (*lda <= 0 || ! (*lrows) && *lda < *nl - nt) {
|
|
kusano |
7d535a |
xerbla_("CLAROT", &c__8);
|
|
kusano |
7d535a |
return 0;
|
|
kusano |
7d535a |
}
|
|
kusano |
7d535a |
|
|
kusano |
7d535a |
/* Rotate
|
|
kusano |
7d535a |
|
|
kusano |
7d535a |
CROT( NL-NT, A(IX),IINC, A(IY),IINC, C, S ) with complex C, S */
|
|
kusano |
7d535a |
|
|
kusano |
7d535a |
i__1 = *nl - nt - 1;
|
|
kusano |
7d535a |
for (j = 0; j <= i__1; ++j) {
|
|
kusano |
7d535a |
i__2 = ix + j * iinc;
|
|
kusano |
7d535a |
q__2.r = c->r * a[i__2].r - c->i * a[i__2].i, q__2.i = c->r * a[i__2]
|
|
kusano |
7d535a |
.i + c->i * a[i__2].r;
|
|
kusano |
7d535a |
i__3 = iy + j * iinc;
|
|
kusano |
7d535a |
q__3.r = s->r * a[i__3].r - s->i * a[i__3].i, q__3.i = s->r * a[i__3]
|
|
kusano |
7d535a |
.i + s->i * a[i__3].r;
|
|
kusano |
7d535a |
q__1.r = q__2.r + q__3.r, q__1.i = q__2.i + q__3.i;
|
|
kusano |
7d535a |
tempx.r = q__1.r, tempx.i = q__1.i;
|
|
kusano |
7d535a |
i__2 = iy + j * iinc;
|
|
kusano |
7d535a |
r_cnjg(&q__4, s);
|
|
kusano |
7d535a |
q__3.r = -(doublereal)q__4.r, q__3.i = -(doublereal)q__4.i;
|
|
kusano |
7d535a |
i__3 = ix + j * iinc;
|
|
kusano |
7d535a |
q__2.r = q__3.r * a[i__3].r - q__3.i * a[i__3].i, q__2.i = q__3.r * a[
|
|
kusano |
7d535a |
i__3].i + q__3.i * a[i__3].r;
|
|
kusano |
7d535a |
r_cnjg(&q__6, c);
|
|
kusano |
7d535a |
i__4 = iy + j * iinc;
|
|
kusano |
7d535a |
q__5.r = q__6.r * a[i__4].r - q__6.i * a[i__4].i, q__5.i = q__6.r * a[
|
|
kusano |
7d535a |
i__4].i + q__6.i * a[i__4].r;
|
|
kusano |
7d535a |
q__1.r = q__2.r + q__5.r, q__1.i = q__2.i + q__5.i;
|
|
kusano |
7d535a |
a[i__2].r = q__1.r, a[i__2].i = q__1.i;
|
|
kusano |
7d535a |
i__2 = ix + j * iinc;
|
|
kusano |
7d535a |
a[i__2].r = tempx.r, a[i__2].i = tempx.i;
|
|
kusano |
7d535a |
/* L10: */
|
|
kusano |
7d535a |
}
|
|
kusano |
7d535a |
|
|
kusano |
7d535a |
/* CROT( NT, XT,1, YT,1, C, S ) with complex C, S */
|
|
kusano |
7d535a |
|
|
kusano |
7d535a |
i__1 = nt;
|
|
kusano |
7d535a |
for (j = 1; j <= i__1; ++j) {
|
|
kusano |
7d535a |
i__2 = j - 1;
|
|
kusano |
7d535a |
q__2.r = c->r * xt[i__2].r - c->i * xt[i__2].i, q__2.i = c->r * xt[
|
|
kusano |
7d535a |
i__2].i + c->i * xt[i__2].r;
|
|
kusano |
7d535a |
i__3 = j - 1;
|
|
kusano |
7d535a |
q__3.r = s->r * yt[i__3].r - s->i * yt[i__3].i, q__3.i = s->r * yt[
|
|
kusano |
7d535a |
i__3].i + s->i * yt[i__3].r;
|
|
kusano |
7d535a |
q__1.r = q__2.r + q__3.r, q__1.i = q__2.i + q__3.i;
|
|
kusano |
7d535a |
tempx.r = q__1.r, tempx.i = q__1.i;
|
|
kusano |
7d535a |
i__2 = j - 1;
|
|
kusano |
7d535a |
r_cnjg(&q__4, s);
|
|
kusano |
7d535a |
q__3.r = -(doublereal)q__4.r, q__3.i = -(doublereal)q__4.i;
|
|
kusano |
7d535a |
i__3 = j - 1;
|
|
kusano |
7d535a |
q__2.r = q__3.r * xt[i__3].r - q__3.i * xt[i__3].i, q__2.i = q__3.r *
|
|
kusano |
7d535a |
xt[i__3].i + q__3.i * xt[i__3].r;
|
|
kusano |
7d535a |
r_cnjg(&q__6, c);
|
|
kusano |
7d535a |
i__4 = j - 1;
|
|
kusano |
7d535a |
q__5.r = q__6.r * yt[i__4].r - q__6.i * yt[i__4].i, q__5.i = q__6.r *
|
|
kusano |
7d535a |
yt[i__4].i + q__6.i * yt[i__4].r;
|
|
kusano |
7d535a |
q__1.r = q__2.r + q__5.r, q__1.i = q__2.i + q__5.i;
|
|
kusano |
7d535a |
yt[i__2].r = q__1.r, yt[i__2].i = q__1.i;
|
|
kusano |
7d535a |
i__2 = j - 1;
|
|
kusano |
7d535a |
xt[i__2].r = tempx.r, xt[i__2].i = tempx.i;
|
|
kusano |
7d535a |
/* L20: */
|
|
kusano |
7d535a |
}
|
|
kusano |
7d535a |
|
|
kusano |
7d535a |
/* Stuff values back into XLEFT, XRIGHT, etc. */
|
|
kusano |
7d535a |
|
|
kusano |
7d535a |
if (*lleft) {
|
|
kusano |
7d535a |
a[1].r = xt[0].r, a[1].i = xt[0].i;
|
|
kusano |
7d535a |
xleft->r = yt[0].r, xleft->i = yt[0].i;
|
|
kusano |
7d535a |
}
|
|
kusano |
7d535a |
|
|
kusano |
7d535a |
if (*lright) {
|
|
kusano |
7d535a |
i__1 = nt - 1;
|
|
kusano |
7d535a |
xright->r = xt[i__1].r, xright->i = xt[i__1].i;
|
|
kusano |
7d535a |
i__1 = iyt;
|
|
kusano |
7d535a |
i__2 = nt - 1;
|
|
kusano |
7d535a |
a[i__1].r = yt[i__2].r, a[i__1].i = yt[i__2].i;
|
|
kusano |
7d535a |
}
|
|
kusano |
7d535a |
|
|
kusano |
7d535a |
return 0;
|
|
kusano |
7d535a |
|
|
kusano |
7d535a |
/* End of CLAROT */
|
|
kusano |
7d535a |
|
|
kusano |
7d535a |
} /* clarot_ */
|
|
kusano |
7d535a |
|