use crate::defined::{float, METER};
mod advanced_drive;
mod filter;
mod fpga_info;
mod legacy_drive;
mod stm_focus;
pub use advanced_drive::{AdvancedDriveDuty, AdvancedDrivePhase};
pub use filter::{FilterDuty, FilterPhase};
pub use fpga_info::FPGAInfo;
pub use legacy_drive::LegacyDrive;
pub use stm_focus::STMFocus;
pub const FPGA_CLK_FREQ: usize = 163840000;
pub const FPGA_SUB_CLK_FREQ_DIV: usize = 8;
pub const FPGA_SUB_CLK_FREQ: usize = FPGA_CLK_FREQ / FPGA_SUB_CLK_FREQ_DIV;
pub const FOCUS_STM_FIXED_NUM_UNIT: float = 0.025e-3 * METER;
pub const FOCUS_STM_FIXED_NUM_WIDTH: usize = 18;
pub const FOCUS_STM_FIXED_NUM_UPPER: i32 = (1 << (FOCUS_STM_FIXED_NUM_WIDTH - 1)) - 1;
pub const FOCUS_STM_FIXED_NUM_LOWER: i32 = -(1 << (FOCUS_STM_FIXED_NUM_WIDTH - 1));
pub const MIN_CYCLE: u16 = 2;
pub const MAX_CYCLE: u16 = 8191;
pub const SAMPLING_FREQ_DIV_MIN: u32 = 4096 / FPGA_SUB_CLK_FREQ_DIV as u32;
pub const SAMPLING_FREQ_DIV_MAX: u32 = u32::MAX / FPGA_SUB_CLK_FREQ_DIV as u32;
pub const MOD_BUF_SIZE_MIN: usize = 2;
pub const MOD_BUF_SIZE_MAX: usize = 65536;
pub const STM_BUF_SIZE_MIN: usize = 2;
pub const FOCUS_STM_BUF_SIZE_MAX: usize = 65536;
pub const GAIN_STM_BUF_SIZE_MAX: usize = 1024;
pub const GAIN_STM_LEGACY_BUF_SIZE_MAX: usize = 2048;