pub mod device;
pub mod inference;
pub mod prelude;
pub mod training;
pub(crate) mod config;
pub(crate) mod engine;
pub(crate) mod error;
pub(crate) mod layout;
pub(crate) mod lm;
pub(crate) mod model;
pub(crate) mod optim;
pub(crate) mod param_io;
pub(crate) mod runtime;
pub(crate) mod screen;
pub(crate) mod tile;
#[cfg(not(feature = "cuda"))]
pub use device::cpu;
pub use device::{auto_device, cuda};
pub use inference::{ChatModel, GenerationConfig};
pub use training::{ParameterBudget, Trainer, TrainingReport};
pub use error::{Error, Result};
pub use model::{
DefaultMultiscreenModel, EvaluationResult, ModelInferenceConfig, ModelTrainingConfig,
ModelTrainingReport, MultiscreenModel, MultiscreenModelConfig, MultiscreenModelOutput,
MultiscreenParameterBudget, cross_entropy_loss_with_mask,
};
pub use runtime::{DefaultAutodiffBackend, DefaultBackend, Device, device_label};
#[cfg(not(feature = "cuda"))]
pub use runtime::default_device;
#[cfg(feature = "cuda")]
pub use runtime::{CudaAutodiffBackend, CudaDevice, CudaMultiscreenModel};
pub use config::{InferenceConfig, MultiscreenConfig, TrimConfig};
pub use engine::{InferenceOutput, MultiscreenEngine, TrainInput, TrainReport};
pub use layout::{
ScreenLayout, TokenSpan, causal_softmask, causal_trim_relevance, trim_and_square,
};
pub use screen::{Screen, ScreenConfig};
pub use tile::{ScreeningGridConfig, Tile, TileConfig};
pub use burn::{
tensor::backend::{AutodiffBackend, Backend},
tensor::{Int, Tensor, TensorData},
};
#[cfg(feature = "cuda")]
pub use burn::backend::Cuda;
#[deprecated(note = "use MultiscreenConfig; the paper styles this as one word")]
pub type MultiScreenConfig = MultiscreenConfig;
#[deprecated(note = "use MultiscreenEngine; the paper styles this as one word")]
pub type MultiScreenEngine = MultiscreenEngine;
#[deprecated(note = "use ScreeningGridConfig for N_L x N_H naming")]
pub type GridConfig = ScreeningGridConfig;