Coverage Report

Created: 2026-01-25 06:59

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/src/quantlib/ql/math/randomnumbers/latticersg.cpp
Line
Count
Source
1
/* -*- mode: c++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
2
3
/*
4
Copyright (C) 2007 Mark Joshi
5
6
This file is part of QuantLib, a free-software/open-source library
7
for financial quantitative analysts and developers - http://quantlib.org/
8
9
QuantLib is free software: you can redistribute it and/or modify it
10
under the terms of the QuantLib license.  You should have received a
11
copy of the license along with this program; if not, please email
12
<quantlib-dev@lists.sf.net>. The license is also available online at
13
<https://www.quantlib.org/license.shtml>.
14
15
This program is distributed in the hope that it will be useful, but WITHOUT
16
ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
17
FOR A PARTICULAR PURPOSE.  See the license for more details.
18
*/
19
20
/*! \file latticersg.cpp
21
\brief lattice rule code for low discrepancy numbers
22
*/
23
24
#include <ql/math/randomnumbers/latticersg.hpp>
25
#include <utility>
26
namespace QuantLib {
27
28
    LatticeRsg::LatticeRsg(Size dimensionality, std::vector<Real> z, Size N)
29
0
    : dimensionality_(dimensionality), N_(N), z_(std::move(z)),
30
0
      sequence_(std::vector<Real>(dimensionality), 1.0) {}
31
    /*! skip to the n-th sample in the low-discrepancy sequence */
32
    void LatticeRsg::skipTo(unsigned long n)
33
0
    {
34
0
        i_+=n;
35
0
    }
36
37
    const LatticeRsg::sample_type& LatticeRsg::nextSequence()
38
0
    {
39
0
        for (Size j=0; j < dimensionality_; ++j)
40
0
        {
41
0
            Real theta = i_*z_[j]/N_;
42
0
            sequence_.value[j]= std::fmod(theta,1.0);
43
0
        }
44
0
        ++i_;
45
46
0
        return sequence_;
47
    
48
0
    }
49
50
}