[R-SIG-Finance] Stock Total Returns?
Joshua Ulrich
josh.m.ulrich at gmail.com
Mon Feb 20 00:22:01 CET 2012
There is also quantmod::adjustOHLC, which will provide better adjusted
OHL prices than using the Close / Adjusted Close ratio.
--
Joshua Ulrich | FOSS Trading: www.fosstrading.com
R/Finance 2012: Applied Finance with R
www.RinFinance.com
On Sat, Feb 18, 2012 at 4:44 PM, SW <kryp33 at yahoo.com> wrote:
> Hi Michael,
>
> Thanks a lot! You are right. The adjusted prices will give me the correct numbers for total returns. I kind of overlooked it.
>
> Best regards,
> Sergey
>
>
>
>
> --- On Sat, 2/18/12, R. Michael Weylandt <michael.weylandt at gmail.com> wrote:
>
>> From: R. Michael Weylandt <michael.weylandt at gmail.com>
>> Subject: Re: [R-SIG-Finance] Stock Total Returns?
>> To: "SW" <kryp33 at yahoo.com>
>> Cc: r-sig-finance at r-project.org
>> Date: Saturday, February 18, 2012, 5:27 PM
>> I think you're over-thinking this: if
>> you have adjusted prices, they
>> already incorporate splits+dividends --- so the return in
>> adjusted
>> price *is* the total return. (Up to some fuzziness in how
>> that
>> adjustment should be done)
>>
>> Michael
>>
>> On Sat, Feb 18, 2012 at 5:20 PM, SW <kryp33 at yahoo.com>
>> wrote:
>> > Hello All,
>> >
>> >
>> > I am relatively new to R and I am still not very
>> comfortable with syntactic and libraries. Is there are any
>> nice way to calculate and plot total returns for stocks
>> which I would define as change in price and paid dividends?
>> I made a code to do that but the loop that constructs
>> prices+dividends looks ugly(see code below). Any suggestions
>> to do it more efficiently? Thanks. Sergey
>> >
>> > ############## CODE
>> ##################################
>> > library(quantmod)
>> > library(PerformanceAnalytics)
>> >
>> > #Time frame
>> > dt.end = "2010-01-01"
>> > dt.start = "2007-01-01"
>> >
>> > tickers = c('SPY',
>> > 'XLY',
>> > 'XLP',
>> > 'XLE',
>> > 'XLF',
>> > 'XLV',
>> > 'XLI',
>> > 'XLB',
>> > 'XLK',
>> > 'XLU')
>> > tickers.desc = c('SNP500',
>> > 'ConsumerCyclicals',
>> > 'ConsumerStaples',
>> > 'Energy',
>> > 'Financials',
>> > 'HealthCare',
>> > 'Industrials',
>> > 'Materials',
>> > 'Technology',
>> > 'Utilities')
>> >
>> > ############ Get prices
>> ###############################
>> > setDefaults(getSymbols,
>> warnings=FALSE,auto.assign=FALSE)
>> > fnPx <- function(i) {
>> return(Ad(getSymbols(tickers[i], from=dt.start,to=dt.end)))
>> }
>> > ts = lapply(1:length(tickers), fnPx)
>> >
>> ###########################################################################
>> >
>> > ############ Get Dividends
>> ################################
>> > fnDiv<- function(i) {
>> return(getDividends(tickers[i],
>> from=dt.start,to=dt.end,auto.assign=FALSE)) }
>> > div = lapply(1:length(tickers), fnDiv)
>> >
>> ###########################################################################
>> >
>> > ########### Create Prices + Dividends (UGLY !!!!)
>> #####################
>> > fnTotPx <- function(i)
>> > {
>> > ret = ts[[i]]
>> > for(j in 1:length(div[[i]]))
>> > {
>> > row = div[[i]][j,]
>> > tm = time(row)
>> > val = as.double(row[1,1])
>> > iFwd = paste(tm,"::",sep='')
>> > iBk = paste("::",tm-1,sep='')
>> > unch = ret[iBk]
>> > chg = ret[iFwd]+val
>> > ret = rbind(unch,chg)
>> > }
>> > return(ret)
>> > }
>> > totPx = lapply(1:length(tickers), fnTotPx)
>> >
>> ############################################################################
>> >
>> >
>> > ################ Calc Total Returns
>> ##########################
>> > fnRet <- function(i) {
>> return(periodReturn(totPx[[i]],period='daily')) }
>> > ts.ret = lapply(1:length(tickers), fnRet)
>> >
>> > ################ Plot Total Returns
>> ##########################
>> > ts.ret.df = as.data.frame(ts.ret)
>> > colnames(ts.ret.df)=tickers.desc
>> > chart.CumReturns(ts.ret.df, main="Cumulative
>> Returns",geometric=FALSE,legend.loc="bottomleft")
>> >
>> ############################################################################
>> >
>> > _______________________________________________
>> > R-SIG-Finance at r-project.org
>> mailing list
>> > https://stat.ethz.ch/mailman/listinfo/r-sig-finance
>> > -- Subscriber-posting only. If you want to post,
>> subscribe first.
>> > -- Also note that this is not the r-help list where
>> general R questions should go.
>>
>
> _______________________________________________
> R-SIG-Finance at r-project.org mailing list
> https://stat.ethz.ch/mailman/listinfo/r-sig-finance
> -- Subscriber-posting only. If you want to post, subscribe first.
> -- Also note that this is not the r-help list where general R questions should go.
More information about the R-SIG-Finance
mailing list