use ferrum_kernels::backend::Backend;
use ferrum_types::Result;
use crate::config::QuantConfig;
use crate::traits::Linear;
pub trait WeightLoader<B: Backend>: Send + Sync {
fn load_tensor(&self, name: &str) -> Result<B::Buffer>;
fn load_linear(&self, name: &str) -> Result<Box<dyn Linear<B>>>;
fn has_tensor(&self, name: &str) -> bool;
fn quant_config(&self) -> Option<&QuantConfig>;
}
pub struct PrefixedLoader<'a, B: Backend> {
inner: &'a dyn WeightLoader<B>,
prefix: String,
}
impl<'a, B: Backend> PrefixedLoader<'a, B> {
pub fn new(inner: &'a dyn WeightLoader<B>, prefix: impl Into<String>) -> Self {
Self {
inner,
prefix: prefix.into(),
}
}
}
impl<'a, B: Backend> WeightLoader<B> for PrefixedLoader<'a, B> {
fn load_tensor(&self, name: &str) -> Result<B::Buffer> {
self.inner.load_tensor(&format!("{}{}", self.prefix, name))
}
fn load_linear(&self, name: &str) -> Result<Box<dyn Linear<B>>> {
self.inner.load_linear(&format!("{}{}", self.prefix, name))
}
fn has_tensor(&self, name: &str) -> bool {
self.inner.has_tensor(&format!("{}{}", self.prefix, name))
}
fn quant_config(&self) -> Option<&QuantConfig> {
self.inner.quant_config()
}
}