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