Basic recurrent (RNN) layer that unrolls over time steps with a shared activation.
More...
|
| | Recurrent (const Shape &={0, 0}, const Shape &={0}) |
| | Constructs a recurrent layer with input and output shapes.
|
| |
| Shape | get_input_shape () const override |
| | Returns the input tensor shape (time_steps, input_features).
|
| |
| Shape | get_output_shape () const override |
| | Returns the output tensor shape (hidden units).
|
| |
| const TensorView & | get_biases () const |
| |
| const TensorView & | get_input_weights () const |
| |
| const TensorView & | get_recurrent_weights () const |
| |
| const string & | get_activation_function () const |
| |
| vector< TensorSpec > | get_parameter_specs () const override |
| | Returns the tensor specifications for the trainable parameters.
|
| |
| vector< TensorSpec > | get_forward_specs (Index batch_size) const override |
| | Returns the tensor specifications used during forward propagation.
|
| |
| vector< TensorSpec > | get_backward_specs (Index batch_size) const override |
| | Returns the tensor specifications used during back propagation.
|
| |
| void | set (const Shape &={}, const Shape &={}) |
| | Reconfigures the layer with new input and output shapes.
|
| |
| void | set_input_shape (const Shape &) override |
| | Updates the layer for a new input shape.
|
| |
| void | set_output_shape (const Shape &) override |
| | Updates the layer for a new output shape.
|
| |
| void | set_activation_function (const string &) |
| | Sets the activation function by name (e.g. "Tanh", "ReLU").
|
| |
| void | forward_propagate (ForwardPropagation &, size_t, bool) noexcept override |
| | Runs the forward pass, unrolling the recurrence across time steps.
|
| |
| void | back_propagate (ForwardPropagation &, BackPropagation &, size_t) const noexcept override |
| | Runs the backward pass (backpropagation through time).
|
| |
| void | read_JSON_body (const Json *) override |
| | Reads the layer configuration from a JSON node.
|
| |
| void | write_JSON_body (JsonWriter &) const override |
| | Writes the layer configuration to a JSON writer.
|
| |
| string | write_expression (const vector< string > &input_names, const vector< string > &output_names) const override |
| | Returns a symbolic expression of the layer for export.
|
| |
| virtual | ~Layer ()=default |
| |
| const string & | get_label () const |
| |
| const string & | get_name () const |
| |
| LayerType | get_type () const |
| |
| void | set_label (string new_label) |
| |
| Index | get_parameters_number () const |
| | Returns the total number of trainable parameters owned by this layer.
|
| |
| const vector< Operator * > & | get_operators () const |
| |
| virtual vector< TensorSpec > | get_state_specs () const |
| | Returns the tensor specs of persistent state (e.g. running mean/variance).
|
| |
| virtual ActivationOp::Function | get_output_activation () const |
| | Returns the layer's output activation (Identity for most layers; overridden by Dense/Bounding).
|
| |
| Index | get_inputs_number () const |
| |
| Index | get_outputs_number () const |
| |
| virtual void | from_JSON (const JsonDocument &document) |
| | Restores layer configuration and parameters from a JSON document.
|
| |
| virtual void | load_state_from_JSON (const JsonDocument &document) |
| | Restores persistent state (e.g. running statistics) from a JSON document.
|
| |
| virtual void | to_JSON (JsonWriter &writer) const |
| | Serializes layer configuration and parameters to a JSON writer.
|
| |
| virtual void | print () const |
| | Prints a human-readable summary of the layer to standard output.
|
| |
| bool | get_is_trainable () const |
| |
| Type | get_compute_dtype () const |
| |
| void | set_compute_dtype (Type new_compute_dtype) |
| | Sets the compute dtype and notifies subclasses via on_compute_dtype_changed().
|
| |
| virtual void | on_compute_dtype_changed () |
| | Subclass hook invoked when the compute dtype changes; default is no-op.
|
| |
| virtual float * | link_states (float *pointer) |
| | Binds the persistent-state region of the shared buffer to operator views.
|
| |
| float * | link_gradients (float *pointer, vector< TensorView > &gradient_views) |
| | Binds the gradient slice of the shared buffer to operator gradient views.
|
| |
| vector< TensorView > & | get_parameter_views () |
| |
| const vector< TensorView > & | get_parameter_views () const |
| |
| void | redistribute_parameters_to_operators () |
| | Re-binds operator parameter views after the parameter buffer has been resized or moved.
|
| |
Basic recurrent (RNN) layer that unrolls over time steps with a shared activation.