mirror of
https://github.com/huggingface/candle.git
synced 2025-06-16 10:38:54 +00:00
Add the swiglu activation from the chatglm PR. (#1246)
This commit is contained in:
@ -14,6 +14,7 @@ pub enum Activation {
|
||||
Silu,
|
||||
Sigmoid,
|
||||
HardSigmoid,
|
||||
Swiglu,
|
||||
Swish,
|
||||
HardSwish,
|
||||
Elu(f64),
|
||||
@ -32,6 +33,7 @@ impl super::Module for Activation {
|
||||
Self::Silu => crate::ops::silu(xs),
|
||||
Self::Sigmoid => crate::ops::sigmoid(xs),
|
||||
Self::HardSigmoid => crate::ops::hard_sigmoid(xs),
|
||||
Self::Swiglu => crate::ops::swiglu(xs),
|
||||
Self::Swish => xs * crate::ops::sigmoid(xs)?,
|
||||
Self::HardSwish => xs * crate::ops::hard_sigmoid(xs)?,
|
||||
&Self::Elu(alpha) => xs.elu(alpha),
|
||||
|
@ -39,6 +39,11 @@ pub fn silu(xs: &Tensor) -> Result<Tensor> {
|
||||
xs / (xs.neg()?.exp()? + 1.0)?
|
||||
}
|
||||
|
||||
pub fn swiglu(xs: &Tensor) -> Result<Tensor> {
|
||||
let xs = xs.chunk(2, candle::D::Minus1)?;
|
||||
crate::ops::silu(&xs[0])? * &xs[1]
|
||||
}
|
||||
|
||||
pub fn sigmoid(xs: &Tensor) -> Result<Tensor> {
|
||||
// TODO: Should we have a specialized op for this?
|
||||
(xs.neg()?.exp()? + 1.0)?.recip()
|
||||
|
Reference in New Issue
Block a user