| 1 | /** Diagonlizes a 3x3 matrix.
|
|---|
| 2 | * Most of here comes from the GSL example
|
|---|
| 3 | */
|
|---|
| 4 |
|
|---|
| 5 | #include <stdio.h>
|
|---|
| 6 | #include <gsl/gsl_math.h>
|
|---|
| 7 | #include <gsl/gsl_eigen.h>
|
|---|
| 8 |
|
|---|
| 9 | #include "version.h"
|
|---|
| 10 |
|
|---|
| 11 | int main(int argc, char **argv)
|
|---|
| 12 | {
|
|---|
| 13 | double matrix[9];
|
|---|
| 14 | int i;
|
|---|
| 15 |
|
|---|
| 16 | fprintf(stdout, "%s\n", ESPACKVersion);
|
|---|
| 17 |
|
|---|
| 18 | if (argc < 9) {
|
|---|
| 19 | printf("Usage: %s <9 entries of 3x3 matrix>\n", argv[0]);
|
|---|
| 20 | return 1;
|
|---|
| 21 | } else {
|
|---|
| 22 | for(i=0;i<9;i++)
|
|---|
| 23 | matrix[i] = atof(argv[i+1]);
|
|---|
| 24 | }
|
|---|
| 25 |
|
|---|
| 26 | gsl_matrix_view m
|
|---|
| 27 | = gsl_matrix_view_array (matrix, 3, 3);
|
|---|
| 28 |
|
|---|
| 29 | gsl_vector *eval = gsl_vector_alloc (3);
|
|---|
| 30 | gsl_matrix *evec = gsl_matrix_alloc (3, 3);
|
|---|
| 31 |
|
|---|
| 32 | gsl_eigen_symmv_workspace * w =
|
|---|
| 33 | gsl_eigen_symmv_alloc (4);
|
|---|
| 34 |
|
|---|
| 35 | gsl_eigen_symmv (&m.matrix, eval, evec, w);
|
|---|
| 36 |
|
|---|
| 37 | gsl_eigen_symmv_free (w);
|
|---|
| 38 |
|
|---|
| 39 | gsl_eigen_symmv_sort (eval, evec,
|
|---|
| 40 | GSL_EIGEN_SORT_ABS_ASC);
|
|---|
| 41 |
|
|---|
| 42 | {
|
|---|
| 43 | for (i = 0; i < 3; i++)
|
|---|
| 44 | {
|
|---|
| 45 | double eval_i
|
|---|
| 46 | = gsl_vector_get (eval, i);
|
|---|
| 47 | gsl_vector_view evec_i
|
|---|
| 48 | = gsl_matrix_column (evec, i);
|
|---|
| 49 |
|
|---|
| 50 | fprintf (stderr, "eigenvalue = %g\n", eval_i);
|
|---|
| 51 | fprintf (stderr, "eigenvector = \n");
|
|---|
| 52 | gsl_vector_fprintf (stderr,
|
|---|
| 53 | &evec_i.vector, "%g");
|
|---|
| 54 | }
|
|---|
| 55 | }
|
|---|
| 56 | fprintf (stdout, "eigenvalues: %lg\t%lg\t%lg\n", gsl_vector_get (eval, 0), gsl_vector_get (eval, 1), gsl_vector_get (eval, 2));
|
|---|
| 57 |
|
|---|
| 58 | gsl_vector_free (eval);
|
|---|
| 59 | gsl_matrix_free (evec);
|
|---|
| 60 |
|
|---|
| 61 |
|
|---|
| 62 | return 0;
|
|---|
| 63 | }
|
|---|