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.

tradingbigboy

Muliple Output Functions Easy Language

Recommended Posts

Hi All,

 

For the pros in here, I would love for you to tell me if this is possible. I've coded an indicator using a different zigzag algorithm - not TS but the one used by MT4 and Dukas etc. It is coded perfectly and works. It does 2 passes through the data and simply operates ONLY on the lastbar of the chart.

 

If LastBarOnChart then Begin
   Array_SetMaxIndex(lowMapBuffer, BarNumber+1);
   Array_SetMaxIndex(highMapBuffer, BarNumber+1);
   Array_SetMaxIndex(zigzagBuffer, BarNumber+1);

etc.

 

Now I want to make this multi-timeframe and use the zigzag values in strategies etc so am attempting to turn this into a function. I get the function finished and values are all correct. The function has the same structure as the indicator, just doesn't draw TL and stuff. Now I'm trying to get values FROM this function.

 

The problem is most functions operate per bar from the beginning 1 pass through and spit out values like averages and other stuff. This indicator that pings the function must grab all of its values as well from the last bar on the chart. This would seem like the function must really return an array to the indy/strategy and I'm lost at how to do this.

 

Here's the inputs I have for the zigzag function:

inputs:
   extDepth(Numericsimple),  // 12
   extDeviation(Numericsimple),  // 5
   extBackstep(Numericsimple),   // 3
   oshift(Numericref),
   oZZupBeg(numericref),
   oZZupEnd(numericref),
   oZZdnBeg(numericref), 
   oZZdnEnd(numericref);
   Input: oZZ[n](numericarrayRef);

I'm experimenting here trying to get something to work including a numericarryref but it is not giving values.

 

In the function itself I have the oZZ being assigned as follows:

oZZ[n]=zigzagBuffer[shiftago];

 

In the indicator to test the function I have tried this:

If LastBarOnChart then begin
//method void AnalysisTechnique_Initialized( elsystem.Object sender, elsystem.InitializedEventArgs args ) 
value2 = ZZdukas(12,5,3,shift,oZZupBegval,oZZupEndval,oZZdnBegval,oZZdnEndval,oZZvalsa);
For Value1 = 0 to 999 begin
print("oZZvalsa[value1] = ",oZZvalsa[value1]);
end;

It all verfies but there is nothing but zeros in the values.

 

Any help is appreciated!!

TBB

Share this post


Link to post
Share on other sites

tbb,

 

Didn't exactly follow all you're trying to accomplish (esp re multiple timeframes, etc.)

but if you're putting this code into a strategy, instead of calling a function in the long run you would be better off putting the code in a method and appending (multiple timeframe) returns to elements in a (circular) vector ...

call method only when it's needed for real - instead of last bar on chart, etc...

 

hth

Share this post


Link to post
Share on other sites

Hi hth!

Thank you so much for your reply. I figured out how to use the Global Dictionary to share values but need to rework this code for ZigZags as I need to reference values of it BEFORE the lastbaronchart in order to use values in strategies etc. I can take the lastbaronchart and uncomment it BUT it gets VERY expensive in computation to do this each bar and really shouldn't be calculating always from the beginning but should retain values from past calculations. I don't know how this is done in easy langauge but I'm sure you know. Yes I would love to first make it efficient THEN put it into a method as you say but I'm not a OOP guy. In fact I switched back to easy language partly because Java was killing me. I did manage to port this zigzag over correctly and thought I was golden. :( Anyway thank you so much for your help here.

 

// ZigZag Best Algorithm
inputs:
   extDepth(12),
   extDeviation(5),
   extBackstep(3);

variables:
int whatlookfor(0),
int lasthighpos(0),
int lastlowpos(0),
   double val(0.0),
   double res(0.0),
   int shift(0),
   int shiftago(0),
   int back(0),
int j(0),
double lastlow(0),
double lasthigh(0),
double curlow(0),
double curhigh(0), 
double instrPips(0.0001),
double zigzagago(0),
zigzagagobar(0),
double zzupstartpr(0),
zzupstartbar(0),
double zzdnstartpr(0),
zzdnstartbar(0), 
IDup(0),
IDdn(0),
double Dnfibhighpr(0.0),
double Dnfiblowpr(0.0),
Dnfibstartbar(0),
double Upfibhighpr(0.0),
double Upfiblowpr(0.0),
Upfibstartbar(0);	
Arrays:
Double lowMapBuffer[](0.0),
Double highMapBuffer[](0.0),
Double zigzagBuffer[](0.0);	

If LastBarOnChart then Begin
//If Currentbar=0 then Begin
   Array_SetMaxIndex(lowMapBuffer, BarNumber+1);
   Array_SetMaxIndex(highMapBuffer, BarNumber+1);
   Array_SetMaxIndex(zigzagBuffer, BarNumber+1);
   // initialize array each time through
   Value40=0;
   While Value40 <= BarNumber+1 begin
   	lowMapBuffer[Value40]=0.0;
   	highMapBuffer[Value40]=0.0;
   	zigzagBuffer[Value40]=0.0;
   	Value40=Value40+1;
   End;

   IDdn=0;
zzdnstartpr=0;
zzdnstartbar=0;
IDup=0;
zzupstartpr=0;
zzupstartbar=0;
zigzagago=0;
zigzagagobar=0;
instrPips= 1 Point;
Value2 = MinMove / PriceScale;
//print(date," ",time," instrPips = ",instrPips:0:4," minmove/pricescale = ",Value2:0:4);

   While TL_Exist(TL_GetFirst(1)) begin
   	value50 = TL_GetFirst(1);
   	Value51 = TL_Delete(value50);
   end;


For shift = (1 + extDepth) to Currentbar Begin 
	//If Currentbar = 1 then Begin
	shiftago = Currentbar - shift;
	///    Lows
	val = Low[shiftago];
//print(date[shiftago]," ",time[shiftago]," shiftago = ",shiftago," shift = ",shift," Low shiftago = ",Low[shiftago]:0:4);
	For j = (shift-1) Downto (shift - extDepth) Begin
		Value2 = Currentbar - j;
		val = MinList(val, Low[Value2]);
//If shift=13 then print(date[Value2]," ",time[Value2]," J = ",J," Shift - 1 = ",shift-1," shift - extdepth = ",shift-extDepth," val = ",val);
	End; 
	If (val = lastlow) then Begin
		val = 0.0;
	End
	Else Begin
		lastlow = val;
		If (Low[shiftago] - val > extDeviation * instrPips) then Begin
			val = 0.0;
		End
		Else Begin
			For back = 1 to extBackstep Begin
			    value3=shift-back;
			    value4=Currentbar-value3;
				// res=lowMapBuffer[shift - back];
				res=lowMapBuffer[value4];
				If res <> 0 and res > val then Begin
					// lowMapBuffer[shift - back] = 0.0;
			     lowMapBuffer[value4] = 0.0;
				End;
			End;
		End;
	End;		
	If Low[shiftago] = val then Begin
		//lowMapBuffer[shift] = val;
		lowMapBuffer[shiftago] = val;
	End
	Else Begin
		//lowMapBuffer[shift] = 0.0;
		lowMapBuffer[shiftago] = 0.0;
	End;
	//   Highs now
	val = High[shiftago];
	For j = (shift-1) Downto (shift - extDepth) Begin
		Value2 = Currentbar - J; 
		val = MaxList(val, High[Value2]);
	End; 
	If val = lasthigh then Begin
		val = 0.0;
	End
	Else Begin
		lasthigh = val;
		If (val - High[shiftago] > extDeviation * instrPips) then Begin
			val = 0.0;
		End
		Else Begin
			For back = 1 to extBackstep Begin
				value3= shift-back;
				Value4 = Currentbar - value3;
				//res=highMapBuffer[shift-back];
				res=highMapBuffer[value4];
				If res <> 0 and res < val then Begin
					//highMapBuffer[shift - back] = 0.0;
					highMapBuffer[value4] = 0.0;
				End;
			End;
		End;
	End; 
	If High[shiftago] = val then Begin
		//highMapBuffer[shift] = val;
		highMapBuffer[shiftago] = val;
		End
	Else Begin
		//highMapBuffer[shift] = 0.0;
		highMapBuffer[shiftago] = 0.0;
	End;
End;
////   FINAL CUTTING
If whatlookfor = 0 then Begin
	lastlow = 0;
	lasthigh = 0;
End
Else Begin
	lastlow = curlow;
	lasthigh = curhigh;
End;
For shift = (1 + extDepth) to Currentbar Begin // 2nd loop through

	shiftago = Currentbar - shift;
	Switch (whatlookfor)
	Begin
	Case 0:  // look for peak or lawn 
		If highMapBuffer[shiftago] <> 0 then Begin
			lasthigh = High[shiftago];
			lasthighpos = shiftago;
			whatlookfor = -1;
			zigzagBuffer[shiftago] = lasthigh;
		End;
		If lowMapBuffer[shiftago] <> 0 then Begin
			lastlow = Low[shiftago];
			lastlowpos = shiftago;
			whatlookfor = 1;
			zigzagBuffer[shiftago] = lastlow;
		End;
		Break;
	Case 1:   // look for peak
		If (lowMapBuffer[shiftago] <> 0 And lowMapBuffer[shiftago] < lastlow And highMapBuffer[shiftago] = 0.0) then Begin
			zigzagBuffer[lastlowpos] = 0.0;
			lastlowpos = shiftago;
			lastlow = lowMapBuffer[shiftago];
			zigzagBuffer[shiftago] = lastlow;
		End;
		If (highMapBuffer[shiftago] <> 0 And lowMapBuffer[shiftago] = 0.0) then Begin
			lasthigh = highMapBuffer[shiftago];
			lasthighpos = shiftago;
			zigzagBuffer[shiftago] = lasthigh;
			whatlookfor = -1;
		End;
		Break;	
	Case -1:  // look for lawn
		If (highMapBuffer[shiftago] <> 0 And highMapBuffer[shiftago] > lasthigh And lowMapBuffer[shiftago] = 0.0) then Begin
			zigzagBuffer[lasthighpos] = 0.0;
			lasthighpos = shiftago;
			lasthigh = highMapBuffer[shiftago];
			zigzagBuffer[shiftago] = lasthigh;
		End;
		If (lowMapBuffer[shiftago] <> 0 And highMapBuffer[shiftago] = 0.0) then Begin
			lastlow = lowMapBuffer[shiftago];
			lastlowpos = shiftago;
			zigzagBuffer[shiftago] = lastlow;
			whatlookfor = 1;
		End;
		Break;
	End;  // end of case begin
If zigzagBuffer[shiftago] <> 0.0 then Begin
	If zigzagago > 0.0 then begin
		If zigzagBuffer[shiftago] > zigzagago then begin  // zigzag is up
		    IDdn=0;
		    If zzupstartpr=0 then begin
		    	// set begin zigzag vars
		    	zzupstartpr = zigzagago;
		    	zzupstartbar = zigzagagobar;

		    	//  reset zzdn vars
		    	zzdnstartpr=0;
		    	zzdnstartbar=0;
		    End;
	    	If IDup <> 0 then TL_Delete(IDup);
		    IDup = TL_New(date[zzupstartbar],time[zzupstartbar], zzupstartpr, date[shiftago], Time[shiftago], zigzagBuffer[shiftago]);
			If IDup > 0 then Begin
				TL_SetColor(IDup, Green);
				TL_SetSize(IDup, 1);
			End;



		End  /// end of zigzag is up

		Else Begin	// zigzag is down
		    IDup=0;
;
			If zzdnstartpr = 0 then begin
				// set begin ZZ vars
				zzdnstartpr = zigzagago;
				zzdnstartbar = zigzagagobar;
				// reset ZZUP vars
				zzupstartpr=0;
				zzupstartbar=0;
			End;

		    If IDdn <> 0 then TL_Delete(IDdn);
		    IDdn = TL_New(date[zzdnstartbar],time[zzdnstartbar], zzdnstartpr, date[shiftago], Time[shiftago], zigzagBuffer[shiftago]);
			If IDdn > 0 then begin
				TL_SetColor(IDdn, Red);
				TL_SetSize(IDdn, 1);
			End;


		End;
	End  // endzigzagago <> 0.0
	Else Begin  //   endzigzagago = 0.0 so this is first on chart
		//Print("Starting zigzag");
	End;
//print(Date[shiftago]," ",Time[shiftago]," ","IDup = ",IDup," IDdn = ",IDdn);
	zigzagago = zigzagBuffer[shiftago];
	zigzagagobar = shiftago;
End;
//If zigzagBuffer[shiftago] <> 0.0 then Print(Date[shiftago]," ",Time[shiftago]," END - zigzagBuffer[shiftago] = ",zigzagBuffer[shiftago]:0:4," shiftago = ",shiftago);
End;  // End of For Shift 2nd loop
End;  // end of lastbaronchart = 1

Share this post


Link to post
Share on other sites
  tradingbigboy said:
Hi hth!

Thank you so much for your reply. I figured out how to use the Global Dictionary to share values but need to rework this code for ZigZags as I need to reference values of it BEFORE the lastbaronchart in order to use values in strategies etc. I can take the lastbaronchart and uncomment it BUT it gets VERY expensive in computation to do this each bar and really shouldn't be calculating always from the beginning but should retain values from past calculations. I don't know how this is done in easy langauge but I'm sure you know. Yes I would love to first make it efficient THEN put it into a method as you say but I'm not a OOP guy. In fact I switched back to easy language partly because Java was killing me. I did manage to port this zigzag over correctly and thought I was golden. :( Anyway thank you so much for your help here.

 

 

 

Think of ‘it’s not really OOP’ so much as it is EOP (event oriented programming)...

 

Think of methods as a way of putting function calls ‘in-line’ ... after initial ‘learning curve’, etc. I find them much easier to debug,etc.

 

Think of vectors as a way of storing an array with multiple ‘data’ types in it... once you get the ‘read’ and 'write' syntax down, they are just as manageable and usable as arrays

 

hth

Share this post


Link to post
Share on other sites

Thank HTH,

 

So before I go down this path, let me ask a few questions about methods. First they must be called in the analysis or strategy and the code must be placed there, yes?

 

If so, then the analysis or strategy that seeks to utilize multiple time frames must have that time frame as a 2nd symbol on the chart, correct?

 

OR, can a method in a different chart somehow share info with an analysis or strategy on a different chart using some type of global variables in this method, or would it end up also using the global dictionary to accomplish this??

 

Thank you!! The easylanguage helps on the internet rarely give help to programming in the new OOP additions to easylanguage so there are almost no examples of how to do this stuff.

 

TTB

Share this post


Link to post
Share on other sites

TTB,

 

re: ""... in the new OOP additions to easylanguage so there are almost no examples of how to do this stuff."

 

Omg It’s worse than that. ... and now they’ve had years to build some good instructions... and haven’t...

For adequate beginner coverage of OOEL, look for OOEL+Concepts_AndroidMarvin.pdf in TS Forum. If you can’t get or find it, pm me with an email address and I will attach a copy to you.

 

re: "Methods... must be called in the analysis or strategy and the code must be placed there...? "

Yes. All method code is placed after procedural level declarations , etc. and before procedure code.

 

re: "If so, then the analysis or strategy that seeks to utilize multiple time frames must have that time frame as a 2nd symbol on the chart, correct?

 

OR, can a method in a different chart somehow share info with an analysis or strategy on a different chart "

Either would work... ultimately depends on your design preferences and requirements. How many timeframes are involved?

 

re: "different chart ... using the global dictionary to accomplish this??"

Global dictionary has some little wierdnesses but can ultimately be designed to run like a global vector. If I remember correctly, the pdf mentioned above uses zigs in his global dictionary example

 

hth

 

zdo

Share this post


Link to post
Share on other sites

Hi hth,

 

Yes I'm using at minimum 2 different time frames on a chart plus another symbol as I'm doing some divergence analysis as well. In fact for some reason one of my indies won't run with a forex and stock on the same chart so have to run that in a different chart so it gets complicated and yes I would like to figure out how to have this data wherever I need it.

 

Perhaps it needs to be a OOEL method placed in a function?

 

Thanks for your help!

TBB

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

    • HLF Herbalife stock, watch for a bull flag breakout above 9.02 at https://stockconsultant.com/?HLF
    • Date: 1st April 2025.   Will Gold’s Rally Hold Strong as New Trade Tariffs Take Effect Tomorrow?   Gold continues to increase in value for a sixth consecutive day and is trading more than 17% higher in 2025. Amid fear of higher inflation, a recession and the tariffs war escalating investors continue to invest into Gold pushing demand higher. The trade policy from April 2nd onwards continues to be a key factor for the whole market. Can Gold maintain its upward trend? Trade Policy From Tomorrow Onwards Starting as soon as tomorrow, a 25% tariff will be imposed on all passenger cars imported into the United States. While this White House policy is anticipated to negatively affect European industrial performance, it will also lead to higher transportation and maintenance costs for everyday American taxpayers. The negative impact expected on both the EU and US is one of the reasons investors continue to buy Gold. Additionally, last month, President Donald Trump announced reciprocal sanctions against any trade partners that impose import restrictions on US goods. Furthermore, tariffs on products from Canada and the EU could increase even more if they attempt to coordinate a response. Overall, investors continue to worry that new trade barriers will prompt retaliatory measures, particularly from China, the Eurozone, and Japan. Any retaliation is likely to escalate the trade conflict and prompt another reaction from the US. Experts at Goldman Sachs and other investment banks warn that this will lead to rising inflation and unemployment. They also caution that it could effectively halt economic growth in the US.   XAUUSD 1-Hour Chart   The Weakness In The US Dollar Another factor which is allowing the price of XAUUSD to increase in value is the US Dollar which has been unable to maintain any bullish momentum. Despite last week’s Core PCE Price Index rising to its highest level since February 2024, the US Dollar has been unable to see any significant rise in value. Due to the US Dollar and Gold's inverse correlation, the price of Gold is benefiting from the Dollar weakness. Investors worry that new trade barriers will prompt retaliatory measures from China, the Eurozone, and Japan, potentially escalating the conflict. Experts at The Goldman Sachs Group Inc. believe that such actions by the US administration will drive rising inflation and unemployment while effectively halting economic growth in the country. Can Gold Maintain Momentum? When it comes to technical analysis, the price of Gold is not trading at a price where oscillators are indicating the instrument is overbought. The Relative Strength Index currently trades at 68.88, outside of the overbought area, since Gold’s price fell 0.65% during this morning’s session. However, even with this decline, the price still remains 0.40% higher than the day’s open price. In terms of fundamental analysis, there continues to be plenty of factors indicating the price could continue to rise. However, the price movement of the week will also partially depend on the employment data from the US. The US is due to release the JOLTS Job Vacancies for February this afternoon, the ADP Non-Farm Employment Change tomorrow, and the NFP Change and Unemployment Rate on Friday. If all data reads higher than expectations, investors may look to sell to lock in profits at the high price. Key Takeaway Points: Gold’s Rally Continues – Up 17% in 2025 as investors seek safety from inflation, recession fears, and trade tensions. Trade War Impact – New US tariffs and potential retaliation from China, the EU, and Japan drive uncertainty, boosting Gold demand. Weak US Dollar – The Dollar’s struggle supports Gold’s rise due to their inverse correlation. Gold’s Outlook – Uptrend may continue, but US jobs data could trigger profit-taking. 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.
    • Date: 31st March 2025.   Trump Confirms Tariffs on All Countries, Sending Stocks Lower.   The NASDAQ continues to trade lower due to the US confirming the latest tariffs will be on all countries. In addition to this, bearish volatility also is largely due to the higher inflation data from Friday. The NASDAQ declines to its lowest price since September 11th 2024. Core PCE Price Index - Inflation Increases Again! The PCE Price Index read 2.5% aligning with expert forecasts not triggering any alarm bells. However, the Core PCE Price Index rose from 0.3% to 0.4% MoM and from 2.7% to 2.8% YoY, signalling growing inflationary pressure. This increases the likelihood that the Federal Reserve will maintain elevated interest rates for an extended period. The NASDAQ fell 2.60% due to the higher inflation reading which is known to pressure the stock market due to pressure on consumer demand and a more hawkish Federal Reserve. Boston Fed President Susan Collins recently commented that tariffs could drive up inflation, though the long-term impact remains uncertain. She told journalists that a short-term spike is the most probable outcome but believes the current pause in monetary policy adjustments is appropriate given the prevailing uncertainties. Although, certain investment banks such as JP Morgan actually believe the Federal Reserve will be forced into cutting rates. This is due to expectations that the economy will struggle under the new trade policy. For example, JP Morgan expects the Federal Reserve to delay rate cuts but will quickly cut towards the end of 2025. Market Risk Appetite Takes a Hit! A big factor for the day is the drop in the risk appetite of investors. This can be seen from the VIX which is up almost 6%, Gold which is trading 1.30% higher and the Japanese Yen which is the day’s best performing currency. Most safe haven assets, bar the US Dollar, increase in value. It is also worth noting that all indices are decreasing in value during this morning's Asian session with the Nikkei225 and NASDAQ witnessing the strongest decline. Previously the stock market rose in value as investors heard rumours that tariffs would only be on certain countries. This bullish swing occurred between March 14th and 25th. Over the weekend, President Donald Trump indicated that the upcoming tariffs would apply to all countries, not just those with the largest trade imbalances with the US. NASDAQ - Technical Analysis In terms of technical analysis, the NASDAQ continues to obtain indications that sellers control the price action. The price opens on a bearish price gap measuring 0.30% and trades below all Moving Averages on all timeframes. The NASDAQ also trades below the VWAP and almost 100% of the most influential components (stocks) are declining in value.     The next significant support level is at $18,313, and the resistance level stands at $20,367.95. Key Takeaway Points: NASDAQ falls to its lowest since September 2024 as the US confirms tariffs on all countries, adding to inflation concerns. Core PCE inflation rises to 0.4% MoM and 2.8% YoY, increasing the likelihood of prolonged high interest rates. Investor risk appetite drops as VIX jumps 6%, gold gains 1.3%, and safe-haven assets outperform. NASDAQ shows strong bearish momentum, trading below key technical levels with support at $18,313 and resistance at $20,367.95. 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.
    • PM Philip Morris stock, top of range breakout at https://stockconsultant.com/?PM
    • EXC Exelon stock, nice range breakout at https://stockconsultant.com/?EXC
×
×
  • Create New...

Important Information

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