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

    • My wife Robin just wanted some groceries.   Simple enough.   She parked the car for fifteen minutes, and returned to find a huge scratch on the side.   Someone keyed her car.   To be clear, this isn’t just any car.   It’s a Cybertruck—Elon Musk's stainless-steel spaceship on wheels. She bought it back in 2021, before Musk became everyone's favorite villain or savior.   Someone saw it parked in a grocery lot and felt compelled to carve their hatred directly into the metal.   That's what happens when you stand out.   Nobody keys a beige minivan.   When you're polarizing, you're impossible to ignore. But the irony is: the more attention something has, the harder it is to find the truth about it.   What’s Elon Musk really thinking? What are his plans? What will happen with DOGE? Is he deserving of all of this adoration and hate? Hard to say.   Ideas work the same way.   Take tariffs, for example.   Tariffs have become the Cybertrucks of economic policy. People either love them or hate them. Even if they don’t understand what they are and how they work. (Most don’t.)   That’s why, in my latest podcast (link below), I wanted to explore the “in-between” truth about tariffs.   And like Cybertrucks, I guess my thoughts on tariffs are polarizing.   Greg Gutfield mentioned me on Fox News. Harvard professors hate me now. (I wonder if they also key Cybertrucks?)   But before I show you what I think about tariffs… I have to mention something.   We’re Headed to Austin, Texas This weekend, my team and I are headed to Austin. By now, you should probably know why.   Yes, SXSW is happening. But my team and I are doing something I think is even better.   We’re putting on a FREE event on “Tech’s Turning Point.”   AI, quantum, biotech, crypto, and more—it’s all on the table.   Just now, we posted a special webpage with the agenda.   Click here to check it out and add it to your calendar.   The Truth About Tariffs People love to panic about tariffs causing inflation.   They wave around the ghost of the Smoot-Hawley Tariff from the Great Depression like it’s Exhibit A proving tariffs equal economic collapse.   But let me pop this myth:   Tariffs don’t cause inflation. And no, I'm not crazy (despite what angry professors from Harvard or Stanford might tweet at me).   Here's the deal.   Inflation isn’t when just a couple of things become pricier. It’s when your entire shopping basket—eggs, shirts, Netflix subscriptions, bananas, everything—starts costing more because your money’s worth less.   Inflation means your dollars aren’t stretching as far as they used to.   Take the 1800s.   For nearly a century, 97% of America’s revenue came from tariffs. Income tax? Didn’t exist. And guess what inflation was? Basically zero. Maybe 1% a year.   The economy was booming, and tariffs funded nearly everything. So, why do people suddenly think tariffs cause inflation today?   Tariffs are taxes on imports, yes, but prices are set by supply and demand—not tariffs.   Let me give you a simple example.   Imagine fancy potato chips from Canada cost $10, and a 20% tariff pushes that to $12. Everyone panics—prices rose! Inflation!   Nope.   If I only have $100 to spend and the price of my favorite chips goes up, I either stop buying chips or I buy, say, fewer newspapers.   If everyone stops buying newspapers because they’re overspending on chips, newspapers lower their prices or go out of business.   Overall spending stays the same, and inflation doesn’t budge.   Three quick scenarios:   We buy pricier chips, but fewer other things: Inflation unchanged. Manufacturers shift to the U.S. to avoid tariffs: Inflation unchanged (and more jobs here). We stop buying fancy chips: Prices drop again. Inflation? Still unchanged. The only thing that actually causes inflation is printing money.   Between 2020 and 2022 alone, 40% of all money ever created in history appeared overnight.   That’s why inflation shot up afterward—not because of tariffs.   Back to tariffs today.   Still No Inflation Unlike the infamous Smoot-Hawley blanket tariff (imagine Oprah handing out tariffs: "You get a tariff, and you get a tariff!"), today's tariffs are strategic.   Trump slapped tariffs on chips from Taiwan because we shouldn’t rely on a single foreign supplier for vital tech components—especially if that supplier might get invaded.   Now Taiwan Semiconductor is investing $100 billion in American manufacturing.   Strategic win, no inflation.   Then there’s Canada and Mexico—our friendly neighbors with weirdly huge tariffs on things like milk and butter (299% tariff on butter—really, Canada?).   Trump’s not blanketing everything with tariffs; he’s pressuring trade partners to lower theirs.   If they do, everybody wins. If they don’t, well, then we have a strategic trade chess game—but still no inflation.   In short, tariffs are about strategy, security, and fairness—not inflation.   Yes, blanket tariffs from the Great Depression era were dumb. Obviously. Today's targeted tariffs? Smart.   Listen to the whole podcast to hear why I think this.   And by the way, if you see a Cybertruck, don’t key it. Robin doesn’t care about your politics; she just likes her weird truck.   Maybe read a good book, relax, and leave cars alone.   (And yes, nobody keys Volkswagens, even though they were basically created by Hitler. Strange world we live in.) Source: https://altucherconfidential.com/posts/the-truth-about-tariffs-busting-the-inflation-myth    Profits from free accurate cryptos signals: https://www.predictmag.com/       
    • No, not if you are comparing apples to apples. What we call “poor” is obviously a pretty high bar but if you’re talking about like a total homeless shambling skexie in like San Fran then, no. The U.S.A. in not particularly kind to you. It is not an abuse so much as it is a sad relatively minor consequence of our optimism and industriousness.   What you consider rich changes with circumstances obviously. If you are genuinely poor in the U.S.A., you experience a quirky hodgepodge of unhelpful and/or abstract extreme lavishnesses while also being alienated from your social support network. It’s about the same as being a refugee. For a fraction of the ‘kindness’ available to you in non bio-available form, you could have simply stayed closer to your people and been MUCH better off.   It’s just a quirk of how we run the place and our values; we are more worried about interfering with people’s liberty and natural inclination to do for themselves than we are about no bums left behind. It is a slightly hurtful position and we know it; we are just scared to death of socialism cancer and we’re willing to put our money where our mouth is.   So, if you’re a bum; you got 5G, the ER will spend like $1,000,000 on you over a hangnail but then kick you out as soon as you’re “stabilized”, the logistics are surpremely efficient, you have total unchecked freedom of speech, real-estate, motels, and jobs are all natural healthy markets in perfect competition, you got compulsory three ‘R’’s, your military owns the sky, sea, space, night, information-space, and has the best hairdos, you can fill out paper and get all the stuff up to and including a Ph.D. Pretty much everything a very generous, eager, flawless go-getter with five minutes to spare would think you might need.   It’s worse. Our whole society is competitive and we do NOT value or make any kumbaya exception. The last kumbaya types we had werr the Shakers and they literally went extinct. Pueblo peoples are still around but they kind of don’t count since they were here before us. So basically, if you’re poor in the U.S.A., you are automatically a loser and a deadbeat too. You will be treated as such by anybody not specifically either paid to deal with you or shysters selling bejesus, Amway, and drugs. Plus, it ain’t safe out there. Not everybody uses muhfreedoms to lift their truck, people be thugging and bums are very vulnerable here. The history of a large mobile workforce means nobody has a village to go home to. Source: https://askdaddy.quora.com/Are-the-poor-people-in-the-United-States-the-richest-poor-people-in-the-world-6   Profits from free accurate cryptos signals: https://www.predictmag.com/ 
    • TDUP ThredUp stock, watch for a top of range breakout above 2.94 at https://stockconsultant.com/?TDUP
    • TDUP ThredUp stock, watch for a top of range breakout above 2.94 at https://stockconsultant.com/?TDUP
    • TDUP ThredUp stock, watch for a top of range breakout above 2.94 at https://stockconsultant.com/?TDUP
×
×
  • Create New...

Important Information

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