source: util/src/diagonalize.c@ 59b70a

Last change on this file since 59b70a was ef87ee, checked in by Frederik Heber <heber@…>, 16 years ago

Added versioning to each executable.

  • credits to Ralf Wildenhues for writing the Makefile.am code
  • version.c section added to Makefile.am (pcp, molecuilder and util)
  • src/version.h to each pcp, molecuilder and util
  • each of the executables includes version.h and prints version in main()

Signed-off-by: Frederik Heber <heber@…>

  • Property mode set to 100644
File size: 1.3 KB
Line 
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
11int 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}
Note: See TracBrowser for help on using the repository browser.