LatNet Builder Manual 2.1.3-6
Software Package for Constructing Highly Uniform Point Sets
Loading...
Searching...
No Matches
tutorial/MeritSeqNonCBC.cc

This example shows how to instantiate a sequence of merit values not based on a component-by-component (CBC) sequence of lattice definitions, but using the same algorithms as in the CBC case.

This example shows how to instantiate a sequence of merit values not based on a component-by-component (CBC) sequence of lattice definitions, but using the same algorithms as in the CBC case.

// This file is part of LatNet Builder.
//
// Copyright (C) 2012-2021 The LatNet Builder author's, supervised by Pierre L'Ecuyer, Universite de Montreal.
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
#include "latbuilder/CoordUniformFigureOfMerit.h"
#include "latticetester/ProductWeights.h"
#include "latbuilder/Kernel/PAlpha.h"
#include "latbuilder/Kernel/PAlphaTilde.h"
#include "latbuilder/Accumulator.h"
#include "latbuilder/Storage.h"
#include "latbuilder/MeritFilterList.h"
#include "latbuilder/MeritSeq/LatSeqOverCBC.h"
#include "latbuilder/MeritSeq/CoordUniformCBC.h"
#include "latbuilder/MeritSeq/CoordUniformInnerProd.h"
#include "latbuilder/LatSeq/Korobov.h"
#include "latbuilder/GenSeq/GeneratingValues.h"
#include "latbuilder/GenSeq/Creator.h"
#include "latbuilder/TextStream.h"
#include "Path.h"
#include <iostream>
#include <limits>
using namespace LatBuilder;
using TextStream::operator<<;
template <typename T, typename... ARGS>
std::unique_ptr<T> unique(ARGS&&... args)
{ return std::unique_ptr<T>(new T(std::forward<ARGS>(args)...)); }
template <LatticeType LA, EmbeddingType L, Compress C>
void test(const Storage<LA, L, C>& storage, Dimension dimension)
{
auto weights = unique<LatticeTester::ProductWeights>();
weights->setDefaultWeight(0.7);
CoordUniformFigureOfMerit<Kernel::PAlpha> figure(std::move(weights), 2);
std::cout << "figure of merit: " << figure << std::endl;
/*
// The P_{\alpha,PLR} figure of merit for polynomial lattices
auto weights = unique<LatticeTester::ProductWeights>();
weights->setDefaultWeight(0.7);
typedef ProjDepMerit::CoordUniform<Kernel::PAlphaTilde> ProjDep;
WeightedFigureOfMerit<ProjDep, Functor::Sum> figure(2, std::move(weights), ProjDep(2));
std::cout << "figure of merit: " << figure << std::endl;
*/
typedef GenSeq::GeneratingValues<LA, decltype(figure)::suggestedCompression()> Coprime;
auto genSeq = GenSeq::Creator<Coprime>::create(storage.sizeParam());
auto latSeqOverCBC = MeritSeq::latSeqOverCBC(cbc);
auto latSeq = LatSeq::korobov(storage.sizeParam(), Coprime(storage.sizeParam().modulus()), dimension);
auto meritSeq = latSeqOverCBC.meritSeq(latSeq);
auto filteredSeq = filters.apply(meritSeq);
auto best = std::min_element(filteredSeq.begin(), filteredSeq.end());
std::cout << "BEST LATTICE: " << std::endl << *best.base().base() << "Merit value: " << *best << std::endl;
}
int main()
{
SET_PATH_TO_LATNETBUILDER_FOR_EXAMPLES();
Dimension dim = 3;
/*
test(Storage<LatticeType::POLYNOMIAL, EmbeddingType::UNILEVEL, Compress::NONE>(PolynomialFromInt(115)), dim);
*/
return 0;
}
This file contains a global variable PATH_TO_LATNETBUILDER_DIR which should always equal the path to ...
Base base class for coordinate-uniform figures of merit.
Definition CoordUniformFigureOfMerit.h:33
Indexed sequence of generating values: -For ordinary lattices: integers coprime with a specified modu...
Definition GeneratingValues.h:48
List of filters for merit values.
Definition MeritFilterList.h:176
Seq< MERITSEQ > apply(MERITSEQ meritSeq) const
Applies the filters to the input sequence meritSeq of merit values.
Definition MeritFilterList.h:243
Lattice size parameter.
Definition SizeParam.h:30
Storage policy.
Definition Storage.h:114
Korobov< LR, ET, GENSEQ > korobov(const SizeParam< LR, ET > &size, const GENSEQ &genSeqs, Dimension dimension)
Creates a Korobov lattice sequence.
Definition Korobov.h:81
CBC< LR, ET, COMPRESS, PLO, PROJDEP, ACC > cbc(Storage< LR, ET, COMPRESS, PLO > storage, const WeightedFigureOfMerit< PROJDEP, ACC > &figure)
Creates a CBC algorithm.
Definition CBC.h:221
LatSeqOverCBC< CBC > latSeqOverCBC(CBC cbc)
Creates a search algorithm on top of a CBC algorithm.
Definition LatSeqOverCBC.h:138
LatBuilder namespace.
Definition libtut_lat.dox:17
size_t Dimension
Scalar integer type for dimension.
Definition Types.h:53
static result_type create(const SizeParam< LR, L > &sizeParam, ARGS &&... t)
Creates a new sequence object.
Definition Creator.h:43
Lattice traits.
Definition Types.h:92