[R-SIG-Finance] trouble with timeSequence
Yohan Chalabi
chalabi at phys.ethz.ch
Tue Sep 21 18:30:00 CEST 2010
On Sep 21, 2010, at 5:55 PM, Mercurio Danilo 1850 SPI wrote:
> Hi!
>
> I was trying to use the function "timeSequence" in order to generate a sequence of dates at 6 months frequency but I could not.
>
> In order to obtain 3 month frequency I wrote this:
>
> ----------------
> timeSequence(from = "1999-12-31", to = "2000-12-31", by = "quarter")
> ------------
>
> which delivers the exact output:
>
> ----------
> GMT
> [1] [1999-12-31] [2000-03-31] [2000-07-01] [2000-10-01] [2000-12-31]
> ------------
>
> If I try to obtain the 6 month frequency, I write the following (after having read the help file):
>
> ---------------------------------
> timeSequence(from = "1999-12-31", to = "2000-12-31", by = "6 months")
> -----------------------------
>
> which returns:
> ----------------------
> error in match.arg(by) :
> 'arg' should be one of "day", "year", "quarter", "month", "week", "hour", "min", "sec"
> ---------------------
>
> so I took a look to the code behind the function 'timeSequence' (see below).
> The function "match.arg(by)" checks that "by" equals one of:
> "day", "year", "quarter", "month", "week", "hour", "min", "sec"
>
> however the computation (as far as I understood) is made by another function (?): "seq.timeDate" which apparently accepts
> the value " by = "3 months" ".
Hi,
try fhe following
td1 <- timeDate("1999-12-31")
td2 <- timeDate("2000-12-31")
seq(td1, td2, by = "6 months")
HTH
Yohan
>
> What puzzles me is that whe I try to call the function "seq.timeDate" R answers me that it cannot find it.
>
> Of course I could be able to construct a time sequence with 6 month frequency with some workaround, however I would like
> to understand the problem a little more.
>
> Thank you for any help!
>
> Kind regards
>
> Danilo
>
> -------------------------------------------------------------------------------------------------------------------
>> timeSequence
> function (from, to = Sys.timeDate(), by = c("day", "year", "quarter",
> "month", "week", "hour", "min", "sec"), length.out = NULL,
> format = NULL, zone = "", FinCenter = "")
> {
> if (zone == "")
> zone <- getRmetricsOptions("myFinCenter")
> if (FinCenter == "")
> FinCenter <- getRmetricsOptions("myFinCenter")
> if (missing(from))
> from = timeDate(to, format = format, zone = zone, FinCenter = FinCenter) -
> 24 * 29 * 3600
> if (!is.null(length.out))
> to = from
> by = match.arg(by)
> if (by == "quarter")
> by = "3 months"
> format.from = format.to = format
> if (is.null(format)) {
> format.from = whichFormat(as.character(from))
> format.to = whichFormat(as.character(to))
> from <- timeDate(from, format = format.from, zone = zone,
> FinCenter = FinCenter)
> to <- timeDate(to, format = format.to, zone = zone, FinCenter = FinCenter)
> }
> else {
> from <- timeDate(from, format = format, zone = zone,
> FinCenter = FinCenter)
> to <- timeDate(to, format = format, zone = zone, FinCenter = FinCenter)
> }
> tseq <- if (length(length.out))
> seq.timeDate(from = from, by = by, length.out = length.out)
> else seq.timeDate(from = from, to = to, by = by)
> tseq
> }
>
> Dr. Danilo Mercurio
> Quantitative Analyst
> Erste Sparinvest
> Global Strategies and Research
> Habsburgergasse 2
> A-1010 Wien
> Tel.: +43 (0) 50100 - 19957
> Fax.: +43 (0) 50100 9 - 19957
> Mob.: +43 (0) 50100 6 - 19957
>
> _______________________________________________
> R-SIG-Finance at stat.math.ethz.ch 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.
>
--
PhD candidate
Swiss Federal Institute of Technology
Zurich
www.ethz.ch
More information about the R-SIG-Finance
mailing list