forked from M-Labs/nalgebra
Merge pull request #938 from Nateckert/omatrix_to_string
Make display generical for Omatrix
This commit is contained in:
commit
b007e192d4
@ -1819,7 +1819,6 @@ macro_rules! impl_fmt {
|
|||||||
where
|
where
|
||||||
T: Scalar + $trait,
|
T: Scalar + $trait,
|
||||||
S: Storage<T, R, C>,
|
S: Storage<T, R, C>,
|
||||||
DefaultAllocator: Allocator<usize, R, C>,
|
|
||||||
{
|
{
|
||||||
fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
|
fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
|
||||||
#[cfg(feature = "std")]
|
#[cfg(feature = "std")]
|
||||||
@ -1837,20 +1836,17 @@ macro_rules! impl_fmt {
|
|||||||
4
|
4
|
||||||
}
|
}
|
||||||
|
|
||||||
let (nrows, ncols) = self.data.shape();
|
let (nrows, ncols) = self.shape();
|
||||||
|
|
||||||
if nrows.value() == 0 || ncols.value() == 0 {
|
if nrows == 0 || ncols == 0 {
|
||||||
return write!(f, "[ ]");
|
return write!(f, "[ ]");
|
||||||
}
|
}
|
||||||
|
|
||||||
let mut max_length = 0;
|
let mut max_length = 0;
|
||||||
let mut lengths: OMatrix<usize, R, C> = Matrix::zeros_generic(nrows, ncols);
|
|
||||||
let (nrows, ncols) = self.shape();
|
|
||||||
|
|
||||||
for i in 0..nrows {
|
for i in 0..nrows {
|
||||||
for j in 0..ncols {
|
for j in 0..ncols {
|
||||||
lengths[(i, j)] = val_width(&self[(i, j)], f);
|
max_length = crate::max(max_length, val_width(&self[(i, j)], f));
|
||||||
max_length = crate::max(max_length, lengths[(i, j)]);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1867,7 +1863,7 @@ macro_rules! impl_fmt {
|
|||||||
for i in 0..nrows {
|
for i in 0..nrows {
|
||||||
write!(f, " │")?;
|
write!(f, " │")?;
|
||||||
for j in 0..ncols {
|
for j in 0..ncols {
|
||||||
let number_length = lengths[(i, j)] + 1;
|
let number_length = val_width(&self[(i, j)], f) + 1;
|
||||||
let pad = max_length_with_space - number_length;
|
let pad = max_length_with_space - number_length;
|
||||||
write!(f, " {:>thepad$}", "", thepad = pad)?;
|
write!(f, " {:>thepad$}", "", thepad = pad)?;
|
||||||
match f.precision() {
|
match f.precision() {
|
||||||
@ -1900,19 +1896,29 @@ impl_fmt!(fmt::UpperHex, "{:X}", "{:1$X}");
|
|||||||
impl_fmt!(fmt::Binary, "{:b}", "{:.1$b}");
|
impl_fmt!(fmt::Binary, "{:b}", "{:.1$b}");
|
||||||
impl_fmt!(fmt::Pointer, "{:p}", "{:.1$p}");
|
impl_fmt!(fmt::Pointer, "{:p}", "{:.1$p}");
|
||||||
|
|
||||||
#[test]
|
#[cfg(test)]
|
||||||
fn lower_exp() {
|
mod tests {
|
||||||
let test = crate::Matrix2::new(1e6, 2e5, 2e-5, 1.);
|
#[test]
|
||||||
assert_eq!(
|
fn empty_display() {
|
||||||
format!("{:e}", test),
|
let vec: Vec<f64> = Vec::new();
|
||||||
r"
|
let dvector = crate::DVector::from_vec(vec);
|
||||||
|
assert_eq!(format!("{}", dvector), "[ ]")
|
||||||
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn lower_exp() {
|
||||||
|
let test = crate::Matrix2::new(1e6, 2e5, 2e-5, 1.);
|
||||||
|
assert_eq!(
|
||||||
|
format!("{:e}", test),
|
||||||
|
r"
|
||||||
┌ ┐
|
┌ ┐
|
||||||
│ 1e6 2e5 │
|
│ 1e6 2e5 │
|
||||||
│ 2e-5 1e0 │
|
│ 2e-5 1e0 │
|
||||||
└ ┘
|
└ ┘
|
||||||
|
|
||||||
"
|
"
|
||||||
)
|
)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/// # Cross product
|
/// # Cross product
|
||||||
|
@ -1108,3 +1108,31 @@ fn partial_eq_different_types() {
|
|||||||
// assert_ne!(static_mat, typenum_static_mat);
|
// assert_ne!(static_mat, typenum_static_mat);
|
||||||
//assert_ne!(typenum_static_mat, static_mat);
|
//assert_ne!(typenum_static_mat, static_mat);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fn generic_omatrix_to_string<D>(
|
||||||
|
vector: &nalgebra::OVector<f64, D>,
|
||||||
|
matrix: &nalgebra::OMatrix<f64, D, D>,
|
||||||
|
) -> (String, String)
|
||||||
|
where
|
||||||
|
D: nalgebra::Dim,
|
||||||
|
nalgebra::DefaultAllocator: nalgebra::base::allocator::Allocator<f64, D>,
|
||||||
|
nalgebra::DefaultAllocator: nalgebra::base::allocator::Allocator<f64, D, D>,
|
||||||
|
{
|
||||||
|
(vector.to_string(), matrix.to_string())
|
||||||
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn omatrix_to_string() {
|
||||||
|
let dvec: nalgebra::DVector<f64> = nalgebra::dvector![1.0, 2.0];
|
||||||
|
let dmatr: nalgebra::DMatrix<f64> = nalgebra::dmatrix![1.0, 2.0; 3.0, 4.0];
|
||||||
|
let svec: nalgebra::SVector<f64, 2> = nalgebra::vector![1.0, 2.0];
|
||||||
|
let smatr: nalgebra::SMatrix<f64, 2, 2> = nalgebra::matrix![1.0, 2.0; 3.0, 4.0];
|
||||||
|
assert_eq!(
|
||||||
|
generic_omatrix_to_string(&dvec, &dmatr),
|
||||||
|
(dvec.to_string(), dmatr.to_string())
|
||||||
|
);
|
||||||
|
assert_eq!(
|
||||||
|
generic_omatrix_to_string(&svec, &smatr),
|
||||||
|
(svec.to_string(), smatr.to_string())
|
||||||
|
);
|
||||||
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user