/usr/include/ql/experimental/credit/issuer.hpp is in libquantlib0-dev 1.1-2build1.
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 104 105 106 | /* -*- mode: c++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
/*
Copyright (C) 2008, 2009 StatPro Italia srl
Copyright (C) 2009 Jose Aparicio
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 issuer.hpp
\brief Classes for credit-name handling.
*/
#ifndef quantlib_issuer_hpp
#define quantlib_issuer_hpp
#include <ql/experimental/credit/defaultevent.hpp>
#include <ql/experimental/credit/defaultprobabilitykey.hpp>
#include <ql/termstructures/defaulttermstructure.hpp>
#include <set>
#include <vector>
namespace QuantLib {
typedef std::set<boost::shared_ptr<DefaultEvent>,
earlier_than<boost::shared_ptr<DefaultEvent> > >
DefaultEventSet;
class Issuer {
public:
typedef std::pair<DefaultProbKey,
Handle<DefaultProbabilityTermStructure> >
key_curve_pair;
/*! The first argument represents the probability of an issuer
of having any of its bonds with the given seniority,
currency incurring in that particular event. The second
argument represents the history of past events. Theres no
check on wether the event list makes sense, events can
occur several times and several of them can take place on
the same date.
To do: add settlement event access
*/
Issuer(const std::vector<key_curve_pair>& probabilities =
std::vector<key_curve_pair>(),
const DefaultEventSet& events = DefaultEventSet());
Issuer(const std::vector<std::vector<
boost::shared_ptr<DefaultType> > >& eventTypes,
const std::vector<Currency>& currencies,
const std::vector<Seniority>& seniorities,
const std::vector<Handle<DefaultProbabilityTermStructure> >&
curves,
const DefaultEventSet& events = DefaultEventSet());
//! \name Inspectors
//@{
const Handle<DefaultProbabilityTermStructure>&
defaultProbability(const DefaultProbKey& key) const;
//@}
//! \name Utilities
//@{
//! If a default event with the required seniority and
// restructuring type is found, it is returned for
// inspection; otherwise, the method returns an empty pointer.
boost::shared_ptr<DefaultEvent>
defaultedBetween(const Date& start,
const Date& end,
const DefaultProbKey& key,
bool includeRefDate = false
) const;
//@}
std::vector<boost::shared_ptr<DefaultEvent> >
defaultsBetween(const Date& start,
const Date& end,
const DefaultProbKey& contractKey,
bool includeRefDate
) const ;
private:
//! probabilities of events for each bond collection
// vector of pairs preferred over maps for performance
std::vector<std::pair<DefaultProbKey,
Handle<DefaultProbabilityTermStructure> > > probabilities_;
//! History of past events affecting this issuer. Notice it is possible
// for the same event to occur on the same bond several times along
// time.
DefaultEventSet events_;
};
}
#endif
|