PineHelperLibrary   "PineHelper" 
This library provides various functions to reduce your time.
 recent_opentrade_entry_bar_index() 
  get a recent opentrade entry bar_index
  Returns: (int) bar_index
 recent_closedtrade_entry_bar_index() 
  get a recent closedtrade entry bar_index
  Returns: (int) bar_index
 recent_closedtrade_exit_bar_index() 
  get a recent closedtrade exit bar_index
  Returns: (int) bar_index
 all_opnetrades_roi() 
  get all aopentrades roi
  Returns: (float) roi
 bars_since_recent_opentrade_entry() 
  get bars since recent opentrade entry
  Returns: (int) number of bars
 bars_since_recent_closedtrade_entry() 
  get bars since recent closedtrade entry
  Returns: (int) number of bars
 bars_since_recent_closedtrade_exit() 
  get bars since recent closedtrade exit
  Returns: (int) number of bars
 recent_opentrade_entry_id() 
  get recent opentrade entry ID
  Returns: (string) entry ID
 recent_closedtrade_entry_id() 
  get recent closedtrade entry ID
  Returns: (string) entry ID
 recent_closedtrade_exit_id() 
  get recent closedtrade exit ID
  Returns: (string) exit ID
 recent_opentrade_entry_price() 
  get recent opentrade entry price
  Returns: (float) price
 recent_closedtrade_entry_price() 
  get recent closedtrade entry price
  Returns: (float) price
 recent_closedtrade_exit_price() 
  get recent closedtrade exit price
  Returns: (float) price
 recent_opentrade_entry_time() 
  get recent opentrade entry time
  Returns: (int) time
 recent_closedtrade_entry_time() 
  get recent closedtrade entry time
  Returns: (int) time
 recent_closedtrade_exit_time() 
  get recent closedtrade exit time
  Returns: (int) time
 time_since_recent_opentrade_entry() 
  get time since recent opentrade entry
  Returns: (int) time
 time_since_recent_closedtrade_entry() 
  get time since recent closedtrade entry
  Returns: (int) time
 time_since_recent_closedtrade_exit() 
  get time since recent closedtrade exit
  Returns: (int) time
 recent_opentrade_size() 
  get recent opentrade size
  Returns: (float) size
 recent_closedtrade_size() 
  get recent closedtrade size
  Returns: (float) size
 all_opentrades_size() 
  get all opentrades size
  Returns: (float) size
 recent_opentrade_profit() 
  get recent opentrade profit
  Returns: (float) profit
 all_opentrades_profit() 
  get all opentrades profit
  Returns: (float) profit
 recent_closedtrade_profit() 
  get recent closedtrade profit
  Returns: (float) profit
 recent_opentrade_max_runup() 
  get recent opentrade max runup
  Returns: (float) runup
 recent_closedtrade_max_runup() 
  get recent closedtrade max runup
  Returns: (float) runup
 recent_opentrade_max_drawdown() 
  get recent opentrade maxdrawdown
  Returns: (float) mdd
 recent_closedtrade_max_drawdown() 
  get recent closedtrade maxdrawdown
  Returns: (float) mdd
 max_open_trades_drawdown() 
  get max open trades drawdown
  Returns: (float) mdd
 recent_opentrade_commission() 
  get recent opentrade commission
  Returns: (float) commission
 recent_closedtrade_commission() 
  get recent closedtrade commission
  Returns: (float) commission
 qty_by_percent_of_equity(percent) 
  get qty by percent of equtiy
  Parameters:
     percent : (series float) percent that you want to set 
  Returns: (float) quantity
 qty_by_percent_of_position_size(percent) 
  get size by percent of position size
  Parameters:
     percent : (series float) percent that you want to set 
  Returns: (float) size
 is_day_change() 
  get bool change of day
  Returns: (bool) day is change or not
 is_in_trade() 
  get bool using number of bars
  Returns: (bool) allowedToTrade
 discord_message(name, message) 
  get json format discord message
  Parameters:
     name : (string) name of bot 
     message : (string) message that you want to send
  Returns: (string) json format string
 telegram_message(chat_id, message) 
  get json format telegram message
  Parameters:
     chat_id : (string) chatId of bot
     message : (string) message that you want to send
  Returns: (string) json format string
Formatting
HexLibrary   "Hex" 
Hex String Utility
 intToHex(_n) 
  helper Binary half octet to hex character
  Parameters:
     _n : Digits to convert
 fromDigits(_input, _buffer) 
  Digits to Hex String output
  Parameters:
     _input : Integer Input
     _buffer : Number of 0's to pad Hex with
  Returns: string  output hex character value buffered to desired length (00-ff default)
MiteTricksLibrary "MiteTricks"
Matrix Global Registry.
Get, Set, automatic growing, universal get/set,
multi-matrix dictionaries, multi-dictionary matrixes..
add slice matrixes of any type, share one common global key registry
pull up an item from a category, and item name ie a table of info.
same cell needs a color, a size, a string, a value, etc..
all of which can be pulled up with the same group id, and key id.
just swap which matrix you pull the value from.
this has a side benefit of non-repainting and recalculating
when pulling values, changing inputs..
makes for very fast/clean usage..
benefit :
floats = value
strings = names
lines = drawn items
table =table of data items for this key
colors = color for line/table/fill,label..
all of those can be pulled with "get(_VALUES,_groupIDX,_keyIDX)" where only the values matrix needs be swapped, and the same item/coordinates remains for all the possible matrixes that item appears in.
also useful as a dictionary/registry for any given type of item,,
and goes very handy with floats/strings/colors/bools with my matrixautotable
very helpful when prototyping or doing development work as a shortcut.
initRegistry()
  Registry inititalizer
  Returns: registry of string matrix type
newbool(optional, optional, optional)
  create bool type new matrix presized 2x2 for reg
  Parameters:
    optional: row size
    optional: column size
    optional: fill value(default is bool (na)
  Returns: bool matrix of specified size and fill, or blank 2x2 for registry use
newbox(optional, optional, optional)
  create box type new matrix presized 2x2 for reg
  Parameters:
    optional: row size
    optional: column size
    optional: fill value(default is box (na)
  Returns: box matrix of specified size and fill, or blank 2x2 for registry use
newcolor(optional, optional, optional)
  create color type new matrix presized 2x2 for reg
  Parameters:
    optional: row size
    optional: column size
    optional: fill value(default is color (na)
  Returns: color matrix of specified size and fill, or blank 2x2 for registry use
newfloat(optional, optional, optional)
  create float type new matrix presized 2x2 for reg
  Parameters:
    optional: row size
    optional: column size
    optional: fill value(default is float (na)
  Returns: float matrix of specified size and fill, or blank 2x2 for registry use
newint(optional, optional, optional)
  create int type new matrix presized 2x2 for reg
  Parameters:
    optional: row size
    optional: column size
    optional: fill value(default is int (na)
  Returns: int matrix of specified size and fill, or blank 2x2 for registry use
newlabel(optional, optional, optional)
  create label type new matrix presized 2x2 for reg
  Parameters:
    optional: row size
    optional: column size
    optional: fill value(default is label (na)
  Returns: label matrix of specified size and fill, or blank 2x2 for registry use
newline(optional, optional, optional)
  create line type new matrix presized 2x2 for reg
  Parameters:
    optional: row size
    optional: column size
    optional: fill value(default is line (na)
  Returns: line matrix of specified size and fill, or blank 2x2 for registry use
newlinefill(optional, optional, optional)
  create linefill type new matrix presized 2x2 for reg
  Parameters:
    optional: row size
    optional: column size
    optional: fill value(default is linefill(na)
  Returns: linefill matrix of specified size and fill, or blank 2x2 for registry use
newstring(optional, optional, optional)
  create string type new matrix presized 2x2 for reg
  Parameters:
    optional: row size
    optional: column size
    optional: fill value(default is string (na)
  Returns: string matrix of specified size and fill, or blank 2x2 for registry use
newtable(optional, optional, optional)
  create table type new matrix presized 2x2 for reg
  Parameters:
    optional: row size
    optional: column size
    optional: fill value(default is table (na)
  Returns: table matrix of specified size and fill, or blank 2x2 for registry use
newfrom(INIT_FILL)
  newfrom Matrix full of item input
  Parameters:
    INIT_FILL: item to fill (2x2) the matri and set type. a type(na) works
addrow(m, v)
  addrow Add new row to matrix
  Parameters:
    m: matrix of type being added to
    v: value of type being added to ( best leave NA on string for registry purposes)
addcolumn(matrix, value)
  addcolumn
  Parameters:
    matrix: of type being added to
    value: of type being added to ( best leave NA on string for registry purposes)
get(_VALS, _KEYREG, _GROUP, _KEY)
  get Grabs value and returns single item
  Parameters:
    _VALS: Matrix Values slice
    _KEYREG: Registry values matrix (strings)
    _GROUP: name of group/category or int group key
    _KEY: name of item to fetch from value registry or int key id
  Returns: item 
get(_VALS, _GROUP, _KEY)
  get Grabs value and returns single item
  Parameters:
    _VALS: Matrix Values slice
    _GROUP: name of group/category
    _KEY: name of item to fetch from value registry
getgid(_KEYREG, _GROUP)
  getgid
  Parameters:
    _KEYREG: Reg to pull group id from
    _GROUP: group index int, or string name to get the other missing type
getkid(_KEYREG, _GROUP, _KEY)
  getkid
  Parameters:
    _KEYREG: Reg to pull Key id from
    _GROUP: group index int, or string name
    _KEY: index of string key id to get it's ID int
getkey(_KEYREG, _GROUP, _KEY)
  getkey
  Parameters:
    _KEYREG: Reg to pull Key id from
    _GROUP: group index int, or string name for getting key string
    _KEY: index of string key id to get it's match of other type
set(_VALS, _KEYREG, _GROUP, _KEY, _value)
  set items to reg and matrix container
  Parameters:
    _VALS: Values matrix container
    _KEYREG: Key registry
    _GROUP: (string) Group/Category name
    _KEY: (string) Key for item
    _value: item
  Returns: void
del(_VALS, _KEYREG, _GROUP, _KEY)
  del grroup id
  Parameters:
    _VALS: Matrix Values slice
    _KEYREG: Registry values matrix (strings)
    _GROUP: name of group/category
    _KEY: name of item to Delete from values and key
detached(_GROUP, _KEY, _VALUE)
  detached make detached registry/val matrix
  Parameters:
    _GROUP: Name of first group
    _KEY: Name of first item
    _VALUE: Item of any type, sets the output type too.
 
threengine_global_automation_libraryLibrary   "threengine_global_automation_library" 
A collection of functions used for trade automation
 getBaseCurrency() 
  Gets the base currency for the chart's ticker. Supported trade pairs are USD, USDT, USDC, BTC, and PERP.
  Returns: Base currency as a string
 getChartSymbol() 
  Get the current chart's symbol without the base currency appended to it. Supported trade paris are USD, USDT, USDC, BTC, and PERP.
  Returns: Ssymbol and base currency
 getDecimals() 
  Calculates how many decimals are on the quote price of the current market
  Returns: The current deimal places on the market quote price
 checkVar() 
  Plot a string as a label on the chart to test variable value. Use str.tostring() for any variable that isn't a string.
  Returns: Label with stringified variable
 getStrategyAlertMessage() 
  Generates stringified JSON for a limit order that can be passed to the strategy alert_message for a long entry.
  Returns: Stringifed JSON for a long entry
 taGetAdx() 
  Calculates the Average Directional Index
  Returns: The value of ADX as a float
 taGetEma() 
  Calculates the EMA based on a type, source, and length. Supported types are EMA, SMA, RMA, and WMA.
  Returns: The value of the selected EMA
 isBetweenTwoTimes() 
  Checks to see if within a rage based on two times
@retunrs true/false boolean
 getAllTradeIDs() 
  This gets all closed trades and open trades
@retunrs an array of all open and closed trade ID's
 getOpenTradeIDs() 
  This gets all open trades
@retunrs an array of all open trade ID's
 orderAlreadyExists() 
  This checks to see if a provided order id uses the getAllTradeIDs() function to check
@retunrs an array of all open and closed trade ID's
 orderCurrentlyExists() 
  This checks to see if a provided order id uses the getAllTradeIDs() function to check
  Returns: an array of all open and closed trade ID's
 getContractCount() 
  calulates the number of contracts you can buy with a set amount of capital and a limit price
  Returns: number of contracts you can buy based on amount of capital you want to use and a price
 getLadderSteps() 
  Returns: array of ladder entry prices and amounts based on total amount you want to invest across all ladder rungs and either a range between ladderStart and LadderStop based on specificed number of ladderRungs OR ladderStart, ladderRungs, and LadderSpacingPercent
HarmonicSwitches█ OVERVIEW 
This library is complementary for  XABCD Harmonic Pattern Custom Range Interactive 
 TupleSwitchHL() 
  : Tuple Switch for High Low
  Parameters:
     : : _bool, low_X, high_X, low_A, high_A, low_B, high_B, low_C, high_C
  Returns: : price_X, price_A, price_B, price_C
 TupleSwitchStyleColor() 
  : Tuple switch for style and color
  Parameters:
     : : _bool
  Returns: : style0, style1, col_dir
 TupleSwitchString() 
  : Tuple switch for string
  Parameters:
     : : _bool
  Returns: : str_dir, str_X, str_A
 TupleSwitchValid() 
  : Tuple switch for valid
  Parameters:
     : : _str
  Returns: : str_invalid, str_valid
 TupleSwitchTime() 
  : Tuple switch for time
  Parameters:
     : : _str, time_1, time_2, time_3
  Returns: : E1, E2
 SwitchColor() 
  : Switch color
  Parameters:
     : : _str
  Returns: : col_valid
 SwitchExtend() 
  : Extend line
  Parameters:
     : : _str
  Returns: : _extend
srcCalcLibrary   "srcCalc" 
Provides functions for converting input strings 'open','high','low','close','hl2','hlc3','ohlc4','hlcc4' to corresponding source values.
 get_src(src) 
  Converts string to source float value
  Parameters:
     src : String to use (`close` is used if no argument is supplied).
  Returns: Returns the float value of the string
CommonMarkupLibrary   "CommonMarkup" 
Provides functions for chart markup, such as indicating recession bands.
 markRecessionBands(showBands, lineY, labelY) 
  Mark vertical bands and show recession band labels if argument showBands is true. Example "markRecessionBands(bar_index ,3.0"
  Parameters:
     showBands : - show vertical recession bands when true. Functionally equiv to no op when false
     lineY : - y-axis value for line positioning
     labelY : - y-axis value for label positioning
@return true - always answers the value of showBands
Object: object oriented programming made possible! Hash map's in Pinescript?? Absolutely 
This Library is the first step towards bringing a much needed data structure to the Pine Script community.
"Object" allows Pine coders to finally create objects full or unique key:value pairs, which are converted to strings and stored in an array. Data can be stored and accessed using dedicated get and set methods.
 The workflow is simple, but has a few nuances:
0. Import this library into your project; you can give it whatever alias you'd like (I'll be using obj)
1. Create your first object using the obj.new() method and assign it a variable or "ID".
2. Use the object's ID as the first argument into the obj.set() method, for the key and value there's one extra step required. They must be added as arguments to the appropriate prop_() method.
 Note: While objects in this library technically only store data as strings, any primitive data type can be converted to a string before being stored, meaning that one object can hold data from multiple types at once. There's a trade off though..Pine Script requires that all exported function parameters have pre-defined types, meaning that as convenient as it would be to have a single method for storing and returning data of every type, it's not currently possible. Instead there are functions to add properties for each individual type, which are then converted to strings automatically (the original type is flagged and stored along with the data). Furthermore, since switch/if statements can only return values of the same type, there must also be "get" methods which correspond with each type. Again, a single "get" method which auto-detects the returned value's type  was  the goal but it's just not currently possible. Instead each get method is only allowed to return a value of its own type. No worries though, all the "get" methods will throw errors if they can't access the data you're trying to access. In that error message, you'll be informed exactly which "get" method you need to use if you ever lose track of what type of data you should be returning.   
3. The second argument for obj.set() method is the obj.prop_() method. You just plug in your key as a string and your value and you're done. Easy as that.
 Please do not skip this step, properties must be formatted correctly for data to be stored and accessed correctly  
4. Obj.get_ (s: string, f: float, b: bool, i: int) methods are even easier, just choose whichever method will return the data type you need, then plug in your ID, and key and that's it. Objects will output data of the same type they were stored as! 
There's a short example at the end of the script if you'd like to see more!
 prop_string(string: key, string: value) 
 
 returns property formatted to string and flagged as string type
 
 prop_float(string: key, float: value) 
 
 returns property formatted to string and flagged as  float type
 
 prop_bool(string: key, bool: value) 
 
 returns property formatted to string and flagged as bool type
 
 prop_int(string: key, int: value) 
 
 returns property formatted to string and flagged as int type
 
 Support for lines and shapes coming soon! 
 new() 
 
 returns an empty object
 
 set(string : ID, string: property) 
 
 adds new property to object
 
 get_f(string : ID, string: key) 
 
 returns float values
 
 get_s(string : ID, string: key) 
 
 returns string values
 
 get_b(string : ID, string: key) 
 
 returns boolean values
 
 get_i(string : ID, string: key) 
 
 returns int values
 
 More methods like Obj.remove(), Obj.size(), Obj.fromString, Obj.fromArray, Obj.toJSON, Obj.keys, & Obj.values coming very soon!!
HarmonicCalculation█ OVERVIEW
This library is complementary for  XABCD Harmonic Pattern Custom Range Interactive 
 PriceDiff() 
  : Price Difference
  Parameters:
     : : price_1, price_2
  Returns: : PriceDiff
 TimeDiff() 
  : Time Difference
  Parameters:
     : : time_1, time_2
  Returns: : TimeDiff
 ReturnIndexOf3Arrays() 
  : Return Index Of 3 Arrays
  Parameters:
     : : id1, id2, id3, _int
  Returns: : ReturnIndexOf3Arrays
 AbsoluteRange() 
  : Price Difference
  Parameters:
     : : price, y, point
  Returns: : AbsoluteRange
 PriceAverage() 
  : To calculate average of 2 prices
  Parameters:
     : : price_1, price_2
  Returns: : PriceAverage
 TimeAverage() 
  : To calculate average of 2 times
  Parameters:
     : : time_1, time_2
  Returns: : TimeAverage
 StringBool() 
  : To show ratio in 3 decimals format
  Parameters:
     : : _value, _bool, _text
  Returns: : StringBool
 PricePercent() 
  : To show Price in percent format
  Parameters:
     : : _price, PriceRef, str_dir
  Returns: : PricePercent
 BoolCurrency() 
  : To show syminfo.currency
  Parameters:
     : : _bool
  Returns: : BoolCurrency
 RatioText() 
  : To show RatioText in 3 decimals format
  Parameters:
     : : _value, _text
  Returns: : RatioText
 RangeText() 
  : To display RangeText in Harmonic Range Format
  Parameters:
     : : _id1, _id2, _int, _text
  Returns: : RangeText
 PriceCurrency() 
  : To show Currency in Price Format
  Parameters:
     : : _bool, _value
  Returns: : PriceCurrency
"Swap" - Bool/Position/Value  : Array / Matrix / Var AutoswapLibrary   "swap" 
Side / Boundary Based All Types Swapper
- three automagical types for Arrays, Matrixes, and Variables
-- no signal     : Long/ Short position autoswap
-- true / false  : Boolean based side choice
-- Src / Thresh  : if source is above or  below the threshold
- two operating modes for variables, Holding mode only for arrays/matrixes
-- with two   items, will automatically change between the two caveat is it does not delete table/box/line(fill VAR items automatically)
-- with three items, a neutral is available for NA input or neutral
- one function name for all of them. One import name that's easy to type/remember
-- make life easy for your conditional items.
 side(source, thresh, _a, _b, _c) 
  side    Change outputs based on position or a crossing level
  Parameters:
     source : (float)  OPTIONAL value    input      
     thresh : (float)  OPTIONAL boundary line to cross
     _a : (any)    if Long/True/Above
     _b : (any)    if Short/False/Below
     _c : (any)    OPTIONAL  NOT FOR MTX OR ARR... Neutral Item, if var/varip on a/b it will leave behind, ie, a table or box or line will not erase , if it's a varip you're sending in. 
  Returns: first, second, or third items based on input conditions
Please notify if bugs found.
Thanks.
TradingHookLibrary   "TradingHook" 
This library is a client script for making a webhook signal formatted string to TradingHook webhook server.
 buy_message(password, amount, order_name)  Make a buy Message for TradingHook.
  Parameters:
     password : (string)   password that you set in  .env  file.
     amount : (float)    amount. If not set, your strategy qty will be sent.
     order_name : (string)    order_name. The default name is "Order".
  Returns: (string) A string containing the formatted webhook message.
 sell_message(password, percent, order_name)  Make a sell message for TradingHook.
  Parameters:
     password : (string)   password that you set in  .env  file.
     percent : (string)    what percentage of your quantity you want to sell.
     order_name : (string)   order_name. The default name is "Order".
  Returns: (string) A string containing the formatted webhook message.
You can use TradingHook WebServer open source code in github(github.com)
SizeAndPlaceLibrary   "SizeAndPlace" 
size and location shortcuts
 posYtoInt(string)  posYtoInt as titled..
  Parameters:
     string : _inp
 posXtoInt(string)  posXtoInt as titled..
  Parameters:
     string : _inp
 sizeToInt(string)  sizeToInt as titled..
  Parameters:
     string : size
 sizeToString(int)  sizeToString as titled..
  Parameters:
     int : size
 sizeStringToSize(string)  sizeStringToSize as titled..
  Parameters:
     string : size
 locationIntToStr(int)  locationIntToStr as titled..
  Parameters:
     int : inp
 locStringToLoc(string)  locStringToLoc as titled..
  Parameters:
     string : location
 posIntToString(int, int)  posIntToString as titled..
  Parameters:
     int : _x      
     int : _y
Time█   OVERVIEW 
This library is a Pine Script™ programmer’s tool containing a variety of time related functions to calculate or measure time, or format time into string variables.
█   CONCEPTS 
 `formattedTime()`, `formattedDate()` and `formattedDay()` 
Pine Script™, like many other programming languages, uses timestamps in UNIX format, expressed as the number of milliseconds elapsed since 00:00:00 UTC, 1 January 1970. These three functions convert a UNIX timestamp to a formatted string for human consumption. 
These are examples of ways you can call the functions, and the ensuing results:
 CODE                                                            RESULT
formattedTime(timenow)                                  >>>     "00:40:35"
formattedTime(timenow, "short")                         >>>     "12:40 AM"
formattedTime(timenow, "full")                          >>>     "12:40:35 AM UTC"
formattedTime(1000 * 60 * 60 * 3.5, "HH:mm")            >>>     "03:30"
formattedDate(timenow, "short")                         >>>     "4/30/22"
formattedDate(timenow, "medium")                        >>>     "Apr 30, 2022"
formattedDate(timenow, "full")                          >>>     "Saturday, April 30, 2022"
formattedDay(timenow, "E")                              >>>     "Sat"
formattedDay(timenow, "dd.MM.yy")                       >>>     "30.04.22"
formattedDay(timenow, "yyyy.MM.dd G 'at' hh:mm:ss z")   >>>     "2022.04.30 AD at 12:40:35 UTC" 
These functions use  str.format()  and some of the special formatting codes it allows for. Pine Script™ documentation does not yet contain complete specifications on these codes, but in the meantime you can find some information in the  The Java™ Tutorials  and in Java documentation of its  MessageFormat class . Note that  str.format()  implements only a subset of the MessageFormat features in Java.
 `secondsSince()` 
The introduction of  varip  variables in Pine Script™ has made it possible to track the time for which a condition is true when a script is executing on a realtime bar. One obvious use case that comes to mind is to enable trades to exit only when the exit condition has been true for a period of time, whether that period is shorter that the chart's timeframe, or spans across multiple realtime bars.
For more information on this function and  varip  please see our  Using `varip` variables  publication. 
 `timeFrom( )` 
When plotting  lines ,  boxes , and  labels  one often needs to calculate an offset for past or future end points relative to the time a condition or point occurs in history. Using  xloc.bar_index  is often the easiest solution, but some situations require the use of  xloc.bar_time . We introduce  `timeFrom()`  to assist in calculating time-based offsets. The function calculates a timestamp using a negative (into the past) or positive (into the future) offset from the current bar's starting or closing time, or from the current time of day. The offset can be expressed in units of chart timeframe, or in seconds, minutes, hours, days, months or years. This function was ported from our  Time Offset Calculation Framework .
 `formattedNoOfPeriods()` and `secondsToTfString()`  
Our final two offerings aim to confront two remaining issues: 
 How much time is represented in a given timestamp? 
How can I produce a "simple string" timeframe usable with  request.security()  from a timeframe expressed in seconds? 
 `formattedNoOfPeriods()`  converts a time value in ms to a quantity of time units. This is useful for calculating a difference in time between 2 points and converting to a desired number of units of time. If no unit is supplied, the function automatically chooses a unit based on a predetermined time step. 
 `secondsToTfString()`  converts an input time in seconds to a target timeframe string in  timeframe.period  string format. This is useful for implementing stepped timeframes relative to the chart time, or calculating multiples of a given chart timeframe. Results from this function are in  simple  form, which means they are useable as `timeframe` arguments in functions like  request.security() . 
 
█   NOTES 
Although the example code is commented in detail, the size of the library justifies some further explanation as many concepts are demonstrated. Key points are as follows: 
 • Pivot points are used to draw lines from.  `timeFrom( )`  calculates the length of the lines in the specified unit of time.
  By default the script uses 20 units of the charts timeframe. Example: a 1hr chart has arrows 20 hours in length.
 • At the point of the arrows  `formattedNoOfPeriods()`  calculates the line length in the specified unit of time from the input menu. 
  If  “Use Input Time”  is disabled, a unit of time is automatically assigned. 
 • At each pivot point a label with a formatted date or time is placed with one of the three formatting helper functions to display the time or date the pivot occurred. 
 • A label on the last bar showcases  `secondsSince()` . The label goes through three stages of detection for a timed alert.
  If the difference between the high and the open in ticks exceeds the input value, a timer starts and will turn the label red once the input time is exceeded to simulate a time-delayed alert. 
 • In the bottom right of the screen  `secondsToTfString()`  posts the chart timeframe in a table. This can be multiplied from the input menu. 
 Look first. Then leap.  
█   FUNCTIONS 
 formattedTime(timeInMs, format)  
  Converts a UNIX timestamp (in milliseconds) to a formatted time string.
  Parameters:
     timeInMs : (series float) Timestamp to be formatted. 
     format : (series string) Format for the time. Optional. The default value is "HH:mm:ss".
  Returns: (string) A string containing the formatted time.
 formattedDate(timeInMs, format)  
  Converts a UNIX timestamp (in milliseconds) to a formatted date string.
  Parameters:
     timeInMs : (series float) Timestamp to be formatted. 
     format : (series string) Format for the date. Optional. The default value is "yyyy-MM-dd".
  Returns: (string) A string containing the formatted date.
 formattedDay(timeInMs, format)  
  Converts a UNIX timestamp (in milliseconds) to the name of the day of the week.
  Parameters:
     timeInMs : (series float) Timestamp to be formatted. 
     format : (series string) Format for the day of the week. Optional. The default value is "EEEE" (complete day name).
  Returns: (string) A string containing the day of the week.
 secondsSince(cond, resetCond)  
  The duration in milliseconds that a condition has been true.
  Parameters:
     cond : (series bool) Condition to time.       
     resetCond : (series bool) When `true`, the duration resets. 
  Returns: The duration in seconds for which `cond` is continuously true.
 timeFrom(from, qty, units)  
  Calculates a +/- time offset in variable units from the current bar's time or from the current time.
  Parameters:
     from : (series string) Starting time from where the offset is calculated: "bar" to start from the bar's starting time, "close" to start from the bar's closing time, "now" to start from the current time.
     qty : (series int) The +/- qty of units of offset required. A "series float" can be used but it will be cast to a "series int".
     units : (series string) String containing one of the seven allowed time units: "chart" (chart's timeframe), "seconds", "minutes", "hours", "days", "months", "years".
  Returns: (int) The resultant time offset `from` the `qty` of time in the specified `units`.
 formattedNoOfPeriods(ms, unit)  
  Converts a time value in ms to a quantity of time units.
  Parameters:
     ms : (series int) Value of time to be formatted. 
     unit : (series string) The target unit of time measurement. Options are "seconds", "minutes", "hours", "days", "weeks", "months". If not used one will be automatically assigned. 
  Returns: (string) A formatted string from the number of `ms` in the specified `unit` of time measurement
 secondsToTfString(tfInSeconds, mult)  
  Convert an input time in seconds to target string TF in `timeframe.period` string format.
  Parameters:
     tfInSeconds : (simple int) a timeframe in seconds to convert to a string.       
     mult : (simple float) Multiple of `tfInSeconds` to be calculated. Optional. 1 (no multiplier) is default. 
  Returns: (string) The `tfInSeconds` in `timeframe.period` format usable with `request.security()`.
jsonLibrary   "json" 
Convert JSON strings to tradingview       
▦ FEATURES ▦                        
█ Json to array  █  Get json key names  █ Get json key values  █ Size of json
                 
 get_json_keys_names(raw_json)  Returns string array with all key names
  Parameters:
     raw_json : (string) Raw JSON string 
  Returns: (string array) Array with all key names
 get_values_by_id_name(raw_json, key_name)  Returns string array with values of the input key name
  Parameters:
     raw_json : (string) Raw JSON string 
     key_name : (string) Name of the key to be fetched
  Returns: (string array) Array with values of the input key name
 size_of_json_string(raw_json)  Returns size of raw JSON string  
  Parameters:
     raw_json : (string) Raw JSON string 
  Returns:   Size of n_of_values, size of n_of_keys_names
TS_FFALibrary   "TS_FFA" 
Splits the ticker and generates best configs for FP and PP
splitter(x) Splits the ticker and found the configuration regarding to name.
  Parameters:
    _x: ticker
  Returns: Fib and Profit percent values
- Splitter had been added.
- USDTPERP coins on Binance had been added
- timeFrameMultiplier() timeframe multiplier had been added to the library
- timeframe period value fixed
- Changed timezone multiplier
- Changed VWMA Percent values
CRCHud - HUD Library (Heads Up Display)Library   "CRCHud" 
Library of functions which will contain functions that allow reusable HUD (Heads up Display) components to used from within other scripts
 add_cell_change()  - Adds a new cell to designated table which displays the data source value, the line color, data title, and automatically calculated %percent change stats based on lookback value supplied (default   - previous bar)
Thange VaultLibrary   "ThangeVault" 
Thange Vault is a collection of utility functions required by the Thange Woodwind Playbook.
 debug(msg)  Print debug information
  Parameters:
     msg : message to be logged on console
  Returns: nothing
 tickFormat()  Create a string template to restrict stop-loss, take-profit level precision to ticks.
  Returns: A string format template
Dictionary/Object LibraryThis Library is aimed to mitigate the limitation of Pinescript having only one structured data type which is only arrays. 
It lacks data types like Dictionaries(in Python) or Object (in JS) that are standard for other languages. Tuples do exist, but it hardly solves any problem.
Working only with Arrays could be overwhelming if your codebase is large. I looked for alternatives to arrays but couldn't find any library. 
So I coded it myself and it's been working good for me. So I wanted to share it with you all.
 What does it do: 
==================
If you are familiar with Python or Javascript, this library tries to immimate Object/Dictonary like structure with Key Value Pairs. 
For Example:
object= {name:"John Doe", age: 28 , org: "PineCoders"}
And then it also tries to immitate the Array of Objects (I call it Stack)
like this:
stack= Array({name:"John Doe", age: 28 , org: "PineCoders"},
         {name:"Adam Smith", age: 32 , org: "PineCoders"},
         {name:"Paragjyoti Deka", age: 25 , org: "PineCoders"})
So there are basically two ideas: Objects and Stacks.
But it looks whole different in Pinescript for obvious reasons. 
 Limitation:  
The major limitation I couldn't overcome was that, for all of the values: both input and return values for properties will be of string type.
This is due to the limiation of Pinecsript that there is no way to return a value on a if-else statement dynamically with different data types. 
And as the input data type must be explicitly defined when exporting the library functions, only string inputs are allowed. 
Now that doesn't mean you won't be able to use integer, float or boolens, you just need to pass the string value for it using str.tostring() method. 
And the output for the getter functions will be in strings as well. But I have added some type conversion methods that you could use from this library itself.
From String to Float, String To Integer and String to Boolean: these three methods are included in this library.
So basically the whole library is based on a manipulatiion of Array of strings under the hood.
///////////////
 Usage 
///////////////
Import the library using this statement:
import paragjyoti2012/STR_Dict_Lib/4 as DictLib
 Objects 
First define an object using this method:
 
 for eample:
 object1= DictLib.init("name=John,age=26,org=") 
 This is similar to 
     object1= {name:"John",age:"26", org:""} in JS or Python
  
  Just like we did here in for "org", you can set initital value to "". But remember to pass string values, even for a numerical properties, like here in "age". 
  You can use "age="+str.tostring(age). If you find it tedious, you can always add properties later on using .set() method.
  
  So it could also be initiated like this
    object= DictLib.init("name=John")
  and later on
     DictLib.set(object1,"age", str.toString(age))
     DictLib.set(object1,"org", "PineCoders")
The getter function looks like this
age= DictLib.get(object1,"age")
name=DictLib.get(object1,"name")
The first argument for all methods .get, .set, and .remove is the pointer (name of the object). 
///////////////////////////
 Array Of Objects  (Stacks)  
///////////////////////////
As I mentioned earlier, I call the array of objects as Stack.
Here's how to initialize a Stack.
 stack= DictLib.initStack(object1)
 
 The .initStack() method takes an object pointer as argument. It simply converts the array into a string and pushes it into the newly created stack.
 Rest of all the methods for Stacks, takes the stack pointer as it's first arument.
 For example:
     DictLib.pushStack(stack,object2)
 The second argument here is the object pointer. It adds the object to it's stack. Although it might feel like a two dimentional array, it's actually an one dimentional array with string values.
 Under the hood, it looks like this  
////////////////////
 Methods  
////////////////////
For Objects
-------------------
 init()  : Initializes the object. 
params: (string) e.g 
returns: The object ( )
example: 
    object1=DictLib.init("name=John,age=26,org=")
...................
 get()  : Returns the value for given property
params: (string  object_pointer, string property)
returns: string
example:
    age= DictLib.get(object1,"age")
.......................
 set()  : Adds a new property or updates an existing property
params: (string  object_pointer, string property, string value)
returns: void
example:
    DictLib.set(object1,"age", str.tostring(29))
........................
 remove()  : Removes a property from the object
params   : (string  object_pointer, string property)
returns: void
example: 
    DictLib.set(object1,"org")
    
........................
For Array Of Objects (Stacks)
-------------------------------
 initStack()  : Initializes the stack. 
params: (string  object_pointer) e.g 
returns: The Stack
example: 
    stack= DictLib.initStack(object1)
...................
 pushToStack()  : Adds an object at at last index of the stack
params: (string  stack_pointer, string  object_pointer)
returns: void
example:
    DictLib.pushToStack(stack,object2)
.......................
 popFromStack()  : Removes the last object from the stack
params: (string  stack_pointer)
returns: void
example:
    DictLib.popFromStack(stack)
.......................
 insertToStack()  : Adds an object at at the given index of the stack
params: (string  stack_pointer, string  object_pointer, int index)
returns: void
example:
    DictLib.insertToStack(stack,object3,1)
.......................
 removeFromStack()  : Removes the object from the given index of the stack
params: (string  stack_pointer, int index)
returns: void
example:
    DictLib.removeFromStack(stack,2)
.......................
 getElement ()  : Returns the value for given property from an object in the stack (index must be given)
params: (string  stack_pointer, int index, string property)
returns: string
example:
    ageFromObject1= DictLib.getElement(stack,0,"age")
.......................
 setElement()  : Updates an existing property of an object in the stack (index must be given)
params: (string  stack_pointer, int index, string property, string value)
returns: void
example:
    DictLib.setElement(stack,0,"age", str.tostring(32))
........................
 includesElement()  : Checks if any object exists in the stack with the given property-value pair
params   : (string  stack_pointer, string property, string value)
returns : Boolean
example: 
  doesExist= DictLib.includesElement(stack,"org","PineCoders")
    
........................
 searchStack()  : Search for a property-value pair in the stack and returns it's index
params: (stringp  stack_pointer, string property, string value)
returns: int (-1 if doesn't exist)
example: 
  index= DictLib.searchElement(stack,"org","PineCoders")
///////////////////////
 Type Conversion Methods 
///////////////////////
 strToFloat()  : Converts String value to Float
params: (string value)
returns: float
example: 
  floatVal= DictLib.strToFloat("57.96")
.............................
 strToInt()  : Converts String value to Integer
params: (string value)
returns: int
example: 
  intVal= DictLib.strToFloat("45")
.............................
 strToBool()  : Converts String value to Boolean
params: (string value)
returns: boolean
example: 
  boolVal= DictLib.strToBool("true")
.............................
 Points to remember 
...............
    1. Always pass string values as arguments.
    2. The return values will be of type string, so convert them before to avoid typecasting conflict.
    3. Horses can't vomit. 
 More Informations 
====================
 
    Yes, You can store this objects and stacks for persisting through the iterations of a script across successive bars.
    You just need to set the variable using "var" keyword. Remember this objects and stacks are just arrays, 
    so any methods and properties an array have it pinescript, would be applicable for objects and stacks.
    It can also be used in security functions without any issues for MTF Analysis.
    If you have any suggestions or feedback, please comment on the thread, I would surely be happy to help.
ConverterTFLibrary   "ConverterTF" 
I have found a bug Regarding the timeframe display, on the chart I have found that the display is numeric, for example 4Hr timeframe instead of '4H', but it turns out to be '240', which I want it to be displayed in abbreviated form. And in all other timeframes it's the same. So this library was created to solve those problems. It converts a timeframe from a numeric string type to an integer type by selecting a timeframe manually and displaying it on the chart.
 CTF()  
 str = "240"
X.GetTF( str ) 
 Example 
str = input.timeframe(title='Time frame', defval='240')
TimeF = CTF(str)
L=label.new(bar_index, high, 'Before>> Timeframe '+str+' After>> Timeframe '+TimeF,style=label.style_label_down,size=size.large)
label.delete(L )
Custom timeframes can handle this issue as well.
  
An example from the use. You will find it on the bottom right hand side.
  
  
 Hopefully it will be helpful to the Tradingview community. :) 
StringtoNumberThis library is used to convert Text type numbers are numbers.
Library   "StringtoNumber" 
str1 = '12340'  , vv = numstrToNum(str1)
 numstrToNum()  
 Example 
// This source code is subject to the terms of the Mozilla Public License 2.0 at mozilla.org
// © hapharmonic
//@version=5
indicator("My Script")
import hapharmonic/StringtoNumber/1 as CV
TF = '240'
GETTF = CV.numstrToNum(TF)
L = label.new(bar_index, high, '|| numstrToNum :>> || ' + str.tostring(GETTF), style=label.style_label_down,size=size.large)
label.delete(L )
DiscordWebhookFunctionLibrary   "DiscordWebhookFunction" 
 discordMarkdown(_str, _italic, _bold, _code, _strike, _under)  Convert string to markdown formatting User can combine any function at the same time.
  Parameters:
     _str : String input
     _italic : Italic
     _bold : Bold
     _code : Code markdown
     _strike : Strikethrough
     _under : Underline
  Returns: string Markdown formatted string.
 discordWebhookJSON(_username, _avatarImgUrl, _contentText, _bodyTitle, _descText, _bodyUrl, _embedCol, _timestamp, _authorName, _authorUrl, _authorIconUrl, _footerText, _footerIconUrl, _thumbImgUrl, _imageUrl)  Convert data to JSON format for Discord Webhook Integration.
  Parameters:
     _username : Override bot (webhook) username string / name,
     _avatarImgUrl : Override bot (webhook) avatar by image URL,
     _contentText : Main content page message,
     _bodyTitle : Custom Webhook's embed message body title,
     _descText : Webhook's embed message body description,
     _bodyUrl : Webhook's embed body direct link URL,
     _embedCol : Webhook's embed color,
     _timestamp : Timestamp,
     _authorName : Webhook's embed author name / title,
     _authorUrl : Webhook's embed author direct link URL,
     _authorIconUrl : Webhook's embed author icon by image URL,
     _footerText : Webhook's embed footer text / title,
     _footerIconUrl : Webhook's embed footer icon by image URL,
     _thumbImgUrl : Webhook's embed thumbnail image URL,
     _imageUrl : Webhook's embed body image URL. 
  Returns: string Single-line JSON format
DrawIndicatorOnTheChartLibrary   "DrawIndicatorOnTheChart" 
this library is used to show an indicator (such RSI, CCI, MOM etc) on the main chart with indicator's horizontal lines in a window. Location of the window is calculated dynamically by last price movemements
 drawIndicator(indicatorName, indicator, indicatorcolor, period, indimax_, indimin_, levels, precision, xlocation)  draws the related indicator on the chart
  Parameters:
     indicatorName : is the indicator name as string such "RSI", "CCI" etc
     indicator : is the indicator you want to show, such rsi(close, 14), mom(close, 10) etc
     indicatorcolor : is the color of indicator line
     period : is the length of the window to show
     indimax_ : is the maximum value of the indicator, for example for RSI it's 100.0, if the indicator (such CCI, MOM etc) doesn't have maximum value then use "na"
     indimin_ : is the minimum value of the indicator, for example for RSI it's 0.0, if the indicator (such CCI, MOM etc)doesn't have maximum value then use "na"
     levels : is the levels of the array for the horizontal lines. for example if you want horizontal lines at 30.0, and 70.0 then use array.from(30.0, 70.0). if no horizontal lines then use array.from(na)
     precision : is the precision/number of decimals that is used to show indicator values, for example for RSI set it 2
     xlocation : is end location of the indicator window, for example if xlocation = 0 window is created on the index of the last bar/candle
  Returns: none
ZenLibraryLibrary   "ZenLibrary" 
A collection of custom tools & utility functions commonly used with my scripts.
 getDecimals()  Calculates how many decimals are on the quote price of the current market
  Returns: The current decimal places on the market quote price
 truncate(float, float)  Truncates (cuts) excess decimal places
  Parameters:
     float : _number The number to truncate
     float : _decimalPlaces (default=2) The number of decimal places to truncate to
  Returns: The given _number truncated to the given _decimalPlaces
 toWhole(float)  Converts pips into whole numbers
  Parameters:
     float : _number The pip number to convert into a whole number
  Returns: The converted number
 toPips(float)  Converts whole numbers back into pips
  Parameters:
     float : _number The whole number to convert into pips
  Returns: The converted number
 av_getPositionSize(float, float, float, float)  Calculates OANDA forex position size for AutoView based on the given parameters
  Parameters:
     float : _balance The account balance to use
     float : _risk The risk percentage amount (as a whole number - eg. 1 = 1% risk)
     float : _stopPoints The stop loss distance in POINTS (not pips)
     float : _conversionRate The conversion rate of our account balance currency
  Returns: The calculated position size (in units - only compatible with OANDA)
 getMA(int, string)  Gets a Moving Average based on type
  Parameters:
     int : _length The MA period
     string : _maType The type of MA
  Returns: A moving average with the given parameters
 getEAP(float)  Performs EAP stop loss size calculation (eg. ATR >= 20.0 and ATR < 30, returns 20)
  Parameters:
     float : _atr The given ATR to base the EAP SL calculation on
  Returns: The EAP SL converted ATR size
 barsAboveMA(int, float)  Counts how many candles are above the MA
  Parameters:
     int : _lookback The lookback period to look back over
     float : _ma The moving average to check
  Returns: The bar count of how many recent bars are above the MA
 barsBelowMA(int, float)  Counts how many candles are below the MA
  Parameters:
     int : _lookback The lookback period to look back over
     float : _ma The moving average to reference
  Returns: The bar count of how many recent bars are below the EMA
 barsCrossedMA(int, float)  Counts how many times the EMA was crossed recently
  Parameters:
     int : _lookback The lookback period to look back over
     float : _ma The moving average to reference
  Returns: The bar count of how many times price recently crossed the EMA
 getPullbackBarCount(int, int)  Counts how many green & red bars have printed recently (ie. pullback count)
  Parameters:
     int : _lookback The lookback period to look back over
     int : _direction The color of the bar to count (1 = Green, -1 = Red)
  Returns: The bar count of how many candles have retraced over the given lookback & direction
 getBodySize()  Gets the current candle's body size (in POINTS, divide by 10 to get pips)
  Returns: The current candle's body size in POINTS
 getTopWickSize()  Gets the current candle's top wick size (in POINTS, divide by 10 to get pips)
  Returns: The current candle's top wick size in POINTS
 getBottomWickSize()  Gets the current candle's bottom wick size (in POINTS, divide by 10 to get pips)
  Returns: The current candle's bottom wick size in POINTS
 getBodyPercent()  Gets the current candle's body size as a percentage of its entire size including its wicks
  Returns: The current candle's body size percentage
 isHammer(float, bool)  Checks if the current bar is a hammer candle based on the given parameters
  Parameters:
     float : _fib (default=0.382) The fib to base candle body on
     bool : _colorMatch (default=false) Does the candle need to be green? (true/false)
  Returns: A boolean - true if the current bar matches the requirements of a hammer candle
 isStar(float, bool)  Checks if the current bar is a shooting star candle based on the given parameters
  Parameters:
     float : _fib (default=0.382) The fib to base candle body on
     bool : _colorMatch (default=false) Does the candle need to be red? (true/false)
  Returns: A boolean - true if the current bar matches the requirements of a shooting star candle
 isDoji(float, bool)  Checks if the current bar is a doji candle based on the given parameters
  Parameters:
     float : _wickSize (default=2) The maximum top wick size compared to the bottom (and vice versa)
     bool : _bodySize (default=0.05) The maximum body size as a percentage compared to the entire candle size
  Returns: A boolean - true if the current bar matches the requirements of a doji candle
 isBullishEC(float, float, bool)  Checks if the current bar is a bullish engulfing candle
  Parameters:
     float : _allowance (default=0) How many POINTS to allow the open to be off by (useful for markets with micro gaps)
     float : _rejectionWickSize (default=disabled) The maximum rejection wick size compared to the body as a percentage
     bool : _engulfWick (default=false) Does the engulfing candle require the wick to be engulfed as well?
  Returns: A boolean - true if the current bar matches the requirements of a bullish engulfing candle
 isBearishEC(float, float, bool)  Checks if the current bar is a bearish engulfing candle
  Parameters:
     float : _allowance (default=0) How many POINTS to allow the open to be off by (useful for markets with micro gaps)
     float : _rejectionWickSize (default=disabled) The maximum rejection wick size compared to the body as a percentage
     bool : _engulfWick (default=false) Does the engulfing candle require the wick to be engulfed as well?
  Returns: A boolean - true if the current bar matches the requirements of a bearish engulfing candle
 timeFilter(string, bool)  Determines if the current price bar falls inside the specified session
  Parameters:
     string : _sess The session to check
     bool : _useFilter (default=false) Whether or not to actually use this filter
  Returns: A boolean - true if the current bar falls within the given time session
 dateFilter(int, int)  Determines if this bar's time falls within date filter range
  Parameters:
     int : _startTime The UNIX date timestamp to begin searching from
     int : _endTime the UNIX date timestamp to stop searching from
  Returns: A boolean - true if the current bar falls within the given dates
 dayFilter(bool, bool, bool, bool, bool, bool, bool)  Checks if the current bar's day is in the list of given days to analyze
  Parameters:
     bool : _monday Should the script analyze this day? (true/false)
     bool : _tuesday Should the script analyze this day? (true/false)
     bool : _wednesday Should the script analyze this day? (true/false)
     bool : _thursday Should the script analyze this day? (true/false)
     bool : _friday Should the script analyze this day? (true/false)
     bool : _saturday Should the script analyze this day? (true/false)
     bool : _sunday Should the script analyze this day? (true/false)
  Returns: A boolean - true if the current bar's day is one of the given days
 atrFilter(float, float)  Checks the current bar's size against the given ATR and max size
  Parameters:
     float : _atr (default=ATR 14 period) The given ATR to check
     float : _maxSize The maximum ATR multiplier of the current candle
  Returns: A boolean - true if the current bar's size is less than or equal to _atr x _maxSize
 fillCell(table, int, int, string, string, color, color)  This updates the given table's cell with the given values
  Parameters:
     table : _table The table ID to update
     int : _column The column to update
     int : _row The row to update
     string : _title The title of this cell
     string : _value The value of this cell
     color : _bgcolor The background color of this cell
     color : _txtcolor The text color of this cell
  Returns: A boolean - true if the current bar falls within the given dates






















