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

    • In Italy, I saw many of our brothers from different parts of Africa, sleeping and living in the park, the weather was very cold and its obvious that they were looked down upon. It made me want to cry and several questions overwhelmed my heart.   Is it not better to remain in Africa than to be homeless in this freezing cold weather?   I wish I have all the money in the world to rescue them...   Is this the reason why our skin color is looked down upon?   Do our government officials see this sight when they also travel outside of the country...does it hurt them or pain them like it pained me? By Frank Abah, Quora   Profits from free accurate cryptos signals: https://www.predictmag.com/   
    • ELV Elevance Health stock, watch for an upside gap breakout at https://stockconsultant.com/?ELV
    • ORLY OReilly Automotive stock, nice top of range breakout, from Stocks to Watch at https://stockconsultant.com/?ORLY
    • Date: 28th March 2025.   Market Selloff Deepens as Tariff Concerns Weigh on Investors     Global stock markets extended their losing streak for a third day as concerns over looming US tariffs and an escalating trade war dampened investor sentiment. The flight to safety saw gold prices surge to a record high, underscoring growing risk aversion. Stock Selloff Intensifies The MSCI World Index recorded its longest losing streak in a month, while Asian equities saw their sharpest decline since late February. US and European stock futures also signalled potential weakness, while cryptocurrency markets retreated and bond yields edged lower. Investors are scaling back their exposure ahead of President Donald Trump’s expected announcement of ‘reciprocal tariffs’ on April 2. His latest move to impose a 25% levy on all foreign-made automobiles has sparked fresh concerns over inflation and economic growth, prompting traders to reassess their strategies. Investor Strategies Shift Market experts are adjusting their portfolios in anticipation of heightened volatility. ‘It’s impossible to predict Trump’s next move,’ said Xin-Yao Ng of Aberdeen Investments. ‘Our focus is on companies that are less vulnerable to tariff policies while taking advantage of market dips to find value opportunities.’ Yield Curve Signals Economic Concerns In the bond market, the spread between 30-year and 5-year US Treasury yields widened to its highest level since early 2022. Investors are bracing for potential Federal Reserve rate cuts if economic growth slows further. Long-term Treasury yields hit a one-month peak as inflation risks tied to tariffs spurred demand for higher-yielding assets. Boston Fed President Susan Collins noted that while tariffs may contribute to short-term price increases, their long-term effects remain uncertain. Gold Hits Record High as Safe-Haven Demand Rises Amid market turbulence, gold prices soared 0.7% on Friday, reaching an all-time high of $3,077.60 per ounce. Major banks have raised their price targets for the precious metal, with Goldman Sachs now forecasting gold to hit $3,300 per ounce by year-end. Looking Ahead As investors digest economic data showing US growth acceleration in Q4, attention will turn to Friday’s release of the personal consumption expenditures (PCE) price index—the Federal Reserve’s preferred inflation measure. This data will be critical in shaping expectations for future Fed policy moves. With markets on edge and trade tensions escalating, investors will closely monitor upcoming developments, particularly Trump’s tariff announcement next week, which could further dictate market direction.   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 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.
    • Crypto hype is everywhere since it also making new riches as well, i however trade crypto little as compared to other forex trading pairs.
×
×
  • Create New...

Important Information

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