# File dip.R
# Part of the hydroTSM R package, https://github.com/hzambran/hydroTSM ;
# https://CRAN.R-project.org/package=hydroTSM
# Copyright 2008-2017 Mauricio Zambrano-Bigiarini
# Distributed under GPL 2 or later
################################################################################
# 'dip' #
################################################################################
# Purpose: Given any starting and ending dates, it generates: #
# 1) a vector with all the days between the two dates, OR #
# 2) the amount of days between the two dates #
################################################################################
# Author : Mauricio Zambrano-Bigiarini #
# Started: 2008 #
# Updates: 29-May-2013 #
# 24-aug-2022 #
################################################################################
# 'from' : Character indicating the starting date for computing the number of dyas.
# It MUST have the date format specified by 'date.fmt'
# 'to' : Character indicating the ending date for computing the number of dyas.
# It MUST have the date format specified by 'date.fmt'
# 'date.fmt': Character indicating the date format in which you provide 'from' and 'to'. (e.g., "%d-%m-%Y")
# 'out.type': Character indicating the type of result that is given by this function.
# Valid values are:
# -) type= "seq" => a vectorial sequence with all the days within the given time period
# -) type= "nmbr" => the number of days in the vectorial sequence with all the days within the given time period
dip <- function(from, to, date.fmt="%Y-%m-%d", out.type="seq") {
# Checking 'out.type'
if (is.na(match(out.type, c("seq", "nmbr"))))
stop("Invalid argument: 'out.type' must be of class 'seq' or 'nmbr'")
# Converting 'from' into a Date object (if necessary)
if ( !inherits(from, "Date") ) {
from.bak <- from
from <- as.Date(from, format=date.fmt)
} # IF end
# Checking that 'from' is a valid Date object
if (is.na(from))
stop("Invalid argument: 'from' (", from.bak,
") is not compatible with 'date.ftm' (", date.fmt, ") !")
# Converting 'to' into a Date object (if necessary)
if ( !inherits(to, "Date") ) {
to.bak <- to
to <- as.Date(to, format=date.fmt)
} # IF end
# Checking that 'to' is a valid Date object
if (is.na(to))
stop("Invalid argument: 'to' (", to.bak,
") is not compatible with 'date.ftm' (", date.fmt, ") !")
# Checking that 'from' is lower or equal to 'to'
if (to < from) stop("Invalid argument: 'from > to' (", from, " > ", to, ")")
# Generating an Annual-regular time series of Dates.
vec.days <- seq( from=from, to=to, by="days" )
if (out.type=="seq") return(vec.days)
else if (out.type=="nmbr") return ( length(vec.days) )
} # 'dip' END
Add the following code to your website.
For more information on customizing the embed code, read Embedding Snippets.