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.

dupaski

"Rebase" function in Tradestation

Recommended Posts

I came across the following chart on a blog (it was Teresa Lo's site). I've been trying to do this in Investor RT for a few weeks now and can only get it to a ratio chart with my primary frame of reference as a line chart.

 

I really like how it appears that Tradestation can reference the benchmark as a zero line, but I can't seem to fins anyplace else that references the "rebase" on the chart. Is that merely what the author has named the function, and if so what is the function I would be able to research in Tradestation to learn more about this.

 

Also, if anyone knows IRT and can point out how I would be able to accomplish this on that platform I would also be grateful.

 

Thanks

-Derek

01-sectors.thumb.gif.0c36ba05001e8942c7501483f257f2f0.gif

Share this post


Link to post
Share on other sites
what is the function I would be able to research in Tradestation to learn more about this
Don't know anything about IRT but Rebase is not a built in function or indicator in TS. If your read T Lo, :
The thesis is simple. Identify sectors that begin to outperform the benchmark, get on board and rotate out when the greatest fool is securely on board. Identify sectors that have been totally beaten down and buy after all the weak longs have puked.

 

Start with a rebased chart. In this example, the S&P 500 Index is our benchmark. We plot the nine Sector SPDRs (utilities are missing for now, because my code is out at Sean’s to fix) and look at the performance since the beginning of this year.

TS allows you to insert multiple symbols as datastreams into subgraphs in a chart (as data1, data2 ....) and you can calculate a new stream output for each data in the bottom subgraph using a baseline number from eg 1/1/07 in this case. It looks like that is what Rebase is: a simple indicator calculating a ratio starting in the new year of each data to the first trading day of the year, for each sector listed.

 

If you are using IRT, you just have to find out if IRT supports inserting multiple symbols into a chart and calculate the data and output that into a subgraph or a new chart.

 

There is no reason to do this all in one chart, it just makes it easier to see the whole picture in comparing the nine sectors listed.

Share this post


Link to post
Share on other sites

Thank you for the response.

 

So the chart attached above is showing how each sector did in relation to the price of the S&P on 1/1/07?

 

The article seemed to indicate that crossing the 0 line showed outperformance of the S&P and I just assumed it was year to date, (i.e. a change in a sectors price was in relation to the change in the S&P day over day). In that scenario, if the index rose 1% and one of the SPDRs rose 1% over the same period it would register as a 0%.

 

IRT will allow for the plotting of multiple instruments on the same scale as a percentage change so I may be able to do this with that combo. It almost seems that this would be easier to do in excel.

 

 

-Derek

Share this post


Link to post
Share on other sites
IRT will allow for the plotting of multiple instruments on the same scale as a percentage change so I may be able to do this with that combo
Good luck with your efforts in IRT. Here is an example of TS code that will do this:

//A look at sector rotation, plot the nine Sector SPDRs vs base line, start at 1st of the year, changeable.
INPUTS: 
MyDate(1070103),
DataNum(9); // match this with number of Datastreams;  also chart limit array set at 24

Var:
Num (0);
Array:
CloseData[24] (0);

For Num = 1 to DataNum
begin
 If date = MyDate then CloseData[num] = Close of data(num);  // assign the start date close value
end;

If date >= MyDate then
begin	
plot1 (Close of Data(1)/ CloseData[1] - 1, "Clo1" , Blue );
plot2 (Close of Data(2)/ CloseData[2] - 1, "Clo2" , Cyan );
plot3 (Close of Data(3)/ CloseData[3] - 1, "Clo3" , Red  );
plot4 (Close of Data(4)/ CloseData[4] - 1, "Clo4" , Green );
plot5 (Close of Data(5)/ CloseData[5] - 1, "Clo6" , DarkBlue);
plot6 (Close of Data(6)/ CloseData[6] - 1, "Clo6" , Magenta );
plot7 (Close of Data(7)/ CloseData[7] - 1, "Clo7" , DarkGray);
plot8 (Close of Data(8)/ CloseData[8] - 1, "Clo8" , DarkRed );
plot9 (Close of Data(9)/ CloseData[9] - 1, "Clo9" , DarkBrown);
end;

 

Sample output, top 6 symbols cut off and not shown.

attachment.php?attachmentid=4384&stc=1&d=1197175958

5aa70e2937569_NineSectorSPDRs2007-12-08_234609.png.67b87808bafc24e7385d4bfc771881dc.png

5aa70e293ac76_NineSectorLookup2007-12-08_234640.png.2992877a965cfdb1299bf629a4637df6.png

Share this post


Link to post
Share on other sites

This is an awesome idea. I am wondering what changes do I have to make to utilize this intraday with like 2min or 5min charts and where all the sectors start together at the beginning of the day and spread from there intraday? Any help out there? Thanks

Share this post


Link to post
Share on other sites

janlani,

 

using thrunner's code you could probably do something like

in

inputs

change

myDate(nDate) to MyTime(0930),

 

and change

If date = MyDate then... to

if time = MyTime

 

and change

If date >= MyDate then to

if time > MyTime {and barstatus(1) = 2 {if you only need it to update at end of bar}} then...

 

and it should take off at the opening from 'rebase'

 

hth

 

zdo

Share this post


Link to post
Share on other sites

I keep on getting cannot divide by zero errors when activating it in tradestation. What am i doing wrong? I have all nine ETF loaded into the page..... Hmmmm stuck.

 

--------------------------------------------------------------------------------

 

//A look at sector rotation, plot the nine Sector SPDRs vs base line, start at 1st of the year, changeable.

INPUTS:

MyTime(0930),

DataNum(9); // match this with number of Datastreams; also chart limit array set at 24

 

Var:

Num (0);

Array:

CloseData[24] (0);

 

For Num = 1 to DataNum

begin

If time = MyTime then

CloseData[num] = Close of data(num); // assign the start date close value

end;

 

If time > MyTime then

begin

plot1 (Close of Data(1)/ CloseData[1] - 1, "Clo1" , Blue );

plot2 (Close of Data(2)/ CloseData[2] - 1, "Clo2" , Cyan );

plot3 (Close of Data(3)/ CloseData[3] - 1, "Clo3" , Red );

plot4 (Close of Data(4)/ CloseData[4] - 1, "Clo4" , Green );

plot5 (Close of Data(5)/ CloseData[5] - 1, "Clo5" , DarkBlue);

plot6 (Close of Data(6)/ CloseData[6] - 1, "Clo6" , Magenta );

plot7 (Close of Data(7)/ CloseData[7] - 1, "Clo7" , DarkGray);

plot8 (Close of Data(8)/ CloseData[8] - 1, "Clo8" , DarkRed );

plot9 (Close of Data(9)/ CloseData[9] - 1, "Clo9" , DarkBrown);

end;

Share this post


Link to post
Share on other sites

The market opens at 09:30 EST. Since TS based it's timestamps on the close of the bar, the first bar will have time past 0930. If you trade 5 minute bars, the fist bar will have a timestamp of 0935. So your if statement is never true and CloseData[num] is always 0.

 

Change Mytime(0930) to MyTime(0935) in the case of 5 minute bars. If it is three minute bars, then change it to 0933, etc.

 

Since this will be evaluated at the end of the first bar now, you want to know what the open of the first bar was to rebase, so your for loop should be:

For Num = 1 to DataNum 
begin
If time = MyTime then 
CloseData[num] = Open of data(num); // assign the start date close value 
end; 

 

Also, since you are in TX and in Central timezone, make sure your charts are not setup to run in Central Time. If so, then market opens at 0830 for you in TX when it is 0930 in NY.

Share this post


Link to post
Share on other sites

Sevensa,

I really appreciate your time and help. I made the changes but still receive the divide by zero error regardless if I use 0830 or 0832 with 2min charts of the etf's on the page. Yes, my charts start off at 8:30am (adjusted to my time zone). I am not sure why I am getting stuck still?????

 

 

//A look at sector rotation, plot the nine Sector SPDRs vs base line, start at 1st of the year, changeable.

INPUTS:

MyTime(0832),

DataNum(9); // match this with number of Datastreams; also chart limit array set at 24

 

Var:

Num (0);

Array:

CloseData[24] (0);

 

For Num = 1 to DataNum

begin

If time = MyTime then

CloseData[num] = Open of data(num); // assign the start date close value

end;

 

If time > MyTime then

begin

plot1 (Close of Data(1)/ CloseData[1] - 1, "Clo1" , Blue );

plot2 (Close of Data(2)/ CloseData[2] - 1, "Clo2" , Cyan );

plot3 (Close of Data(3)/ CloseData[3] - 1, "Clo3" , Red );

plot4 (Close of Data(4)/ CloseData[4] - 1, "Clo4" , Green );

plot5 (Close of Data(5)/ CloseData[5] - 1, "Clo5" , DarkBlue);

plot6 (Close of Data(6)/ CloseData[6] - 1, "Clo6" , Magenta );

plot7 (Close of Data(7)/ CloseData[7] - 1, "Clo7" , DarkGray);

plot8 (Close of Data(8)/ CloseData[8] - 1, "Clo8" , DarkRed );

plot9 (Close of Data(9)/ CloseData[9] - 1, "Clo9" , DarkBrown);

end;

Share this post


Link to post
Share on other sites

Well the error is obviously that at least one of your CloseData[num] values is 0. All I can suggest is to look at the actual charts for each of the datastreams and confirm that they all really have a 0832 bar and that the close value is not zero.

Share this post


Link to post
Share on other sites

don’t have much time here and already closed TS down but

1 use iff or related conditions to make sure each of the closeData[n] is not zero and if it is, assign an appropriate value to it ie make sure each of the data streams actually has a value at 830 etc

 

2 make sure your data starts soon enough to have large enough number of records by 830 and maybe use currentbar condition - this prob not an issue here but...

 

If you need it, hopefully someone can help you over the weekend.

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: 21st February 2025.   European PMI Disappoint, Weighing on Euro Before German Elections   The Euro is the first currency to witness the volatility on this month’s PMI reports. The French, German and British PMI data have resulted in the Euro being the worst-performing currency of the European Session so far. However, will the Euro continue to decline throughout the day? European Purchasing Managers’ Indexes The French Purchasing Managers Index was the first European index to be made public. The release resulted in the Euro instantly declining 0.24%. The main concern from the French data was the Services PMI which fell from 48.2 to 44.5. Previously the market was expecting the data to remain more or less unchanged. The weak data triggered the decline which came to a halt after Germany’s PMI was released.     The German Manufacturing PMI read 0.5 points higher than previous expectations and the Services PMI was 0.2 points lower. The data from Germany was a relief for Euro investors and the price rose 0.12% higher. However, traders should note that the price of the EURUSD continues to remain 0.20% lower than yesterday’s close. The price of the EURUSD will now depend on the PMI data from the US. The value of the US Dollar will depend on its PMI release this afternoon and the Consumer Sentiment Index. Analysts expect both the US Services and Manufacturing PMI data to remain above the 50.00 level in the expansion zone. German Elections 2 Days Away Germany is set to hold a general election this Sunday, February 23rd, following the collapse of the coalition of social democrats, liberals, and greens. Given the country's highly proportional electoral system, German polls provide a strong indication of potential government formations post-election. The main concern for Germany is the AFD party who are Far-Right Nationalists. Currently, ahead in the polls are CDU (centre-right), and AFD (far right), followed by the SPD (centre-left). Traders should note that the results of the elections are likely to trigger strong volatility on Monday, but also influence volatility today. Economists may become further concerned if the far-right gains power for the first time due to uncertainty. If the government, similar to France, is unable to form a coalition, this would also be a concern for the Eurozone. Furthermore, the Euro this week is also under pressure from comments from members of the European Central Bank. ECB Governing Council member Fabio Panetta said to journalists that officials need not slow interest rate cuts, as January's 2.5% inflation is still expected to reach the 2.0% target this year. He also advised the European economy is weaker than previously expected. EURUSD - Technical Analysis and Indicators The EURUSD is trading above the 75-bar Exponential Moving Average and 100-bar Simple Moving Average on the 2-hour chart. However, the price is moving away from the key resistance level at 1.05058 indicating the price is losing momentum. The short-term volatility is indicating the price is retracing downwards. On the 5-minute timeframe, the price is trading below the 200-bar SMA and is also forming clear lower lows and highs. Simultaneously, the US Dollar Index is trading above the 200-bar SMA on the 5-minute chart confirming no current conflicts. Currently, the US Dollar is the best-performing currency of the day attempting to regain losses from the past 2 weeks. Watch today’s Live Analysis Session for more signals as they develop!   Key Takeaway Points: Weak French Services PMI triggered an initial Euro decline, but German PMI provide a slight relief. However, EURUSD remains lower than yesterday’s close. The Euro’s direction now depends on the US PMI reports, with analysts expecting US data to stay in expansion territory. Sunday's German election could drive volatility, especially if the far-right AFD gains power or if coalition formation proves difficult. ECB official Fabio Panetta suggested no need to slow rate cuts, citing weaker-than-expected economic performance and expected inflation decline. 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.
    • BE Bloom Energy stock, watch for a range breakout, target 34 area at https://stockconsultant.com/?BE
    • APLD Applied Digital stock. nice rally, watch for a top of range breakout at https://stockconsultant.com/?APLD
    • UAL United Airlines stock, watch for a narrow range breakout, target 122 area at https://stockconsultant.com/?UAL
    • WBD Warner Bros Discovery stock, watch for a range breakout at https://stockconsultant.com/?WBD
×
×
  • Create New...

Important Information

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