2019-02-20 15:24:51 +03:00
|
|
|
# Buffers
|
2020-08-08 15:51:04 +07:00
|
|
|
|
2021-05-07 19:59:21 +07:00
|
|
|
Buffer is one of main building blocks of kmath. It is a basic interface allowing random-access read and write (
|
|
|
|
with `MutableBuffer`). There are different types of buffers:
|
2019-02-20 15:24:51 +03:00
|
|
|
|
2021-05-07 19:59:21 +07:00
|
|
|
* Primitive buffers wrapping like `DoubleBuffer` which are wrapping primitive arrays.
|
2019-02-20 15:24:51 +03:00
|
|
|
* Boxing `ListBuffer` wrapping a list
|
|
|
|
* Functionally defined `VirtualBuffer` which does not hold a state itself, but provides a function to calculate value
|
|
|
|
* `MemoryBuffer` allows direct allocation of objects in continuous memory block.
|
|
|
|
|
2021-05-07 19:59:21 +07:00
|
|
|
Some kmath features require a `BufferFactory` class to operate properly. A general convention is to use functions
|
|
|
|
defined in
|
|
|
|
`Buffer` and `MutableBuffer` companion classes. For example factory `Buffer.Companion::auto` in most cases creates the
|
|
|
|
most suitable buffer for given reified type (for types with custom memory buffer it still better to use their
|
|
|
|
own `MemoryBuffer.create()` factory).
|
2019-02-20 15:24:51 +03:00
|
|
|
|
|
|
|
## Buffer performance
|
2020-08-08 15:51:04 +07:00
|
|
|
|
2021-05-07 19:59:21 +07:00
|
|
|
One should avoid using default boxing buffer wherever it is possible. Try to use primitive buffers or memory buffers
|
2024-04-15 17:42:52 +03:00
|
|
|
instead.
|