Introduction
A wise person told me that it will be a full moon on the upcoming Valentine’s Day, but that it will be a long time until another one. I decided to check this with astronomical calculation.
Procedure
The Oce package has a function called moonAngle()
that returns, among other things, the illuminated fraction of the moon visible at any given time. This can be used to test for a full moon on Valentine’s day.
The first step is to construct the times of Valentine’s days, starting with the one this year. Then the illuminated fraction can be calculated (here, for Halifax, the lover’s capital of Canada), and that fraction can be plotted for each of the next fifty years, with red dots for the romantic times, and blue ones for the sosad ones.

times < seq(as.POSIXct("20140214"), length.out = 50, by = "year")
library(oce)

## Loading required package: methods
## Loading required package: mapproj
## Loading required package: maps

fraction < moonAngle(times, lon = 63, lat = 43)$illuminatedFraction
full < fraction > 0.99
plot(times, fraction, xlab = "Year", ylab = "Moon Illuminated Fraction", col = ifelse(full,
"red", "blue"), pch = 16, cex = 2)

Here, red has been used to indicate years with full moon on Valentine’s Day, and sad blue otherwise.
Results
Yes, it will be a long time until the next full moon on Valentine’s Day:

times[full]

## [1] "20140214 AST" "20330214 AST" "20520214 AST"
Conclusions
Buy candy now.
 Source code: 20140413valentinemoon.R
Rbloggers.com offers daily email updates about R news and tutorials on topics such as: Data science, Big Data, R jobs, visualization (ggplot2, Boxplots, maps, animation), programming (RStudio, Sweave, LaTeX, SQL, Eclipse, git, hadoop, Web Scraping) statistics (regression, PCA, time series, trading) and more...