ChannelAssignment

Enum ChannelAssignment 

Source
pub enum ChannelAssignment {
    Independent(Independent),
    LeftSide,
    SideRight,
    MidSide,
}
Expand description

How the channels are assigned in a FLAC frame

BitsChannel Assingment
00001 mono channel
00012 independent channels
00103 independent channels
00114 independent channels
01005 independent channels
01016 independent channels
01107 independent channels
01118 independent channels
1000left channel, side channel
1001side channel, right channel
1010mid channel, side channel
1011invalid channel assignment
1100invalid channel assignment
1101invalid channel assignment
1110invalid channel assignment
1111invalid channel assignment

§Example

use flac_codec::stream::{ChannelAssignment, Independent};
use bitstream_io::{BitReader, BitRead, BigEndian};

let data: &[u8] = &[
    0b0000_100_0,             // channels + bps + pad
];

let mut r = BitReader::endian(data, BigEndian);
assert_eq!(
    r.parse::<ChannelAssignment>().unwrap(),
    ChannelAssignment::Independent(Independent::Mono),
);

The samples in the side channel can be calculated like:

sideᵢ = leftᵢ - rightᵢ

This requires that the side channel have one additional bit-per-sample during decoding, since the difference between the left and right channels could overflow if the two are at opposite extremes.

And with a bit of math, we can see that:

rightᵢ = leftᵢ - sideᵢ

or:

leftᵢ = sideᵢ + rightᵢ

For transforming left-side and side-right assignments back to left-right for output.

The samples in the mid channel can be calculated like:

midᵢ = (leftᵢ + rightᵢ) ÷ 2

Mid-side assignment can be restored to left-right like:

sumᵢ = midᵢ × 2 + |sideᵢ| % 2

leftᵢ = (sumᵢ + sideᵢ) ÷ 2

rightᵢ = (sumᵢ - sideᵢ) ÷ 2

The mid channel does not require any additional bits to decode, since the average cannot exceed either channel.

Variants§

§

Independent(Independent)

Channels are stored independently

§

LeftSide

Channel 0 is stored verbatim, channel 1 derived from both

§

SideRight

Channel 0 is derived from both, channel 1 is stored verbatim

§

MidSide

Channel 0 is averaged from both, channel 1 is derived from both

Implementations§

Source§

impl ChannelAssignment

Source

pub fn count(&self) -> u8

Returns total number of channels defined by assignment

Trait Implementations§

Source§

impl Clone for ChannelAssignment

Source§

fn clone(&self) -> ChannelAssignment

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 ChannelAssignment

Source§

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

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

impl Display for ChannelAssignment

Source§

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

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

impl FromBitStream for ChannelAssignment

Source§

type Error = Error

Error generated during parsing, such as io::Error
Source§

fn from_reader<R: BitRead + ?Sized>(r: &mut R) -> Result<Self, Error>

Parse Self from reader
Source§

impl PartialEq for ChannelAssignment

Source§

fn eq(&self, other: &ChannelAssignment) -> 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 ToBitStream for ChannelAssignment

Source§

type Error = Error

Error generated during building, such as io::Error
Source§

fn to_writer<W: BitWrite + ?Sized>(&self, w: &mut W) -> Result<(), Error>

Generate self to writer
Source§

fn bits<C>(&self) -> Result<C, Self::Error>
where C: Counter, Self: Sized,

Returns length of self in bits, if possible
Source§

fn bits_len<C, E>(&self) -> Result<C, Self::Error>
where C: Counter, E: Endianness, Self: Sized,

👎Deprecated since 4.0.0: use of bits() is preferred
Returns total length of self, if possible
Source§

impl Copy for ChannelAssignment

Source§

impl Eq for ChannelAssignment

Source§

impl StructuralPartialEq for ChannelAssignment

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> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
Source§

impl<T> ToString for T
where T: Display + ?Sized,

Source§

fn to_string(&self) -> String

Converts the given value to a String. Read more
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.