summaryrefslogtreecommitdiff
path: root/src/matrixOperations/spec2
diff options
context:
space:
mode:
authortorset2009-02-17 13:15:21 +0000
committertorset2009-02-17 13:15:21 +0000
commitfde5f7914c9b74fad2c8208e93995d1d19611142 (patch)
tree87422643ba979dc399228d720357cda014481efc /src/matrixOperations/spec2
parent106b738f4e54417e5e51ff93ea4b509e5676895d (diff)
downloadscilab2c-fde5f7914c9b74fad2c8208e93995d1d19611142.tar.gz
scilab2c-fde5f7914c9b74fad2c8208e93995d1d19611142.tar.bz2
scilab2c-fde5f7914c9b74fad2c8208e93995d1d19611142.zip
Fixed errors in spec2
Diffstat (limited to 'src/matrixOperations/spec2')
-rw-r--r--src/matrixOperations/spec2/dspec2a.c34
1 files changed, 25 insertions, 9 deletions
diff --git a/src/matrixOperations/spec2/dspec2a.c b/src/matrixOperations/spec2/dspec2a.c
index 630cf55e..47a4a445 100644
--- a/src/matrixOperations/spec2/dspec2a.c
+++ b/src/matrixOperations/spec2/dspec2a.c
@@ -59,15 +59,36 @@ void dspec2a(double* in, int rows,doubleComplex* eigenvalues,doubleComplex* eige
/* apply lapack function according to symmetry */
if(symmetric){
C2F(dsyev)( "V", "U", &rows, inCopy, &rows, outReal, pdblWork, &iWorkSize, &INFO );
- for (i=0;i<rows*rows;i++) eigenvectors[i]=DoubleComplex(inCopy[i],0);
dzerosa(outImag,1,rows);
}
else {
pdblRightvectors=malloc((uint)(rows*rows) * sizeof(double));
C2F(dgeev)( "N", "V", &rows, inCopy, &rows, outReal, outImag,
pdblLeftvectors, &rows, pdblRightvectors, &rows, pdblWork, &iWorkSize, &INFO );
-
- for(j = 0 ; j < rows ; j+=2){
+ }
+
+ /* Computation of eigenvalues */
+ zzerosa(eigenvalues,1,rows*rows);
+ for (i=0;i<rows;i++) eigenvalues[i+i*rows]=DoubleComplex(outReal[i],outImag[i]);
+
+
+
+ /* Computation of eigenvectors */
+ j=0;
+ while (j<rows)
+ {
+ if (outImag[j]==0)
+ {
+ for(i = 0 ; i < rows ; i++)
+ {
+ ij = i + j * rows;
+ if (symmetric) eigenvectors[ij] = DoubleComplex(inCopy[ij],0);
+ else eigenvectors[ij] = DoubleComplex(pdblRightvectors[ij],0);
+ }
+ j = j + 1;
+ }
+ else
+ {
for(i = 0 ; i < rows ; i++)
{
ij = i + j * rows;
@@ -75,14 +96,9 @@ void dspec2a(double* in, int rows,doubleComplex* eigenvalues,doubleComplex* eige
eigenvectors[ij] = DoubleComplex(pdblRightvectors[ij],pdblRightvectors[ij1]);
eigenvectors[ij1] = DoubleComplex(pdblRightvectors[ij],-pdblRightvectors[ij1]);
}
+ j = j + 2;
}
-
}
-
-
- zzerosa(eigenvalues,1,rows*rows);
- for (i=0;i<rows;i++) eigenvalues[i+i*rows]=DoubleComplex(outReal[i],outImag[i]);
-
free(inCopy);
free(outReal);