Library "A_Traders_Edge__Library" - A Trader's Edge (ATE)_Library was created to assist in constructing Market Overview Scanners (MOS)
LabelLocation(_firstLocation) This function is used when there's a desire to print an assets ALERT LABELS at a set location on the scale that will NOT change throughout the progression of the script. This is created so that if a lot of alerts are triggered, they will stay relatively visible and not overlap each other. Ex. If you set your '_firstLocation' parameter as 1, since there are a max of 40 assets that can be scanned, the 1st asset's location is assigned the value in the '_firstLocation' parameter, the 2nd asset's location is the (1st asset's location+1)...and so on. If your first location is set to 81 then the 1st asset is 81 and 2nd is 82 and so on until the 40th location = 120(in this particular example). Parameters: _firstLocation (simple int): (simple int) Optional(starts at 1 if no parameter added). Location that you want the first asset to print its label if is triggered to do so. ie. loc2=loc1+1, loc3=loc2+1, etc.
Returns: Returns 40 output variables each being a different location to print the labels so that an asset is asssigned to a particular location on the scale. Regardless of if you have the maximum amount of assets being screened (40 max), this function will output 40 locations… So there needs to be 40 variables assigned in the tuple in this function. What I mean by that is you need to have 40 output location variables within your tuple (ie. between the '[]') regarless of if your scanning 40 assets or not. If you only have 20 assets in your scripts input settings, then only the first 20 variables within the '[]' Will be assigned to a value location and the other 20 will be assigned 'NA', but their variables still need to be present in the tuple.
SeparateTickerids(_string) You must form this single tickerID input string exactly as described in the scripts info panel (little gray 'i' that is circled at the end of the settings in the settings/input panel that you can hover your cursor over this 'i' to read the details of that particular input). IF the string is formed correctly then it will break up this single string parameter into a total of 40 separate strings which will be all of the tickerIDs that the script is using in your MO scanner. Parameters: _string (simple string): (string) A maximum of 40 Tickers (ALL joined as 1 string for the input parameter) that is formulated EXACTLY as described within the tooltips of the TickerID inputs in my MOS Scanner scripts: assets = input.text_area(tIDset1, title="TickerID (MUST READ TOOLTIP)", tooltip="Accepts 40 TICKERID's for each copy of the script on the chart. TEXT FORMATTING RULES FOR TICKERID'S: (1) To exclude the EXCHANGE NAME in the Labels, de-select the next input option. (2) MUST have a space (' ') AFTER each TickerID. (3) Capitalization in the Labels will match cap of these TickerID's. (4) If your asset has a BaseCurrency & QuoteCurrency (ie. ADAUSDT [ADA=base USDT=quote]) BUT you ONLY want Labels to show BaseCurrency(ie.'ADA'), include a FORWARD SLASH ('/') between the Base & Quote (ie.'ADA/USDT')", display=display.none)
Returns: Returns 40 output variables of the different strings of TickerID's (ie. you need to output 40 variables within the tuple '[]' regardless of if you were scanning using all possible (40) assets or not. If your scanning for less than 40 assets, then once the variables are assigned to all of the tickerIDs, the rest of the 40 variables in the tuple will be assigned "NA".
TickeridForLabelsAndSecurity(_includeExchange, _ticker) This function accepts the TickerID Name as its parameter and produces a single string that will be used in all of your labels. Parameters: _includeExchange (simple bool): (bool) Optional(if parameter not included in function it defaults to false [ie. Exchange Name will not be included in Labels]). Used to determine if the Exchange name will be included in all labels/triggers/alerts.
_ticker (simple string): (string) For this parameter, input the varible named '_coin' from your 'f_main()' function for this parameter. It is the raw Ticker ID name that will be processed.
Returns: ([string, string]) Returns 2 output variables: 1st ('_securityTickerid') is to be used in the 'request.security()' function as this string will contain everything TV needs to pull the correct assets data. 2nd ('lblTicker') is to be used in all of the labels in your MOS as it will only contain what you want your labels to show as determined by how the tickerID is formulated in the MOS's input.
InvalidTID(_tablePosition, _stackVertical, _close, _securityTickerid, _invalidArray) This is to add a table in the middle right of your chart that prints all the TickerID's that were either not formulated correctly in the '_source' input or that is not a valid symbol and should be changed. Parameters: _tablePosition (simple string): (string) Optional(if parameter not included, it defaults to position.middle_right). Location on the chart you want the table printed. Possible strings include: position.top_center, position.top_left, position.top_right, position.middle_center, position.middle_left, position.middle_right, position.bottom_center, position.bottom_left, position.bottom_right.
_stackVertical (simple bool): (bool) Optional(if parameter not included, it defaults to true). All of the assets that are counted as INVALID will be created in a list. If you want this list to be prited as a column then input 'true' here.
_close (float): (float) If you want them printed as a single row then input 'false' here. This should be the closing value of each of the assets being tested to determine in the TickerID is valid or not.
_securityTickerid (string): (string) Throughout the entire charts updates, if a '_close' value is never regestered then the logic counts the asset as INVALID. This will be the 1st TickerID varible (named _securityTickerid) outputted from the tuple of the TickeridForLabels() function above this one.
_invalidArray (string[]): (array string) Input the array from the original script that houses all of the invalidArray strings.
Returns: (na) Returns a table with the screened assets Invalid TickerID's. Table draws automatically if any are Invalid, thus, no output variable to deal with.
LabelSizes(_barCnt, _lblSzRfrnce) This function sizes your Alert Trigger Labels according to the amount of Printed Bars the chart has printed within a set time period, while also keeping in mind the smallest relative reference size you input in the 'lblSzRfrnceInput' parameter of this function. A HIGHER % of Printed Bars(aka...more trades occurring for that asset on the exchange), the LARGER the Name Label will print, potentially showing you the better opportunities on the exchange to avoid exchange manipulation liquidations.
*** SHOULD NOT be used as size of labels that are your asset Name Labels next to each asset's Line Plot... if your MOS includes these as you want these to be the same size for every asset so the larger ones dont cover the smaller ones if the plots are all close to each other *** Parameters: _barCnt (float): (float) Get the 1st variable('barCnt') from the 'PrintedBarCount' function's tuple and input it as this functions 1st input parameter which will directly affect the size of the 2nd output variable ('alertTrigLabel') outputted by this function.
_lblSzRfrnce (string): (string) Optional(if parameter not included, it defaults to size.small). This will be the size of the 1st variable outputted by this function ('assetNameLabel') BUT also affects the 2nd variable outputted by this function.
Returns: ([string,string]) Returns 2 variables: 1st output variable ('AssetNameLabel') is assigned to the size of the 'lblSzRfrnceInput' parameter. 2nd output variable('alertTrigLabel') can be of variying sizes depending on the 'barCnt' parameter...BUT the smallest size possible for the 2nd output variable ('alertTrigLabel') will be the size set in the 'lblSzRfrnceInput' parameter.
AssetColor() This function is used to assign 40 different colors to 40 variables to be used for the different labels/plots. Returns: Returns 40 output variables each with a different color assigned to them to be used in your plots & labels. Regardless of if you have the maximum amount of assets your scanning(40 max) or less, this function will assign 40 colors to 40 variables that you have between the '[]'.
PrintedBarCount(_time, _barCntLength, _barCntPercentMin) The Printed BarCount Filter looks back a User Defined amount of minutes and calculates the % of bars that have printed out of the TOTAL amount of bars that COULD HAVE been printed within the same amount of time. Parameters: _time (int): (int) The time associated with the chart of the particular asset that is being screened at that point.
_barCntLength (int): (int) The amount of time (IN MINUTES) that you want the logic to look back at to calculate the % of bars that have actually printed in the span of time you input into this parameter.
_barCntPercentMin (int): (int) The minimum % of Printed Bars of the asset being screened has to be GREATER than the value set in this parameter for the output variable 'bc_gtg' to be true.
Returns: ([float, bool]) Returns 2 outputs: 1st is the % of Printed Bars that have printed within the within the span of time you input in the '_barCntLength' parameter. 2nd is true/false according to if the Printed BarCount % is above the threshold that you input into the '_barCntPercentMin' parameter.
RCI(_rciLength, _source, _interval) You will see me using this a lot. DEFINITELY my favorite oscillator to utilize for SO many different things from timing entries/exits to determining trends.Calculation of this indicator based on Spearmans Correlation. Parameters: _rciLength (int): (int) Amount of bars back to use in RCI calculations.
_source (float): (float) Source to use in RCI calculations (can use ANY source series. Ie, open,close,high,low,etc).
_interval (int): (int) Optional(if parameter not included, it defaults to 3). RCI calculation groups bars by this amount and then will. rank these groups of bars.
Returns: (float) Returns a single RCI value that will oscillates between -100 and +100.
RCIAVG(firstLength, _amtBtLengths, _rciSMAlen, _source, _interval) 20 RCI's are averaged together to get this RCI Avg (Rank Correlation Index Average). Each RCI (of the 20 total RCI) has a progressively LARGER Lookback Length. Though the RCI Lengths are not individually adjustable, there are 2 factors that ARE: (1) the Lookback Length of the 1st RCI and (2) the amount of values between one RCI's Lookback Length and the next. *** If you set 'firstLength' to it's default of 200 and '_amtBtLengths' to it's default of 120 (aka AMOUNT BETWEEN LENGTHS=120)... then RCI_2 Length=320, RCI_3 Length=440, RCI_4 Length=560, and so on. Parameters: firstLength (int): (int) Optional(if parameter is not included when the function is called, then it defaults to 200). This parameter is the Lookback Length for the 1st RCI used in the RCI Avg.
_amtBtLengths (int): (int) Optional(if parameter not included when the function is called, then it defaults to 120). This parameter is the value amount between each of the progressively larger lengths used for the 20 RCI's that are averaged in the RCI Avg. ***** BEWARE ***** Too large of a value here will cause the calc to look back too far, causing an error(thus the value must be lowered)
_rciSMAlen (int): (int) Unlike the Single RCI Function, this function smooths out the end result using an SMA with a length value that is this parameter.
_source (float): (float) Source to use in RCI calculations (can use ANY source series. Ie, open,close,high,low,etc).
_interval (int): (int) Optional(if parameter not included, it defaults to 3). Within the RCI calculation, bars next to each other are grouped together and then these groups are Ranked against each other. This parameter is the number of adjacent bars that are grouped together.
Returns: (float) Returns a single RCI value that is the Avg of many RCI values that will oscillate between -100 and +100.
PercentChange(_startingValue, _endingValue) This is a quick function to calculate how much % change has occurred between the '_startingValue' and the '_endingValue' that you input into the function. Parameters: _startingValue (float): (float) The source value to START the % change calculation from.
_endingValue (float): (float) The source value to END the % change caluclation from.
Returns: Returns a single output being the % value between 0-100 (with trailing numbers behind a decimal). If you want only a certain amount of numbers behind the decimal, this function needs to be put within a formatting function to do so.
Rescale(_source, _oldMin, _oldMax, _newMin, _newMax) Rescales series with a known '_oldMin' & '_oldMax'. Use this when the scale of the '_source' to rescale is known (bounded). [ie. RSI = 0-100] Parameters: _source (float): (float) Source to be normalized.
_oldMin (int): (float) The known minimum of the '_source'.
_oldMax (int): (float) The known maximum of the '_source'.
_newMin (int): (float) What you want the NEW minimum of the '_source' to be.
_newMax (int): (float) What you want the NEW maximum of the '_source' to be.
Returns: Outputs your previously bounded '_source', but now the value will only move between the '_newMin' and '_newMax' values you set in the variables.
Normalize_Historical(_source, _minimumLvl, _maximumLvl) Normalizes '_source' that has a previously unknown min/max(unbounded) determining the max & min of the '_source' FROM THE ENTIRE CHARTS HISTORY. [ie. MACD = no limits to boundaries]] Parameters: _source (float): (float) Source to be normalized.
_minimumLvl (int): (float) The Lower Boundary Level.
_maximumLvl (int): (float) The Upper Boundary Level.
Returns: Returns your same '_source', but now the value will MOSTLY stay between the minimum and maximum values you set in the '_minimumLvl' and '_maximumLvl' variables (ie. if the source you input is an RSI...the output is the same RSI value but instead of moving between 0-100 it will move between the maxand min you set).
Normailize_Local(_source, _length, _minimumLvl, _maximumLvl) Normalizes series with previously unknown min/max(unbounded). Much like the Normalize_Historical function above this one, but rather than using the Highest/Lowest Values within the ENTIRE charts history, this on looks for the Highest/Lowest values of '_source' within the last ___ bars (set by user as/in the '_length' parameter. [ie. MACD = no limits to boundaries]] Parameters: _source (float): (float) Source to be normalized.
_length (int): (float) The amount of bars to look back to determine the highest/lowest '_source' value.
_minimumLvl (int): (float) The Lower Boundary Level.
_maximumLvl (int): (float) The Upper Boundary Level.
Returns: Returns a single output variable being the previously unbounded '_source' that is now normalized and bound between the values used for '_minimumLvl'/'_maximumLvl' of the '_source' within the user defined lookback period.
Dalam semangat sebenar TradingView, penulis telah menerbitkan kod Pine ini sebagai satu perpustakaan sumber terbuka supaya pengaturcara Pine lain dari komuniti kami boleh menggunakannya semula. Sorakan kepada penulis! Anda boleh menggunakan perpustakaan ini secara peribadi atau dalam penerbitan sumber terbuka lain, tetapi penggunaan semula kod dalam penerbitan ini adalah dikawal oleh Peraturan dalaman.
Maklumat dan penerbitan adalah tidak dimaksudkan untuk menjadi, dan tidak membentuk, nasihat untuk kewangan, pelaburan, perdagangan dan jenis-jenis lain atau cadangan yang dibekalkan atau disahkan oleh TradingView. Baca dengan lebih lanjut di Terma Penggunaan.