fast_image_resize 6.0.0

Library for fast image resizing with using of SIMD instructions
Documentation
#[allow(unused_imports)]
// It is used to implement floats in no_std
use crate::compat::*;
use crate::convolution::Coefficients;
use crate::pixels::I32;
use crate::{ImageView, ImageViewMut};

pub(crate) fn horiz_convolution(
    src_view: &impl ImageView<Pixel = I32>,
    dst_view: &mut impl ImageViewMut<Pixel = I32>,
    offset: u32,
    coeffs: &Coefficients,
) {
    let coefficients_chunks = coeffs.get_chunks();
    let src_rows = src_view.iter_rows(offset);
    let dst_rows = dst_view.iter_rows_mut(0);
    for (dst_row, src_row) in dst_rows.zip(src_rows) {
        for (dst_pixel, coeffs_chunk) in dst_row.iter_mut().zip(&coefficients_chunks) {
            let first_x_src = coeffs_chunk.start as usize;
            let mut ss = 0.;
            let src_pixels = unsafe { src_row.get_unchecked(first_x_src..) };
            for (&k, &pixel) in coeffs_chunk.values.iter().zip(src_pixels) {
                ss += pixel.0 as f64 * k;
            }
            dst_pixel.0 = ss.round() as i32;
        }
    }
}

pub(crate) fn vert_convolution(
    src_view: &impl ImageView<Pixel = I32>,
    dst_view: &mut impl ImageViewMut<Pixel = I32>,
    offset: u32,
    coeffs: &Coefficients,
) {
    let coefficients_chunks = coeffs.get_chunks();
    let dst_rows = dst_view.iter_rows_mut(0);
    let start_src_x = offset as usize;
    for (&coeffs_chunk, dst_row) in coefficients_chunks.iter().zip(dst_rows) {
        let first_y_src = coeffs_chunk.start;
        let mut src_x = start_src_x;
        for dst_pixel in dst_row.iter_mut() {
            let mut ss = 0.;
            let src_rows = src_view.iter_rows(first_y_src);
            for (src_row, &k) in src_rows.zip(coeffs_chunk.values) {
                let src_pixel = unsafe { src_row.get_unchecked(src_x) };
                ss += src_pixel.0 as f64 * k;
            }
            dst_pixel.0 = ss.round() as i32;
            src_x += 1;
        }
    }
}