Logo
Fully annotated reference manual - version 1.8.12
All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Modules Pages
trace.hpp
Go to the documentation of this file.
1/*
2 Copyright (C) 2016 Quaternion Risk Management Ltd
3 All rights reserved.
4
5 This file is part of ORE, a free-software/open-source library
6 for transparent pricing and risk analysis - http://opensourcerisk.org
7
8 ORE is free software: you can redistribute it and/or modify it
9 under the terms of the Modified BSD License. You should have received a
10 copy of the license along with this program.
11 The license is also available online at <http://opensourcerisk.org>
12
13 This program is distributed on the basis that it will form a useful
14 contribution to risk analytics and model standardisation, but WITHOUT
15 ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
16 FITNESS FOR A PARTICULAR PURPOSE. See the license for more details.
17*/
18
19/*! \file trace.hpp
20 \brief trace of a quadratic matrix
21 \ingroup math
22*/
23
24#ifndef quantext_trace_hpp
25#define quantext_trace_hpp
26
27#include <ql/math/matrix.hpp>
28
29namespace QuantExt {
30using QuantLib::Matrix;
31using QuantLib::Real;
32using QuantLib::Size;
33
34inline Real Trace(const Matrix& m) {
35 QL_REQUIRE(m.rows() == m.columns(), "Trace: input matrix must be quadratic");
36 Real t = 0.0;
37 for (Size i = 0; i < m.rows(); ++i)
38 t += m[i][i];
39 return t;
40}
41
42} // namespace QuantExt
43
44#endif
Real Trace(const Matrix &m)
Definition: trace.hpp:34