/usr/include/ql/time/imm.hpp is in libquantlib0-dev 1.7.1-1.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 | /* -*- mode: c++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
/*
Copyright (C) 2000, 2001, 2002, 2003 RiskMap srl
Copyright (C) 2003, 2004, 2005, 2006, 2007 StatPro Italia srl
Copyright (C) 2004, 2005, 2006 Ferdinando Ametrano
Copyright (C) 2006 Katiuscia Manzoni
This file is part of QuantLib, a free-software/open-source library
for financial quantitative analysts and developers - http://quantlib.org/
QuantLib is free software: you can redistribute it and/or modify it
under the terms of the QuantLib license. You should have received a
copy of the license along with this program; if not, please email
<quantlib-dev@lists.sf.net>. The license is also available online at
<http://quantlib.org/license.shtml>.
This program is distributed in the hope that it will be useful, but WITHOUT
ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
FOR A PARTICULAR PURPOSE. See the license for more details.
*/
/*! \file imm.hpp
\brief IMM-related date functions
*/
#ifndef quantlib_imm_hpp
#define quantlib_imm_hpp
#include <ql/time/date.hpp>
namespace QuantLib {
//! Main cycle of the International %Money Market (a.k.a. %IMM) months
struct IMM {
enum Month { F = 1, G = 2, H = 3,
J = 4, K = 5, M = 6,
N = 7, Q = 8, U = 9,
V = 10, X = 11, Z = 12 };
//! returns whether or not the given date is an IMM date
static bool isIMMdate(const Date& d,
bool mainCycle = true);
//! returns whether or not the given string is an IMM code
static bool isIMMcode(const std::string& in,
bool mainCycle = true);
/*! returns the IMM code for the given date
(e.g. H3 for March 20th, 2013).
\warning It raises an exception if the input
date is not an IMM date
*/
static std::string code(const Date& immDate);
/*! returns the IMM date for the given IMM code
(e.g. March 20th, 2013 for H3).
\warning It raises an exception if the input
string is not an IMM code
*/
static Date date(const std::string& immCode,
const Date& referenceDate = Date());
//! next IMM date following the given date
/*! returns the 1st delivery date for next contract listed in the
International Money Market section of the Chicago Mercantile
Exchange.
*/
static Date nextDate(const Date& d = Date(),
bool mainCycle = true);
//! next IMM date following the given IMM code
/*! returns the 1st delivery date for next contract listed in the
International Money Market section of the Chicago Mercantile
Exchange.
*/
static Date nextDate(const std::string& immCode,
bool mainCycle = true,
const Date& referenceDate = Date());
//! next IMM code following the given date
/*! returns the IMM code for next contract listed in the
International Money Market section of the Chicago Mercantile
Exchange.
*/
static std::string nextCode(const Date& d = Date(),
bool mainCycle = true);
//! next IMM code following the given code
/*! returns the IMM code for next contract listed in the
International Money Market section of the Chicago Mercantile
Exchange.
*/
static std::string nextCode(const std::string& immCode,
bool mainCycle = true,
const Date& referenceDate = Date());
};
}
#endif
|