SimpleRNN¶
- class paddle.nn. SimpleRNN ( input_size, hidden_size, num_layers=1, direction='forward', time_major=False, dropout=0.0, activation='tanh', weight_ih_attr=None, weight_hh_attr=None, bias_ih_attr=None, bias_hh_attr=None, name=None ) [source]
- 
         Multilayer Elman network(SimpleRNN). It takes input sequences and initial states as inputs, and returns the output sequences and the final states. Each layer inside the SimpleRNN maps the input sequences and initial states to the output sequences and final states in the following manner: at each step, it takes step inputs(\(x_{t}\)) and previous states(\(h_{t-1}\)) as inputs, and returns step outputs(\(y_{t}\)) and new states(\(h_{t}\)). \[ \begin{align}\begin{aligned}h_{t} & = act(W_{ih}x_{t} + b_{ih} + W_{hh}h_{t-1} + b_{hh})\\y_{t} & = h_{t}\end{aligned}\end{align} \]where \(act\) is for activation.Using key word arguments to construct is recommended. - Parameters
- 
           - input_size (int) – The input size for the first layer’s cell. 
- hidden_size (int) – The hidden size for each layer’s cell. 
- num_layers (int, optional) – Number of layers. Defaults to 1. 
- direction (str, optional) – The direction of the network. It can be “forward” or “bidirect”(or “bidirectional”). When “bidirect”, the way to merge outputs of forward and backward is concatenating. Defaults to “forward”. 
- time_major (bool, optional) – Whether the first dimension of the input means the time steps. Defaults to False. 
- dropout (float, optional) – The droput probability. Dropout is applied to the input of each layer except for the first layer. Defaults to 0. 
- activation (str, optional) – The activation in each SimpleRNN cell. It can be tanh or relu. Defaults to tanh. 
- weight_ih_attr (ParamAttr, optional) – The parameter attribute for weight_ih of each cell. Defaults to None. 
- weight_hh_attr (ParamAttr, optional) – The parameter attribute for weight_hh of each cell. Defaults to None. 
- bias_ih_attr (ParamAttr, optional) – The parameter attribute for the bias_ih of each cells. Defaults to None. 
- bias_hh_attr (ParamAttr, optional) – The parameter attribute for the bias_hh of each cells. Defaults to None. 
- name (str, optional) – Name for the operation (optional, default is None). For more information, please refer to Name. 
 
 - Inputs:
- 
           - inputs (Tensor): the input sequence. If time_major is True, the shape is [time_steps, batch_size, input_size], else, the shape is [batch_size, time_steps, hidden_size]. 
- initial_states (Tensor, optional): the initial state. The shape is [num_layers * num_directions, batch_size, hidden_size]. If initial_state is not given, zero initial states are used. 
- sequence_length (Tensor, optional): shape [batch_size], dtype: int64 or int32. The valid lengths of input sequences. Defaults to None. If sequence_length is not None, the inputs are treated as padded sequences. In each input sequence, elements whose time step index are not less than the valid length are treated as paddings. 
 
 - Returns
- 
           
           the output sequence. If time_major is True, the shape is [time_steps, batch_size, num_directions * hidden_size], else, the shape is [batch_size, time_steps, num_directions * hidden_size]. Note that num_directions is 2 if direction is “bidirectional” else 1. - final_states (Tensor): final states. The shape is [num_layers * num_directions, batch_size, hidden_size]. Note that num_directions is 2 if direction is “bidirectional” (the index of forward states are 0, 2, 4, 6… and the index of backward states are 1, 3, 5, 7…), else 1. 
 
- Return type
- 
           
           - outputs (Tensor) 
 
 - Variables:
- 
           - weight_ih_l[k]: the learnable input-hidden weights of the k-th layer. If k = 0, the shape is [hidden_size, input_size]. Otherwise, the shape is [hidden_size, num_directions * hidden_size]. 
- weight_hh_l[k]: the learnable hidden-hidden weights of the k-th layer, with shape [hidden_size, hidden_size]. 
- bias_ih_l[k]: the learnable input-hidden bias of the k-th layer, with shape [hidden_size]. 
- bias_hh_l[k]: the learnable hidden-hidden bias of the k-th layer, with shape [hidden_size]. 
 
 Examples import paddle rnn = paddle.nn.SimpleRNN(16, 32, 2) x = paddle.randn((4, 23, 16)) prev_h = paddle.randn((2, 4, 32)) y, h = rnn(x, prev_h) print(y.shape) print(h.shape) #[4,23,32] #[2,4,32] 
