Float32Buffer¶
Inherits: RefCounted
Namespace: TauPlot
Ring buffer that stores float values (32-bit) with a fixed capacity.
Description¶
Float32Buffer stores a sequence of float values (32-bit) in a ring buffer of fixed capacity. When the buffer is full, appending a new value drops the oldest one.
All read and write operations use logical indices. Index 0 refers to the oldest value currently in the buffer. Index size()- 1 refers to the most recently appended one. Logical indices shift when the buffer wraps: after a new value is appended into a full buffer, every index decreases by one.
The buffer is pre-allocated at construction and does not resize unless set_capacity() is called explicitly.
Example¶
# Ring buffer with a capacity of 128 floats (32-bit).
var alphas := TauPlot.Float32Buffer.new(128)
# Append one float
alphas.append_value(0.5)
Notes¶
-
Default value fills unused slots. At construction and after
clear(), every slot is filled withp_default_value. Default:0.0. -
Out-of-range access logs an error.
get_value(),set_value(), andset_values()log an error and return early when the buffer is empty or the index is out of range. -
append_value()andappend_values()always succeed. They never reject input. When the buffer is full, the oldest value is silently overwritten. The return value indicates how many existing values were overwritten.
Constructor¶
new()¶
Creates an empty buffer with the given capacity. The buffer is ready to use immediately after construction.
Parameters
p_capacity: intMaximum number offloatvalues the buffer can hold. Values below1are clamped to1.p_default_value: floatValue used to fill unused slots at construction and afterclear(). Default:0.0.
Methods¶
Introspection¶
get_capacity()¶
Returns the maximum number of values the buffer can hold.
size()¶
Returns the number of values currently stored. Always between 0 and get_capacity().
Reading and writing individual values¶
get_value()¶
Returns the float at the given logical index. Index 0 is the oldest value in the buffer, size()- 1 is the most recent. Logs an error and returns 0.0 if the buffer is empty or the index is out of range.
Parameters
p_logical_index: intLogical index in the range[0,size()- 1].
set_value()¶
Overwrites the float at the given logical index. Index 0 is the oldest value, size()- 1 is the most recent. Logs an error and does nothing if the buffer is empty or the index is out of range.
Parameters
p_logical_index: intLogical index in the range[0,size()- 1].p_value: floatReplacement value.
set_values()¶
Overwrites a contiguous range of values starting at p_start_index. Writes as many values as fit from p_start_index to the end of the currently stored range. Returns the number of values actually written. Returns 0 without writing if p_values is empty, the buffer is empty, or p_start_index is out of range. Logs an error in the latter two cases.
Parameters
p_start_index: intLogical index of the first slot to overwrite. Must be in the range[0,size()- 1].p_values: PackedFloat32ArrayReplacement values. Values beyondsize()- p_start_indexare ignored.
Appending values¶
append_value()¶
Appends one float to the buffer. If the buffer is full, the oldest value is overwritten. Returns 1 if an existing value was overwritten, 0 otherwise.
Parameters
p_value: floatValue to append.
append_values()¶
Appends multiple float values to the buffer. If the buffer does not have enough free slots, the oldest values are overwritten. Returns the number of existing values overwritten. Returns 0 immediately if p_values is empty.
Parameters
p_values: PackedFloat32ArrayValues to append, in order from oldest to newest.
Capacity¶
set_capacity()¶
Resizes the buffer to the new capacity. Values below 1 are clamped to 1. If the new capacity is smaller than the current sample count, the oldest values are dropped. If the new capacity is greater, existing values are preserved, new slots are pre-filled with the default value set at construction, and size() is unchanged. Does nothing if the new capacity equals the current one.
Parameters
p_capacity: intNew maximum number of values the buffer can hold.
Clearing data¶
clear()¶
Removes all stored values. The buffer capacity is unchanged. All slots are refilled with the p_default_value set at construction.
Related Classes¶
ColorBufferSibling ring buffer storingColorvalues.Float64BufferSibling ring buffer storingfloatvalues (64-bit).Int32BufferSibling ring buffer storingintvalues (32-bit).StringBufferSibling ring buffer storingStringvalues.