Bidirectional

Struct Bidirectional 

Source
pub struct Bidirectional<F: Float + Debug + Send + Sync> { /* private fields */ }
Expand description

Bidirectional RNN wrapper for recurrent layers

This layer wraps a recurrent layer to enable bidirectional processing. It processes the input sequence in both forward and backward directions, and concatenates the results.

§Examples

use scirs2_neural::layers::{Layer, recurrent::{Bidirectional, RNN, rnn::RecurrentActivation}};
use scirs2_core::ndarray::{Array, Array3};
use scirs2_core::random::rngs::SmallRng;
use scirs2_core::random::SeedableRng;

// Create RNN layers for forward and backward directions
let mut rng = scirs2_core::random::rng();
let forward_rnn = RNN::new(10, 20, RecurrentActivation::Tanh, &mut rng).unwrap();
let backward_rnn = RNN::new(10, 20, RecurrentActivation::Tanh, &mut rng).unwrap();

// Wrap them in a bidirectional layer
let birnn = Bidirectional::new(Box::new(forward_rnn), Some(Box::new(backward_rnn)), None).unwrap();

// Forward pass with a batch of 2 samples, sequence length 5, and 10 features
let batch_size = 2;
let seq_len = 5;
let input_size = 10;
let input = Array3::<f64>::from_elem((batch_size, seq_len, input_size), 0.1).into_dyn();
let output = birnn.forward(&input).unwrap();

// Output should have dimensions [batch_size, seq_len, hidden_size*2]
assert_eq!(output.shape(), &[batch_size, seq_len, 40]);

Implementations§

Source§

impl<F: Float + Debug + ScalarOperand + Send + Sync + 'static> Bidirectional<F>

Source

pub fn new( forward_layer: Box<dyn Layer<F> + Send + Sync>, backward_layer: Option<Box<dyn Layer<F> + Send + Sync>>, name: Option<&str>, ) -> Result<Self>

Create a new bidirectional wrapper

§Arguments
  • forward_layer - The recurrent layer to use in forward direction
  • backward_layer - Optional recurrent layer for backward direction (if None, forward layer will be used)
  • name - Optional name for the layer
§Returns
  • A new bidirectional layer
Source

pub fn new_with_single_layer( layer: Box<dyn Layer<F> + Send + Sync>, name: Option<&str>, ) -> Result<Self>

Create a new bidirectional wrapper with a single layer This constructor is for backward compatibility

Source

pub fn name(&self) -> Option<&str>

Get the name of the layer

Trait Implementations§

Source§

impl<F: Float + Debug + ScalarOperand + Send + Sync + 'static> Layer<F> for Bidirectional<F>

Source§

fn forward(&self, input: &Array<F, IxDyn>) -> Result<Array<F, IxDyn>>

Forward pass of the layer Read more
Source§

fn backward( &self, _input: &Array<F, IxDyn>, grad_output: &Array<F, IxDyn>, ) -> Result<Array<F, IxDyn>>

Backward pass of the layer to compute gradients Read more
Source§

fn update(&mut self, learningrate: F) -> Result<()>

Update the layer parameters with the given learning rate
Source§

fn as_any(&self) -> &dyn Any

Get the layer as a dyn Any for downcasting
Source§

fn as_any_mut(&mut self) -> &mut dyn Any

Get the layer as a mutable dyn Any for downcasting
Source§

fn params(&self) -> Vec<Array<F, IxDyn>>

Get the parameters of the layer
Source§

fn gradients(&self) -> Vec<Array<F, IxDyn>>

Get the gradients of the layer parameters
Source§

fn set_gradients(&mut self, _gradients: &[Array<F, IxDyn>]) -> Result<()>

Set the gradients of the layer parameters
Source§

fn set_params(&mut self, _params: &[Array<F, IxDyn>]) -> Result<()>

Set the parameters of the layer
Source§

fn set_training(&mut self, _training: bool)

Set the layer to training mode (true) or evaluation mode (false)
Source§

fn is_training(&self) -> bool

Get the current training mode
Source§

fn layer_type(&self) -> &str

Get the type of the layer (e.g., “Dense”, “Conv2D”)
Source§

fn parameter_count(&self) -> usize

Get the number of trainable parameters in this layer
Source§

fn layer_description(&self) -> String

Get a detailed description of this layer
Source§

fn inputshape(&self) -> Option<Vec<usize>>

Get the input shape if known
Source§

fn outputshape(&self) -> Option<Vec<usize>>

Get the output shape if known
Source§

fn name(&self) -> Option<&str>

Get the name of the layer if set

Auto Trait Implementations§

§

impl<F> Freeze for Bidirectional<F>

§

impl<F> !RefUnwindSafe for Bidirectional<F>

§

impl<F> Send for Bidirectional<F>

§

impl<F> Sync for Bidirectional<F>

§

impl<F> Unpin for Bidirectional<F>

§

impl<F> !UnwindSafe for Bidirectional<F>

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> IntoEither for T

Source§

fn into_either(self, into_left: bool) -> Either<Self, Self>

Converts self into a Left variant of Either<Self, Self> if into_left is true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
Source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

Converts self into a Left variant of Either<Self, Self> if into_left(&self) returns true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
Source§

impl<T> Pointable for T

Source§

const ALIGN: usize

The alignment of pointer.
Source§

type Init = T

The type for initializers.
Source§

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
Source§

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
Source§

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
Source§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
Source§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

Source§

fn vzip(self) -> V