From 3964f6fd7c560a07e506c8f841cf4fe65bf2bdb9 Mon Sep 17 00:00:00 2001 From: Jonathan Sweemer Date: Sun, 28 Jul 2024 07:41:10 +0900 Subject: [PATCH] Enable C4127 at W3 warning level --- .clang-format | 4 +- cmake/Platform.cmake | 13 +++--- .../barrieroption/mcdoublebarrierengine.hpp | 6 +-- .../exoticoptions/mceverestengine.hpp | 2 +- .../exoticoptions/mchimalayaengine.hpp | 6 +-- .../exoticoptions/mcpagodaengine.hpp | 2 +- .../mclongstaffschwartzpathengine.hpp | 12 ++--- .../mcbasket/mcpathbasketengine.hpp | 2 +- .../asian/mcdiscreteasianenginebase.hpp | 6 +-- ql/pricingengines/barrier/mcbarrierengine.hpp | 6 +-- .../basket/mceuropeanbasketengine.hpp | 6 +-- .../capfloor/mchullwhiteengine.hpp | 3 +- .../cliquet/mcperformanceengine.hpp | 6 +-- .../forward/mcforwardvanillaengine.hpp | 8 ++-- .../forward/mcvarianceswapengine.hpp | 2 +- .../lookback/mclookbackengine.hpp | 2 +- .../mclongstaffschwartzengine.hpp | 2 +- ql/pricingengines/vanilla/mcvanillaengine.hpp | 6 +-- test-suite/andreasenhugevolatilityinterpl.cpp | 2 +- test-suite/nthtodefault.cpp | 46 +++++++++---------- tools/check_header.py | 2 +- 21 files changed, 71 insertions(+), 73 deletions(-) diff --git a/.clang-format b/.clang-format index 576d5319da8..047c00be4a8 100644 --- a/.clang-format +++ b/.clang-format @@ -1,6 +1,6 @@ --- Language: Cpp -Standard: c++14 +Standard: c++17 # The following is close to the style we've been using all these years @@ -33,7 +33,7 @@ PointerAlignment: Left SortIncludes: true IncludeBlocks: Merge -IncludeCategories: +IncludeCategories: - Regex: '^"' Priority: 1 - Regex: '^ - # In c++17 std::iterator is deprecated. As of boost 1.81 boost::ublas has not provided a fix for this. - add_compile_definitions(_SILENCE_CXX17_ITERATOR_BASE_CLASS_DEPRECATION_WARNING) - endif() + add_compile_options(/wd4267 /wd4819 /wd26812 /w34127) + + # Silence all C++17 deprecation warnings, same as in the vcxproj files + add_compile_definitions(_SILENCE_ALL_CXX17_DEPRECATION_WARNINGS) endif() diff --git a/ql/experimental/barrieroption/mcdoublebarrierengine.hpp b/ql/experimental/barrieroption/mcdoublebarrierengine.hpp index 1b52b098f43..08a21980396 100644 --- a/ql/experimental/barrieroption/mcdoublebarrierengine.hpp +++ b/ql/experimental/barrieroption/mcdoublebarrierengine.hpp @@ -58,9 +58,9 @@ namespace QuantLib { requiredSamples_, maxSamples_); results_.value = this->mcModel_->sampleAccumulator().mean(); - if (RNG::allowsErrorEstimate) - results_.errorEstimate = - this->mcModel_->sampleAccumulator().errorEstimate(); + if constexpr (RNG::allowsErrorEstimate) + results_.errorEstimate = + this->mcModel_->sampleAccumulator().errorEstimate(); } protected: diff --git a/ql/experimental/exoticoptions/mceverestengine.hpp b/ql/experimental/exoticoptions/mceverestengine.hpp index 722bb73ae84..07ab06ea33e 100644 --- a/ql/experimental/exoticoptions/mceverestengine.hpp +++ b/ql/experimental/exoticoptions/mceverestengine.hpp @@ -59,7 +59,7 @@ namespace QuantLib { maxSamples_); results_.value = this->mcModel_->sampleAccumulator().mean(); - if (RNG::allowsErrorEstimate) { + if constexpr (RNG::allowsErrorEstimate) { results_.errorEstimate = this->mcModel_->sampleAccumulator().errorEstimate(); } diff --git a/ql/experimental/exoticoptions/mchimalayaengine.hpp b/ql/experimental/exoticoptions/mchimalayaengine.hpp index 9d66fc94015..b56be047bcf 100644 --- a/ql/experimental/exoticoptions/mchimalayaengine.hpp +++ b/ql/experimental/exoticoptions/mchimalayaengine.hpp @@ -57,9 +57,9 @@ namespace QuantLib { maxSamples_); results_.value = this->mcModel_->sampleAccumulator().mean(); - if (RNG::allowsErrorEstimate) - results_.errorEstimate = - this->mcModel_->sampleAccumulator().errorEstimate(); + if constexpr (RNG::allowsErrorEstimate) + results_.errorEstimate = + this->mcModel_->sampleAccumulator().errorEstimate(); } private: diff --git a/ql/experimental/exoticoptions/mcpagodaengine.hpp b/ql/experimental/exoticoptions/mcpagodaengine.hpp index e3688679144..a6613856543 100644 --- a/ql/experimental/exoticoptions/mcpagodaengine.hpp +++ b/ql/experimental/exoticoptions/mcpagodaengine.hpp @@ -57,7 +57,7 @@ namespace QuantLib { requiredSamples_, maxSamples_); results_.value = this->mcModel_->sampleAccumulator().mean(); - if (RNG::allowsErrorEstimate) + if constexpr (RNG::allowsErrorEstimate) results_.errorEstimate = this->mcModel_->sampleAccumulator().errorEstimate(); } diff --git a/ql/experimental/mcbasket/mclongstaffschwartzpathengine.hpp b/ql/experimental/mcbasket/mclongstaffschwartzpathengine.hpp index d9f563b930e..7f264a62247 100644 --- a/ql/experimental/mcbasket/mclongstaffschwartzpathengine.hpp +++ b/ql/experimental/mcbasket/mclongstaffschwartzpathengine.hpp @@ -64,7 +64,7 @@ namespace QuantLib { void calculate() const; protected: - virtual ext::shared_ptr + virtual ext::shared_ptr lsmPathPricer() const = 0; TimeGrid timeGrid() const; @@ -112,7 +112,7 @@ namespace QuantLib { "timeSteps must be positive, " << timeSteps << " not allowed"); QL_REQUIRE(timeStepsPerYear != 0, - "timeStepsPerYear must be positive, " + "timeStepsPerYear must be positive, " << timeStepsPerYear << " not allowed"); this->registerWith(process_); } @@ -122,7 +122,7 @@ namespace QuantLib { inline ext::shared_ptr::path_pricer_type> - MCLongstaffSchwartzPathEngine::pathPricer() + MCLongstaffSchwartzPathEngine::pathPricer() const { QL_REQUIRE(pathPricer_, "path pricer unknown"); @@ -132,7 +132,7 @@ namespace QuantLib { template class MC, class RNG, class S> inline - void MCLongstaffSchwartzPathEngine::calculate() + void MCLongstaffSchwartzPathEngine::calculate() const { pathPricer_ = this->lsmPathPricer(); this->mcModel_ = ext::shared_ptr >( @@ -147,7 +147,7 @@ namespace QuantLib { requiredSamples_, maxSamples_); this->results_.value = this->mcModel_->sampleAccumulator().mean(); - if (RNG::allowsErrorEstimate) { + if constexpr (RNG::allowsErrorEstimate) { this->results_.errorEstimate = this->mcModel_->sampleAccumulator().errorEstimate(); } @@ -177,7 +177,7 @@ namespace QuantLib { inline ext::shared_ptr::path_generator_type> - MCLongstaffSchwartzPathEngine::pathGenerator() + MCLongstaffSchwartzPathEngine::pathGenerator() const { Size dimensions = process_->factors(); diff --git a/ql/experimental/mcbasket/mcpathbasketengine.hpp b/ql/experimental/mcbasket/mcpathbasketengine.hpp index 19b604e194a..6056641449b 100644 --- a/ql/experimental/mcbasket/mcpathbasketengine.hpp +++ b/ql/experimental/mcbasket/mcpathbasketengine.hpp @@ -64,7 +64,7 @@ namespace QuantLib { requiredSamples_, maxSamples_); results_.value = this->mcModel_->sampleAccumulator().mean(); - if (RNG::allowsErrorEstimate) + if constexpr (RNG::allowsErrorEstimate) results_.errorEstimate = this->mcModel_->sampleAccumulator().errorEstimate(); } diff --git a/ql/pricingengines/asian/mcdiscreteasianenginebase.hpp b/ql/pricingengines/asian/mcdiscreteasianenginebase.hpp index 2aa4624ef6c..ed0e1411ccf 100644 --- a/ql/pricingengines/asian/mcdiscreteasianenginebase.hpp +++ b/ql/pricingengines/asian/mcdiscreteasianenginebase.hpp @@ -88,14 +88,14 @@ namespace QuantLib { } results_.value = this->mcModel_->sampleAccumulator().mean(); - + if (this->controlVariate_) { // control variate might lead to small negative // option values for deep OTM options this->results_.value = std::max(0.0, this->results_.value); } - - if (RNG::allowsErrorEstimate) + + if constexpr (RNG::allowsErrorEstimate) results_.errorEstimate = this->mcModel_->sampleAccumulator().errorEstimate(); diff --git a/ql/pricingengines/barrier/mcbarrierengine.hpp b/ql/pricingengines/barrier/mcbarrierengine.hpp index 5bf72fcf18d..7bc51301ae3 100644 --- a/ql/pricingengines/barrier/mcbarrierengine.hpp +++ b/ql/pricingengines/barrier/mcbarrierengine.hpp @@ -83,9 +83,9 @@ namespace QuantLib { requiredSamples_, maxSamples_); results_.value = this->mcModel_->sampleAccumulator().mean(); - if (RNG::allowsErrorEstimate) - results_.errorEstimate = - this->mcModel_->sampleAccumulator().errorEstimate(); + if constexpr (RNG::allowsErrorEstimate) + results_.errorEstimate = + this->mcModel_->sampleAccumulator().errorEstimate(); } protected: diff --git a/ql/pricingengines/basket/mceuropeanbasketengine.hpp b/ql/pricingengines/basket/mceuropeanbasketengine.hpp index 9d5d3657346..fbe65751715 100644 --- a/ql/pricingengines/basket/mceuropeanbasketengine.hpp +++ b/ql/pricingengines/basket/mceuropeanbasketengine.hpp @@ -65,9 +65,9 @@ namespace QuantLib { requiredSamples_, maxSamples_); results_.value = this->mcModel_->sampleAccumulator().mean(); - if (RNG::allowsErrorEstimate) - results_.errorEstimate = - this->mcModel_->sampleAccumulator().errorEstimate(); + if constexpr (RNG::allowsErrorEstimate) + results_.errorEstimate = + this->mcModel_->sampleAccumulator().errorEstimate(); } protected: diff --git a/ql/pricingengines/capfloor/mchullwhiteengine.hpp b/ql/pricingengines/capfloor/mchullwhiteengine.hpp index cffec61e67e..6fc1c46e712 100644 --- a/ql/pricingengines/capfloor/mchullwhiteengine.hpp +++ b/ql/pricingengines/capfloor/mchullwhiteengine.hpp @@ -89,7 +89,7 @@ namespace QuantLib { requiredSamples_, maxSamples_); results_.value = this->mcModel_->sampleAccumulator().mean(); - if (RNG::allowsErrorEstimate) + if constexpr (RNG::allowsErrorEstimate) results_.errorEstimate = this->mcModel_->sampleAccumulator().errorEstimate(); } @@ -248,4 +248,3 @@ namespace QuantLib { #endif - diff --git a/ql/pricingengines/cliquet/mcperformanceengine.hpp b/ql/pricingengines/cliquet/mcperformanceengine.hpp index feda8046f9d..1af65b28694 100644 --- a/ql/pricingengines/cliquet/mcperformanceengine.hpp +++ b/ql/pricingengines/cliquet/mcperformanceengine.hpp @@ -53,9 +53,9 @@ namespace QuantLib { requiredSamples_, maxSamples_); results_.value = this->mcModel_->sampleAccumulator().mean(); - if (RNG::allowsErrorEstimate) - results_.errorEstimate = - this->mcModel_->sampleAccumulator().errorEstimate(); + if constexpr (RNG::allowsErrorEstimate) + results_.errorEstimate = + this->mcModel_->sampleAccumulator().errorEstimate(); } protected: diff --git a/ql/pricingengines/forward/mcforwardvanillaengine.hpp b/ql/pricingengines/forward/mcforwardvanillaengine.hpp index abacd281f1d..fc909b025b4 100644 --- a/ql/pricingengines/forward/mcforwardvanillaengine.hpp +++ b/ql/pricingengines/forward/mcforwardvanillaengine.hpp @@ -59,9 +59,9 @@ namespace QuantLib { requiredSamples_, maxSamples_); this->results_.value = this->mcModel_->sampleAccumulator().mean(); - if (RNG::allowsErrorEstimate) - this->results_.errorEstimate = - this->mcModel_->sampleAccumulator().errorEstimate(); + if constexpr (RNG::allowsErrorEstimate) + this->results_.errorEstimate = + this->mcModel_->sampleAccumulator().errorEstimate(); } protected: @@ -176,4 +176,4 @@ namespace QuantLib { } -#endif \ No newline at end of file +#endif diff --git a/ql/pricingengines/forward/mcvarianceswapengine.hpp b/ql/pricingengines/forward/mcvarianceswapengine.hpp index c086884c8d2..6d2f917e195 100644 --- a/ql/pricingengines/forward/mcvarianceswapengine.hpp +++ b/ql/pricingengines/forward/mcvarianceswapengine.hpp @@ -92,7 +92,7 @@ namespace QuantLib { results_.value = multiplier * (results_.variance - arguments_.strike); - if (RNG::allowsErrorEstimate) { + if constexpr (RNG::allowsErrorEstimate) { Real varianceError = this->mcModel_->sampleAccumulator().errorEstimate(); results_.errorEstimate = multiplier * varianceError; diff --git a/ql/pricingengines/lookback/mclookbackengine.hpp b/ql/pricingengines/lookback/mclookbackengine.hpp index eae25732387..6b9c08fd754 100644 --- a/ql/pricingengines/lookback/mclookbackengine.hpp +++ b/ql/pricingengines/lookback/mclookbackengine.hpp @@ -58,7 +58,7 @@ namespace QuantLib { requiredSamples_, maxSamples_); this->results_.value = this->mcModel_->sampleAccumulator().mean(); - if (RNG::allowsErrorEstimate) + if constexpr (RNG::allowsErrorEstimate) this->results_.errorEstimate = this->mcModel_->sampleAccumulator().errorEstimate(); } diff --git a/ql/pricingengines/mclongstaffschwartzengine.hpp b/ql/pricingengines/mclongstaffschwartzengine.hpp index d7342d7671a..c95e90d128e 100644 --- a/ql/pricingengines/mclongstaffschwartzengine.hpp +++ b/ql/pricingengines/mclongstaffschwartzengine.hpp @@ -203,7 +203,7 @@ namespace QuantLib { this->results_.value = this->mcModel_->sampleAccumulator().mean(); this->results_.additionalResults["exerciseProbability"] = this->pathPricer_->exerciseProbability(); - if (RNG::allowsErrorEstimate) { + if constexpr (RNG::allowsErrorEstimate) { this->results_.errorEstimate = this->mcModel_->sampleAccumulator().errorEstimate(); } diff --git a/ql/pricingengines/vanilla/mcvanillaengine.hpp b/ql/pricingengines/vanilla/mcvanillaengine.hpp index a4d4a232a5e..ea37df4386d 100644 --- a/ql/pricingengines/vanilla/mcvanillaengine.hpp +++ b/ql/pricingengines/vanilla/mcvanillaengine.hpp @@ -42,9 +42,9 @@ namespace QuantLib { requiredSamples_, maxSamples_); this->results_.value = this->mcModel_->sampleAccumulator().mean(); - if (RNG::allowsErrorEstimate) - this->results_.errorEstimate = - this->mcModel_->sampleAccumulator().errorEstimate(); + if constexpr (RNG::allowsErrorEstimate) + this->results_.errorEstimate = + this->mcModel_->sampleAccumulator().errorEstimate(); } protected: diff --git a/test-suite/andreasenhugevolatilityinterpl.cpp b/test-suite/andreasenhugevolatilityinterpl.cpp index 1bbdcf21299..4ccd458c20b 100644 --- a/test-suite/andreasenhugevolatilityinterpl.cpp +++ b/test-suite/andreasenhugevolatilityinterpl.cpp @@ -116,7 +116,7 @@ CalibrationData AndreasenHugeExampleData() { const Size nStrikes = LENGTH(raw); const Size nMaturities = LENGTH(maturityTimes); - QL_REQUIRE(nMaturities == LENGTH(raw[1])-1, "check raw data"); + static_assert(nMaturities == LENGTH(raw[1])-1, "check raw data"); AndreasenHugeVolatilityInterpl::CalibrationSet calibrationSet; diff --git a/test-suite/nthtodefault.cpp b/test-suite/nthtodefault.cpp index 5dd70fd7134..54f2a8c559a 100644 --- a/test-suite/nthtodefault.cpp +++ b/test-suite/nthtodefault.cpp @@ -152,14 +152,14 @@ BOOST_AUTO_TEST_CASE(testGauss, *precondition(if_speed(Slow))) { ext::shared_ptr simpleQuote (new SimpleQuote(0.0)); Handle correlationHandle (simpleQuote); - ext::shared_ptr copula( new - ConstantLossModel( correlationHandle, - std::vector(names, recovery), - LatentModelIntegrationType::GaussianQuadrature, names, + ext::shared_ptr copula( new + ConstantLossModel( correlationHandle, + std::vector(names, recovery), + LatentModelIntegrationType::GaussianQuadrature, names, GaussianCopulaPolicy::initTraits())); /* If you like the action you can price with the simulation engine below - instead below. But you need at least 1e6 simulations to pass the pricing + instead below. But you need at least 1e6 simulations to pass the pricing error tests */ //ext::shared_ptr gLM( @@ -170,9 +170,9 @@ BOOST_AUTO_TEST_CASE(testGauss, *precondition(if_speed(Slow))) { //Size numSimulations = 1000000; //// Size numCoresUsed = 4; use your are in the multithread branch //// Sobol, many cores - //ext::shared_ptr > copula( - // new RandomDefaultLM(gLM, - // std::vector(names, recovery), numSimulations, 1.e-6, + //ext::shared_ptr > copula( + // new RandomDefaultLM(gLM, + // std::vector(names, recovery), numSimulations, 1.e-6, // 2863311530)); // Set up pool and basket @@ -182,7 +182,7 @@ BOOST_AUTO_TEST_CASE(testGauss, *precondition(if_speed(Slow))) { std::vector issuers; for(Size i=0; i curves(1, + std::vector curves(1, std::make_pair(NorthAmericaCorpDefaultKey( EURCurrency(), QuantLib::SeniorSec, Period(), 1. // amount threshold @@ -195,10 +195,10 @@ BOOST_AUTO_TEST_CASE(testGauss, *precondition(if_speed(Slow))) { thePool->add(namesIds[i], issuers[i], NorthAmericaCorpDefaultKey( EURCurrency(), QuantLib::SeniorSec, Period(), 1.)); - std::vector defaultKeys(probabilities.size(), + std::vector defaultKeys(probabilities.size(), NorthAmericaCorpDefaultKey(EURCurrency(), SeniorSec, Period(), 1.)); - ext::shared_ptr basket(new Basket(asofDate, namesIds, + ext::shared_ptr basket(new Basket(asofDate, namesIds, std::vector(names, namesNotional/names), thePool, 0., 1.)); ext::shared_ptr engine( @@ -211,18 +211,18 @@ BOOST_AUTO_TEST_CASE(testGauss, *precondition(if_speed(Slow))) { ntd.back().setPricingEngine(engine); } - QL_REQUIRE (LENGTH(hwCorrelation) == 3, + static_assert(LENGTH(hwCorrelation) == 3, "correlation length does not match"); Real diff, maxDiff = 0; basket->setLossModel(copula); - + for (Size j = 0; j < LENGTH(hwCorrelation); j++) { simpleQuote->setValue (hwCorrelation[j]); for (Size i = 0; i < ntd.size(); i++) { QL_REQUIRE (ntd[i].rank() == hwData[i].rank, "rank does not match"); - QL_REQUIRE (LENGTH(hwCorrelation) == LENGTH(hwData[i].spread), + static_assert(LENGTH(hwCorrelation) == LENGTH(hwData[i].spread), "vector length does not match"); diff = 1e4 * ntd[i].fairPremium() - hwData[i].spread[j]; maxDiff = std::max(maxDiff, fabs (diff)); @@ -293,9 +293,9 @@ BOOST_AUTO_TEST_CASE(testStudent, *precondition(if_speed(Slow))) { TCopulaPolicy::initTraits iniT; iniT.tOrders = std::vector(2,5); - ext::shared_ptr copula( new - ConstantLossModel( correlationHandle, - std::vector(names, recovery), + ext::shared_ptr copula( new + ConstantLossModel( correlationHandle, + std::vector(names, recovery), LatentModelIntegrationType::GaussianQuadrature, names, iniT)); // Set up pool and basket @@ -305,7 +305,7 @@ BOOST_AUTO_TEST_CASE(testStudent, *precondition(if_speed(Slow))) { std::vector issuers; for(Size i=0; i curves(1, + std::vector curves(1, std::make_pair(NorthAmericaCorpDefaultKey( EURCurrency(), QuantLib::SeniorSec, Period(), 1. // amount threshold @@ -318,10 +318,10 @@ BOOST_AUTO_TEST_CASE(testStudent, *precondition(if_speed(Slow))) { thePool->add(namesIds[i], issuers[i], NorthAmericaCorpDefaultKey( EURCurrency(), QuantLib::SeniorSec, Period(), 1.)); - std::vector defaultKeys(probabilities.size(), + std::vector defaultKeys(probabilities.size(), NorthAmericaCorpDefaultKey(EURCurrency(), SeniorSec, Period(), 1.)); - ext::shared_ptr basket(new Basket(asofDate, namesIds, + ext::shared_ptr basket(new Basket(asofDate, namesIds, std::vector(names, namesNotional/names), thePool, 0., 1.)); ext::shared_ptr engine( @@ -334,7 +334,7 @@ BOOST_AUTO_TEST_CASE(testStudent, *precondition(if_speed(Slow))) { ntd.back().setPricingEngine(engine); } - QL_REQUIRE (LENGTH(hwCorrelation) == 3, + static_assert(LENGTH(hwCorrelation) == 3, "correlation length does not match"); Real maxDiff = 0; @@ -347,7 +347,7 @@ BOOST_AUTO_TEST_CASE(testStudent, *precondition(if_speed(Slow))) { // simpleQuote->setValue (hwCorrelation[j]); // for (Size i = 0; i < ntd.size(); i++) { // QL_REQUIRE (ntd[i].rank() == hwData[i].rank, "rank does not match"); - // QL_REQUIRE (LENGTH(hwCorrelation) == LENGTH(hwData[i].spread), + // static_assert(LENGTH(hwCorrelation) == LENGTH(hwData[i].spread), // "vector length does not match"); // diff = 1e4 * ntd[i].fairPremium() - hwData[i].spread[j]; // maxDiff = std::max(maxDiff, fabs (diff)); @@ -360,7 +360,7 @@ BOOST_AUTO_TEST_CASE(testStudent, *precondition(if_speed(Slow))) { //instead of this BEGIN simpleQuote->setValue (0.3); - + for (Size i = 0; i < ntd.size(); i++) { QL_REQUIRE (ntd[i].rank() == hwDataDist[i].rank, "rank does not match"); diff --git a/tools/check_header.py b/tools/check_header.py index 4e76e8fd9f6..f4a343c1e5f 100755 --- a/tools/check_header.py +++ b/tools/check_header.py @@ -11,7 +11,7 @@ def check(header): source_file = header + ".cpp" shutil.copy(header, source_file) object_file = header + ".o" - command = f"{cxx} -std=c++14 -c -Wno-unknown-pragmas -Wall -Werror -I. {source_file} -o {object_file}" + command = f"{cxx} -std=c++17 -c -Wno-unknown-pragmas -Wall -Werror -I. {source_file} -o {object_file}" print(command, file=sys.stderr) code = os.system(command) try: