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
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.

 

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

    • re TikTok Recently metafakebook made what was apparently a move to stay aligned with ‘culture’ - no more fact ‘checking’, no more censorhip... basically ‘Zucker’ was shown that his mission was failing because they were only building profiles on ‘useful idiots’ instead of those who oppose the great centralization  (... just like long ago he only saw campus potential and had to be shown the promise and rewarded for fronting the great spyware and social engineering project called Fakebook)... ie they could have replaced him long ago In the same vein, who holds ‘title’ to tiktok doesn’t matter either... it will remain a spyware project regardless of who ‘buys’ it... and the data will forever be available to the CCP Just sayin’
    • Omobola,  As an engineer surely you have money to buy a ticket to Monterey, Mexico... just a hop and a jump from there to Texas...  hth zdo 
    • Date: 20th January 2025.   The NASDAQ Rises As Trump Inauguration Edges Closer!   US indices increased in value for the first time after struggling for 5 consecutive weeks. Of the main US indices the NASDAQ witnessed the strongest gains (4.12%). Risk indicators point to a higher risk appetite under the new US President, Donald Trump. President Trump's inauguration will take place this afternoon and has promised to sign over 100 consecutive orders within his first week. NASDAQ - Higher Investor Confidence! NASDAQ traders begin to stomach less frequent interest rate adjustments, the market turns its attention to earnings and Trump’s presidency. Investors are becoming more bullish under expectations that Trump will apply policies to support the US economy and entice further investment into the US stock market. A "risk-on" sentiment is evident in today's sessions, reflected in risk indicators like the VIX, High-Low Index, and Bond yields.     Investors this week will concentrate on two factors. The first factor is Trump’s consecutive orders which he has advised will be signed within his first week. Investors will closely monitor how and if these policies influence the US economy and stocks. The second factor is earnings season, which will start to gain momentum this week. Tomorrow, Netflix will release its quarterly earnings report after the market closes. Netflix is the NASDAQ’s 10th most influential company and 11th most impactful stock. Analysts expect the company’s earnings per share to drop from $5.40 to $4.21, but for Revenue to rise to $10.11 Billion. If Netflix is able to beat the earnings per share and revenue expectations, fundamental elections would indicate a rise in the price. Over the past 12 months the price has risen 76%. A further increase would further support the NASDAQ. Thereafter, investors will turn their attention to Intuitive Surgical’s earnings report. Currently, investors believe the company’s earnings per share and revenue will rise compared to the previous quarter. Intuitive’s stock has risen by more than 9% in the past week alone indicating that investors believe the company will continue to beat earnings expectations. The company has beat expectations over the past 12-months. How are Markets Reacting to Trump's inauguration? Trump pledged to issue executive orders aimed at advancing artificial intelligence programs and establishing the Department of Government Efficiency (Doge). Analysts expect these two alone to support US stocks. However, investors are not yet certain to what extent upcoming tariffs will pressure the NASDAQ and stocks. During the previous trade wars, the NASDAQ fell by 25% over a period of 4-months. Traders also should note that the NASDAQ rose in the 6-weeks after Trump won the elections. Over the past week, the VIX index fell by more than 12% indicating that the market believes US stocks will perform well under a Trump presidency. Simultaneously, US Bond yields have fallen from 4.80% to 4.58% which is known to positively influence the US stock market. Both the VIX and lower bond yields indicate higher investor confidence as Trump advises that policies will prompt more employment, US made products and more pro-US policies. NASDAQ - Technical Analysis The price of the NASDAQ trades above the 200-bar Moving Average on a 5-minute Chart indicating bullish price movement. Moving Averages have also crossed over upwards and the price trades above the VWAP indicating that the asset is maintaining its bullish momentum. Price action is also forming clear higher highs and higher lows, but investors will be cautious if the price does not find resistance at the $21,637 resistance level. In order to break above this level, investors will be hoping for positive earnings data from Netflix and Intuitive.     Key Takeaways: President Trump's inauguration will take place this afternoon with promise to sign over 100 consecutive orders within his first week. US indices rise after 5 weeks of declines, with the NASDAQ leading at 4.12%. Trump pledged to issue executive orders aimed at advancing artificial intelligence programs and establishing the Department of Government Efficiency. Analysts expect Netflix earnings per share to drop from $5.40 to $4.21, but for Revenue to rise to $10.11 Billion. Investors are becoming more bullish under expectations that President Trump will apply policies to support the US economy and entice further investment into the US stock market. 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. Michalis Efthymiou 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.
    • Consider: some 80% of small to medium-sized businesses around the world don’t have a website.   Many businesses in emerging economies rely on social media platforms (e.g., WhatsApp, Facebook) as their primary digital presence instead of formal websites.   But even in more digitally advanced economies, the number can hover around half.   Why? Simple answer: although we’ve made it easier to make a website, it’s still not easy enough.   Let’s say a yoga instructor wants to offer online classes but lacks tech skills or a budget.   Instead of struggling with confusing platforms, she tells her AI agent, “Set up a website for me to host yoga classes.”   The AI handles everything.   It integrates Stripe for payments, Zoom for live classes, scheduling services for in-person classes, and a chat module for inquiries.   It even suggests templates.   When the instructor picks one and asks for a purple and white color scheme, the AI updates it instantly.   No coding. No frustration. Just results.   And the best part? She didn’t have to touch a single screen or key.   This is the future Wilson describes in Age of Invisible Machines.   And, as mentioned, it’s powered by three core technologies:   Conversational User Interfaces (CUIs): Say what you need; the system handles it. From building websites to booking flights, it’s fast and human-like.   Composable Architecture: Traditional business solutions become “modules”. Like LEGO bricks, modular tools—payments, chats, scheduling—snap together to create custom solutions without starting from scratch.   No-Code Programming: AI agents code for you, empowering anyone to create without needing a developer. It’s not just a better way to interact with technology…   It’s a complete reimagining of how industries operate.   As Harvard Business School’s Marco Iansiti says, “This isn’t disruption—it’s a fundamental shift in production and interaction.”   And, the thing is…   It’s not just possible. It’s already happening.   Early examples are already here. – Chris Campbell, AltucherConfidential Profits from free accurate cryptos signals: https://www.predictmag.com/ 
    • Question: My name is Omobola Sikiru from Lagos, Nigeria. I am mechanical engineering. Where can I find someone that can be my helper to relocate me to the USA?   Answer: According to your own profile, you are trying to enter other countries through deception and immigration fraud.   You are an engineer in Nigeria, but you are not licensed as an engineer in any other country.   There are no helpers, no sponsors, and nobody is going to give you money, get you an engineering job, or get you a visa.   You must qualify to immigrate. Nobody can help you with that.   Either you qualify and have settling in money, or you don’t.   You need to improve your English before trying to get a job in a Western, English speaking country. Engineers write reports. You wrote, ‘I am mechanical engineering’. Nobody will hire you if you write like this. Rathkeale Source: https://www.quora.com/My-name-is-Omobola-Sikiru-from-Lagos-Nigeria-I-am-mechanical-engineering-Where-can-I-find-someone-that-can-be-my-helper-to-relocate-me-to-the-USA   Profits from free accurate cryptos signals: https://www.predictmag.com/  
×
×
  • Create New...

Important Information

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