Time Zone CorrectorThe  Time Zone Corrector  library provides a utility function designed to adjust time based on the user's current time zone. This library supports a wide range of time zones across the Americas, Europe, Asia, and Oceania, making it highly versatile for traders around the world. It simulates a switch-case structure using ternary operators to output the appropriate time offset relative to UTC.
Whether you're dealing with market sessions in New York, Tokyo, London, or other major trading hubs, this library helps ensure your trading algorithms can accurately account for time differences. The library is particularly useful for strategies that rely on precise timing, as it dynamically adjusts the time zone offset depending on the symbol being traded.
MATH
iteratorThe "Iterator" library is designed to provide a flexible way to work with sequences of values. This library offers a set of functions to create and manage iterators for various data types, including integers, floats, and more. Whether you need to generate an array of values with specific increments or iterate over elements in reverse order, this library has you covered.
 Key Features: 
 
 Array Creation:  Easily generate arrays of integers or floats with customizable steps, both inclusive and exclusive of the end values.
 Flexible Iteration:  Includes methods to iterate over arrays of different types, such as booleans, integers, floats, strings, colors, and drawing objects like lines and labels.
 Reverse Iteration:  Support for reverse iteration, giving you control over the order in which elements are processed.
 Automatic Loop Control:  One of the key advantages of this library is that when using the .iterate() method, it only loops over the array when there are values present. This means you don’t have to manually check if the array is populated before iterating, simplifying your code and reducing potential errors.
 Versatile Use Cases:  Ideal for scenarios where you need to loop over an array without worrying about empty arrays or checking conditions manually.
 
This library is particularly useful in cases where you need to perform operations on each element in an array, ensuring that your loops are efficient and free from unnecessary checks.
Library   "iterator" 
The "iterator" library provides a versatile and efficient set of functions for creating and managing iterators.
It allows you to generate arrays of integers or floats with customizable steps, both inclusive and exclusive of the end values.
The library also includes methods for iterating over various types, including booleans, integers, floats, strings, colors,
and drawing objects like lines and labels. With support for reverse iteration and flexible customization options.
 iterator(stop, start, step) 
  Creates an array of integers from start to stop with a specified step, excluding the stop value.
  Parameters:
     stop (int) : The end value of the iterator, exclusive.
     start (int) : The starting value of the iterator. Default is 0.
     step (int) : The increment value for each step in the iterator. Default is 1. Must be greater than 0.
  Returns: An array of integers incremented by the step value from start to stop. Will return and empty array if start = stop.
 iterator(stop, start, step) 
  Creates an array of floats from start to stop with a specified step, excluding the stop value.
  Parameters:
     stop (float) : The end value of the iterator, exclusive.
     start (float) : The starting value of the iterator. Default is 0.
     step (float) : The increment value for each step in the iterator. Default is 1. Must be greater than 0.
  Returns: An array of floats incremented by the step value from start to stop. Will return and empty array if start = stop.
 iterator_inclusive(stop, start, step) 
  Creates an array of integers from start to stop with a specified step, including the stop value.
  Parameters:
     stop (int) : The end value of the iterator, inclusive.
     start (int) : The starting value of the iterator. Default is 0.
     step (int) : The increment value for each step in the iterator. Default is 1. Must be greater than 0.
  Returns: An array of integers incremented by the step value from start to stop, including the stop value.
 iterator_inclusive(stop, start, step) 
  Creates an array of floats from start to stop with a specified step, including the stop value.
  Parameters:
     stop (float) : The end value of the iterator, inclusive.
     start (float) : The starting value of the iterator. Default is 0.
     step (float) : The increment value for each step in the iterator. Default is 1. Must be greater than 0.
  Returns: An array of floats incremented by the step value from start to stop, including the stop value.
 itr(stop, start, step) 
  Creates an array of integers from start to stop with a specified step, excluding the stop value.
  Parameters:
     stop (int) : The end value of the iterator, exclusive.
     start (int) : The starting value of the iterator. Default is 0.
     step (int) : The increment value for each step in the iterator. Default is 1. Must be greater than 0.
  Returns: An array of integers incremented by the step value from start to stop.
 itr(stop, start, step) 
  Creates an array of floats from start to stop with a specified step, excluding the stop value.
  Parameters:
     stop (float) : The end value of the iterator, exclusive.
     start (float) : The starting value of the iterator. Default is 0.
     step (float) : The increment value for each step in the iterator. Default is 1. Must be greater than 0.
  Returns: An array of floats incremented by the step value from start to stop.
 itr_in(stop, start, step) 
  Creates an array of integers from start to stop with a specified step, including the stop value.
  Parameters:
     stop (int) : The end value of the iterator, inclusive.
     start (int) : The starting value of the iterator. Default is 0.
     step (int) : The increment value for each step in the iterator. Default is 1. Must be greater than 0.
  Returns: An array of integers incremented by the step value from start to stop, including the stop value.
 itr_in(stop, start, step) 
  Creates an array of floats from start to stop with a specified step, including the stop value.
  Parameters:
     stop (float) : The end value of the iterator, inclusive.
     start (float) : The starting value of the iterator. Default is 0.
     step (float) : The increment value for each step in the iterator. Default is 1. Must be greater than 0.
  Returns: An array of floats incremented by the step value from start to stop, including the stop value.
 method iterate(self, reverse) 
  Creates an iterator array for the indices of ana array, with an option to reverse the order.
  Namespace types: array
  Parameters:
     self (array) : The array to iterate over.
     reverse (bool) : A boolean flag indicating whether to reverse the iterator order. Default is false.
  Returns: An array of integers representing the indices of the array. The order can be reversed if specified.
 method iterate(self, reverse) 
  Creates an iterator array for the indices of ana array, with an option to reverse the order.
  Namespace types: array
  Parameters:
     self (array) : The array to iterate over.
     reverse (bool) : A boolean flag indicating whether to reverse the iterator order. Default is false.
  Returns: An array of integers representing the indices of the array. The order can be reversed if specified.
 method iterate(self, reverse) 
  Creates an iterator array for the indices of ana array, with an option to reverse the order.
  Namespace types: array
  Parameters:
     self (array) : The array to iterate over.
     reverse (bool) : A boolean flag indicating whether to reverse the iterator order. Default is false.
  Returns: An array of integers representing the indices of the array. The order can be reversed if specified.
 method iterate(self, reverse) 
  Creates an iterator array for the indices of ana array, with an option to reverse the order.
  Namespace types: array
  Parameters:
     self (array) : The array to iterate over.
     reverse (bool) : A boolean flag indicating whether to reverse the iterator order. Default is false.
  Returns: An array of integers representing the indices of the array. The order can be reversed if specified.
 method iterate(self, reverse) 
  Creates an iterator array for the indices of ana array, with an option to reverse the order.
  Namespace types: array
  Parameters:
     self (array) : The array to iterate over.
     reverse (bool) : A boolean flag indicating whether to reverse the iterator order. Default is false.
  Returns: An array of integers representing the indices of the array. The order can be reversed if specified.
 method iterate(self, reverse) 
  Creates an iterator array for the indices of ana array, with an option to reverse the order.
  Namespace types: array
  Parameters:
     self (array) : The array to iterate over.
     reverse (bool) : A boolean flag indicating whether to reverse the iterator order. Default is false.
  Returns: An array of integers representing the indices of the array. The order can be reversed if specified.
 method iterate(self, reverse) 
  Creates an iterator array for the indices of ana array, with an option to reverse the order.
  Namespace types: array
  Parameters:
     self (array) : The array to iterate over.
     reverse (bool) : A boolean flag indicating whether to reverse the iterator order. Default is false.
  Returns: An array of integers representing the indices of the array. The order can be reversed if specified.
 method iterate(self, reverse) 
  Creates an iterator array for the indices of ana array, with an option to reverse the order.
  Namespace types: array
  Parameters:
     self (array) : The array to iterate over.
     reverse (bool) : A boolean flag indicating whether to reverse the iterator order. Default is false.
  Returns: An array of integers representing the indices of the array. The order can be reversed if specified.
 method iterate(self, reverse) 
  Creates an iterator array for the indices of ana array, with an option to reverse the order.
  Namespace types: array
  Parameters:
     self (array) : The array to iterate over.
     reverse (bool) : A boolean flag indicating whether to reverse the iterator order. Default is false.
  Returns: An array of integers representing the indices of the array. The order can be reversed if specified.
 method iterate(self, reverse) 
  Creates an iterator array for the indices of ana array, with an option to reverse the order.
  Namespace types: array
  Parameters:
     self (array) : The array to iterate over.
     reverse (bool) : A boolean flag indicating whether to reverse the iterator order. Default is false.
  Returns: An array of integers representing the indices of the array. The order can be reversed if specified.
 method iterate(self, reverse) 
  Creates an iterator array for the indices of ana array, with an option to reverse the order.
  Namespace types: array
  Parameters:
     self (array) : The array to iterate over.
     reverse (bool) : A boolean flag indicating whether to reverse the iterator order. Default is false.
  Returns: An array of integers representing the indices of the array. The order can be reversed if specified.
 method iterate(self, reverse) 
  Creates an iterator array for the indices of ana array, with an option to reverse the order.
  Namespace types: array
  Parameters:
     self (array) : The array to iterate over.
     reverse (bool) : A boolean flag indicating whether to reverse the iterator order. Default is false.
  Returns: An array of integers representing the indices of the array. The order can be reversed if specified.
LibraryBitwiseOperandsLibrary   "LibraryBitwiseOperands" 
Description: When you need more space for your data you can use bitwise operations. For example if you are creating an Order Block indicator and you have multiple types then you can define variables for each type with only one bit set like these:
const int TYPE_OB = 1
const int TYPE_HH = 2
const int TYPE_LH = 4
const int TYPE_HL = 8
const int TYPE_LL = 16
const int TYPE_BOS = 32
const int TYPE_CHOCH = 64
 bitwise_shift_left(x, y) 
  bitwise_shift_left(): Bitwise left shift: x << y
  Parameters:
     x (int) 
     y (int) 
  Returns: : The left operand’s value is moved toward left by the number of bits specified by the right operand.
 bitwise_shift_right(x, y) 
  bitwise_shift_right(): Bitwise right shift: x >> y
  Parameters:
     x (int) 
     y (int) 
  Returns: : The left operand’s value is moved toward right by the number of bits specified by the right operand.
 bitwise_not(x) 
  bitwise_not(): Bitwise NOT: ~x
  Parameters:
     x (int) 
  Returns: : Inverts individual bits.
 bitwise_and(x, y) 
  bitwise_and(): Bitwise AND: x & y
  Parameters:
     x (int) 
     y (int) 
  Returns: : Result bit 1, if both operand bits are 1; otherwise results bit 0.
 bitwise_or(x, y) 
  bitwise_or(): Bitwise OR: x | y
  Parameters:
     x (int) 
     y (int) 
  Returns: : Result bit 1, if any of the operand bit is 1; otherwise results bit 0.
 bitwise_xor(x, y) 
  bitwise_xor(): Bitwise (exclusive OR) XOR: x ^ y
  Parameters:
     x (int) 
     y (int) 
  Returns: : Result bit 1, if any of the operand bit is 1 but not both, otherwise results bit 0.
 logical_xor(x, y) 
  logical_xor(): Logical (exclusive OR) XOR: x xor y
  Parameters:
     x (bool) 
     y (bool) 
  Returns: : Result true, if any of the operand bit are different, otherwise results bit 0.
 bit_check(x, y) 
  bit_check(): Bitwise Checks the specified bit
  Parameters:
     x (int) 
     y (int) 
  Returns: : Returns True if the bit is set.
 bit_set(x, y) 
  bit_set(): Bitwise Sets the specified bit
  Parameters:
     x (int) 
     y (int) 
  Returns: : Returns a value with the bit set.
 bit_clear(x, y) 
  bit_clear(): Bitwise Clears the specified bit
  Parameters:
     x (int) 
     y (int) 
  Returns: : Returns a value with the bit cleared.
 bit_flip(x, y) 
  bit_flip(): Bitwise Inverts the specified bit
  Parameters:
     x (int) 
     y (int) 
  Returns: : Returns a value with the bit inverted.
 bitmask_check(x, mask) 
  bitmask_check(): Bitwise Checks the specified Mask
  Parameters:
     x (int) 
     mask (int) 
  Returns: : Returns True if the mask is set.
 bitmask_set(x, mask) 
  bitmask_set(): Bitwise Sets the specified Mask
  Parameters:
     x (int) 
     mask (int) 
  Returns: : Returns a value with the mask set.
 bitmask_clear(x, mask) 
  bitmask_clear(): Bitwise Clears the specified Mask
  Parameters:
     x (int) 
     mask (int) 
  Returns: : Returns a value with the mask cleared.
 bitmask_flip(x, mask) 
  bitmask_flip(): Inverts the specified Mask
  Parameters:
     x (int) 
     mask (int) 
  Returns: : Returns a value with the mask inverted.
 math_bit_check(x, y) 
  math_bit_check(): Fast arithmetic bitwise Checks the specified Mask
  Parameters:
     x (int) 
     y (int) 
  Returns: : Returns True if the mask is set.
 math_bit_set(x, y) 
  math_bit_set(): Fast arithmetic bitwise Sets the specified bit
  Parameters:
     x (int) 
     y (int) 
  Returns: : Returns a value with the bit set.
 math_bit_clear(x, y) 
  math_bit_clear(): Fast arithmetic bitwise Clears the specified bit
  Parameters:
     x (int) 
     y (int) 
  Returns: : Returns a value with the bit cleared.
 math_bitmask_check(x, y) 
  math_bitmask_check(): Fast arithmetic bitwise Checks the specified Mask
  Parameters:
     x (int) 
     y (int) 
  Returns: : Returns True if the mask is set.
 math_bitmask_set(x, y) 
  math_bitmask_set(): Fast arithmetic bitwise Sets the specified Mask
  Parameters:
     x (int) 
     y (int) 
  Returns: : Returns a value with the mask set.
 math_bitmask_clear(x, y) 
  math_bitmask_clear(): Fast arithmetic bitwise Clears the specified Mask
  Parameters:
     x (int) 
     y (int) 
  Returns: : Returns a value with the mask cleared.
SpectrumLibrary   "Spectrum" 
    This library includes spectrum analysis tools such as the Fast Fourier Transform (FFT).
      
 method toComplex(data, polar) 
  Creates an array of complex type objects from a float type array.
  Namespace types: array
  Parameters:
     data (array) : The float type array of input data.
     polar (bool) : Initialization coordinates; the default is false (cartesian).
  Returns: The complex type array of converted data.
 method sAdd(data, value, end, start, step) 
  Performs scalar addition of a given float type array and a simple float value.
  Namespace types: array
  Parameters:
     data (array) : The float type array of input data.
     value (float) : The simple float type value to be added.
     end (int) : The last index of the input array (exclusive) on which the operation is performed.
     start (int) : The first index of the input array (inclusive) on which the operation is performed; the default value is 0.
     step (int) : The step by which the function iterates over the input data array between the specified boundaries; the default value is 1.
  Returns: The modified input array.
 method sMult(data, value, end, start, step) 
  Performs scalar multiplication of a given float type array and a simple float value.
  Namespace types: array
  Parameters:
     data (array) : The float type array of input data.
     value (float) : The simple float type value to be added.
     end (int) : The last index of the input array (exclusive) on which the operation is performed.
     start (int) : The first index of the input array (inclusive) on which the operation is performed; the default value is 0.
     step (int) : The step by which the function iterates over the input data array between the specified boundaries; the default value is 1.
  Returns: The modified input array.
 method eMult(data, data02, end, start, step) 
  Performs elementwise multiplication of two given complex type arrays.
  Namespace types: array
  Parameters:
     data (array type from RezzaHmt/Complex/1) : the first complex type array of input data.
     data02 (array type from RezzaHmt/Complex/1) : The second complex type array of input data.
     end (int) : The last index of the input arrays (exclusive) on which the operation is performed.
     start (int) : The first index of the input arrays (inclusive) on which the operation is performed; the default value is 0.
     step (int) : The step by which the function iterates over the input data array between the specified boundaries; the default value is 1.
  Returns: The modified first input array.
 method eCon(data, end, start, step) 
  Performs elementwise conjugation on a given complex type array.
  Namespace types: array
  Parameters:
     data (array type from RezzaHmt/Complex/1) : The complex type array of input data.
     end (int) : The last index of the input array (exclusive) on which the operation is performed.
     start (int) : The first index of the input array (inclusive) on which the operation is performed; the default value is 0.
     step (int) : The step by which the function iterates over the input data array between the specified boundaries; the default value is 1.
  Returns: The modified input array.
 method zeros(length) 
  Creates a complex type array of zeros.
  Namespace types: series int, simple int, input int, const int
  Parameters:
     length (int) : The size of array to be created.
 method bitReverse(data) 
  Rearranges a complex type array based on the bit-reverse permutations of its size after zero-padding.
  Namespace types: array
  Parameters:
     data (array type from RezzaHmt/Complex/1) : The complex type array of input data.
  Returns: The modified input array.
 method R2FFT(data, inverse) 
  Calculates Fourier Transform of a time series using Cooley-Tukey Radix-2 Decimation in Time FFT algorithm, wikipedia.org
  Namespace types: array
  Parameters:
     data (array type from RezzaHmt/Complex/1) : The complex type array of input data.
     inverse (int) : Set to -1 for FFT and to 1 for iFFT.
  Returns: The modified input array containing the FFT result.
 method LBFFT(data, inverse) 
  Calculates Fourier Transform of a time series using Leo Bluestein's FFT algorithm, wikipedia.org This function is nearly 4 times slower than the R2FFT function in practice.
  Namespace types: array
  Parameters:
     data (array type from RezzaHmt/Complex/1) : The complex type array of input data.
     inverse (int) : Set to -1 for FFT and to 1 for iFFT.
  Returns: The modified input array containing the FFT result.
 method DFT(data, inverse) 
  This is the original DFT algorithm. It is not suggested to be used regularly.
  Namespace types: array
  Parameters:
     data (array type from RezzaHmt/Complex/1) : The complex type array of input data.
     inverse (int) : Set to -1 for DFT and to 1 for iDFT.
  Returns: The complex type array of DFT result.
GraphLibrary   "Graph" 
Library to collect data and draw scatterplot and heatmap as graph
 method init(this) 
  Initialise Quadrant Data
  Namespace types: Quadrant
  Parameters:
     this (Quadrant) : Quadrant object that needs to be initialised
  Returns: current Quadrant object
 method init(this) 
  Initialise Graph Data
  Namespace types: Graph
  Parameters:
     this (Graph) : Graph object that needs to be initialised with 4 Quadrants
  Returns: current Graph object
 method add(this, data) 
  Add coordinates to graph
  Namespace types: Graph
  Parameters:
     this (Graph) : Graph object
     data (Coordinate) : Coordinates containing x, y data
  Returns: current Graph object
 method calculate(this) 
  Calculation required for plotting the graph
  Namespace types: Graph
  Parameters:
     this (Graph) : Graph object
  Returns: current Graph object
 method paint(this) 
  Draw graph
  Namespace types: Graph
  Parameters:
     this (Graph) : Graph object
  Returns: current Graph object
 Coordinate 
  Coordinates of sample data
  Fields:
     xValue (series float) : x value of the sample data
     yValue (series float) : y value of the sample data
 Quadrant 
  Data belonging to particular quadrant
  Fields:
     coordinates (array) : Coordinates present in given quadrant
 GraphProperties 
  Properties of Graph that needs to be drawn
  Fields:
     rows (series int) : Number of rows (y values) in each quadrant
     columns (series int) : number of columns (x values) in each quadrant
     graphtype (series GraphType) : Type of graph - scatterplot or heatmap
     plotColor (series color) : color of plots or heatmap
     plotSize (series string) : size of cells in the table
     plotchar (series string) : Character to be printed for display of scatterplot
     outliers (series int) : Excude the outlier percent of data from calculating the min and max
     position (series string) : Table position
     bgColor (series color) : graph background color
 PlotRange 
  Range of a plot in terms of x and y values and the number of data points that fall within the Range
  Fields:
     minX (series float) : min range of X value
     maxX (series float) : max range of X value
     minY (series float) : min range of Y value
     maxY (series float) : max range of Y value
     count (series int) : number of samples in the range
 Graph 
  Graph data and properties
  Fields:
     properties (GraphProperties) : Graph Properties object associated
     quadrants (array) : Array containing 4 quadrant data
     plotRanges (matrix) : range and count for each cell
     xArray (array) : array of x values
     yArray (array) : arrray of y values
MarketAnalysisLibrary   "MarketAnalysis" 
A collection of frequently used market analysis functions in my scripts.
 bullFibRet(priceLow, priceHigh, fibLevel) 
  Calculates a bullish fibonacci retracement value.
  Parameters:
     priceLow (float) : (float) The lowest price point.
     priceHigh (float) : (float) The highest price point.
     fibLevel (float) : (float) The fibonacci level to calculate.
  Returns: The fibonacci value of the given retracement level.
 bearFibRet(priceLow, priceHigh, fibLevel) 
  Calculates a bearish fibonacci retracement value.
  Parameters:
     priceLow (float) : (float) The lowest price point.
     priceHigh (float) : (float) The highest price point.
     fibLevel (float) : (float) The fibonacci level to calculate.
  Returns: The fibonacci value of the given retracement level.
 bullFibExt(priceLow, priceHigh, thirdPivot, fibLevel) 
  Calculates a bullish fibonacci extension value.
  Parameters:
     priceLow (float) : (float) The lowest price point.
     priceHigh (float) : (float) The highest price point.
     thirdPivot (float) : (float) The third price point.
     fibLevel (float) : (float) The fibonacci level to calculate.
  Returns: The fibonacci value of the given extension level.
 bearFibExt(priceLow, priceHigh, thirdPivot, fibLevel) 
  Calculates a bearish fibonacci extension value.
  Parameters:
     priceLow (float) : (float) The lowest price point.
     priceHigh (float) : (float) The highest price point.
     thirdPivot (float) : (float) The third price point.
     fibLevel (float) : (float) The fibonacci level to calculate.
  Returns: The fibonacci value of the given extension level.
ComplexLibrary   "Complex" 
This library includes user-defined complex type, and functions to perform basic arithmetic operations on complex numbers.
 real(radius, angle) 
  Calculates the real part of a complex number based on its polar coordinates.
  Parameters:
     radius (float) 
     angle (float) 
 imag(radius, angle) 
  Calculates the imaginary part of a complex number based on its polar coordinates.
  Parameters:
     radius (float) 
     angle (float) 
 rds(real, imag) 
  Calculates the radius of a complex number based on its cartesian coordinates.
  Parameters:
     real (float) 
     imag (float) 
 ang(real, imag) 
  Calculates the angle of a complex number based on its cartesian coordinates.
  Parameters:
     real (float) 
     imag (float) 
 method realP(c) 
  Calculates the real part of a complex number represented in polar coordinates.
  Namespace types: complex
  Parameters:
     c (complex) : A complex number expressed in polar coordinates.
 method imagP(c) 
  Calculates the imaginary part of a complex number represented in polar coordinates.
  Namespace types: complex
  Parameters:
     c (complex) : A complex number expressed in polar coordinates.
 method rdsC(c) 
  Calculates the radius of a complex number represented in cartesian coordinates.
  Namespace types: complex
  Parameters:
     c (complex) : A complex number expressed in cartesian coordinates.
 method angC(c) 
  Calculates the angle of a complex number represented in cartesian coordinates.
  Namespace types: complex
  Parameters:
     c (complex) : A complex number expressed in cartesian coordinates.
 method toCart(c) 
  Converts a complex number from its polar representation to cartesian.
  Namespace types: complex
  Parameters:
     c (complex) : A complex number expressed in polar coordinates.
 method toPolar(c) 
  Converts a complex number from its cartesian representation to polar.
  Namespace types: complex
  Parameters:
     c (complex) : A complex number expressed in cartesian coordinates.
 method addC(c, z) 
  Calculates the addition of two complex numbers represented in cartesian coordinates.
  Namespace types: complex
  Parameters:
     c (complex) : First complex number expressed in cartesian coordinates.
     z (complex) : Second complex number expressed in cartesian coordinates.
 method addP(c, z) 
  Calculates the addition of two complex numbers represented in polar coordinates. Performing addition and subtraction operations in cartesian form of complex numbers is more efficient.
  Namespace types: complex
  Parameters:
     c (complex) : First complex number expressed in polar coordinates.
     z (complex) : Second complex number expressed in polar coordinates.
 method subC(c, z) 
  Calculates the subtraction of two complex numbers represented in cartesian coordinates.
  Namespace types: complex
  Parameters:
     c (complex) : First complex number expressed in cartesian coordinates.
     z (complex) : Second complex number expressed in cartesian coordinates.
 method subP(c, z) 
  Calculates the subtraction of two complex numbers represented in polar coordinates.
  Namespace types: complex
  Parameters:
     c (complex) : First complex number expressed in polar coordinates.
     z (complex) : Second complex number expressed in polar coordinates.
 method multC(c, z) 
  Calculates the multiplication of two complex numbers represented in cartesian coordinates. Performing multiplication in polar form of complex numbers is more efficient.
  Namespace types: complex
  Parameters:
     c (complex) : First complex number expressed in cartesian coordinates.
     z (complex) : Second complex number expressed in cartesian coordinates.
 method multP(c, z) 
  Calculates the multiplication of two complex numbers represented in polar coordinates.
  Namespace types: complex
  Parameters:
     c (complex) : First complex number expressed in polar coordinates.
     z (complex) : Second complex number expressed in polar coordinates.
 method powC(c, exp, shift) 
  Exponentiates a complex number represented in cartesian coordinates.
  Namespace types: complex
  Parameters:
     c (complex) : A complex number expressed in cartesian coordinates.
     exp (float) : The exponent.
     shift (float) : The phase shift of the operation. The shift is equal to 2kπ, where k is an integer number from zero to the denominator of the exponent (exclusive). Calculation of the shift value is not included in the function since it isn't always needed and for the purpose of efficiency. Use a for loop to obtain all possible results.
 method powP(c, exp, shift) 
  Exponentiates a complex number represented in polar coordinates.
  Namespace types: complex
  Parameters:
     c (complex) : A complex number expressed in polar coordinates.
     exp (float) : The exponent.
     shift (float) : The phase shift of the operation. The shift is equal to 2kπ, where k is an integer number from zero to the denominator of the exponent (exclusive). Calculation of the shift value is not included in the function since it isn't always needed and for the purpose of efficiency. Use a for loop to obtain all possible results.
 method invC(c) 
  Calculates the multiplicative inverse of a complex number represented in cartesian coordinates.
  Namespace types: complex
  Parameters:
     c (complex) 
 method invP(c) 
  Calculates the multiplicative inverse of a complex number represented in polar coordinates.
  Namespace types: complex
  Parameters:
     c (complex) 
 method negC(c) 
  Negates a complex number represented in cartesian coordinates.
  Namespace types: complex
  Parameters:
     c (complex) 
 method negP(c) 
  Negates a complex number represented in polar coordinates.
  Namespace types: complex
  Parameters:
     c (complex) 
 method con(c) 
  Calculates the conjugate of a complex number in either forms.
  Namespace types: complex
  Parameters:
     c (complex) 
 method fAddC(c, d) 
  Calculates the addition of a complex number represented in cartesian coordinates and a real number.
  Namespace types: complex
  Parameters:
     c (complex) : A complex number expressed in cartesian coordinates.
     d (float) 
  Returns: The complex number resulted by the addition in cartesian form.
 method fAddP(c, d) 
  Calculates the addition of a complex number represented in polar coordinates and a real number.
  Namespace types: complex
  Parameters:
     c (complex) : A complex number expressed in polar coordinates.
     d (float) 
  Returns: The complex number resulted by the addition in polar form.
 method fMultC(c, d) 
  Calculates the multiplication of a complex number represented in cartesian coordinates and a real number.
  Namespace types: complex
  Parameters:
     c (complex) : A complex number expressed in cartesian coordinates.
     d (float) 
  Returns: The complex number resulted by the multiplication in cartesian form.
 method fMultP(c, d) 
  Calculates the multiplication of a complex number represented in polar coordinates and a real number.
  Namespace types: complex
  Parameters:
     c (complex) : A complex number expressed in polar coordinates.
     d (float) 
  Returns: The complex number resulted by the multiplication in polar form.
 complex 
  Complex number expressed in polar or cartesian coordinates.
  Fields:
     R (series float) : Real part or radius of the complex number.
     J (series float) : Imaginary part or angle (phase) of the complex number.
     iP (series bool) : This field is employed to keep track of the coordinates of the number. Note that the functions do not verify this field for the purpose of efficiency.
BinaryLibrary   "Binary" 
        This library includes functions to convert between decimal and binary numeral formats, and logical and arithmetic operations on binary numbers.
 method toBin(value) 
  Converts the provided boolean value into binary integers (0 or 1).
  Namespace types: series bool, simple bool, input bool, const bool
  Parameters:
     value (bool) : The boolean value to be converted.
  Returns: The converted value in binary integers.
 method dec2bin(value, iBits, fBits) 
  Converts a decimal number into its binary representation.
  Namespace types: series float, simple float, input float, const float
  Parameters:
     value (float) : The decimal number to be converted.
     iBits (int) : The number of binary digits allocated for the integer part.
     fBits (int) : The number of binary digits allocated for the fractional part.
  Returns: An array containing the binary digits for the integer part at the rightmost positions and the digits for the fractional part at the leftmost positions. The array indexes correspond to the bit positions.
 method bin2dec(value, iBits, fBits) 
  Converts a binary number into its decimal representation.
  Namespace types: array
  Parameters:
     value (array) : The binary number to be converted.
     iBits (int) : The number of binary digits allocated for the integer part.
     fBits (int) : The number of binary digits allocated for the fractional part.
  Returns: The converted value in decimal format.
 method lgcAnd(a, b) 
  Bitwise logical AND of two binary numbers. The result of ANDing two binary digits is 1 only if both digits are 1, otherwise, 0.
  Namespace types: array
  Parameters:
     a (array) : First binary number.
     b (array) : Second binary number.
  Returns: An array containing the logical AND of the inputs.
 method lgcOr(a, b) 
  Bitwise logical OR of two binary numbers. The result of ORing two binary digits is 0 only if both digits are 0, otherwise, 1.
  Namespace types: array
  Parameters:
     a (array) : First binary number.
     b (array) : Second binary number.
  Returns: An array containing the logical OR of the inputs.
 method lgcXor(a, b) 
  Bitwise logical XOR of two binary numbers. The result of XORing two binary digits is 1 only if ONE of the digits is 1, otherwise, 0.
  Namespace types: array
  Parameters:
     a (array) : First binary number.
     b (array) : Second binary number.
  Returns: An array containing the logical XOR of the inputs.
 method lgcNand(a, b) 
  Bitwise logical NAND of two binary numbers. The result of NANDing two binary digits is 0 only if both digits are 1, otherwise, 1.
  Namespace types: array
  Parameters:
     a (array) : First binary number.
     b (array) : Second binary number.
  Returns: An array containing the logical NAND of the inputs.
 method lgcNor(a, b) 
  Bitwise logical NOR of two binary numbers. The result of NORing two binary digits is 1 only if both digits are 0, otherwise, 0.
  Namespace types: array
  Parameters:
     a (array) : First binary number.
     b (array) : Second binary number.
  Returns: An array containing the logical NOR of the inputs.
 method lgcNot(a) 
  Bitwise logical NOT of a binary number. The result of NOTing a binary digit is 0 if the digit is 1, or vice versa.
  Namespace types: array
  Parameters:
     a (array) : A binary number.
  Returns: An array containing the logical NOT of the input.
 method lgc2sC(a) 
  2's complement of a binary number. The 2's complement of a binary number N with n digits is defined as 2^(n) - N.
  Namespace types: array
  Parameters:
     a (array) : A binary number.
  Returns: An array containing the 2's complement of the input.
 method shift(value, direction, newBit) 
  Shifts a binary number in the specified direction by one position.
  Namespace types: array
  Parameters:
     value (array) 
     direction (int) : The direction of the shift operation.
     newBit (int) : The bit to be inserted into the unoccupied slot.
  Returns: A tuple of the shifted binary number and the serial output of the shift operation.
 method multiShift(value, direction, newBits) 
  Shifts a binary number in the specified direction by multiple positions.
  Namespace types: array
  Parameters:
     value (array) 
     direction (int) : The direction of the shift operation.
     newBits (array) 
  Returns: A tuple of the shifted binary number and the serial output of the shift operation.
 method crclrShift(value, direction, count) 
  Circularly shifts a binary number in the specified direction by multiple positions. Each ejected bit is inserted from the opposite side.
  Namespace types: array
  Parameters:
     value (array) 
     direction (int) : The direction of the shift operation.
     count (int) : The number of positions to be shifted by.
  Returns: The shifted binary number.
 method arithmeticShift(value, direction, count) 
  Performs arithmetic shift on a binary number in the specified direction by multiple positions. Every new bit is 0 if the shift is leftward, otherwise, it equals the sign bit.
  Namespace types: array
  Parameters:
     value (array) 
     direction (int) : The direction of the shift operation.
     count (int) : The number of positions to be shifted by.
  Returns: The shifted binary number.
 method add(a, b, carry) 
  Performs arithmetic addition on two binary numbers.
  Namespace types: array
  Parameters:
     a (array) : First binary number.
     b (array) : Second binary number.
     carry (int) : The input carry of the operation.
  Returns: The result of the arithmetic addition of the inputs.
 method sub(a, b, carry) 
  Performs arithmetic subtraction on two binary numbers.
  Namespace types: array
  Parameters:
     a (array) : First binary number.
     b (array) : Second binary number. The number to be subtracted.
     carry (int) : The input carry of the operation.
  Returns: The result of the arithmetic subtraction of the input b from the input a.
MathTransformLibrary   "MathTransform" 
Auxiliary functions for transforming data using mathematical and statistical methods
 scaler_zscore(x, lookback_window) 
  Calculates Z-Score normalization of a series.
  Parameters:
     x (float) : : floating point series to normalize
     lookback_window (int) : : lookback period for calculating mean and standard deviation
  Returns: Z-Score normalized series
 scaler_min_max(x, lookback_window, min_val, max_val, empiric_min, empiric_max, empiric_mid) 
  Performs Min-Max scaling of a series within a given window, user-defined bounds, and optional midpoint
  Parameters:
     x (float) : : floating point series to transform
     lookback_window (int) : : int : optional lookback window size to consider for scaling.
     min_val (float) : : float : minimum value of the scaled range. Default is 0.0.
     max_val (float) : : float : maximum value of the scaled range. Default is 1.0.
     empiric_min (float) : : float : user-defined minimum value of the input data. This means that the output could exceed the `min_val` bound if there is data in `x` lesser than `empiric_min`. If na, it's calculated from `x` and `lookback_window`.
     empiric_max (float) : : float : user-defined maximum value of the input data. This means that the output could exceed the `max_val` bound if there is data in `x` greater than `empiric_max`. If na, it's calculated from `x` and `lookback_window`.
     empiric_mid (float) : : float : user-defined midpoint value of the input data. If na, it's calculated from `empiric_min` and `empiric_max`.
  Returns: rescaled series
 log(x, base) 
  Applies logarithmic transformation to a value, base can be user-defined.
  Parameters:
     x (float) : : floating point value to transform
     base (float) : : logarithmic base, must be greater than 0
  Returns: logarithm of the value to the given base, if x <= 0, returns logarithm of 1 to the given base
 exp(x, base) 
  Applies exponential transformation to a value, base can be user-defined.
  Parameters:
     x (float) : : floating point value to transform
     base (float) : : base of the exponentiation, must be greater than 0
  Returns: the result of raising the base to the power of the value
 power(x, exponent) 
  Applies power transformation to a value, exponent can be user-defined.
  Parameters:
     x (float) : : floating point value to transform
     exponent (float) : : exponent for the transformation
  Returns: the value raised to the given exponent, preserving the sign of the original value
 tanh(x, scale) 
  The hyperbolic tangent is the ratio of the hyperbolic sine and hyperbolic cosine. It limits an output to a range of −1 to 1.
  Parameters:
     x (float) : : floating point series
     scale (float) 
 sigmoid(x, scale, offset) 
  Applies the sigmoid function to a series.
  Parameters:
     x (float) : : floating point series to transform
     scale (float) : : scaling factor for the sigmoid function
     offset (float) : : offset for the sigmoid function
  Returns: transformed series using the sigmoid function
 sigmoid_double(x, scale, offset) 
  Applies a double sigmoid function to a series, handling positive and negative values differently.
  Parameters:
     x (float) : : floating point series to transform
     scale (float) : : scaling factor for the sigmoid function
     offset (float) : : offset for the sigmoid function
  Returns: transformed series using the double sigmoid function
 logistic_decay(a, b, c, t) 
  Calculates logistic decay based on given parameters.
  Parameters:
     a (float) : : parameter affecting the steepness of the curve
     b (float) : : parameter affecting the direction of the decay
     c (float) : : the upper bound of the function's output
     t (float) : : time variable
  Returns: value of the logistic decay function at time t
Cinnamon_Bear Indicators MA LibraryLibrary   "Cinnamon_BearIndicatorsMALibrary" 
This is a personal Library of the NON built-in PineScript Moving Average function used to code indicators
 ma_dema(source, length) 
  Double Exponential Moving Average (DEMA)
  Parameters:
     source (simple float) 
     length (simple int) 
  Returns: A double level of smoothing helps to follow price movements more closely while still reducing noise compared to a single EMA.
 ma_dsma(source, length) 
  Double Smoothed Moving Average (DSMA)
  Parameters:
     source (simple float) 
     length (simple int) 
  Returns: A double level of smoothing helps to follow price movements more closely while still reducing noise compared to a single SMA.
 ma_tema(source, length) 
  Triple Exponential Moving Average (TEMA)
  Parameters:
     source (simple float) 
     length (simple int) 
  Returns: A Triple level of smoothing helps to follow price movements even more closely compared to a DEMA.
 ma_vwema(source, length) 
  Volume-Weighted Exponential Moving Average (VWEMA)
  Parameters:
     source (simple float) 
     length (simple int) 
  Returns: The VWEMA weights based on volume and recent price, giving more weight to periods with higher trading volumes.
 ma_hma(source, length) 
  Hull Moving Average (HMA)
  Parameters:
     source (simple float) 
     length (simple int) 
  Returns: The HMA formula combines the properties of the weighted moving average (WMA) and the exponential moving average (EMA) to achieve a smoother and more responsive curve.
 ma_ehma(source, length) 
  Enhanced Moving Average (EHMA)
  Parameters:
     source (simple float) 
     length (simple int) 
  Returns: The EHMA is calculated similarly to the Hull Moving Average (HMA) but uses a different weighting factor to further improve responsiveness.
 ma_trix(source, length) 
  Triple Exponential Moving Average (TRIX)
  Parameters:
     source (simple float) 
     length (simple int) 
  Returns: The TRIX is an oscillator that shows the percentage change of a triple EMA. It is designed to filter out minor price movements and display only the most significant trends. The TRIX is a momentum indicator that can help identify trends and buy or sell signals.
 ma_lsma(source, length) 
  Linear Weighted Moving Average (LSMA)
  Parameters:
     source (simple float) 
     length (simple int) 
  Returns: A moving average that gives more weight to recent prices. It is calculated using a formula that assigns linear weights to prices, with the highest weight given to the most recent price and the lowest weight given to the furthest price in the series.
 ma_wcma(source, length) 
  Weighted Cumulative Moving Average (WCMA)
  Parameters:
     source (simple float) 
     length (simple int) 
  Returns: A moving average that gives more weight to recent prices. Compared to a LSMA, the WCMA the weights of data increase linearly with time, so the most recent data has a greater weight compared to older data. This means that the contribution of the most recent data to the moving average is more significant.
 ma_vidya(source, length) 
  Variable Index Dynamic Average (VIDYA)
  Parameters:
     source (simple float) 
     length (simple int) 
  Returns: It is an adaptive moving average that adjusts its momentum based on market volatility using the formula of Chande Momentum Oscillator (CMO) .
 ma_zlma(source, length) 
  Zero-Lag Moving Average (ZLMA)
  Parameters:
     source (simple float) 
     length (simple int) 
  Returns: Its aims to minimize the lag typically associated with MA, designed to react more quickly to price changes.
 ma_gma(source, length, power) 
  Generalized Moving Average (GMA)
  Parameters:
     source (simple float) 
     length (simple int) 
     power (simple int) 
  Returns: It is a moving average that uses a power parameter to adjust the weight of historical data. This allows the GMA to adapt to various styles of MA.
 ma_tma(source, length) 
  Triangular Moving Average (TMA)
  Parameters:
     source (simple float) 
     length (simple int) 
  Returns: MA more sensitive to changes in recent data compared to the SMA, providing a moving average that better adapts to short-term price changes.
FunctionTimeFrequencyLibrary   "FunctionTimeFrequency" 
Functions to encode time in a normalized space (-0.5, 0.5) that corresponds to the position of the
current time in the referrence frequency of time.
The purpose of normalizing the time value in this manner is to provide a consistent and easily comparable
representation of normalized time that can be used for various calculations or comparisons without needing
to consider the specific scale of time. This function can be particularly useful when working with high-precision
timing data, as it allows you to compare and manipulate time values more flexibly than using absolute second
counts alone.
Reference:
github.com
 second_of_minute(t) 
  Second of minute encoded as value between (-0.5, 0.5).
  Parameters:
     t (int) : Time value.
  Returns: normalized time.
 minute_of_hour(t) 
  Minute of hour encoded as value between (-0.5, 0.5).
  Parameters:
     t (int) : Time value.
  Returns: normalized time.
 hour_of_day(t) 
  Hour of day encoded as value between (-0.5, 0.5).
  Parameters:
     t (int) : Time value.
  Returns: normalized time.
 day_of_week(t) 
  Day of week encoded as value between (-0.5, 0.5).
  Parameters:
     t (int) : Time value.
  Returns: normalized time.
 day_of_month(t) 
  Day of month encoded as value between (-0.5, 0.5).
  Parameters:
     t (int) : Time value.
  Returns: normalized time.
 day_of_year(t) 
  Day of year encoded as value between (-0.5, 0.5).
  Parameters:
     t (int) : Time value.
  Returns: normalized time.
 month_of_year(t) 
  Month of year encoded as value between (-0.5, 0.5).
  Parameters:
     t (int) : Time value.
  Returns: normalized time.
 week_of_year(t) 
  Week of year encoded as value between (-0.5, 0.5).
  Parameters:
     t (int) : Time value.
  Returns: normalized time.
signalLib_yashgode9Signal Generation Library = "signalLib_yashgode9"
This library, named "signalLib_yashgode9", is designed to generate buy and sell signals based on the price action of a financial instrument. It utilizes various technical indicators and parameters to determine the market direction and provide actionable signals for traders.
Key Features:-
1.Trend Direction Identification: The library calculates the trend direction by comparing the number of bars since the highest and lowest prices within a specified depth. This allows the library to determine the overall market direction, whether it's bullish or bearish.
2.Dynamic Price Tracking: The library maintains two chart points, zee1 and zee2, which dynamically track the price levels based on the identified market direction. These points serve as reference levels for generating buy and sell signals.
3.Customizable Parameters: The library allows users to adjust several parameters, including the depth of the price analysis, the deviation threshold, and the number of bars to consider for the trend direction. This flexibility enables users to fine-tune the library's behavior to suit their trading strategies.
4.Visual Representation: The library provides a visual representation of the buy and sell signals by drawing a line between the zee1 and zee2 chart points. The line's color changes based on the identified market direction, with red indicating a bearish signal and green indicating a bullish signal.
Usage and Integration:
To use this library, you can call the "signalLib_yashgode9" function and pass in the necessary parameters, such as the lower and higher prices, the depth of the analysis, the deviation threshold, and the number of bars to consider for the trend direction. The function will return the direction of the market (1 for bullish, -1 for bearish), as well as the zee1 and zee2 chart points.You can then use these values to generate buy and sell signals in your trading strategy. For example, you could use the direction value to determine when to enter or exit a trade, and the zee1 and zee2 chart points to set stop-loss or take-profit levels.
Potential Use Cases:
This library can be particularly useful for traders who:
1.Trend-following Strategies: The library's ability to identify the market direction can be beneficial for traders who employ trend-following strategies, as it can help them identify the dominant trend and time their entries and exits accordingly.
2.Swing Trading: The dynamic price tracking provided by the zee1 and zee2 chart points can be useful for swing traders, who aim to capture medium-term price movements.
3.Automated Trading Systems: The library's functionality can be integrated into automated trading systems, allowing for the development of more sophisticated and rule-based trading strategies.
4.Educational Purposes: The library can also be used for educational purposes, as it provides a clear and concise way to demonstrate the application of technical analysis concepts in a trading context.
Important Notice:- This library effectively work on timeframe of 5-minute and 15-minute. 
TRIGLibrary   "TRIG" 
 degreesToRadians(degrees) 
  Parameters:
     degrees (float) 
 radiansToDegrees(radians) 
  Parameters:
     radians (float) 
 rt_get_angleAlphaFromLine(x1, y1, x2, y2, inDegrees) 
  Parameters:
     x1 (int) 
     y1 (float) 
     x2 (int) 
     y2 (float) 
     inDegrees (bool) 
 rt_get_angleBetaFromLine(x1, y1, x2, y2) 
  Parameters:
     x1 (int) 
     y1 (float) 
     x2 (int) 
     y2 (float)
ALGEBRALibrary   "ALGEBRA" 
 line_fromXy(x1, y1, x2, y2) 
  Parameters:
     x1 (int) 
     y1 (float) 
     x2 (int) 
     y2 (float) 
 line_getPrice(x, slope, yInt) 
  Parameters:
     x (int) 
     slope (float) 
     yInt (float) 
 line_length(x1, y1, x2, y2) 
  Parameters:
     x1 (int) 
     y1 (float) 
     x2 (int) 
     y2 (float) 
 distance(x1, y1, x2, y2) 
  Parameters:
     x1 (int) 
     y1 (float) 
     x2 (int) 
     y2 (float)
statsLibrary   "stats" 
stats
 factorial(x) 
  factorial
  Parameters:
     x (int) 
 standardize(x, length, lengthSmooth) 
  standardize
@description Moving Standardization of a time series.
  Parameters:
     x (float) 
     length (int) 
     lengthSmooth (int) 
 dnorm(x, mean, sd) 
  dnorm
@description Approximation for Normal Density Function.
  Parameters:
     x (float) 
     mean (float) 
     sd (float) 
 pnorm(x, mean, sd, log) 
  pnorm
@description Approximation for Normal Cumulative Distribution Function.
  Parameters:
     x (float) 
     mean (float) 
     sd (float) 
     log (bool) 
 ewma(x, length, tau_hl) 
  ewma
@description Exponentially Weighted Moving Average.
  Parameters:
     x (float) 
     length (int) 
     tau_hl (float) 
 ewm_sd(x, length, tau_hl) 
  Exponentially Weighted Moving Standard Deviation.
  Parameters:
     x (float) 
     length (int) 
     tau_hl (float) 
 ewm_scoring(x, length, tau_hl) 
  ewm_scoring
@description Exponentially Weighted Moving Standardization:
  Parameters:
     x (float) 
     length (int) 
     tau_hl (float)
MathOperatorLibrary   "MathOperator" 
Methods to handle operators.
 method add(value_a, value_b) 
  Add value a to b.
  Namespace types: series float, simple float, input float, const float
  Parameters:
     value_a (float) : float, value a.
     value_b (float) : float, value b.
  Returns: float.
 method subtract(value_a, value_b) 
  subtract value b from a.
  Namespace types: series float, simple float, input float, const float
  Parameters:
     value_a (float) : float, value a.
     value_b (float) : float, value b.
  Returns: float.
 method multiply(value_a, value_b) 
  multiply value a with b.
  Namespace types: series float, simple float, input float, const float
  Parameters:
     value_a (float) : float, value a.
     value_b (float) : float, value b.
  Returns: float.
 method divide(value_a, value_b) 
  divide value a with b.
  Namespace types: series float, simple float, input float, const float
  Parameters:
     value_a (float) : float, value a.
     value_b (float) : float, value b.
  Returns: float.
 method remainder(value_a, value_b) 
  remainder of a with b.
  Namespace types: series float, simple float, input float, const float
  Parameters:
     value_a (float) : float, value a.
     value_b (float) : float, value b.
  Returns: float.
 method equal(value_a, value_b) 
  equality of value a with b.
  Namespace types: series float, simple float, input float, const float
  Parameters:
     value_a (float) : float, value a.
     value_b (float) : float, value b.
  Returns: bool.
 method not_equal(value_a, value_b) 
  inequality of value a with b.
  Namespace types: series float, simple float, input float, const float
  Parameters:
     value_a (float) : float, value a.
     value_b (float) : float, value b.
  Returns: bool.
 method over(value_a, value_b) 
  value a is over b.
  Namespace types: series float, simple float, input float, const float
  Parameters:
     value_a (float) : float, value a.
     value_b (float) : float, value b.
  Returns: bool.
 method under(value_a, value_b) 
  value a is under b.
  Namespace types: series float, simple float, input float, const float
  Parameters:
     value_a (float) : float, value a.
     value_b (float) : float, value b.
  Returns: bool.
 method over_equal(value_a, value_b) 
  value a is over equal b.
  Namespace types: series float, simple float, input float, const float
  Parameters:
     value_a (float) : float, value a.
     value_b (float) : float, value b.
  Returns: bool.
 method under_equal(value_a, value_b) 
  value a is under equal b.
  Namespace types: series float, simple float, input float, const float
  Parameters:
     value_a (float) : float, value a.
     value_b (float) : float, value b.
  Returns: bool.
 method and_(value_a, value_b) 
  logical and of a with b
  Namespace types: series bool, simple bool, input bool, const bool
  Parameters:
     value_a (bool) : bool, value a.
     value_b (bool) : bool, value b.
  Returns: bool.
 method or_(value_a, value_b) 
  logical or of a with b.
  Namespace types: series bool, simple bool, input bool, const bool
  Parameters:
     value_a (bool) : bool, value a.
     value_b (bool) : bool, value b.
  Returns: bool.
 method not_(value_a) 
  logical not of a.
  Namespace types: series bool, simple bool, input bool, const bool
  Parameters:
     value_a (bool) : bool, value a.
  Returns: bool.
 method xor_(value_a, value_b) 
  logical xor of a with b.
  Namespace types: series bool, simple bool, input bool, const bool
  Parameters:
     value_a (bool) : bool, value a.
     value_b (bool) : bool, value b.
  Returns: bool.
 method xnor_(value_a, value_b) 
  logical xnor of a with b.
  Namespace types: series bool, simple bool, input bool, const bool
  Parameters:
     value_a (bool) : bool, value a.
     value_b (bool) : bool, value b.
  Returns: bool.
 method nand_(value_a, value_b) 
  logical nand of a with b.
  Namespace types: series bool, simple bool, input bool, const bool
  Parameters:
     value_a (bool) : bool, value a.
     value_b (bool) : bool, value b.
  Returns: bool.
 method nor_(value_a, value_b) 
  logical nor of a with b.
  Namespace types: series bool, simple bool, input bool, const bool
  Parameters:
     value_a (bool) : bool, value a.
     value_b (bool) : bool, value b.
  Returns: bool.
strategy_helpersThis library is designed to aid traders and developers in calculating risk metrics efficiently across different asset types like equities, futures, and forex. It includes comprehensive functions that calculate the number of units or contracts to trade, the value at risk, and the total value of the position based on provided entry prices, stop levels, and risk percentages. Whether you're managing a portfolio or developing trading strategies, this library provides essential tools for risk management. Functions also automatically select the appropriate risk calculation method based on asset type, calculate leverage levels, and determine potential liquidation points for leveraged positions. Perfect for enhancing the precision and effectiveness of your trading strategies.
Library   "strategy_helpers" 
Provides tools for calculating risk metrics across different types of trading strategies including equities, futures, and forex. Functions allow for precise control over risk management by calculating the number of units or contracts to trade, the value at risk, and the total position value based on entry prices, stop levels, and desired risk percentage. Additional utilities include automatic risk calculation based on asset type, leverage level calculations, and determination of liquidation levels for leveraged trades.
 calculate_risk(entry, stop_level, stop_range, capital, risk_percent, trade_direction, whole_number_buy) 
  Calculates risk metrics for equity trades based on entry, stop level, and risk percent
  Parameters:
     entry (float) : The price at which the position is entered. Use close if you arent adding to a position. Use the original entry price if you are adding to a position.
     stop_level (float) : The price level where the stop loss is placed
     stop_range (float) : The price range from entry to stop level
     capital (float) : The total capital available for trading
     risk_percent (float) : The percentage of capital risked on the trade. 100% is represented by 100.
     trade_direction (bool) : True for long trades, false for short trades
     whole_number_buy (bool) : True to adjust the quantity to whole numbers
  Returns: A tuple containing the number of units to trade, the value at risk, and the total value of the position:  
 calculate_risk_futures(risk_capital, stop_range) 
  Calculates risk metrics for futures trades based on the risk capital and stop range
  Parameters:
     risk_capital (float) : The capital allocated for the trade
     stop_range (float) : The price range from entry to stop level
  Returns: A tuple containing the number of contracts to trade, the value at risk, and the total value of the position:  
 calculate_risk_forex(entry, stop_level, stop_range, capital, risk_percent, trade_direction) 
  Calculates risk metrics for forex trades based on entry, stop level, and risk percent
  Parameters:
     entry (float) : The price at which the position is entered. Use close if you arent adding to a position. Use the original entry price if you are adding to a position.
     stop_level (float) : The price level where the stop loss is placed
     stop_range (float) : The price range from entry to stop level
     capital (float) : The total capital available for trading
     risk_percent (float) : The percentage of capital risked on the trade. 100% is represented by 100.
     trade_direction (bool) : True for long trades, false for short trades
  Returns: A tuple containing the number of lots to trade, the value at risk, and the total value of the position:  
 calculate_risk_auto(entry, stop_level, stop_range, capital, risk_percent, trade_direction, whole_number_buy) 
  Automatically selects the risk calculation method based on the asset type and calculates risk metrics
  Parameters:
     entry (float) : The price at which the position is entered. Use close if you arent adding to a position. Use the original entry price if you are adding to a position.
     stop_level (float) : The price level where the stop loss is placed
     stop_range (float) : The price range from entry to stop level
     capital (float) : The total capital available for trading
     risk_percent (float) : The percentage of capital risked on the trade. 100% is represented by 100.
     trade_direction (bool) : True for long trades, false for short trades
     whole_number_buy (bool) : True to adjust the quantity to whole numbers, applicable only for non-futures and non-forex trades
  Returns: A tuple containing the number of units or contracts to trade, the value at risk, and the total value of the position:  
 leverage_level(account_equity, position_value) 
  Calculates the leverage level used based on account equity and position value
  Parameters:
     account_equity (float) : Total equity in the trading account
     position_value (float) : Total value of the position taken
  Returns: The leverage level used in the trade
 calculate_liquidation_level(entry, leverage, trade_direction, maintenance_margine) 
  Calculates the liquidation price level for a leveraged trade
  Parameters:
     entry (float) : The price at which the position is entered
     leverage (float) : The leverage level used in the trade
     trade_direction (bool) : True for long trades, false for short trades
     maintenance_margine (float) : The maintenance margin requirement, expressed as a percentage
  Returns: The price level at which the position would be liquidated, or na if leverage is zero
mathLibrary   "math" 
It's a library of discrete aproximations of a price or Series float it uses Fourier Discrete transform, Laplace Discrete Original and Modified transform and Euler's Theoreum for Homogenus White noice operations. Calling functions without source value it automatically take close as the default source value.
Here is a picture of Laplace and Fourier approximated close prices from this library:
  
Copy this indicator and try it yourself:
 import AutomatedTradingAlgorithms/math/1 as math
//@version=5
indicator("Close Price with Aproximations", shorttitle="Close and Aproximations", overlay=false)
// Sample input data (replace this with your own data)
inputData = close
// Plot Close Price
plot(inputData, color=color.blue, title="Close Price")
ltf32_result = math.LTF32(a=0.01)
plot(ltf32_result, color=color.green, title="LTF32 Aproximation")
fft_result = math.FFT()
plot(fft_result, color=color.red, title="Fourier Aproximation")
wavelet_result = math.Wavelet()
plot(wavelet_result, color=color.orange, title="Wavelet Aproximation")
wavelet_std_result = math.Wavelet_std()
plot(wavelet_std_result, color=color.yellow, title="Wavelet_std Aproximation")
 
 DFT3(xval, _dir) 
Discrete Fourier Transform with last 3 points
  Parameters:
     xval (float) : Source series
     _dir (int) : Direction parameter
  Returns: Aproxiated source value
 DFT2(xval, _dir) 
Discrete Fourier Transform with last 2 points
  Parameters:
     xval (float) : Source series
     _dir (int) : Direction parameter
  Returns: Aproxiated source value
 FFT(xval) 
Fast Fourier Transform once. It aproximates usig last 3 points.
  Parameters:
     xval (float) : Source series
  Returns: Aproxiated source value
 DFT32(xval) 
Combined Discrete Fourier Transforms of DFT3 and DTF2 it aproximates last point by first
aproximating last 3 ponts and than using last 2 points of the previus.
  Parameters:
     xval (float) : Source series
  Returns: Aproxiated source value
 DTF32(xval) 
Combined Discrete Fourier Transforms of DFT3 and DTF2 it aproximates last point by first
aproximating last 3 ponts and than using last 2 points of the previus.
  Parameters:
     xval (float) : Source series
  Returns: Aproxiated source value
 LFT3(xval, _dir, a) 
Discrete Laplace Transform with last 3 points
  Parameters:
     xval (float) : Source series
     _dir (int) : Direction parameter
     a (float) : laplace coeficient
  Returns: Aproxiated source value
 LFT2(xval, _dir, a) 
Discrete Laplace Transform with last 2 points
  Parameters:
     xval (float) : Source series
     _dir (int) : Direction parameter
     a (float) : laplace coeficient
  Returns: Aproxiated source value
 LFT(xval, a) 
Fast Laplace Transform once. It aproximates usig last 3 points.
  Parameters:
     xval (float) : Source series
     a (float) : laplace coeficient
  Returns: Aproxiated source value
 LFT32(xval, a) 
Combined Discrete Laplace Transforms of LFT3 and LTF2 it aproximates last point by first
aproximating last 3 ponts and than using last 2 points of the previus.
  Parameters:
     xval (float) : Source series
     a (float) : laplace coeficient
  Returns: Aproxiated source value
 LTF32(xval, a) 
Combined Discrete Laplace Transforms of LFT3 and LTF2 it aproximates last point by first
aproximating last 3 ponts and than using last 2 points of the previus.
  Parameters:
     xval (float) : Source series
     a (float) : laplace coeficient
  Returns: Aproxiated source value
 whitenoise(indic_, _devided, minEmaLength, maxEmaLength, src) 
Ehler's Universal Oscillator with White Noise, without extra aproximated src.
It uses dinamic EMA to aproximate indicator and thus reducing noise.
  Parameters:
     indic_ (float) : Input series for the indicator values to be smoothed
     _devided (int) : Divisor for oscillator calculations
     minEmaLength (int) : Minimum EMA length
     maxEmaLength (int) : Maximum EMA length
     src (float) : Source series
  Returns: Smoothed indicator value
 whitenoise(indic_, dft1, _devided, minEmaLength, maxEmaLength, src) 
Ehler's Universal Oscillator with White Noise and DFT1.
It uses src and sproxiated src (dft1) to clearly define white noice.
It uses dinamic EMA to aproximate indicator and thus reducing noise.
  Parameters:
     indic_ (float) : Input series for the indicator values to be smoothed
     dft1 (float) : Aproximated src value for white noice calculation
     _devided (int) : Divisor for oscillator calculations
     minEmaLength (int) : Minimum EMA length
     maxEmaLength (int) : Maximum EMA length
     src (float) : Source series
  Returns: Smoothed indicator value
 smooth(dft1, indic__, _devided, minEmaLength, maxEmaLength, src) 
Smoothing source value with help of indicator series and aproximated source value
It uses src and sproxiated src (dft1) to clearly define white noice.
It uses dinamic EMA to aproximate src and thus reducing noise.
  Parameters:
     dft1 (float) : Value to be smoothed.
     indic__ (float) : Optional input for indicator to help smooth dft1 (default is FFT)
     _devided (int) : Divisor for smoothing calculations
     minEmaLength (int) : Minimum EMA length
     maxEmaLength (int) : Maximum EMA length
     src (float) : Source series
  Returns: Smoothed source (src) series
 smooth(indic__, _devided, minEmaLength, maxEmaLength, src) 
Smoothing source value with help of indicator series
It uses dinamic EMA to aproximate src and thus reducing noise.
  Parameters:
     indic__ (float) : Optional input for indicator to help smooth dft1 (default is FFT)
     _devided (int) : Divisor for smoothing calculations
     minEmaLength (int) : Minimum EMA length
     maxEmaLength (int) : Maximum EMA length
     src (float) : Source series
  Returns: Smoothed src series
 vzo_ema(src, len) 
Volume Zone Oscillator with EMA smoothing
  Parameters:
     src (float) : Source series
     len (simple int) : Length parameter for EMA
  Returns: VZO value
 vzo_sma(src, len) 
Volume Zone Oscillator with SMA smoothing
  Parameters:
     src (float) : Source series
     len (int) : Length parameter for SMA
  Returns: VZO value
 vzo_wma(src, len) 
Volume Zone Oscillator with WMA smoothing
  Parameters:
     src (float) : Source series
     len (int) : Length parameter for WMA
  Returns: VZO value
 alma2(series, windowsize, offset, sigma) 
Arnaud Legoux Moving Average 2 accepts sigma as series float
  Parameters:
     series (float) : Input series
     windowsize (int) : Size of the moving average window
     offset (float) : Offset parameter
     sigma (float) : Sigma parameter
  Returns: ALMA value
 Wavelet(src, len, offset, sigma) 
Aproxiates srt using Discrete wavelet transform.
  Parameters:
     src (float) : Source series
     len (int) : Length parameter for ALMA
     offset (simple float) 
     sigma (simple float) 
  Returns: Wavelet-transformed series
 Wavelet_std(src, len, offset, mag) 
Aproxiates srt using Discrete wavelet transform with standard deviation as a magnitude.
  Parameters:
     src (float) : Source series
     len (int) : Length parameter for ALMA
     offset (float) : Offset parameter for ALMA
     mag (int) : Magnitude parameter for standard deviation
  Returns: Wavelet-transformed series
 LaplaceTransform(xval, N, a) 
Original Laplace Transform over N set of close prices
  Parameters:
     xval (float) : series to aproximate
     N (int) : number of close prices in calculations
     a (float) : laplace coeficient
  Returns: Aproxiated source value
 NLaplaceTransform(xval, N, a, repeat) 
Y repetirions on Original Laplace Transform over N set of close prices, each time N-k set of close prices
  Parameters:
     xval (float) : series to aproximate
     N (int) : number of close prices in calculations
     a (float) : laplace coeficient
     repeat (int) : number of repetitions
  Returns: Aproxiated source value
 LaplaceTransformsum(xval, N, a, b) 
Sum of 2 exponent coeficient of Laplace Transform over N set of close prices
  Parameters:
     xval (float) : series to aproximate
     N (int) : number of close prices in calculations
     a (float) : laplace coeficient
     b (float) : second laplace coeficient
  Returns: Aproxiated source value
 NLaplaceTransformdiff(xval, N, a, b, repeat) 
Difference of 2 exponent coeficient of Laplace Transform over N set of close prices
  Parameters:
     xval (float) : series to aproximate
     N (int) : number of close prices in calculations
     a (float) : laplace coeficient
     b (float) : second laplace coeficient
     repeat (int) : number of repetitions
  Returns: Aproxiated source value
 N_divLaplaceTransformdiff(xval, N, a, b, repeat) 
N repetitions of Difference of 2 exponent coeficient of Laplace Transform over N set of close prices, with dynamic rotation
  Parameters:
     xval (float) : series to aproximate
     N (int) : number of close prices in calculations
     a (float) : laplace coeficient
     b (float) : second laplace coeficient
     repeat (int) : number of repetitions
  Returns: Aproxiated source value
 LaplaceTransformdiff(xval, N, a, b) 
Difference of 2 exponent coeficient of Laplace Transform over N set of close prices
  Parameters:
     xval (float) : series to aproximate
     N (int) : number of close prices in calculations
     a (float) : laplace coeficient
     b (float) : second laplace coeficient
  Returns: Aproxiated source value
 NLaplaceTransformdiffFrom2(xval, N, a, b, repeat) 
N repetitions of Difference of 2 exponent coeficient of Laplace Transform over N set of close prices, second element has for 1 higher exponent factor
  Parameters:
     xval (float) : series to aproximate
     N (int) : number of close prices in calculations
     a (float) : laplace coeficient
     b (float) : second laplace coeficient
     repeat (int) : number of repetitions
  Returns: Aproxiated source value
 N_divLaplaceTransformdiffFrom2(xval, N, a, b, repeat) 
N repetitions of Difference of 2 exponent coeficient of Laplace Transform over N set of close prices, second element has for 1 higher exponent factor, dynamic rotation
  Parameters:
     xval (float) : series to aproximate
     N (int) : number of close prices in calculations
     a (float) : laplace coeficient
     b (float) : second laplace coeficient
     repeat (int) : number of repetitions
  Returns: Aproxiated source value
 LaplaceTransformdiffFrom2(xval, N, a, b) 
Difference of 2 exponent coeficient of Laplace Transform over N set of close prices, second element has for 1 higher exponent factor
  Parameters:
     xval (float) : series to aproximate
     N (int) : number of close prices in calculations
     a (float) : laplace coeficient
     b (float) : second laplace coeficient
  Returns: Aproxiated source value
AminioLibraryLibrary   "AminioLibrary" 
: this is my personal library that is being used in different indicators and strategies
 calculateMA(source, len, maType) 
  This fuction returns a moving average value based on the type
  Parameters:
     source (float) : Is the time series source to calculate average from
     len (simple int) : The length of the moving average, this should be integer
     maType (string) : The type of moving average, acceptable types are : SMA, HMA, EMA, RMA, WMA, VWMA
  Returns: value of moving average
 atr(source, len) 
  This fuction returns atr value for a given source
  Parameters:
     source (float) : Is the time series source to calculate atr from
     len (simple int) : The length of the atr, this should be integer
  Returns: value of atr from source
 superTrend(source, factor, len) 
  This fuction returns value of super trend indicator and the trend direction as a tupple
  Parameters:
     source (float) : Is the time series source to calculate super trend from
     factor (simple float) : The multiplication factor for upper and lower band calcualtion, this can be a float
     len (simple int) : The length of the super trend, this should be integer
  Returns: value of atr from source
 halfTrend(am, chdev) 
  This fuction returns a hTrend type carrying different values for half trend indicator
  Parameters:
     am (int) : This is the amplitude used for calcucating the half trend, use integers
     chdev (float) : This is the Channel Deviation value used for calculating upper and lower atr channel boundaries, you can use floats
  Returns: hTrend data type
 hTrend 
  Fields:
     halfTrend (series__float) 
     trend (series__integer) 
     atrHigh (series__float) 
     atrLow (series__float) 
     arrowUp (series__float) 
     arrowDown (series__float)
divergingchartpatternLibrary   "divergingchartpattern" 
Library having implementation of converging chart patterns
 getPatternNameByType(patternType) 
  Returns pattern name based on type
  Parameters:
     patternType (int) : integer value representing pattern type
  Returns: string name of the pattern
 method find(this, sProperties, dProperties, patterns, ohlcArray) 
  find converging patterns for given zigzag
  Namespace types: zg.Zigzag
  Parameters:
     this (Zigzag type from Trendoscope/ZigzagLite/2) : Current zigzag Object
     sProperties (ScanProperties) : ScanProperties Object
     dProperties (DrawingProperties type from Trendoscope/abstractchartpatterns/5) : DrawingProperties Object
     patterns (array type from Trendoscope/abstractchartpatterns/5) : array of existing patterns to check for duplicates
     ohlcArray (array type from Trendoscope/ohlc/1) : array of OHLC values for historical reference
  Returns: string name of the pattern
 ScanProperties 
  Object containing properties for pattern scanning
  Fields:
     baseProperties (ScanProperties type from Trendoscope/abstractchartpatterns/5) : Object of Base Scan Properties
     convergingDistanceMultiplier (series float)
utilsLibrary   "utils" 
Provides a set of utility functions for use in strategies or indicators.
 colorGreen(opacity) 
  Parameters:
     opacity (int) 
 colorRed(opacity) 
  Parameters:
     opacity (int) 
 colorTeal(opacity) 
  Parameters:
     opacity (int) 
 colorBlue(opacity) 
  Parameters:
     opacity (int) 
 colorOrange(opacity) 
  Parameters:
     opacity (int) 
 colorPurple(opacity) 
  Parameters:
     opacity (int) 
 colorPink(opacity) 
  Parameters:
     opacity (int) 
 colorYellow(opacity) 
  Parameters:
     opacity (int) 
 colorWhite(opacity) 
  Parameters:
     opacity (int) 
 colorBlack(opacity) 
  Parameters:
     opacity (int) 
 trendChangingUp(emaShort, emaLong) 
  Signals when the trend is starting to change in a positive direction.
  Parameters:
     emaShort (float) 
     emaLong (float) 
  Returns: bool
 trendChangingDown(emaShort, emaLong) 
  Signals when the trend is starting to change in a negative direction.
  Parameters:
     emaShort (float) 
     emaLong (float) 
  Returns: bool
 percentChange(start, end) 
  Returns the percent change between a start number and end number. A positive change returns a positive value and vice versa.
  Parameters:
     start (float) 
     end (float) 
  Returns: float
 percentOf(percent, n) 
  Returns the number that's the percentage of the provided value.
  Parameters:
     percent (float) : Use 0.2 for 20 percent, 0.35 for 35 percent, etc.
     n (float) : The number to calculate the percentage of.
  Returns: float
 targetPriceByPercent(percent, n) 
  Parameters:
     percent (float) 
     n (float) 
 hasNegativeSlope(start, end) 
  Parameters:
     start (float) 
     end (float) 
 timeinrange(resolution, session, timezone) 
  Returns true when the current time is within a given session window. Note, the time is calculated in the "America/New_York" timezone.
  Parameters:
     resolution (simple string) : The time interval to use to start/end the background color. Use "1" for the coloring the background up to the minute.
     session (simple string) : The session string to use to identify the time window. Example: "0930-1600:23456" means normal market hours on weekdays.
     timezone (simple string) 
  Returns: series bool
 barsSinceLastEntry() 
  Returns the number of bars since the last entry order.
  Returns: series int
 barsSinceLastExit() 
  Returns the number of bars since the last exit order.
  Returns: series int
 calcSlope(ln, lookback) 
  Calculates the slope of the provided line based on its x,y coordinates in the previous bar to the current bar.
  Parameters:
     ln (float) 
     lookback (int) 
  Returns: series float
 openPL() 
  Returns slope of the line given the start and end x,y coordinates.
  Returns: series float
 hasConsecutiveNegativeCandles(lookbackInput) 
  Returns true if the number of consecutive red candles matches the provided count.
  Parameters:
     lookbackInput (int) : The amount of bars to look back to check for consecutive negative bars. Default = 1.
  Returns: series bool
 stdevPercent(stdev, price) 
  Returns the standard deviation as a percentage of price.
  Parameters:
     stdev (float) : The standard deviation value
     price (float) : The current price of the target ticker.
  Returns: series float
XXPivotsBreakoutsLibrary   "XXPivotsBreakouts" 
Utilizes k-NN machine learning to predict breakout zones from pivot points, aiding traders in identifying potential bullish and bearish market movements. Ideal for trend-following and breakout strategies.
 breakouts(pivotBars, numNeighbors, maxData, predictionSmoothing) 
  Detects and predicts breakout points from pivot data.
  Parameters:
     pivotBars (int) : int: Number of bars for pivot point detection.
     numNeighbors (int) : int: Neighbors count for k-NN prediction.
     maxData (int) : int: Maximum pivot data points for analysis.
     predictionSmoothing (int) : int: Smoothing period for predictions.
  Returns:  : Lower and higher prediction bands plus pivot signal, 1 for ph and -1 for pl.
regressionsLibrary   "regressions" 
This library computes least square regression models for polynomials of any form for a given data set of x and y values.
 fit(X, y, reg_type, degrees) 
  Takes a list of X and y values and the degrees of the polynomial and returns a least square regression for the given polynomial on the dataset.
  Parameters:
     X (array) : (float )    X inputs for regression fit.
     y (array) : (float ) 	 y outputs for regression fit.
     reg_type (string) : (string)	 The type of regression. If passing value for degrees use reg.type_custom
     degrees (array) : (int )      The degrees of the polynomial which will be fit to the data. ex: passing array.from(0, 3) would be a polynomial of form c1x^0 + c2x^3 where c2 and c1 will be coefficients of the best fitting polynomial.
  Returns: (regression) returns a regression with the best fitting coefficients for the selecected polynomial
 regress(reg, x) 
  Regress one x input.
  Parameters:
     reg (regression) : (regression) The fitted regression which the y_pred will be calulated with.
     x (float) : (float)      The input value cooresponding to the y_pred.
  Returns: (float)		 The best fit y value for the given x input and regression.
 predict(reg, X) 
  Predict a new set of X values with a fitted regression. -1 is one bar ahead of the realtime
  Parameters:
     reg (regression) : (regression) 		The fitted regression which the y_pred will be calulated with.
     X (array) 
  Returns: (float )		 	The best fit y values for the given x input and regression.
 generate_points(reg, x, y, left_index, right_index) 
  Takes a regression object and creates chart points which can be used for plotting visuals like lines and labels.
  Parameters:
     reg (regression) : (regression)    Regression which has been fitted to a data set.
     x (array) : (float )		x values which coorispond to passed y values
     y (array) : (float )		y values which coorispond to passed x values
     left_index (int) : (int)      		The offset of the bar farthest to the realtime bar should be larger than left_index value.
     right_index (int) : (int)      		The offset of the bar closest to the realtime bar should be less than right_index value.
  Returns: (chart.point )	 Returns an array of chart points
 plot_reg(reg, x, y, left_index, right_index, curved, close, line_color, line_width) 
  Simple plotting function for regression	for more custom plotting use generate_points() to create points then create your own plotting function.
  Parameters:
     reg (regression) : (regression) 	Regression which has been fitted to a data set.
     x (array) 
     y (array) 
     left_index (int) : (int)      		The offset of the bar farthest to the realtime bar should be larger than left_index value.
     right_index (int) : (int)      		The offset of the bar closest to the realtime bar should be less than right_index value.
     curved (bool) : (bool)  		If the polyline is curved or not.
     close (bool) : (bool)  		If true the polyline will be closed.
     line_color (color) : (color) 		The color of the line.
     line_width (int) : (int) 			The width of the line.
  Returns: (polyline)      The polyline for the regression.
 series_to_list(src, left_index, right_index) 
  Convert a series to a list. Creates a list of all the cooresponding source values
from left_index to right_index. This should be called at the highest scope for consistency.
  Parameters:
     src (float) : (float ) 	The source the list will be comprised of.
     left_index (int) : (float )   The left most bar (farthest back historical bar) which the cooresponding source value will be taken for.
     right_index (int) : (float )   The right most bar closest to the realtime bar which the cooresponding source value will be taken for.
  Returns: (float )  	An array of size left_index-right_index
 range_list(start, stop, step) 
  Creates an from the start value to the stop value.
  Parameters:
     start (int) : (float ) 	The true y values.
     stop (int) : (float )   The predicted y values.
     step (int) : (int)   	Positive integer. The spacing between the values. ex: start=1, stop=6, step=2:  
  Returns: (float )  	An array of size stop-start
 regression 
  Fields:
     coeffs (array__float) 
     degrees (array__float) 
     type_linear (series__string) 
     type_quadratic (series__string) 
     type_cubic (series__string) 
     type_custom (series__string) 
     _squared_error (series__float) 
     X (array__float)






















