Signal Generator: HTF EMA Momentum + MACDSignal Generator: HTF EMA Momentum + MACD
What this script does
This indicator combines a higher-timeframe EMA trend filter with a MACD crossover on the chart’s timeframe. The goal is to make MACD signals more selective by checking whether they occur in the same direction as the broader trend.
How it works
- On the higher timeframe, two EMAs are calculated (short and long). Their difference is used as a simple momentum measure.
- On the chart timeframe, the MACD is calculated. Crossovers are then filtered with two conditions:
   1.They must align with the higher-timeframe EMA trend.
   2.They must occur beyond a small “zero band” threshold, with a minimum distance between MACD and signal lines.
- When both conditions are met, the script can plot BUY or SELL labels. ATR is used only to shift labels up or down for visibility.
Visuals and alerts
- Histogram bars show whether higher-timeframe EMA momentum is rising or falling.
- MACD main and signal lines are plotted with optional scaling.
- Dotted lines show the zero band region.
- Optional large BUY/SELL labels appear when conditions are confirmed on the previous bar.
- Alerts can be enabled for these signals; they trigger once per bar close.
Notes and limitations
- Higher-timeframe values are only confirmed once the higher-timeframe candle has closed.
- Scaling factors affect appearance only, not the logic.
- This is an open-source study intended as a learning and charting tool. It does not provide financial advice or guarantee performance.
Generator
waves█  OVERVIEW 
This library intended for use in  Bar Replay  provides functions to generate various wave forms (sine, cosine, triangle, square) based on time and customizable parameters.  Useful for testing and in creating oscillators, indicators, or visual effects.
█  FUNCTIONS 
 •  getSineWave() 
 •  getCosineWave() 
 •  getTriangleWave() 
 •  getSquareWave() 
█  USAGE EXAMPLE 
 
//@version=6
indicator("Wave Example")
import kaigouthro/waves/1
plot(waves.getSineWave(cyclesPerMinute=15)) 
 
█  NOTES 
*    barsPerSecond  defaults to 10. Adjust this if not using 10x in Bar Replay.
*   Phase shift is in  degrees. 
---
Library   "waves" 
 getSineWave(cyclesPerMinute, bar, barsPerSecond, amplitude, verticalShift, phaseShift) 
  `getSineWave`
> Calculates a sine wave based on bar index, cycles per minute (BPM), and wave parameters.
  Parameters:
     cyclesPerMinute (float) : (float) The desired number of cycles per minute (BPM). Default is 30.0.
     bar (int) : (int) The current bar index. Default is bar_index.
     barsPerSecond (float) : (float) The number of bars per second. Default is 10.0 for Bar Replay
     amplitude (float) : (float) The amplitude of the sine wave. Default is 1.0.
     verticalShift (float) : (float) The vertical shift of the sine wave. Default is 0.0.
     phaseShift (float) : (float) The phase shift of the sine wave in radians. Default is 0.0.
  Returns: (float) The calculated sine wave value.
 getCosineWave(cyclesPerMinute, bar, barsPerSecond, amplitude, verticalShift, phaseShift) 
  `getCosineWave`
> Calculates a cosine wave based on bar index, cycles per minute (BPM), and wave parameters.
  Parameters:
     cyclesPerMinute (float) : (float) The desired number of cycles per minute (BPM). Default is 30.0.
     bar (int) : (int) The current bar index. Default is bar_index.
     barsPerSecond (float) : (float) The number of bars per second. Default is 10.0 for Bar Replay
     amplitude (float) : (float) The amplitude of the cosine wave. Default is 1.0.
     verticalShift (float) : (float) The vertical shift of the cosine wave. Default is 0.0.
     phaseShift (float) : (float) The phase shift of the cosine wave in radians. Default is 0.0.
  Returns: (float) The calculated cosine wave value.
 getTriangleWave(cyclesPerMinute, bar, barsPerSecond, amplitude, verticalShift, phaseShift) 
  `getTriangleWave`
> Calculates a triangle wave based on bar index, cycles per minute (BPM), and wave parameters.
  Parameters:
     cyclesPerMinute (float) : (float) The desired number of cycles per minute (BPM). Default is 30.0.
     bar (int) : (int) The current bar index. Default is bar_index.
     barsPerSecond (float) : (float) The number of bars per second. Default is 10.0 for Bar Replay
     amplitude (float) : (float) The amplitude of the triangle wave. Default is 1.0.
     verticalShift (float) : (float) The vertical shift of the triangle wave. Default is 0.0.
     phaseShift (float) : (float) The phase shift of the triangle wave in radians. Default is 0.0.
  Returns: (float) The calculated triangle wave value.
 getSquareWave(cyclesPerMinute, bar, barsPerSecond, amplitude, verticalShift, dutyCycle, phaseShift) 
  `getSquareWave`
> Calculates a square wave based on bar index, cycles per minute (BPM), and wave parameters.
  Parameters:
     cyclesPerMinute (float) : (float) The desired number of cycles per minute (BPM). Default is 30.0.
     bar (int) : (int) The current bar index. Default is bar_index.
     barsPerSecond (float) : (float) The number of bars per second. Default is 10.0 for Bar Replay
     amplitude (float) : (float) The amplitude of the square wave. Default is 1.0.
     verticalShift (float) : (float) The vertical shift of the square wave. Default is 0.0.
     dutyCycle (float) : (float) The duty cycle of the square wave (0.0 to 1.0). Default is 0.5 (50% duty cycle).
     phaseShift (float) : (float) The phase shift of the square wave in radians. Default is 0.0.
  Returns: (float) The calculated square wave value.
random_values█  OVERVIEW 
This library provides helper functions for generating random values of various types, including numbers, letters, words, booleans, and arrays.  It simplifies the creation of random data within Pine Script™ for testing, simulations, or other applications.
█  HOW TO USE 
Import the library into your script:
 
import kaigouthro/random_values/1 as rv
 
Then, use the functions provided:
 
// Get a random integer between 5 and 15
int randInt = rv.intVal(5, 15)
// Generate a random word with 8 characters
string randWord = rv.word(8)
// Create a boolean array with 5 elements
array randBoolArray = rv.boolArray(5)
// And other options! See below for details.
 
█  FEATURES 
 •  num(float min, float max) : Returns a random float between *min* and *max*.  (Internal helper function, not exported).
 •  letter() : Returns a random lowercase letter (a-z).
 •  word(int size = 0) : Returns a random word. *size* specifies the length (default: random length between 3 and 10).
 •  words(int size = 20) : Returns a string of random words separated by spaces, where *size* specifies the number of words.
 •  boolVal() : Returns a random boolean (true or false).
 •  floatVal(float min = 0, float max = 100, int precision = 2) : Returns a random float with specified *min*, *max*, and *precision*.
 •  intVal(int min = 1, int max = 100) : Returns a random integer between *min* and *max*.
 •  stringArray(int size = 0) : Returns an array of random words. *size* specifies the array length (default: random between 3 and 10).
 •  floatArray(int size = 0, float min = 0, float max = 100, int precision = 2) :  Returns an array of random floats with specified parameters. *size* determines the array length.
 •  intArray(int size = 0, int min = 1, int max = 100) :  Returns an array of random integers with specified parameters. *size* determines the array length.
 •  boolArray(int size = 0) : Returns an array of random booleans. *size* specifies the array length (default: random between 3 and 10).
█  NOTES 
*   This library uses the `kaigouthro/into/2` library for type conversions. Make sure it's available.
*   Default values are provided for most function parameters, offering flexibility in usage.
█  LICENSE 
This Pine Script™ code is subject to the terms of the Mozilla Public License 2.0 at  mozilla.org 
```
**Changes and Rationale:**
*   **OVERVIEW:**  Clearly states the library's purpose.
*   **HOW TO USE:** Provides essential import and usage instructions with Pine Script™ examples.
*   **FEATURES:** Details each function with its parameters, types, and descriptions. Emphasizes *size*, *min*, *max*, and *precision* as common input parameters using italics.  Uses custom bulleted lists.
*   **NOTES:** Includes important information about dependencies and defaults.
*   **LICENSE:**  Directly links to the license URL using the proper ` ` tag.
*   **Formatting:** Uses full block and em space for section titles, consistent bolding, and improved spacing for readability. Removes unnecessary blank lines.  
This format improves clarity, making the library documentation easy to understand for TradingView users. Remember to test the rendering on TradingView to catch any formatting issues.
Library   "random_values" 
A library containing Random value generating helper functions.
 letter() 
  Random letter generator.
  Returns: (string) A random lowercase letter.
 word(size) 
  Random word generator.
  Parameters:
     size (int) : (int) The desired length of the word. If 0 or not provided, a random length between 3 and 10 is used.
  Returns: (string) A random word.
 words(size) 
  Random words generator.
  Parameters:
     size (int) : (int) The number of words to generate. If 0 or not provided, a random number between 3 and 10 is used.
  Returns: (string) A string of random words separated by spaces.
 boolVal() 
  Random boolean generator.
  Returns: (bool) A random boolean value (true or false).
 floatVal(min, max, precision) 
  Random float number generator.
  Parameters:
     min (float) : (float) The minimum float value. Defaults to 0.
     max (float) : (float) The maximum float value. Defaults to 100.
     precision (int) : (int)   The number of decimal places. Defaults to 2.
  Returns: (float) A random float number.
 intVal(min, max) 
  Random integer number generator.
  Parameters:
     min (int) : (int) The minimum integer value. Defaults to 1.
     max (int) : (int) The maximum integer value. Defaults to 100.
  Returns: (int) A random integer number.
 stringArray(size) 
  Random string array generator.
  Parameters:
     size (int) : (int) The desired size of the array. If 0 or not provided, a random size between 3 and 10 is used.
  Returns: (array) An array of random words.
 floatArray(size, min, max, precision) 
  Random float array generator.
  Parameters:
     size (int) : (int)   The desired size of the array. If 0 or not provided, a random size between 3 and 10 is used.
     min (float) : (float) The minimum float value. Defaults to 0.
     max (float) : (float) The maximum float value. Defaults to 100.
     precision (int) : (int)   The number of decimal places. Defaults to 2.
  Returns: (array) An array of random float numbers.
 intArray(size, min, max) 
  Random integer array generator.
  Parameters:
     size (int) : (int) The desired size of the array. If 0 or not provided, a random size between 3 and 10 is used.
     min (int) : (int) The minimum integer value. Defaults to 1.
     max (int) : (int) The maximum integer value. Defaults to 100.
  Returns: (array) An array of random integer numbers.
 boolArray(size) 
  Random boolean array generator.
  Parameters:
     size (int) : (int) The desired size of the array. If 0 or not provided, a random size between 3 and 10 is used.
  Returns: (array) An array of random boolean values.
lib_colorLibrary   "lib_color" 
 offset_mono(original, offset, transparency) 
  get offset color
  Parameters:
     original (simple color) : original color
     offset (float) : offset for new color
     transparency (float) : transparency for new color
  Returns: offset color
lib_colorsLibrary   "lib_colors" 
 offset_mono(original, offset, transparency) 
  get offset color
  Parameters:
     original (simple color) : original color
     offset (float) : offset for new color
     transparency (float) : transparency for new color
  Returns: offset color
curveLibrary   "curve" 
Regression array Creator. Handy for weights, Auto Normalizes array while holding curves.
 curve(_size, _power) 
  Curve Regression Values Tool
  Parameters:
     _size : (float) Number of Steps required (float works, future consideration)
     _power : (float) Strength of value decrease
  Returns: (float ) Array of multipliers from 1 downwards to 0.
Synthetic Price Action GeneratorNOTICE:
First thing you need to know, it "DOES NOT" reflect the price of the ticker you will load it on. THIS IS NOT AN INDICATOR FOR TRADING! It's a developer tool solely generating random values that look exactly like the fractals we observe every single day. This script's generated candles are as fake as the never ending garbage news cycles we are often force fed and expected to believe by using carefully scripted narratives peddled as hypnotic truth to psychologically and emotionally influence you to the point of control by coercion and subjugation. I wanted to make the script's synthetic nature very clear using that analogy, it's dynamically artificial. Do not accidentally become disillusioned by this scripts values, make trading decisions from it, and lastly don't become victim to predatory media magic ministry parrots with pretty, handsome smiles, compelling you to board their ferris wheel of fear. Now, on to the good stuff...
BACKSTORY:
Occasionally I find myself in situations where I have to build analyzers in Pine to actually build novel quantitative analytic indicators and tools worthy of future use. These analyzers certainly don't exist on this platform, but usually are required to engineer and tweak algorithms of the highest quality with the finest computational caliber. I have numerous other synthesizers to publish besides this one.
For many reasons, I needed a synthetic environment to utilize the analyzers I built in Pine, to even pursue building some exotic indicators and algorithms. Pine doesn't allow sourcing of tuples. Not to mention, I required numerous Pine advancements to make long held dreams into tangible realities. Many Pine upgrades have arrived and MANY, MANY more are in need of implementation for all. Now that I have this, intending to use it in the future often when in need, you can now use it too. I do anticipate some skilled Pine poets will employ this intended handy utility to design and/or improved indicators for trading.
 
ORIGIN:
This was inspired by the brilliance from the world renowned ALGOmist John F. Ehlers, but it's taken on a completely alien form from its original DNA. Browsing on the internet for something else, I came across an article with a small code snippet, and I remembered an old wish of mine. I have long known that by flipping back and forth on specific tickers and timeframes in my Watchlist is not the most efficient way to evaluate indicators in multiple theatres of price action. I realized, I always wanted to possess and use this sort of tool, so... I put it into Pine form, but now have decided to inject it with Pine Script steroids. The outcome is highly mutable candle formations in a reusable mutagenic package, observable above and masquerading as genuine looking price candles.
 
OVERVIEW:
I guess you could call it a price action synthesizer, but I entitled it "Synthetic Price Action Generator" for those who may be searching for such a thing. You may find this more useful on the All or 5Y charts initially to witness indication from beginning (barstate.isfirst === barindex==0) to end (last_bar_index), but you may also use keyboard shortcuts   +   +   to view the earliest plottable bars on any timeframe. I often use that keyboard shortcut to qualify an indicator through the entirety of it's runtime.
A lot can go wrong unexpectedly with indicator initialization, and you will never know it if you don't inspect it. Many recursively endowed Infinite Impulse Response (IIR) Filters can initialize with unintended results that minutely ring in slightly erroneous fashion for the entire runtime, beginning to end, causing deviations from "what should of been..." values with false signals. Looking closely at spg(), you will recognize that 3 EMAs are employed to manage and maintain randomness of CLOSE, HIGH, and LOW. In fact, any indicator's barindex==0 initialization can be inspected with the keyboard shortcuts above. If you see anything obviously strange in an authors indicator, please contact the developer if possible and respectfully notify them.
 
PURPOSE:
The primary intended application of this script, is to offer developers from advanced to even novice skill levels assistance with building next generation indicators. Mostly, it's purpose is for testing and troubleshooting indicators AND evaluating how they perform in a "manageable" randomized environment. Some times indicators flake out on rare but problematic price fluctuations, and this may help you with finding your issues/errata sooner than later. While the candles upon initial loading look pristine, by tweaking it to the minval/maxval parameters limits OR beyond with a few code modifications, you can generate unusual volatility, for instance... huge wicks. Limits of minval= and maxval= of are by default set to a comfort zone of operation. Massive wicks or candle bodies will undoubtedly affect your indication and often render them useless on tickers that exhibit that behavior, like WGMCF intraday currently.
Copy/paste boundaries are provided for relevant insertion into another script. Paste placement should happen at the very top of a script. Note that by overwriting the close, open, high, etc... values, your compiler will give you generous warnings of "variable shadowing" in abundance, but this is an expected part of applying it to your novel script, no worries. plotcandle() can be copied over too and enabled/disabled in Settings->Style. Always remember to fully remove this scripts' code and those assignments properly before actual trading use of your script occurs, AND specifically when publishing. The entirety of this provided code should never, never exist in a published indicator.
 
OTHER INTENTIONS:
Even though these are 100% synthetic generated price points, you will notice ALL of the fractal pseudo-patterns that commonly exist in the markets, are naturally occurring with this generator too. You can also swiftly immerse yourself in pattern recognition exercises with increased efficiency in real time by clicking any SPAG Setting in focus and then using the up/down arrow keys. I hope I explained potential uses adequately...
On a personal note, the existence of fractal symmetry often makes me wonder, do we truly live in a totality chaotic universe or is it ordered mathematically for some outcomes to a certain extent. I think both. My observations, it's a pre-deterministic reality completely influenced by infinitesimal amounts of sentient free will with unimaginable existing and emerging quantities. Some how an unknown mysterious mechanism governing the totality of universal physics and mathematics counts this 100.0% flawlessly and perpetually. Anyways, you can't change the past that long existed before your birth or even yesterday, but you can choose to dream, create, and forge the future into your desires and hopes. As always, shite always happens when your not looking for it. What you choose to do after stepping in it unintentionally... is totally up to you. :) Maybe this tool and tips provided will aid you in not stepping in an algo cachucha up to your ankles somehow.
SCRIPTING LESSONS PORTRAYED IN THIS SCRIPT:
Pine etiquette and code cleanliness
Overwrite capabilities of built-in Pine variables for testing indicators
Various techniques to organize Settings panel while providing ease of adjustment utility
Use of tooltip= to provide users adequate valuable information. Most people want to trade with indicators, not blindly make adjustments to them without any knowledge of their intended operation/effects
When available time provides itself, I will consider your inquiries, thoughts, and concepts presented below in the comments section, should you have any questions or comments regarding this indicator. When my indicators achieve more prevalent use by TV members , I may implement more ideas when they present themselves as worthy additions. Have a profitable future everyone!
Random Synthetic Asset GenerationThis script generates  pseudo-random asset data . Due to the nature of the random generator, it is  impossible to use this indicator as input for other indicators  because the instance of the script that the indicator is applied to will automatically be different from the instance that is plotted on the chart. Therefore, the idea is to use this script in other scripts (to make it possible to backtest on random data, for example).
The script has four main input parameters.
 
 Random Number Generator Method:  It supports two methods for generating the pseudo-random numbers (one by Ricardo Santos and one by Wichmann-Hill).
 Seed:  You can specify the seed to use. Each unique seed will generate a unique set of pseudo-random data.
 Intrabar Volatility:  This basically sets how volatile the generated wicks will be (0 = no wicks).
 Price Multiplier:  This is just a multiplier for the generated price data, so that you can scale up or down the generated price data.
 
You can also change the colors of the bars.
In addition to this, the indicator also generates random volume. In order to make it possible to show both volume and price, you need to have two identical instances of the indicator. One on the chart, and one in its own panel. Then, go into the Style tab in the indicator settings on the instance in the panel. Untick Up-Candles and  Down-Candles  boxes, and tick the  Volume  box.
In a similar manner, you can also plot the  true range  data and the candle  change  data as well, by ticking one of those boxes instead.
Candle Color GeneratorCandle Color Generator: 
This indicator is designed to highlight the candle colors based on the combinations of Parabolic SAR (PSAR) and 2 Hull Moving Averages (HMA).
 Colors: 
Yellow, Red, and Green colors are used to describe the candle colors depends on its position to PSAR and 2 HMAs.
 PSAR: 
PSAR position above or below candle position is differentiated by Red and Green colors
 HMAs: 
As default settings 20 HMA is considered as lower period and 50 HMA is considered period for the calculation
 Trade What You See: 
This indicator will help to see how the setup of particular instrument coming up. Users/Traders can use and trade based on what they see and interpret from it.
 Disclaimer: 
Idea of publishing this script is to identify the strength of the instrument using multiple confirmation. 
Using this indicator, changing inputs (show/hide/change period), and trading decisions are up to the users/traders.
 Courtesy: 
Thanks to inventors of HMA (Alan Hull), PSAR(Welles Wilder) as these inputs are used to make some calculations
Pseudo-Random Number Generators via Pine ScriptThese are my "Pseudo-Random Number Generators via Pine Script", having uniform distribution between 0 and 1. In my quest for sequential pseudo-random numbers in Pine, tinkering with mathematical chaos, I have come up with these three simple yet handy generators. I believe these may be useful in the future by developers of the Tradingview community.
 NOTICE:  Use it as you please, this is free code to implement into your new Pine projects. You don't have to ask for my permission to reuse these functions in your published scripts, simply because I have better things to do than answer requests for the reuse of these simplistic PRNG functions. I don't require accreditation for members to reuse these functions either. I simply don't want any credit. I only require that you respectfully put it to "good and proper use" complimenting the elaborate script you have in mind. I would however like to see some great ideas utilizing these when I randomly and accidentally come across them in the public library. I didn't know where to put this script, so I just tossed it into the "Trend Analysis" category.
The comments section below is solely just for commenting and other remarks, ideas, compliments, etc... regarding only this indicator, not others. When available time provides itself, I will consider your inquiries, thoughts, and concepts presented below in the comments section, should you have any questions or comments regarding this indicator. When my indicators achieve more prevalent use by TV members, I may implement more ideas when they present themselves as worthy additions. As always, "Like" it if you simply just like it with a proper thumbs up, and also return to my scripts list occasionally for additional postings. Have a profitable future everyone!
Smart Labelling - Range FilterThis is a  labelling module  based on a  range filter . Notice that the trick here is to use  fibonachi numbers . Use smaller range multiplier for higher TFs. This module may serve as a signal generator to be passed through a signal filter.
Quote from the original author: 
This is an experimental study designed to filter out minor price action for a clearer view of trends. Inspired by the QQE's volatility filter, this filter applies the process directly to price rather than to a smoothed RSI. First, a smooth average price range is calculated for the basis of the filter and multiplied by a specified amount. Next, the filter is calculated by gating price movements that do not exceed the specified range. Lastly the target ranges are plotted to display the prices that will trigger filter movement.
Godmode Oscillator 3.2This is nothing other than an update and slight modification to the original Godmode Oscillator published by  xSilas 
The update done by sco77m4r7in and myself.
 Change Log: 
Repaired the multi exchange option for BTC
Added additional 'Caution!' dots with color coding.
 
 white = Early Caution signal
 yellow = standard 'Caution!' signal
 red = Extreme Caution signal
 
Be sure to give everyone a big thanks!
Original Godmode Script and Tutorial by  xSilas : 
Godmode Oscillator, fresh bread generator, free to use!Greetings Mates,
!!! If you want to use this tool for free you have to to following steps:
1) say thanks to LEGION who coded the first version.
2) say thanks to LAZYBEAR cause we ripped some code snippets from him.
3) say thanks to Ni6HTH4wK who coded the latest version. 
4) say thanks to xSilas who gave the idea.
5) I know i said its a FREE Tool and you dont need to donate me cause i have Godmode :), but lets have a litte thought on all the people that are a bit poorer than us. It would be really great if we get some DOLLARS for a great charity action for children.
6) Feel free to spend some Bitcoins to this Address: 1BNjs1Prsux8YQawVWYfiYoxzoKzfReckX
(i start and going to spend 1 BTC) (! the spended amount is revealed at the end!)
7) If you know said thankyou to everybody and may spend some dollars we can go on with Godmode trading.
8) Enjoy the Tool, merry Xmas and cheers for another great volatile bitcoin year :).
GODMODE OSCILLATOR, FRESH BREAD GENERATOR, FREE TO USE!Greetings Mates,
!!! If you want to use this tool for free you have to to following steps:
1) say thanks to LEGION who coded the first version.
2) say thanks to LAZYBEAR cause we ripped some code snippets from him.
3) say thanks to Ni6HTH4wK who coded the latest version. 
4) say thanks to xSilas who gave the idea.
5) I know i said its a FREE Tool and you dont need to donate me cause i have Godmode :), but lets have a litte thought on all the people that are a bit poorer than us. It would be really great if we get some DOLLARS for a great charity action for children.
6) Feel free to spend some Bitcoins to this Address: 1BNjs1Prsux8YQawVWYfiYoxzoKzfReckX
(i start and going to spend 1 BTC) (! the spended amount is revealed at the end!)
7) If you know said thankyou to everybody and may spend some dollars we can go on with Godmode trading.
8) Enjoy the Tool, merry Xmas and cheers for another great volatile bitcoin year :).
---------------------------------------------------------
Godmode How To:
1) Spikey Pattern ^
Godmode spikes with 0-5 caution dots, great OTE Signal.
2) Snake Pattern ~
extreme pressure building, more movement 
in same direction following.
3) Rounding Pattern U
more than 5 caution dots, rounding
pressure building "normally" more to come













