This example shows how to use signals to control the number of elements from a random lattice sequence to be examined by a minimization algorithm, and thus ignore candidate lattices rejected by filters.
This example shows how to use signals to control the number of elements from a random lattice sequence to be examined by a minimization algorithm, and thus ignore candidate lattices rejected by filters.
 
#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/MeritFilter.h"
#include "latbuilder/Norm/Normalizer.h"
#include "latbuilder/Norm/PAlphaSL10.h"
#include "latbuilder/Functor/LowPass.h"
 
#include "latbuilder/MeritSeq/CoordUniformCBC.h"
#include "latbuilder/MeritSeq/CoordUniformInnerProd.h"
#include "latbuilder/GenSeq/GeneratingValues.h"
#include "latbuilder/GenSeq/Creator.h"
 
#include "latbuilder/Traversal.h"
#include "latbuilder/LFSR258.h"
#include "latbuilder/Functor/MinElement.h"
 
#include "latbuilder/TextStream.h"
 
 
#include <iostream>
#include <limits>
 
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 ET>
class Observer {
public:
 
   Observer(int maxCount) { m_maxCount = maxCount; m_count = m_totalCount = 0; }
   void onStart() { m_count = m_totalCount = 0; }
   bool onElementVisited(const Real&) { ++m_totalCount; return ++m_count < m_maxCount; }
   void onReject(const LatDef&) { m_count--; }
   int count() const { return m_count; }
   int totalCount() const { return m_totalCount; }
private:
   int m_maxCount;
   int m_count;
   int m_totalCount;
};
 
 
template <LatticeType LA, EmbeddingType L, Compress C>
{
   auto weights = unique<LatticeTester::ProductWeights>();
   weights->setDefaultWeight(0.7);
 
   std::cout << "figure of merit: " << figure << std::endl;
 
    
   auto weights = unique<LatticeTester::ProductWeights>();
   weights->setDefaultWeight(0.7);
 
   CoordUniformFigureOfMerit<Kernel::PAlphaTilde> figure(std::move(weights), 2);
   std::cout << "figure of merit: " << figure << std::endl;
   */
 
   auto normalizer = unique<Norm::Normalizer<LA, L, Norm::PAlphaSL10>>(
         );
   filters.add(std::move(normalizer));
   filters.add(std::move(lowPass));
   std::cout << "filters: " << filters << std::endl;
   Observer<LA, L> obs(samples);
   minElement.
onStart().connect(boost::bind(&Observer<LA, L>::onStart, &obs));
   minElement.
onElementVisited().connect(boost::bind(&Observer<LA, L>::onElementVisited, &obs, _1));
   filters.template onReject<L>().connect(boost::bind(&Observer<LA, L>::onReject, &obs, _1));
   while (
cbc.baseLat().dimension() < dimension) {
 
 
 
      std::cout << "CBC search for dimension: " << (baseDim + 1) << std::endl;
      std::cout << 
"base lattice: " << std::endl << 
cbc.baseLat();
      std::cout << 
"base merit value: " << 
cbc.baseMerit() << std::endl;
      auto meritSeq = 
cbc.meritSeq(baseDim == 0 ? genSeq0 : genSeq);
 
      auto filteredSeq = filters.
apply(meritSeq);
 
      auto best = minElement(filteredSeq.begin(), filteredSeq.end(), 0);
      std::cout << 
"BEST LATTICE: " << std::endl << 
cbc.baseLat() << 
"Merit value: " << *best << std::endl;
      std::cout << obs.count() << " accepted / " << obs.totalCount() << " tried" << std::endl;;
 
      
      genSeq.randomGenerator().jump();
   }
}
 
int main()
{
   SET_PATH_TO_LATNETBUILDER_FOR_EXAMPLES();
   int samples = 15;
   
   test(Storage<LatticeType::POLYNOMIAL, EmbeddingType::UNILEVEL, Compress::NONE>(PolynomialFromInt(115)), dim, samples);
   */
   return 0;
}
This file contains a global variable PATH_TO_LATNETBUILDER_DIR which should always equal the path to ...
Low pass filter.
Definition LowPass.h:28
Indexed sequence of generating values: -For ordinary lattices: integers coprime with a specified modu...
Definition GeneratingValues.h:48
Definition of a rank-1 lattice.
Definition LatDef.h:40
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
Bound on the weighted  discrepancy.
Definition PAlphaSL10.h:113
Lattice size parameter.
Definition SizeParam.h:30
Storage policy.
Definition Storage.h:114
Random traversal type.
Definition Traversal.h:76
CBC< LR, ET, GENSEQ > cbc(LatDef< LR, ET > baseLat, GENSEQ genSeq)
Creates a CBC lattice sequence.
Definition CBC.h:148
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
LatBuilder namespace.
Definition libtut_lat.dox:17
size_t Dimension
Scalar integer type for dimension.
Definition Types.h:53
Minimum element functor.
Definition MinElement.h:35
OnStart & onStart()
Start signal.
Definition MinElement.h:123
OnElementVisited & onElementVisited()
Element-visited updated signal.
Definition MinElement.h:156
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