UtilityLibrary

A collection of custom utility functions used in my scripts.
milliseconds_per_bar()
Gets the number of milliseconds per bar.
Returns: (int) The number of milliseconds per bar.
realtime()
Checks if the current bar is the actual realtime bar.
Returns: (bool) `true` when the current bar is the actual realtime bar, `false` otherwise.
replay()
Checks if the current bar is the last replay bar.
Returns: (bool) `true` when the current bar is the last replay bar, `false` otherwise.
bar_elapsed()
Checks how much of the current bar has elapsed.
Returns: (float) Between 0 and 1.
even(number)
Checks if a number is even.
Parameters:
number (float): (float) The number to evaluate.
Returns: (bool) `true` when the number is even, `false` when the number is odd.
sign(number)
Gets the sign of a float.
Parameters:
number (float): (float) The number to evaluate.
Returns: (int) 1 or -1, unlike math.sign() which returns 0 if the number is 0.
atan2(y, x)
Derives an angle in radians from the XY coordinate.
Parameters:
y (float): (float) Y coordinate.
x (float): (float) X coordinate.
Returns: (float) Between -π and π.
clamp(number, min, max)
Ensures a value is between the `min` and `max` thresholds.
Parameters:
number (float): (float) The number to clamp.
min (float): (float) The minimum threshold (0 by default).
max (float): (float) The maximum threshold (1 by default).
Returns: (float) Between `min` and `max`.
remove_gamma(value)
Removes gamma from normalized sRGB channel values.
Parameters:
value (float): (float) The normalized channel value [0, 1].
Returns: (float) Channel value with gamma removed.
add_gama(value)
Adds gamma into normalized linear RGB channel values.
Parameters:
value (float): (float) The normalized channel value [0, 1].
Returns: (float) Channel value with gamma added.
rgb_to_xyz(Color)
Extracts XYZ-D65 channels from sRGB colors.
Parameters:
Color (color): (color) The sRGB color to process.
Returns: (float tuple) [x, y, z]
xyz_to_rgb(x, y, z)
Converts XYZ-D65 channels to sRGB channels.
Parameters:
x (float): (float) The X channel value.
y (float): (float) The Y channel value.
z (float): (float) The Z channel value.
Returns: (int tuple) [r, g, b]
rgb_to_oklab(Color)
Extracts OKLAB-D65 channels from sRGB colors.
Parameters:
Color (color): (color) The sRGB color to process.
Returns: (float tuple) [l, a, b]
oklab_to_rgb(l, a, b)
Converts OKLAB-D65 channels to sRGB channels.
Parameters:
l (float): (float) The L channel value.
a (float): (float) The A channel value.
b (float): (float) The B channel value.
Returns: (int tuple) [r, g, b]
rgb_to_oklch(Color)
Extracts OKLCH channels from sRGB colors.
Parameters:
Color (color): (color) The sRGB color to process.
Returns: (float tuple) [l, c, h]
oklch_to_rgb(l, c, h)
Converts OKLCH channels to sRGB channels.
Parameters:
l (float): (float) The L channel value.
c (float): (float) The C channel value.
h (float): (float) The H channel value.
Returns: (float tuple) [r, g, b]
hues(l1, h1, l2, h2, dist)
Ensures the hue angles are set correctly for linearly interpolating OKLCH.
Parameters:
l1 (float): (float) The first L channel value.
h1 (float): (float) The first H channel value.
l2 (float): (float) The second L channel value.
h2 (float): (float) The second H channel value.
dist (string): (string) The preferred angular distance to use. Options: `min` or `max` (`min` by default).
Returns: (float tuple) [h1, h2]
lerp(a, b, t)
Linearly interpolates between two values.
Parameters:
a (float): (float) The starting point (first value).
b (float): (float) The ending point (second value).
t (float): (float) The interpolation factor [0, 1].
Returns: (float) Between `a` and `b`.
smoothstep(t, precise)
A non-linear (smooth) interpolation between 0 and 1.
Parameters:
t (float): (float) The interpolation factor [0, 1].
precise (bool): (bool) Sets if the calc should be precise or efficient (`true` by default).
Returns: (float) Between 0 and 1.
ease(t, n, v, x1, y1, x2, y2)
A customizable non-linear interpolation between 0 and 1.
Parameters:
t (float): (float) The interpolation factor [0, 1].
n (float): (float) The degree of ease [0≤] (1 by default).
v (string): (string) The easing variant type: `in-out`, `in`, or `out` (`in-out` by default).
x1 (float): (float) Optional X coordinate of starting point [0, 1] (0 by default).
y1 (float): (float) Optional Y coordinate of starting point [0, 1] (0 by default).
x2 (float): (float) Optional X coordinate of ending point [0, 1] (1 by default).
y2 (float): (float) Optional Y coordinate of ending point [0, 1] (1 by default).
Returns: (float) Between 0 and 1.
mix(color1, color2, blend, space, dist)
Linearly interpolates between two colors.
Parameters:
color1 (color): (color) The first color.
color2 (color): (color) The second color.
blend (float): (float) The interpolation factor [0, 1].
space (string): (string) The color space to use for interpolating. Options: `rgb`, `oklab`, and `oklch` (`rgb` by default).
dist (string): (string) The anglular distance to use for the hue change when the color space is set to `oklch`. Options: `min` and `max` (`min` by default).
Returns: (color) Blend of `color1` and `color2`.
Added:
fade(Color, Alpha)
Linearly interpolates a colors transparency.
Parameters:
Color (color): (color) The color to process.
Alpha (float): (float) The interpolation factor [0, 1], where `0` is fully transparent and `1` is the original transparency value (0.5 by default).
Returns: (color) The same RGB color with an interpolated A channel.
Added:
bar_index_to_time(Bar_Index)
Converts a `bar_index` into a `bar_time`.
Parameters:
Bar_Index (int): (int) The `bar_index`.
Returns: (int) `bar_time` of `bar_index`
source(s, o, h, l, c)
Calculates a source value. Most useful when a script uses `request.security` or `request.security_lower_tf`.
Parameters:
s (string): (string) The desired source. Options: `open`, `high`, `low`, `close`, `hl2`, `hlc3`, `ohlc4`, `hlcc4`, `min`, or `max`.
o (float): (float) The opening value.
h (float): (float) The highest value.
l (float): (float) The lowest value.
c (float): (float) The closing value.
Returns: (foat) The specified source, or 0 if the result is `na`.
Added:
method is_transparent(Color)
Method for determining if a color is invisible.
Namespace types: series color, simple color, input color, const color
Parameters:
Color (color): (color) Color to evaluate.
Returns: (bool) `true` when the color is transparent, `false` otherwise.
inv_lerp(a, b, v)
Normalizes a value between two other values (inverse lerp).
Parameters:
a (float): (float) Starting value.
b (float): (float) Ending value.
v (float): (float) Current value.
Returns: (float) Value between 0 and 1.
remap(iMin, iMax, oMin, oMax, v)
Linearly interpolates between two values given a non-normalized value.
Parameters:
iMin (float): (float) Input minimum (where to start interpolating).
iMax (float): (float) Input maximum (where to stop interpolating).
oMin (float): (float) Output minimum (lowest output value).
oMax (float): (float) Output maximum (highest output value).
v (float): (float) Current value.
Returns: (float) Value between `oMin` and `oMax`
cubic_bezier(t, p0, p1, p2, p3)
A non-linear (smooth) approximated interpolation between 0 and 1 derived from the 4 points of a Cubic Bézier Curve. Note: oddly shaped curves may produce unexpected results. Further, because the interpolation is being approximated within a bifurcation loop, calling the function with each chart update may be inefficient. While useful, minimizing calls to this function is recommended.
Parameters:
t (float): (float) Interpolation factor [0, 1].
p0 (point): (point) Starting point ((0,0) by default).
p1 (point): (point) First control point ((0.25,1) by default).
p2 (point): (point) Second control point ((0,1) by default).
p3 (point): (point) Ending point ((1,1) by default).
Returns: (float) Value between 0 and 1.
point
Coordinates for a 2D point.
Fields:
x (series float): (float) X coordinate of point.
y (series float): (float) Y coordinate of point.
Improved:
realtime()
Renamed:
bar_index_to_time() to index_to_time()
Added:
time_to_index(number_of_milliseconds)
Converts a `bar_time` offset into a `bar_index` equivalent.
Parameters:
number_of_milliseconds (int): (int) The `bar_time` offset in milliseconds.
Returns: (int) Offset converted to number of bars.
For additional information, please reference the code comments. The original function descriptions required trimming to fall within the character limit of this description.
Added:
max_bars_per_session
Gets the maximum number of intraday bars per session.
minutes_since_midnight
Converts a bars time into the number of minutes since midnight.
clock_time_from_minutes
Converts a tally of minutes since midnight into a 24-hour clock time equivalent.
tanh
Derives the Y coordinate of a hyperbolic tangent.
pushift
Ensures array size ≤ max size while appending a value.
insort
Ensures array size ≤ max size, while maintaining the sort order, and inserting a value.
nearest
Gets the array value nearest to the target value.
furthest
Gets the array value furthest from the target value.
dot
Gets the dot product of two identically sized arrays.
mag
Gets the magnitude (Euclidean norm) of an array.
cos_sim
Gets the cosine similarity between two arrays.
weighted_average
Weighted average of two arrays. When source and weight are not the same size, source values are proportionally remapped to weight indices.
between
Checks if a value is equal to or between the min-max values.
compress
Hyperbolically interpolates (eases) between two values after the a threshold is exceeded.
sclamp
A semi-linear (smooth) clamp, ensuring a value is between the min and max.
bezier_points
Simplifies point creation for the Cubic Bézier function.
lerp_lut
Generates a look-up table (an array) for a given shaping function.
length
Increments a length to the maximum value with each new bar. Intended to be used with moving averages.
ema
Similar to the built-in ta.ema, but with a more flexible length (series and optionally progressive), adjustable alpha via weight, and is anchorable like ta.vwapta.vwap.
wma
Weighted moving average, similar to ta.wma, but with explicit weight declarations.
vec2 (previously "point")
Coordinates for a 2D point.
vec2_x4
A collection of four 2D points, used by this libraries cubic_bezier function.
Minor Updates (mostly the comments):
- milliseconds_per_bar
- index_to_time
- time_to_index
- realtime
- replay
- even
- sign
- clamp
- inv_lerp
- remap
- smoothstep
- ease
- cubic_bezier
- source
- method is_transparent
- mix
Removed:
- point (now vec2)
Added:
session_index
Gets the index of the current intraday session. Similar to bar_index but for sessions.
session_bar_index
Gets the index of the current intraday bar relative to its parent session.
bars_per_session()
Counts the number of elapsed bars within a session on intraday charts.
session_anchor()
Checks if the current bar is the first bar of an intraday session.
Updated ease function to include out-in as a variant.
Added:
deltatime
Gets the number of milliseconds between consecutive script executions.
len
Gets the Euclidean length (magnitude) of a 2D point, relative to the origin (0,0).
zero
Zero's a point to an origin.
lma
An anchorable Linearly Interpolated Moving Average.
rgb_to_lin
Extracts Linear RGB channels [0,1] from sRGB color.
lin_to_rgb
Converts Linear RGB channels [0,1] into an sRGB color.
Added:
math
Returns an array of floats resulting from an element-wise operation between two input arrays.
eval
Returns an array of booleans resulting from an element-wise comparison between two input arrays.
Added overloads for:
math
eval
Removed thumbnail code form library.
-  Fixed remap() bug
-  Improved sign() reliability for near zero floats
-  Converted tabs to spaces
-  Added barValAvgStr enum.
-  Added textSizeStr enum.
Changed:
replay to last_replay_bar
Added:
replay_mode
Checks if replay mode is active on all bars.
binary_search_nearest
Gets an array index nearest to the target value.
Updated:
insort
Now uses binary_search_nearest to get the insertion index.
-  Modified sign() to detect the sign of negative zero.
-  Updated pushift(): removed while-loop and added overload to merge arrays (not just single values).
-  Added simple int milliseconds_per_bar to minimize redundant calculations within functions.
-  Updated "session_anchor()" to more reliably return true.
Added:
- mod(): Alternate to the built-in % operator; if you're working with potentially negative values and care about consistency with absolute values or wrapping.
Updated:
- even(): Now works with floats; only checks if the integer part of a number is even.
- sign(): Simplified logic.
Added:
- e16(): Shifts decimal 16 digits to the right and casts to int. 
Bibliothèque Pine
Dans le plus pur esprit TradingView, l'auteur a publié ce code Pine en tant que bibliothèque open-source afin que d'autres programmeurs Pine de notre communauté puissent le réutiliser. Bravo à l'auteur! Vous pouvez utiliser cette bibliothèque en privé ou dans d'autres publications à code source ouvert, mais la réutilisation de ce code dans des publications est régie par nos Règles.
Website: liquid-trader.com
Clause de non-responsabilité
Bibliothèque Pine
Dans le plus pur esprit TradingView, l'auteur a publié ce code Pine en tant que bibliothèque open-source afin que d'autres programmeurs Pine de notre communauté puissent le réutiliser. Bravo à l'auteur! Vous pouvez utiliser cette bibliothèque en privé ou dans d'autres publications à code source ouvert, mais la réutilisation de ce code dans des publications est régie par nos Règles.
Website: liquid-trader.com
