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.

PeterBrazel

MACDBB Enhancements

Recommended Posts

I have taken a MACDBB Indicator [posted here] and the MACD band expansion indicator [posted here, made a few changes of my own but am now trying to marry the two of these together. Specifically I want the BB's to change color when they are expanding. I have done this but they do not look quite right so I have miscalculated somewhere.

 

If somebody could take a look at this code it would be greatly apprciated.

 

Thanks

 

[LegacyColorValue = false]; 
{ ************************************************** ******************* 
MACD-BB MACD Bolinger Banded 
Last Updated 8/30/2007 
Added Up/Down Color to MACD 

************************************************** *********************} 


Input: 
	Use.XAvg(False),
	PlotCross(True),
	FastMA( 5), {12 default} 
	SlowMA( 13), { 26 default} 
	price( myprice), 
	PlotBBands(true), 
	SDev( 1.5), { 1.5 default} 
	PlotBBAvg(false), 
	BBavg( 10), { 10 default} 
	Plot0Line(true), 
	UpColor(cyan), 
	UpAbove(darkgreen), 
	DnColor(Magenta), 
	DnBelow(darkred),
	Shadow(Yellow),
	Expanding(Green); 
Vars:
	BWI(0);

	value1 = MACD(price,FastMA,SlowMA); 
	value2 = BollingerBand(MACD(price,FastMA,SlowMA),BBavg,SDev);  	//Upper Band
	value3 = BollingerBand(MACD(price,FastMA,SlowMA),BBavg,-SDev) ;	//Lower Band 
// Band Width Indicator
if 		Use.XAvg then
		value5 = XAverage(value1,BBavg)
else
		Value5 = averagefc(value1,BBavg) ;

	{value5 = Average(value1,BBavg) ; }


if 		value1 > value1[1] and value1 > value2 then 
begin 
	// Plot1[1](Plot1[1],"MACD",UpAbove); 
	Plot1(value1,"MACD",UpAbove); 
end else 
begin 
if 		value1 > value1[1] then begin 
	// Plot1[1](Plot1[1],"MACD",UpColor); 
	Plot1(value1,"MACD",UpColor); 
end else 
begin 
if 		value1 < value1[1] and value1 < value3 then begin 
	// Plot1[1](Plot1[1],"MACD",DnBelow); 
	Plot1(value1,"MACD",DnBelow); 
end else 
begin 
	if value1 < value1[1] then begin 
	// Plot1[1](Plot1[1],"MACD",DnColor); 
	Plot1(value1,"MACD",DnColor); 
end; end; end; end; 

	if Plot0Line = true then 
	begin 


if 		value1 < 0 then  
	SetPlotColor(2,Red)
else
	SetPlotColor(2,Blue);

	Plot2(0,"ZeroLine"); 
end; 

if 		PlotBBands = true then
begin 
////////

If		Value5>Value5[1] then
	SetPlotColor[1](3,Expanding);
If		Value5>Value5[1] then
	SetPlotColor[1](4,Expanding);
///////
	plot3(value2,"bband+"); 
	plot4(value3,"bband-"); 
end; 
if 		PlotBBAvg = true then begin 
	Plot5(value5,"avg"); 
end;

	Plot6(value1,"MDShadow");

If		PlotCross 
then
begin
If		Value1[1]<0 and Value1>0
then
	Plot7(Value1,"CrossUp") else
	NoPlot(7);

If		Value1[1]>0 and Value1<0
then
	Plot8(Value1,"CrossDn") else
	NoPlot(8);
end;

MACDBB.png.11982cbe452f6b5338b551d6d0053236.png

Share this post


Link to post
Share on other sites
Thanks Tams

The BB's are not always expanding when the plot changes color. I have attached a screenshot of what I am looking at.

 

 

you have to be MORE specific... a lot more specific

(this is to reflect the clarity of your thinking)

 

what color you are looking at ? (what is the plot # ?)

what color it should be? and WHY ? WHY and WHY ?

what causes it to change?

how many ways does it supposed to change? (# of options/permutations)

 

which section of the code that is supposed to paint the color?

can you articulate the logic in English/pseudo-code ? (in one-line-per-logic format?)

 

 

if you can write them out one thought at a time... you will easily see where it went astray.

Share this post


Link to post
Share on other sites

on suggestion:

 

do not use generic variable names. ie. Value1, Value2, etc.,

 

 

create a custom variable name that makes sense... so that you know what kind of data you are working with.

when your code gets lengthy... you will loose track of which is what.

when you come back to the code 3 months from now... you will have to STUDY the code to figure out which is what.

 

bugs are to be avoided at all cost... this is the first step.

Share this post


Link to post
Share on other sites

Thanks for your response.

 

I guess this is what happens when you take someone elses code, in this case two different authors code and then try to marry them together and then to make changes.

 

The only outstanding issue with my code is that I am trying to have the Bollinger Bands change [in this case from yellow to a green] colour when the bands are expanding. If they are not expanding then just leave them a yellow color.

 

I agree that using Values 1 through 5 is ambiguous and I should look at changing the code.

Value 5 at this point is

// Band Width Indicator

if Use.XAvg then

value5 = XAverage(value1,BBavg)

else

Value5 = averagefc(value1,BBavg) ;

 

Then later on in the code I am using this to change the color:

 

If Value5>Value5[1] then

SetPlotColor[1](3,Expanding);

If Value5>Value5[1] then

SetPlotColor[1](4,Expanding);

///////

plot3(value2,"bband+");

plot4(value3,"bband-");

end;

 

I do need to get an understanding of the code that I took from the site first.

I then need to reconstruct this whole thing so that the naming conventions are meaningful to me as you suggest.

 

Cheers

Share this post


Link to post
Share on other sites

I have reformatted your code... I didn't change the code, only the formatting.

 

You see, you have lots of conditional logic in your code.

Many of the logics are nested...

ie, there are multiple layers of IF condition1=true THEN do-this ELSE do-that...

 

When you have a lot of code, the logic is easy to get lost in the "spaghetti".

 

Formatting (indentation) of the code helps you to visualize your logic flow.

 

Formatting has no effect on the computing process, this is strictly for human consumption.

 

Here's the formated code:

 

 

[LegacyColorValue = false]; 
{ ************************************************** ******************* 
MACD-BB MACD Bolinger Banded 
Last Updated 8/30/2007 
Added Up/Down Color to MACD 

************************************************** *********************} 


Input: 
	Use.XAvg(False),
	PlotCross(True),
	FastMA( 5), {12 default} 
	SlowMA( 13), { 26 default} 
	price( myprice), 
	PlotBBands(true), 
	SDev( 1.5), { 1.5 default} 
	PlotBBAvg(false), 
	BBavg( 10), { 10 default} 
	Plot0Line(true), 
	UpColor(cyan), 
	UpAbove(darkgreen), 
	DnColor(Magenta), 
	DnBelow(darkred),
	Shadow(Yellow),
	Expanding(Green); 
Vars:
	BWI(0);

	value1 = MACD(price,FastMA,SlowMA); 
	value2 = BollingerBand(MACD(price,FastMA,SlowMA),BBavg,SDev);  	//Upper Band
	value3 = BollingerBand(MACD(price,FastMA,SlowMA),BBavg,-SDev) ;	//Lower Band 



// Band Width Indicator
if Use.XAvg then
value5 = XAverage(value1,BBavg)
else
Value5 = averagefc(value1,BBavg) ;

{value5 = Average(value1,BBavg) ; }


if value1 > value1[1] and value1 > value2 then 
begin 
// Plot1[1](Plot1[1],"MACD",UpAbove); 
Plot1(value1,"MACD",UpAbove); 
end 
else 
begin 
if value1 > value1[1] then 
begin 
	// Plot1[1](Plot1[1],"MACD",UpColor); 
	Plot1(value1,"MACD",UpColor); 
end 
else 
begin 
	if value1 < value1[1] and value1 < value3 then 
	begin 
		// Plot1[1](Plot1[1],"MACD",DnBelow); 
		Plot1(value1,"MACD",DnBelow); 
	end 
	else 
	begin 
		if value1 < value1[1] then 
		begin 
			// Plot1[1](Plot1[1],"MACD",DnColor); 
			Plot1(value1,"MACD",DnColor); 
		end; 
	end; 
end; 
end; 


if Plot0Line = true then 
begin 
if value1 < 0 then  
SetPlotColor(2,Red)
else
SetPlotColor(2,Blue);

Plot2(0,"ZeroLine"); 
end; 

if PlotBBands = true then
begin 
////////
If Value5>Value5[1] then
SetPlotColor[1](3,Expanding);

If Value5>Value5[1] then
SetPlotColor[1](4,Expanding);
///////
plot3(value2,"bband+"); 
plot4(value3,"bband-"); 
end; 


if PlotBBAvg = true then 
begin 
Plot5(value5,"avg"); 
end;


Plot6(value1,"MDShadow");

If PlotCross 	then
begin
If Value1[1]<0 and Value1>0 then
Plot7(Value1,"CrossUp") 
else
NoPlot(7);

If Value1[1]>0 and Value1<0 then
Plot8(Value1,"CrossDn") 
else
NoPlot(8);
end;

 

 

here's an illustration of how the formatting helps you see the grouping of logics.

 

attachment.php?attachmentid=16515&stc=1&d=1260595156

 

 

Different people may format their codes different ways;

there is no right or wrong way to format the code,

the only purpose is to help you visualize the logic.

 

 

.

blocks.jpg.3cf4ef541dc27ce1408ab1c5a2cc3e23.jpg

Edited by Tams

Share this post


Link to post
Share on other sites

Thank you for the advice re coding in general.

 

I have changed the terminology of the code to something more meaningful and re-examined what the two different pieces of code were ttrying to achieve, married the two together and achieved a result that looks acceptable to me.

 

Yes there are lots of colours but I find these meaningful. To explain the attached screenshot a rising MACD between the BB's is cyan, above the BB's is blue. A falling MACD between the bands is Magenta and below is red. The BB's change from red to green only when the BB's are expanding. The zero line crossing can be toggled on or off. The zero line changes colour depending on the MACD being above or below.

MACDBB.thumb.png.0d8c064068084c26aa25c20037af543e.png

Share this post


Link to post
Share on other sites
...

Yes there are lots of colours but I find these meaningful. To explain the attached screenshot a rising MACD between the BB's is cyan, above the BB's is blue. A falling MACD between the bands is Magenta and below is red. The BB's change from red to green only when the BB's are expanding. The zero line crossing can be toggled on or off. The zero line changes colour depending on the MACD being above or below.

 

 

you have to use lines

and arrows

and annotations

on the chart

to illustrate your thoughts...

 

nobody on a public forum

is going to spend the trouble

to marry your incoherent ramblings

to your convoluted chart.

... and to guess if this is what you meant,

or to assume if that is what you want.

 

 

 

p.s. also... when thinking about your logics,

get into the habit of

writing one line at a time...

one thought per line,

one action per line,

one phrase per line,

and start a new line

for every sentence...

Edited by Tams

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

    • Date: 25th November 2024. New Secretary Cheers Markets; Trump Trade Eased. Asia & European Sessions:   Equities and Treasuries rise, as markets view Donald Trump’s choice of Scott Bessent for Treasury Secretary as a stabilizing decision for the US economy and markets. Bessent: Head of macro hedge fund Key Square Group, supports Trump’s tax and tariff policies but gradually. He is expected to focus on economic and market stability rather than political gains. His nomination alleviates concerns over protectionist policies that could escalate inflation, trade tensions, and market volatility. Asian stocks rose, driven by gains in Japan, South Korea, and Australia. Chinese equities fail to follow regional trends, presenting investors’ continued disappointment by the lack of strong fiscal measures to boost the economy. The PBOC keeps policy loan rates unchanged after the September cut. US futures also see slight increases. 10-year Treasury yields fall by 5 basis points to 4.35%. Nvidia dropped 3.2%, affected by its high valuation and influence on broader market trends. Intuit fell 5.7% after a disappointing earnings forecast. Meta Platforms declined 0.7% following the Supreme Court’s decision to allow a class action lawsuit over the Cambridge Analytica scandal. Key events this week: Japan’s CPI, as the BOJ signals a possible policy change at December’s meeting. RBNZ expected to cut its key rate on Wednesday. CPI & GDP from Europe will be released. Traders will focus on the Fed’s November meeting minutes, along with consumer confidence and personal consumption expenditure data, to assess potential rate cuts next year. Financial Markets Performance: The US Dollar declines as US Treasuries climb. Bitcoin recovers from a weekend drop, hovering around 98,000, having more than doubled in value this year. Analysts suggest consolidation around the 100,000 level before any potential breakthrough. EURUSD recovers slightly to 1.0463 from 1.0320 lows. Oil prices drop after the largest weekly increase in nearly two months, with ongoing geopolitical risks in Ukraine and the Middle East. UKOIL fell below $75 a barrel, while USOILis at $70.35. Iran announced plans to boost its nuclear fuel-making capacity after being censured by the UN, increasing the potential for sanctions under Trump’s administration. Israel’s ambassador to the US indicated a potential cease-fire deal with Hezbollah, which could ease concerns about Middle Eastern oil production, a region supplying about a third of the world’s oil. Russia’s war in Ukraine escalated with longer-range missile use, raising concerns about potential disruptions to crude flows. Citigroup and JPMorgan predict that OPEC may delay a planned increase in production for the third time during their meeting this weekend. Gold falls to $2667.45 after its largest rise in 20 months last week.Swaps traders see a less-than-even chance the central bank will cut rates next month. Higher borrowing costs tend to weigh on gold, as it doesn’t pay interest. 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 FX and CFDs 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.
    • SNAP stock, big day off support at https://stockconsultant.com/?SNAP
    • SBUX Starbucks stock, nice breakout, from Stocks to Watch at https://stockconsultant.com/?SBUX
    • INTC Intel stock settling at 24.25 double support area at https://stockconsultant.com/?INTC
    • CORZ Core Scientific stock, strong close, watch for a top of range breakout above 18.32 at https://stockconsultant.com/?CORZ
×
×
  • Create New...

Important Information

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