alpar@25: /* -*- C++ -*- alpar@25: * alpar@25: * This file is a part of LEMON, a generic C++ optimization library alpar@25: * alpar@25: * Copyright (C) 2003-2007 alpar@25: * Egervary Jeno Kombinatorikus Optimalizalasi Kutatocsoport alpar@25: * (Egervary Research Group on Combinatorial Optimization, EGRES). alpar@25: * alpar@25: * Permission to use, modify and distribute this software is granted alpar@25: * provided that this copyright notice appears in all copies. For alpar@25: * precise terms see the accompanying LICENSE file. alpar@25: * alpar@25: * This software is provided "AS IS" with no warranty of any kind, alpar@25: * express or implied, and with no claim as to its suitability for any alpar@25: * purpose. alpar@25: * alpar@25: */ alpar@25: alpar@25: #include <deque> alpar@25: #include <set> alpar@25: alpar@25: #include <lemon/concept_check.h> alpar@25: #include <lemon/concepts/maps.h> alpar@25: #include <lemon/maps.h> alpar@25: alpar@25: #include "test_tools.h" alpar@25: alpar@25: using namespace lemon; alpar@25: using namespace lemon::concepts; alpar@25: alpar@25: struct A {}; alpar@25: inline bool operator<(A, A) { return true; } alpar@25: struct B {}; alpar@25: alpar@25: class F { alpar@25: public: alpar@25: typedef A argument_type; alpar@25: typedef B result_type; alpar@25: alpar@25: B operator()(const A &) const {return B();} alpar@25: }; alpar@25: alpar@25: int func(A) {return 3;} alpar@25: alpar@25: int binc(int, B) {return 4;} alpar@25: alpar@25: typedef ReadMap<A,double> DoubleMap; alpar@25: typedef ReadWriteMap<A, double> WriteDoubleMap; alpar@25: alpar@25: typedef ReadMap<A,bool> BoolMap; alpar@25: typedef ReadWriteMap<A, bool> BoolWriteMap; alpar@25: alpar@25: int main() alpar@25: { // checking graph components alpar@25: alpar@25: checkConcept<ReadMap<A,B>, ReadMap<A,B> >(); alpar@25: checkConcept<WriteMap<A,B>, WriteMap<A,B> >(); alpar@25: checkConcept<ReadWriteMap<A,B>, ReadWriteMap<A,B> >(); alpar@25: checkConcept<ReferenceMap<A,B,B&,const B&>, ReferenceMap<A,B,B&,const B&> >(); alpar@25: alpar@25: checkConcept<ReadMap<A,double>, AddMap<DoubleMap,DoubleMap> >(); alpar@25: checkConcept<ReadMap<A,double>, SubMap<DoubleMap,DoubleMap> >(); alpar@25: checkConcept<ReadMap<A,double>, MulMap<DoubleMap,DoubleMap> >(); alpar@25: checkConcept<ReadMap<A,double>, DivMap<DoubleMap,DoubleMap> >(); alpar@25: checkConcept<ReadMap<A,double>, NegMap<DoubleMap> >(); alpar@25: checkConcept<ReadWriteMap<A,double>, NegWriteMap<WriteDoubleMap> >(); alpar@25: checkConcept<ReadMap<A,double>, AbsMap<DoubleMap> >(); alpar@25: checkConcept<ReadMap<A,double>, ShiftMap<DoubleMap> >(); alpar@25: checkConcept<ReadWriteMap<A,double>, ShiftWriteMap<WriteDoubleMap> >(); alpar@25: checkConcept<ReadMap<A,double>, ScaleMap<DoubleMap> >(); alpar@25: checkConcept<ReadWriteMap<A,double>, ScaleWriteMap<WriteDoubleMap> >(); alpar@25: checkConcept<ReadMap<A,double>, ForkMap<DoubleMap, DoubleMap> >(); alpar@25: checkConcept<ReadWriteMap<A,double>, alpar@25: ForkWriteMap<WriteDoubleMap, WriteDoubleMap> >(); alpar@25: alpar@25: checkConcept<ReadMap<B,double>, ComposeMap<DoubleMap,ReadMap<B,A> > >(); alpar@25: alpar@25: checkConcept<ReadMap<A,B>, FunctorMap<F, A, B> >(); alpar@25: alpar@25: checkConcept<ReadMap<A, bool>, NotMap<BoolMap> >(); alpar@25: checkConcept<ReadWriteMap<A, bool>, NotWriteMap<BoolWriteMap> >(); alpar@25: alpar@25: checkConcept<WriteMap<A, bool>, StoreBoolMap<A*> >(); alpar@25: checkConcept<WriteMap<A, bool>, BackInserterBoolMap<std::deque<A> > >(); alpar@25: checkConcept<WriteMap<A, bool>, FrontInserterBoolMap<std::deque<A> > >(); alpar@25: checkConcept<WriteMap<A, bool>, InserterBoolMap<std::set<A> > >(); alpar@25: checkConcept<WriteMap<A, bool>, FillBoolMap<WriteMap<A, B> > >(); alpar@25: checkConcept<WriteMap<A, bool>, SettingOrderBoolMap<WriteMap<A, int> > >(); alpar@25: alpar@25: int a; alpar@25: alpar@25: a=mapFunctor(constMap<A,int>(2))(A()); alpar@25: check(a==2,"Something is wrong with mapFunctor"); alpar@25: alpar@25: B b; alpar@25: b=functorMap(F())[A()]; alpar@25: alpar@25: a=functorMap(&func)[A()]; alpar@25: check(a==3,"Something is wrong with functorMap"); alpar@25: alpar@25: a=combineMap(constMap<B, int, 1>(), identityMap<B>(), &binc)[B()]; alpar@25: check(a==4,"Something is wrong with combineMap"); alpar@25: alpar@25: alpar@25: std::cout << __FILE__ ": All tests passed.\n"; alpar@25: alpar@25: return 0; alpar@25: }