run over a directory

This commit is contained in:
Saurabh 2022-02-28 21:37:13 -07:00
parent 8c1186db3c
commit 424207914b

View File

@ -1,5 +1,8 @@
extern crate nalgebra_sparse; extern crate nalgebra_sparse;
use nalgebra_sparse::CsrMatrix; use nalgebra_sparse::CsrMatrix;
use std::fs::{self, DirEntry};
use std::io;
use std::path::Path;
use std::time::{Duration, Instant}; use std::time::{Duration, Instant};
#[cfg(feature = "io")] #[cfg(feature = "io")]
@ -7,8 +10,11 @@ use nalgebra_sparse::io::load_coo_from_matrix_market_file;
fn main() { fn main() {
#[cfg(feature = "io")] #[cfg(feature = "io")]
{ {
let sparse_input_matrix = let mut file_iter = fs::read_dir("./data").unwrap();
load_coo_from_matrix_market_file::<f64, _>("./data/crankseg_1.mtx").unwrap(); for f in file_iter {
println!("Benchmark file {:?}", f);
let f = f.unwrap().path();
let sparse_input_matrix = load_coo_from_matrix_market_file::<f64, _>(&f).unwrap();
let sparse_input_matrix = CsrMatrix::from(&sparse_input_matrix); let sparse_input_matrix = CsrMatrix::from(&sparse_input_matrix);
let spmm_result = &sparse_input_matrix * &sparse_input_matrix; let spmm_result = &sparse_input_matrix * &sparse_input_matrix;
let now = Instant::now(); let now = Instant::now();
@ -18,6 +24,7 @@ fn main() {
let sum: f64 = spmm_result.triplet_iter().map(|(_, _, v)| v).sum(); let sum: f64 = spmm_result.triplet_iter().map(|(_, _, v)| v).sum();
println!("sum of product is {}", sum); println!("sum of product is {}", sum);
} }
}
#[cfg(not(feature = "io"))] #[cfg(not(feature = "io"))]
{ {
panic!("Run with IO feature only"); panic!("Run with IO feature only");