| TensorRT 10.4.0
    | 
Base class for all layer classes in a network definition. More...
#include <NvInfer.h>
 
  
| Public Member Functions | |
| LayerType | getType () const noexcept | 
| Return the type of a layer.  More... | |
| void | setName (char const *name) noexcept | 
| Set the name of a layer.  More... | |
| char const * | getName () const noexcept | 
| Return the name of a layer.  More... | |
| int32_t | getNbInputs () const noexcept | 
| Get the number of inputs of a layer.  More... | |
| ITensor * | getInput (int32_t index) const noexcept | 
| Get the layer input corresponding to the given index.  More... | |
| int32_t | getNbOutputs () const noexcept | 
| Get the number of outputs of a layer.  More... | |
| ITensor * | getOutput (int32_t index) const noexcept | 
| Get the layer output corresponding to the given index.  More... | |
| void | setInput (int32_t index, ITensor &tensor) noexcept | 
| Replace an input of this layer with a specific tensor.  More... | |
| void | setPrecision (DataType dataType) noexcept | 
| Set the preferred or required computational precision of this layer in a weakly-typed network.  More... | |
| DataType | getPrecision () const noexcept | 
| get the computational precision of this layer  More... | |
| bool | precisionIsSet () const noexcept | 
| whether the computational precision has been set for this layer  More... | |
| void | resetPrecision () noexcept | 
| reset the computational precision for this layer  More... | |
| void | setOutputType (int32_t index, DataType dataType) noexcept | 
| Set the output type of this layer in a weakly-typed network.  More... | |
| DataType | getOutputType (int32_t index) const noexcept | 
| get the output type of this layer  More... | |
| bool | outputTypeIsSet (int32_t index) const noexcept | 
| whether the output type has been set for this layer  More... | |
| void | resetOutputType (int32_t index) noexcept | 
| reset the output type for this layer  More... | |
| void | setMetadata (char const *metadata) noexcept | 
| Set the metadata for this layer.  More... | |
| char const * | getMetadata () const noexcept | 
| Get the metadata of the layer.  More... | |
| Protected Member Functions | |
| virtual | ~ILayer () noexcept=default | 
|  Protected Member Functions inherited from nvinfer1::INoCopy | |
| INoCopy ()=default | |
| virtual | ~INoCopy ()=default | 
| INoCopy (INoCopy const &other)=delete | |
| INoCopy & | operator= (INoCopy const &other)=delete | 
| INoCopy (INoCopy &&other)=delete | |
| INoCopy & | operator= (INoCopy &&other)=delete | 
| Protected Attributes | |
| apiv::VLayer * | mLayer | 
Base class for all layer classes in a network definition.
| 
 | protectedvirtualdefaultnoexcept | 
| 
 | inlinenoexcept | 
Get the layer input corresponding to the given index.
| index | The index of the input tensor. | 
| 
 | inlinenoexcept | 
Get the metadata of the layer.
| 
 | inlinenoexcept | 
Return the name of a layer.
| 
 | inlinenoexcept | 
Get the number of inputs of a layer.
| 
 | inlinenoexcept | 
Get the number of outputs of a layer.
| 
 | inlinenoexcept | 
Get the layer output corresponding to the given index.
| 
 | inlinenoexcept | 
get the output type of this layer
| index | the index of the output | 
| 
 | inlinenoexcept | 
get the computational precision of this layer
| 
 | inlinenoexcept | 
Return the type of a layer.
| 
 | inlinenoexcept | 
whether the output type has been set for this layer
| index | the index of the output | 
| 
 | inlinenoexcept | 
whether the computational precision has been set for this layer
| 
 | inlinenoexcept | 
reset the output type for this layer
| index | the index of the output | 
| 
 | inlinenoexcept | 
reset the computational precision for this layer
| 
 | inlinenoexcept | 
Replace an input of this layer with a specific tensor.
| index | the index of the input to modify. | 
| tensor | the new input tensor | 
Except for IFillLayer, ILoopOutputLayer, INMSLayer, IResizeLayer, IShuffleLayer, and ISliceLayer, this method cannot change the number of inputs to a layer. The index argument must be less than the value of getNbInputs().
See comments for overloads of setInput() for layers with special behavior.
| 
 | inlinenoexcept | 
Set the metadata for this layer.
The metadata is emitted in the JSON returned by IEngineInspector with ProfilingVerbosity set to kDETAILED.
| metadata | The per-layer metadata. | 
| 
 | inlinenoexcept | 
Set the name of a layer.
This method copies the name string.
| 
 | inlinenoexcept | 
Set the output type of this layer in a weakly-typed network.
Setting the output type constrains TensorRT to choose implementations which generate output data with the given type. If it is not set, TensorRT will select output type based on layer computational precision. TensorRT could still choose non-conforming output type based on fastest implementation. To force choosing the requested output type, set exactly one of the following flags, which differ in what happens if no such implementation exists:
In case layer precision is not specified, or falling back, the output type depends on the chosen implementation, based on performance considerations and the flags specified to the builder.
This method cannot be used to set the data type of the second output tensor of the TopK layer. The data type of the second output tensor of the topK layer is always Int32. Also the output type of all layers that are shape operations must be DataType::kINT32, and all attempts to set the output type to some other data type will be ignored except for issuing an error message.
Note that the layer output type is generally not identical to the data type of the output tensor, as TensorRT may insert implicit reformatting operations to convert the former to the latter. Calling layer->setOutputType(i, type) has no effect on the data type of the i-th output tensor of layer, and users need to call layer->getOutput(i)->setType(type) to change the tensor data type. This is particularly relevant if the tensor is marked as a network output, since only setType() [but not setOutputType()] will affect the data representation in the corresponding output binding.
Strongly-typed networks reject calls to method setOutputType. Instead, the output type can be set only for layers that define method setToType(). Those layers are:
| index | the index of the output to set | 
| dataType | the type of the output | 
| 
 | inlinenoexcept | 
Set the preferred or required computational precision of this layer in a weakly-typed network.
Setting the precision directs TensorRT to choose an implementation that runs at this computational precision. TensorRT could still choose a non-conforming fastest implementation that ignores the requested precision. To force choosing an implementation with the requested precision, set exactly one of the following flags, which differ in what happens if no such implementation exists:
If precision is not set, or falling back, TensorRT will select the layer computational precision and layer input type based on global performance considerations and the flags specified to the builder.
For a IIdentityLayer: If it casts to/from float/half/int8/uint8, the precision must be one of those types, otherwise it must be either the input or output type.
Strongly-typed networks reject calls to method setPrecision. In strongly-typed networks, the computation precision is typically controlled by casting the input tensors to the desired type.
| dataType | the computational precision. | 
| 
 | protected | 
   
  Copyright © 2024 NVIDIA Corporation 
   
  Privacy Policy |
  Manage My Privacy |
  Do Not Sell or Share My Data |
  Terms of Service |
  Accessibility |
  Corporate Policies |
  Product Security |
  Contact