autd3_driver/firmware/fpga/
mod.rs1mod fpga_state;
2mod gpio_out;
3mod pulse_width;
4mod stm_focus;
5
6pub use autd3_core::{
7 datagram::{GPIOIn, GPIOOut, LoopBehavior, Segment, TRANSITION_MODE_NONE, TransitionMode},
8 gain::{Drive, EmitIntensity, Phase},
9 sampling_config::SamplingConfig,
10};
11
12pub use fpga_state::FPGAState;
13pub(crate) use gpio_out::DebugValue;
14pub use gpio_out::GPIOOutputType;
15pub use pulse_width::PulseWidth;
16pub(crate) use stm_focus::STMFocus;
17
18use crate::{common::mm, ethercat::DcSysTime};
19
20pub const FOCI_STM_FIXED_NUM_UNIT: f32 = 0.025 * mm;
24const FOCI_STM_FIXED_NUM_WIDTH: usize = 18;
25const FOCI_STM_FIXED_NUM_UPPER: i32 = (1 << (FOCI_STM_FIXED_NUM_WIDTH - 1)) - 1;
26const FOCI_STM_FIXED_NUM_LOWER: i32 = -(1 << (FOCI_STM_FIXED_NUM_WIDTH - 1));
27const FOCI_STM_TR_X_MAX: i32 = 0x1AFC;
28const FOCI_STM_TR_Y_MAX: i32 = 0x14A3;
29pub(crate) const FOCI_STM_FIXED_NUM_UPPER_X: i32 = FOCI_STM_FIXED_NUM_UPPER;
30pub(crate) const FOCI_STM_FIXED_NUM_LOWER_X: i32 = FOCI_STM_FIXED_NUM_LOWER + FOCI_STM_TR_X_MAX;
31pub(crate) const FOCI_STM_FIXED_NUM_UPPER_Y: i32 = FOCI_STM_FIXED_NUM_UPPER;
32pub(crate) const FOCI_STM_FIXED_NUM_LOWER_Y: i32 = FOCI_STM_FIXED_NUM_LOWER + FOCI_STM_TR_Y_MAX;
33pub(crate) const FOCI_STM_FIXED_NUM_UPPER_Z: i32 = FOCI_STM_FIXED_NUM_UPPER;
34pub(crate) const FOCI_STM_FIXED_NUM_LOWER_Z: i32 = FOCI_STM_FIXED_NUM_LOWER;
35
36#[doc(hidden)]
37pub const SILENCER_STEPS_INTENSITY_DEFAULT: u16 = 10;
38#[doc(hidden)]
39pub const SILENCER_STEPS_PHASE_DEFAULT: u16 = 40;
40
41pub const MOD_BUF_SIZE_MIN: usize = 2;
45pub const MOD_BUF_SIZE_MAX: usize = 65536;
49
50pub const STM_BUF_SIZE_MIN: usize = 2;
55pub const FOCI_STM_FOCI_NUM_MAX: usize = 8;
57pub const FOCI_STM_BUF_SIZE_MAX: usize = 65536;
61pub const GAIN_STM_BUF_SIZE_MAX: usize = 1024;
65
66#[doc(hidden)]
67pub const PWE_BUF_SIZE: usize = 256;
68
69#[must_use]
70pub(crate) const fn ec_time_to_sys_time(time: &DcSysTime) -> u64 {
71 (time.sys_time() / 3125) << 6
72}