Trait embedded_hal::Pwm
[−]
[src]
pub trait Pwm { type Channel; type Time; type Duty; fn disable(&mut self, channel: Self::Channel); fn enable(&mut self, channel: Self::Channel); fn get_period(&self) -> Self::Time; fn get_duty(&self, channel: Self::Channel) -> Self::Duty; fn get_max_duty(&self) -> Self::Duty; fn set_duty(&mut self, channel: Self::Channel, duty: Self::Duty); fn set_period<P>(&mut self, period: P)
where
P: Into<Self::Time>; }
Pulse Width Modulation
Examples
Use this interface to control the power output of some actuator
extern crate embedded_hal as hal; use hal::prelude::*; fn main() { let mut pwm: Pwm1 = { // .. }; pwm.set_period(1.khz()); let max_duty = pwm.get_max_duty(); // brightest LED pwm.set_duty(Channel::_1, max_duty); // dimmer LED pwm.set_duty(Channel::_2, max_duty / 4); }
Associated Types
type Channel
Enumeration of channels that can be used with this Pwm
interface
If your Pwm
interface has no channels you can use the type ()
here
type Time
A time unit that can be converted into a human time unit (e.g. seconds)
type Duty
Type for the duty
methods
The implementer is free to choose a float / percentage representation
(e.g. 0.0 .. 1.0
) or an integer representation (e.g. 0 .. 65535
)
Required Methods
fn disable(&mut self, channel: Self::Channel)
Disables a PWM channel
fn enable(&mut self, channel: Self::Channel)
Enables a PWM channel
fn get_period(&self) -> Self::Time
Returns the current PWM period
fn get_duty(&self, channel: Self::Channel) -> Self::Duty
Returns the current duty cycle
fn get_max_duty(&self) -> Self::Duty
Returns the maximum duty cycle value
fn set_duty(&mut self, channel: Self::Channel, duty: Self::Duty)
Sets a new duty cycle
fn set_period<P>(&mut self, period: P) where
P: Into<Self::Time>,
P: Into<Self::Time>,
Sets a new PWM period