R- програмиране - Грешка в get.current.chob() : неправилно зададено или липсващо графично устройство

library(quantmod)
getSymbols("LT.NS")
plot(LT.NS["2013-12-01::2014-12-01"])
close<-Cl(LT.NS["2013-12-01::2014-12-01"])
open<-Op(LT.NS["2013-12-01::2014-12-01"])
close<-as.matrix(close)
open<-as.matrix(open)
bbands<-addBBands(n=20,sd=2)
values_bbands<[email protected]
values_bbands[is.na(values_bbands)]<-0
bbands<-as.matrix(values_bbands)
up<-bbands[,1]
up<-as.matrix(up)
down<-bbands[,3]
down<-as.matrix(down)
data<-read.table("c:\\temp\\dates.txt")
attach(data)
head(data)
stock<-as.matrix(data)

for(i in 131:261)
{
    if(close[i]>down[i])
    {
    print("the selling date is:")
    print(i)
    big.red.dot <- xts(open[i], as.Date(stock[i,1]))
    points(big.red.dot, col="red", pch=19, cex=0.5  )
    }
    if(close[i]<up[i])
    {
        print("the buying date is:")
        print(i)
        big.green.dot <- xts(open[i], as.Date(stock[i,1]))
        points(big.green.dot, col="green", pch=19, cex=0.5  )
    }

}

Когато стартирам този код в R, получавам „****Грешка в get.current.chob(): неправилно зададено или липсващо графично устройство“****. 2-3 пъти можех да получа изход с правилната графика със сигнали за покупка и продажба, посочени на графиката, но сега, когато стартирам кода, тази грешка се показва. Опитах го и на различна версия на R-1.3, но грешката все още се появява. В горния ми код подходящо ли е bbands‹-addBBands(n=20,sd=2)? Защото, когато стартирам кода си в отделни редове, същата грешка се показва и за този ред. Искам крайният изход да бъде графика с точки за покупка и продажба, посочени в съответните точки.


person IceIceIce    schedule 17.03.2015    source източник


Отговори (1)


Не, bbands <- addBBands(n=20,sd=2) не е подходящо.

addBBands трябва да бъде извикан за добавяне на ленти на Болинджър към вече съществуващо графично устройство, създадено от chartSeries. Можете също да го включите директно във вашето chartSeries обаждане:

library(quantmod)
getSymbols("LT.NS")
chartSeries(LT.NS, TA="addBBands(n=20)", subset="2013-12-01::2014-12-01")

Ако просто искате да изчислите Bollinger Bands, просто извикайте TTR::BBands (което прави addBBands).

bbands <- BBands(HLC(LT.NS), n=20, sd=2)

Всички останали неща, които правите, могат да бъдат направени с няколко извиквания на addPoints, след конструиране на необходимите обекти за начертаване.

# sells
sell <- Op(LT.NS)
is.na(sell) <- which(!Cl(LT.NS) > bbands$dn)
addPoints(1:nrow(sell), sell, col='red', pch=19, cex=0.5)
# buys
buy <- Op(LT.NS)
is.na(buy) <- which(!Cl(LT.NS) < bbands$up)
addPoints(1:nrow(buy), buy, col='green', pch=19, cex=0.5)

Но имайте предвид, че вашите покупки и продажби не се изключват взаимно.

> head(cbind(buy,sell))
           LT.NS.Open LT.NS.Open.1
2007-01-01     1445.9       1445.9
2007-01-02     1447.0       1447.0
2007-01-03     1458.0       1458.0
2007-01-04     1489.7       1489.7
2007-01-05     1500.0       1500.0
2007-01-08     1471.0       1471.0
person Joshua Ulrich    schedule 17.03.2015
comment
Благодаря много. @Джошуа Улрих. Това отговаря на въпроса ми. - person IceIceIce; 18.03.2015