Jump to content

Welcome to the new Traders Laboratory! Please bear with us as we finish the migration over the next few days. If you find any issues, want to leave feedback, get in touch with us, or offer suggestions please post to the Support forum here.

  • Welcome Guests

    Welcome. You are currently viewing the forum as a guest which does not give you access to all the great features at Traders Laboratory such as interacting with members, access to all forums, downloading attachments, and eligibility to win free giveaways. Registration is fast, simple and absolutely free. Create a FREE Traders Laboratory account here.

ajhunter

I Don't Understand the Code for the Hull Moving Average

Recommended Posts

I would like to generate an indicator telling me when at what closing price would be required to change the direction of a Hull moving average. I am currently do not understand the Hull moving average function and am therefore unable to do the math/coding.

 

Value1 = 2 * WAverage(price, halvedLength);

Value2 = WAverage(price, length);

Value3 = WAverage((Value1 - Value2), sqrRootLength);

 

jtHMA = Value3;

 

I understand and can calculate value1 and value2 but I have no idea what a weighted average of the difference between the two actually is. I read value3 as being a weighted average of an integer over the squareroot of a period. But a weighted average of an integer makes no sense :confused:.

 

Some elucidation would be greatly appreciated.

Share this post


Link to post
Share on other sites

Indicator:

 

Inputs: Length(20), Offset(0); 


vars: avg1(0), color1(black); 


avg1 = jthma(Close, Length); 

Plot1 (avg1, "JT Hull"); 

color1 = green; 
if avg1 < avg1[1] then color1 = red; 

SetPlotColor[Offset](1, color1); 

 

 

 

 

Function

 

{jtHMA - Hull Moving Average Function}  
{Author: Atavachron}  
{May 2005}		  

Inputs: price(NumericSeries), length(NumericSimple);  
Vars: halvedLength(0), sqLength(0), sqrRootLength(0);  

{  
Original equation is:  
---------------------  
waverage(2*waverage(close,period/2)-waverage(close ,period), SquareRoot(Period)  
Implementation below is more efficient with lengthy Weighted Moving Averages.  
In addition, the length needs to be converted to an integer value after it is halved and  
its square root is obtained in order for this to work with Weighted Moving Averaging  
}  

if ((ceiling(length / 2) - (length / 2))  <= 0.5) then  
halvedLength = ceiling(length / 2)  
else  
halvedLength = floor(length / 2);  

sqLength = SquareRoot(length); 

if ((ceiling(sqLength) - sqLength)  <= 0.5) then  
sqrRootLength = ceiling(sqLength)  
else  
sqrRootLength = floor(sqLength);  

Value1 = 2 * WAverage(price, halvedLength);  
Value2 = WAverage(price, length);  
Value3 = WAverage((Value1 - Value2), sqrRootLength);  

jtHMA = Value3;  

Share this post


Link to post
Share on other sites
  ajhunter said:
I would like to generate an indicator telling me when at what closing price would be required to change the direction of a Hull moving average. I am currently do not understand the Hull moving average function and am therefore unable to do the math/coding.

 

Value1 = 2 * WAverage(price, halvedLength);

Value2 = WAverage(price, length);

Value3 = WAverage((Value1 - Value2), sqrRootLength);

 

jtHMA = Value3;

 

I understand and can calculate value1 and value2 but I have no idea what a weighted average of the difference between the two actually is. I read value3 as being a weighted average of an integer over the squareroot of a period.

1. value3 is not necessary an integer.

 

  ajhunter said:

But a weighted average of an integer makes no sense :confused:.

 

Some elucidation would be greatly appreciated.

2. what/why does it makes no sense?

Edited by Tams

Share this post


Link to post
Share on other sites

The weighted average formula divides wtd sum by cumulative weight, where the weighted sum is generated by adding up different prices over the course of the relevant time period and multiplying them by the length (day in the period) associated with them.

 

JTHMA appears to be essentially a weighted average of other weighted averages -- specifically two weighted averages that have two different periods (length and halvedlength).

 

Here's where I'm confused. Weighted average for (price, length) requires a different price for each period included in the length -- So if I have a length of 5, I need a price for each of those five values of length. However the JTHMA formula just gives me one price (the real number, representing Value1-Value2), despite the fact that it has a length greater than 1.

 

Many thanks for any light you can shed on this!

Share this post


Link to post
Share on other sites

a possible solution to being able to tell what price it will need in order to change direction

is to stick it in a loop and let it find out itself.

i am not sure what you are trying to achieve, if for example your indikator, which in this case is the hull ma is pointing up and you would want to know how much price should move down in order to make your indikator go down or cross below some fix point whithout knowing or needing to know the exact calculations it shouldnt be to hard to find out.

stick the calculation in a loop and let it loop trough untill your disired outcome is calculated, this will then be the price you will need to achieve the theoretical change in the indikator you would like to see.

but then again, imho it is not very helpfull to use an indikator from which one does not know on which formula's it is based.

if you need help let me know this should not be very hard to realize, im not sure if it is what you are trying to achieve here

Edited by flyingdutchmen

Share this post


Link to post
Share on other sites

Weighted average of the difference of price averages with a length of the square root of length(input)

 

Value1 = 2 * WAverage(price, halvedLength); double weights (the 2 * part) the weighted average of price with a period of 1/2 (fast length) the period that you choose with the input length (Inputs: Length(20), Offset(0); ) more on that below

 

Value2 = WAverage(price, length); is the weighted average of price with a period you chose with the input length (slow length). (obviously, I know)

 

Your choice of period you make with the input length is supposed to be made with some kind of statistically significant decision process. You should have a reason why you choose this number. This length is the longest length (slow length) used in the Hull Moving Average so a good setting is the longest moving average period that you generally like using for a moving average you use on your chart (especially if it is a weighted moving average you use) but double the number if your moving average you like moves right up and down with the general price cycles (especially if it is a weighted moving average you consider to show most of the movement cycles).

 

Value3 = WAverage((Value1 - Value2), sqrRootLength); is the weighted average of the difference of the double weighted fast price average and the slow weighted average of price and so it is a rate of change indicator. Many indicators use some kind of fast and slow comparison like this. Using a period of 1/2 of the slow length for the fast length in the equation is based on the slow length being statistically valid for smoothing cycles, thus 1/2 length should move with the cycles. The period used sqrRootLength in this case for the weighted average of the difference is a very fast length so that your hull moving average is of very reduced lag. Some would say that since this period is the square root of the slow length (if really statistically valid) then it is statistically valid- but I haven't tested this.

Ceiling - Returns the lowest integer greater than the specified number.

Floor - Returns the highest integer less than the specified number.

 

The Hull average is most generally used to produce smooth indicators for short time frame charts. I have a simple example for showing 2 fast stochastics, 2 because I am way

too dumb to input a statistically significant length so I hope I choose one that then being halved again will keep somewhere in between and show a significant cycle - which seems to help.

 

 

Inputs: length(20), EOB(true); 


vars: FastStochastic(0), FastStochastic2(0),	price1(0), price2(0), price3(0),
halvedLength(0), sqrRootLength(0), sqLength(0),
Havg(0), Lavg(0), Cavg(0),
price4(0), price5(0), price6(0),
halvedLength2(0), sqrRootLength2(0), sqLength2(0),
halfHavg(0), halfLavg(0), halfCavg(0);

if length < 4 then RaiseRunTimeError("Input length(period) must be 8 or greater"); //////// not required 
/////////////- personal reminder

price1 = (4 * H[3] + 3 * H[2]+ 2 * H[1] + H) * 0.1;
price2 = (4 * L[3] + 3 * L[2]+ 2 * L[1] + L) * 0.1;
price3 = (4 * C[3] + 3 * C[2]+ 2 * C[1] + C)  * 0.1;


halvedLength = round(length * 0.5,0);  
sqLength = SquareRoot(length); 

if ((ceiling(sqLength) - sqLength)  <= 0.5) then  
	sqrRootLength = ceiling(sqLength)  
else  
	sqrRootLength = floor(sqLength); 

halvedLength2 = round(halvedLength * 0.5,0);  
sqLength2 = SquareRoot(halvedLength); 

if ((ceiling(sqLength2) - sqLength2)  <= 0.5) then  
	sqrRootLength2 = ceiling(sqLength2)  
else  
	sqrRootLength2 = floor(sqLength2); 

Value1 = 2 * WAverage(price1, halvedLength);
Value2 = WAverage(price1, length);
Havg = WAverage((Value1 - Value2), sqrRootLength);



Value3 = 2 * WAverage(price2, halvedLength);
Value4 = WAverage(price2, length);
Lavg = WAverage((Value3 - Value4), sqrRootLength);


Value5 = 2 * WAverage(price3, halvedLength);
Value6 = WAverage(price3, length);
Cavg = WAverage((Value5 - Value6), sqrRootLength);


Value7 = 2 * WAverage(price1, halvedLength2);
Value8 = WAverage(price1, halvedLength);
halfHavg = WAverage((Value7 - Value8), sqrRootLength2);



Value9 = 2 * WAverage(price2, halvedLength2);
Value10 = WAverage(price2, halvedLength);
halfLavg = WAverage((Value9 - Value10), sqrRootLength2);


Value11 = 2 * WAverage(price3, halvedLength2);
Value12 = WAverage(price3, halvedLength);
halfCavg = WAverage((Value11 - Value12), sqrRootLength2);


FastStochastic = FastKCustom(Havg, Lavg, Cavg, halvedLength);
FastStochastic2 = FastKCustom(halfHavg, halfLavg, halfCavg, halvedLength2);


	plot1(FastStochastic,"Slow");
	plot2(FastStochastic2,"Fast");
	plot3(20);
	plot4(80);

	if EOB and CheckAlert Then Begin   //// set EOB to false for intrabar alerts
		If plot1 Crosses Over Plot4 Then
		Alert("FastStochastic _Slow_ crossed over 80"); 
		If plot1 Crosses Under Plot3 Then
		Alert("FastStochastic _Slow_  crossed under 20"); 
		If plot1 Crosses Over Plot3 Then
		Alert("FastStochastic _Slow_  crossed over 20"); 
		If plot1 Crosses Under Plot4 Then
		Alert("FastStochastic _Slow_  crossed under 80"); 
		If plot2 Crosses Over Plot4 Then
		Alert("FastStochastic _Fast_ crossed over 80"); 
		If plot2 Crosses Under Plot3 Then
		Alert("FastStochastic _Fast_  crossed under 20"); 
		If plot2 Crosses Over Plot3 Then
		Alert("FastStochastic _Fast_  crossed over 20"); 
		If plot2 Crosses Under Plot4 Then
		Alert("FastStochastic _Fast_  crossed under 80"); 
	End ;

 

and attached image:

 

attachment.php?attachmentid=22389&stc=1&d=1285095602

capture1.jpg.578cf932f3188572edaf59a8198c3347.jpg

Share this post


Link to post
Share on other sites

Join the conversation

You can post now and register later. If you have an account, sign in now to post with your account.
Note: Your post will require moderator approval before it will be visible.

Guest
Reply to this topic...

×   Pasted as rich text.   Paste as plain text instead

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   Your previous content has been restored.   Clear editor

×   You cannot paste images directly. Upload or insert images from URL.


  • Topics

  • Posts

    • YUM Yum Brands stock, nice breakout with volume +34.5%, from Stocks to Watch at https://stockconsultant.com/?YUM
    • Date: 3rd April 2025.   Gold Prices Pull Back After Record High as Traders Eye Trump’s Tariffs.   Key Takeaways:   Gold prices retreated after hitting a record high of $3,167.57 per ounce due to profit-taking. President Trump announced a 10% baseline tariff on all US imports, escalating trade tensions. Gold remains exempt from reciprocal tariffs, reinforcing its safe-haven appeal. Investors await US non-farm payroll data for further market direction. Fed rate cut bets and weaker US Treasury yields underpin gold’s bullish outlook. Gold Prices Retreat from Record Highs Amid Profit-Taking Gold prices saw a pullback on Thursday as traders opted to take profits following a historic surge. Spot gold declined 0.4% to $3,122.10 per ounce as of 0710 GMT, retreating from its fresh all-time high of $3,167.57. Meanwhile, US gold futures slipped 0.7% to $3,145.00 per ounce, reflecting broader market uncertainty over economic and geopolitical developments.   The recent rally was largely fueled by concerns over escalating trade tensions after President Donald Trump unveiled sweeping new import tariffs. The 10% baseline tariff on all goods entering the US further deepened the global trade conflict, intensifying investor demand for safe-haven assets like gold. However, as traders locked in gains from the surge, prices saw a modest retracement.   Trump’s Tariffs and Their Market Implications On Wednesday, Trump introduced a sweeping tariff policy imposing a 10% baseline duty on all imports, with significantly higher tariffs on select nations. While this move was aimed at bolstering domestic manufacturing, it sent shockwaves across global markets, fueling inflation concerns and heightening trade war fears.   Gold’s Role Amid Trade War Escalations Despite the widespread tariff measures, the White House clarified that reciprocal tariffs do not apply to gold, energy, and ‘certain minerals that are not available in the US’. This exemption suggests that central banks and institutional investors may continue favouring gold as a hedge against economic instability. One of the key factors supporting gold is the slowdown that these tariffs could cause in the US economy, which raises the likelihood of future Federal Reserve rate cuts. Gold is currently in a pure momentum trade. Market participants are on the sidelines and until we see a significant shakeout, this momentum could persist.   Impact on the US Dollar and Bond Yields Gold prices typically move inversely to the US dollar, and the latest developments have pushed the dollar to its weakest level since October 2024. Market participants are increasingly pricing in the possibility of a Fed rate cut, as the tariffs could weigh on economic growth.   Additionally, US Treasury yields have plummeted, reflecting growing recession fears. Lower bond yields reduce the opportunity cost of holding non-yielding assets like gold, making it a more attractive investment.         Technical Analysis: Key Levels to Watch Gold’s recent rally has pushed it into overbought territory, with the Relative Strength Index (RSI) above 70. This indicates a potential short-term pullback before the uptrend resumes. The immediate support level lies at $3,115, aligning with the Asian session low. A further decline could bring gold towards the $3,100 psychological level, which has previously acted as a strong support zone. Below this, the $3,076–$3,057 region represents a critical weekly support range where buyers may re-enter the market. In the event of a more significant correction, $3,000 stands as a major psychological floor.   On the upside, gold faces immediate resistance at $3,149. A break above this level could signal renewed bullish momentum, potentially leading to a retest of the record high at $3,167. If bullish momentum persists, the next target is the $3,200 psychological barrier, which could pave the way for further gains. Despite the recent pullback, the broader trend remains bullish, with dips likely to be viewed as buying opportunities.   Looking Ahead: Non-Farm Payrolls and Fed Policy Traders are closely monitoring Friday’s US non-farm payrolls (NFP) report, which could provide critical insights into the Federal Reserve’s next policy moves. A weaker-than-expected jobs report may strengthen expectations for an interest rate cut, further boosting gold prices.   Other key economic data releases, such as jobless claims and the ISM Services PMI, may also impact market sentiment in the short term. However, with rising geopolitical uncertainties, trade tensions, and a weakening US dollar, gold’s safe-haven appeal remains strong.   Conclusion: While short-term profit-taking may trigger minor corrections, gold’s long-term outlook remains bullish. As global trade tensions mount and the Federal Reserve leans toward a more accommodative stance, gold could see further gains in the months ahead.   Always trade with strict risk management. Your capital is the single most important aspect of your trading business.   Please note that times displayed based on local time zone and are from time of writing this report.   Click HERE to access the full HFM Economic calendar.   Want to learn to trade and analyse the markets? Join our webinars and get analysis and trading ideas combined with better understanding of how markets work. Click HERE to register for FREE!   Click HERE to READ more Market news.   Andria Pichidi HFMarkets   Disclaimer: This material is provided as a general marketing communication for information purposes only and does not constitute an independent investment research. Nothing in this communication contains, or should be considered as containing, an investment advice or an investment recommendation or a solicitation for the purpose of buying or selling of any financial instrument. All information provided is gathered from reputable sources and any information containing an indication of past performance is not a guarantee or reliable indicator of future performance. Users acknowledge that any investment in Leveraged Products is characterized by a certain degree of uncertainty and that any investment of this nature involves a high level of risk for which the users are solely responsible and liable. We assume no liability for any loss arising from any investment made based on the information provided in this communication. This communication must not be reproduced or further distributed without our prior written permission.
    • AMZN Amazon stock, nice buying at the 187.26 triple+ support area at https://stockconsultant.com/?AMZN
    • DELL Dell Technologies stock, good day moving higher off the 90.99 double support area, from Stocks to Watch at https://stockconsultant.com/?DELL
    • MCK Mckesson stock, nice trend and continuation breakout at https://stockconsultant.com/?MCK
×
×
  • Create New...

Important Information

By using this site, you agree to our Terms of Use.