File: sparse_solvers.cpp

package info (click to toggle)
cgal 6.0.1-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 141,840 kB
  • sloc: cpp: 797,081; ansic: 203,398; sh: 490; python: 411; makefile: 286; javascript: 174
file content (42 lines) | stat: -rw-r--r-- 1,003 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
#include <CGAL/Eigen_solver_traits.h>
#include <CGAL/Eigen_matrix.h>

typedef CGAL::Eigen_solver_traits<> Eigen_solver;
typedef Eigen_solver::NT            FT;
typedef Eigen_solver::Matrix        Eigen_matrix;
typedef Eigen_solver::Vector        Eigen_vector;

int main(void)
{
  srand(static_cast<unsigned int>(time (nullptr)));
  std::size_t degree = 3000;
  std::size_t nb_nonzero_coef = 100;

  Eigen_vector B(degree); // Zero vector
  Eigen_matrix A(degree);

  // Randomly make some coefficients of the matrix non-zero
  for(std::size_t i=0; i<nb_nonzero_coef; ++i)
  {
    int x = rand() % degree;
    int y = rand() % degree;

    FT value = rand() / static_cast<FT>(RAND_MAX);

    A.add_coef(x, y, value);
    A.add_coef(y, x, value);
  }

  Eigen_vector X(degree);
  FT d;

  Eigen_solver solver;
  if(!(solver.linear_solver(A, B, X, d)))
  {
    std::cerr << "Error: linear solver failed" << std::endl;
    return -1;
  }

  std::cerr << "Linear solve succeeded" << std::endl;
  return 0;
}