embassy-stm32

Crates

git

Versions

stm32n647a0

Flavors

ColorMatrix

Struct ColorMatrix 

Source
pub struct ColorMatrix {
    pub coeffs: [[f32; 3]; 3],
    pub offsets: [f32; 3],
    pub clamp: bool,
}
Expand description

3×3 colour-conversion matrix with per-row offsets, programmed into the DCMIPP Pipe1 ISP via Pipe1::set_color_matrix.

Hardware applies out = M · in + offset, optionally clamped to 8-bit unsigned. Coefficients are encoded as 11-bit signed Q2.8 (effective range -4.0 ..= +3.996, identity coefficient 1.0); offsets are 10-bit signed integers (range -512 ..= 511) added to the matrix product before the optional clamp.

Typical use: write a colour-correction matrix derived from sensor characterisation against a Macbeth chart, plus zero offsets, plus clamp = true for 8-bit display output. For pass-through use ColorMatrix::IDENTITY.

Fields§

§coeffs: [[f32; 3]; 3]

Row-major 3×3 coefficients. Element [i][j] multiplies input channel j to contribute to output channel i, with rows in R/G/B order.

§offsets: [f32; 3]

Per-row offsets in 8-bit-output units, i.e. an offset of +16.0 shifts the corresponding output channel up by 16/255.

§clamp: bool

Clamp the output to [0, 255]. Recommended true for 8-bit display / capture pipelines. Applies to the hardware’s unsigned 8-bit output mode (P1CCCR.TYPE = 0); the signed-output mode is not exposed by this struct.

Implementations§

Source§

impl ColorMatrix

Source

pub const IDENTITY: Self

Identity matrix with zero offsets and clamping enabled. Passing this to Pipe1::set_color_matrix should produce a frame pixel-identical to “no CCM applied” — a useful sanity check that the encoding into the hardware Q-format is correct.

Trait Implementations§

Source§

impl Clone for ColorMatrix

Source§

fn clone(&self) -> ColorMatrix

Returns a duplicate of the value. Read more
1.0.0 · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl Debug for ColorMatrix

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl Format for ColorMatrix
where [[f32; 3]; 3]: Format, [f32; 3]: Format,

Source§

fn format(&self, f: Formatter<'_>)

Writes the defmt representation of self to fmt.
Source§

impl PartialEq for ColorMatrix

Source§

fn eq(&self, other: &ColorMatrix) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl Copy for ColorMatrix

Source§

impl StructuralPartialEq for ColorMatrix

Auto Trait Implementations§

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.