TradingView
moebius1977
16 Apr 2023 pukul 14.47

Profiling: array of UDTs vs UDT of arrays 

BTCUSD Perpetual ContractBybit

Deskripsi

Using Stopwatch Library by PineCoders, I am trying to test which is faster, an array of user-defined type (UDT) objects vs an object with many child arrays.

The task is to store and manipulate array of objects having total 9 values: 4 floats, 4 strings and 1 int.

Option 1: create a UDT with 9 fields and store an array of such UDT objects.
Option 2: create a UDT with 9 arrays individually for each value.

The test task is of three stages:

  • Populate array(s) with some (timenow) values - in the options you can choose how many values to push into the array/arrays. Note that max size of array(s) is set independently, so you can push 1000 of elements into an array capped at 100 max size and as new elements will be pushed (added to the end) the old exceeding elements will be shifted (removed from the beginning)
  • Write - write to random elements of the array. Two options for writing to a UDT object: (1) assign to each field independently, (2) create a UDT object and use array.set() function.
  • Read - read from random elements of the array.
    In the options you can how many times per bar to run each of the steps (same number for each step).


I tested by adding three indicators to the chart and choosing different options for each:
1. Array of UDT's where writing is done by creating a new UDT from the values and then using set(udt)
2. Array of UDT's where writing is done by assigning the value of each of the properties of the UDT individually (saving time on creating of a new object).
3. UDT of arrays.

As of 16 Arpil 2023 the UDT of arrays seems about 20-30% faster than the array of UDT's with setting each property without creating new UDT object.
Komentar
Trendoscope
Few things to note. The real comparison required here is between array of UDTs and parallel arrays.

Though you have done the same, probably not mix with UDTs and primitives
For example,
type UDT int a float b string c


First case is array of UDTs

array<UDT> udtArray = array.new<UDT>()


Second case is set of parallel arrays

array<int> aArray = array.new<int>() array<float> bArray = array.new<float>() array<string> cArray = array.new<string>()


Now add 1000 entries into UDT and add same 1000 entries into each of the arrays and find out which one is faster.

Or run loop through UDT array vs loop through all three individual arrays and see which one is faster.
Lebih lanjut