Class ComputeTensorData
Tensor
data storage for GPU backends
Inherited Members
Namespace: Unity.Barracuda
Syntax
public class ComputeTensorData : UniqueResource, ITensorData, IDisposable, ITensorDataStatistics, IUniqueResource
Constructors
ComputeTensorData(ComputeBuffer, TensorShape, Int32, String, ComputeInfo.ChannelsOrder)
Create ComputeTensorData
with specified buffer
Declaration
public ComputeTensorData(ComputeBuffer buffer, TensorShape shape, int offset, string buffername, ComputeInfo.ChannelsOrder onDeviceChannelsOrder)
Parameters
Type | Name | Description |
---|---|---|
ComputeBuffer | buffer | buffer |
TensorShape | shape | shape |
Int32 | offset | offset |
String | buffername | buffer name |
ComputeInfo.ChannelsOrder | onDeviceChannelsOrder | channels order |
ComputeTensorData(TensorShape, String, ComputeInfo.ChannelsOrder, Boolean)
Create ComputeTensorData
Declaration
public ComputeTensorData(TensorShape shape, string buffername, ComputeInfo.ChannelsOrder onDeviceChannelsOrder, bool clearOnInit = true)
Parameters
Type | Name | Description |
---|---|---|
TensorShape | shape | shape |
String | buffername | buffer name |
ComputeInfo.ChannelsOrder | onDeviceChannelsOrder | channel order |
Boolean | clearOnInit | clear on init |
Fields
name
Parent Tensor
name
Declaration
public string name
Field Value
Type | Description |
---|---|
String |
Properties
buffer
Data storage as ComputeBuffer
Declaration
public ComputeBuffer buffer { get; }
Property Value
Type | Description |
---|---|
ComputeBuffer |
channelsOrder
Channel order channels-first vs channels-last
Declaration
public ComputeInfo.ChannelsOrder channelsOrder { get; }
Property Value
Type | Description |
---|---|
ComputeInfo.ChannelsOrder |
inUse
Returns true if this tensor data is attached to any tensor.
Declaration
public virtual bool inUse { get; }
Property Value
Type | Description |
---|---|
Boolean |
Implements
isGPUMem
Returns true if this tensor data is reserved as GPU memory.
Declaration
public virtual bool isGPUMem { get; }
Property Value
Type | Description |
---|---|
Boolean |
Implements
maxCapacity
Returns the maximum number of element this tensorData can contain.
Declaration
public virtual int maxCapacity { get; }
Property Value
Type | Description |
---|---|
Int32 |
Implements
offset
Offset in the data storage buffer
Declaration
public int offset { get; }
Property Value
Type | Description |
---|---|
Int32 |
Methods
Dispose()
Dispose internal storage
Declaration
public virtual void Dispose()
Download(TensorShape)
Returns an array filled with the values of a tensor.
Depending on the implementation and underlying device this array might be a copy or direct reference to the tensor values.
This is a blocking call, unless data from device was requested via ScheduleAsyncDownload
beforehand and has already arrived.
Declaration
public virtual float[] Download(TensorShape shape)
Parameters
Type | Name | Description |
---|---|---|
TensorShape | shape | the TensorShape (and thus length) of the data to copy |
Returns
Type | Description |
---|---|
Single[] | Tensor data as |
Implements
Finalize()
Finalizer
Declaration
protected void Finalize()
Reserve(Int32)
Reserve uninitialized memory.
Declaration
public virtual void Reserve(int count)
Parameters
Type | Name | Description |
---|---|---|
Int32 | count | element count to reserve |
Implements
ScheduleAsyncDownload(Int32)
Schedule an asynchronous download from device memory.
count
is the number of element to readback.
Declaration
public virtual bool ScheduleAsyncDownload(int count)
Parameters
Type | Name | Description |
---|---|---|
Int32 | count | count of elements to download |
Returns
Type | Description |
---|---|
Boolean |
|
Implements
SharedAccess(out Int32)
Returns an array filled with the values of multiple tensors that share the same tensorData on device.
Depending on the implementation and underlying device this array might be a copy or direct reference to tensor values, no conversion from on device memory layout will occur.
This is a blocking call, unless data from device was requested via ScheduleAsyncDownload
beforehand and has already arrived.
Declaration
public virtual float[] SharedAccess(out int offset)
Parameters
Type | Name | Description |
---|---|---|
Int32 | offset | This function outputs |
Returns
Type | Description |
---|---|
Single[] | array filled with the values of multiple tensors that share the same tensorData on device |
Implements
ToString()
Summary
Declaration
public override string ToString()
Returns
Type | Description |
---|---|
String | summary |
Upload(Single[], TensorShape, Int32)
Initialize with data
.
shape
is the TensorShape (and thus length) of the data to copy.
managedBufferStartIndex
is the offset where to start the copy in the data
Declaration
public virtual void Upload(float[] data, TensorShape shape, int managedBufferStartIndex = 0)
Parameters
Type | Name | Description |
---|---|---|
Single[] | data | data as |
TensorShape | shape | Tensor shape |
Int32 | managedBufferStartIndex | managed buffer start index |