xmake.lua 1.4 KB

123456789101112131415161718192021222324252627282930313233
  1. package("spectra")
  2. set_kind("library", {headeronly = true})
  3. set_homepage("https://spectralib.org/")
  4. set_description("Sparse Eigenvalue Computation Toolkit as a Redesigned ARPACK")
  5. set_license("MPL-2.0")
  6. add_urls("https://github.com/yixuan/spectra/archive/refs/tags/$(version).tar.gz",
  7. "https://github.com/yixuan/spectra.git")
  8. add_versions("v1.2.0", "fdfccacba1c77d9b4ffefae7258c760c99e3c8a2823ca87ea5b11a50d297a73b")
  9. add_versions("v1.1.0", "d29671e3d1b8036728933cadfddb05668a3cd6133331e91fc4535a9b85bedc79")
  10. add_versions("v1.0.1", "919e3fbc8c539a321fd5a0766966922b7637cc52eb50a969241a997c733789f3")
  11. add_deps("cmake", "eigen")
  12. on_install(function (package)
  13. import("package.tools.cmake").install(package)
  14. end)
  15. on_test(function (package)
  16. assert(package:check_cxxsnippets({test = [[
  17. #include <Eigen/Core>
  18. #include <Spectra/SymEigsSolver.h>
  19. void test() {
  20. Eigen::MatrixXd A = Eigen::MatrixXd::Random(10, 10);
  21. Eigen::MatrixXd M = A + A.transpose();
  22. Spectra::DenseSymMatProd<double> op(M);
  23. Spectra::SymEigsSolver<Spectra::DenseSymMatProd<double>> eigs(op, 3, 6);
  24. eigs.init();
  25. int nconv = eigs.compute(Spectra::SortRule::LargestAlge);
  26. }
  27. ]]}, {configs = {languages = "c++14"}}))
  28. end)