ReadValue¶
Versioned name: ReadValue-6
Category: Infrastructure
Short description: ReadValue returns value of the variable_id
variable.
Detailed description:
ReadValue, Assign, and Variable define a coherent mechanism for reading, writing, and storing some memory buffer between inference calls. More details can be found on the StateAPI documentation page.
If the 1st input is provided and this is the first inference or reset has been called, ReadValue returns the value from the 1st input.
If the 1st input is not provided and this is the first inference or reset has been called,
ReadValue returns the tensor with the variable_shape
and variable_type
and zero values.
In all other cases ReadValue returns the value from the corresponding variable_id
variable.
If the 1st input has been provided, the operation checks if variable_shape
and variable_type
extend (relax) the shape and type inferred from the 1st input. If not, it returns an error.
For example, if variable_type
is specified as dynamic, it means that any type for 1st input
is allowed but if it is specified as f32, only f32 type is allowed.
Only one pair of ReadValue and Assign operations is expected for each Variable in the model.
Attributes:
variable_id
Description: identifier of the variable to be read.
Range of values: any non-empty string
Type: string
Required: yes
variable_type
Description: the type of the variable
Range of values: : u1, u4, u8, u16, u32, u64, i4, i8, i16, i32, i64, f16, f32, boolean, bf16
Type:
string
Required: yes
variable_shape
Description: the shape of the variable
Range of values: list of integers, empty list is allowed, which means 0D or scalar tensor
Type:
int[]
Required: yes
Inputs
1:
init_value
- input tensor whose values are used in the first inference or after a reset call. Optional.
Outputs
1: tensor with the same shape and type as specified in variable_type, variable_shape.
Example
<layer ... type="ReadValue" ...>
<data variable_id="lstm_state_1" variable_type="f32" variable_shape="1,3,224,224"/>
<input>
<port id="0">
<dim>1</dim>
<dim>3</dim>
<dim>224</dim>
<dim>224</dim>
</port>
</input>
<output>
<port id="1">
<dim>1</dim>
<dim>3</dim>
<dim>224</dim>
<dim>224</dim>
</port>
</output>
</layer>