src/test/heap_test.cc
author alpar
Fri, 08 Apr 2005 15:46:12 +0000
changeset 1329 1bfaec33215b
parent 1215 81b4731f8a6b
child 1330 52ef02524468
permissions -rw-r--r--
- Insert LP stuff into the module structure
deba@1187
     1
// -*- c++ -*-
deba@1187
     2
deba@1187
     3
#include <iostream>
deba@1187
     4
#include <fstream>
alpar@1215
     5
#include <string>
deba@1187
     6
#include <vector>
deba@1187
     7
deba@1187
     8
#include <lemon/concept_check.h>
deba@1187
     9
deba@1206
    10
#include <lemon/smart_graph.h>
deba@1206
    11
deba@1206
    12
#include <lemon/graph_reader.h>
deba@1206
    13
deba@1187
    14
#include <lemon/bin_heap.h>
deba@1187
    15
#include <lemon/fib_heap.h>
deba@1187
    16
#include <lemon/radix_heap.h>
deba@1187
    17
deba@1206
    18
#include "test_tools.h"
deba@1187
    19
deba@1187
    20
#include "heap_test.h"
deba@1187
    21
deba@1187
    22
deba@1187
    23
using namespace lemon;
deba@1187
    24
deba@1187
    25
template <typename Item, typename Prio, typename ItemIntMap>
deba@1187
    26
class HeapConcept {
deba@1187
    27
public:  
deba@1187
    28
deba@1187
    29
  template <typename _Heap>
deba@1187
    30
  struct Constraints {
deba@1187
    31
  public:
deba@1187
    32
    
deba@1187
    33
    void constraints() {
deba@1187
    34
      Item item;
deba@1187
    35
      Prio prio;
deba@1187
    36
deba@1206
    37
      ignore_unused_variable_warning(item);
deba@1206
    38
      ignore_unused_variable_warning(prio);
deba@1206
    39
deba@1187
    40
      typedef typename _Heap::state_enum state_enum;
deba@1187
    41
      state_enum state;
deba@1206
    42
deba@1206
    43
      ignore_unused_variable_warning(state);
deba@1187
    44
      
deba@1187
    45
      _Heap heap1 = _Heap(map);
deba@1206
    46
deba@1206
    47
      ignore_unused_variable_warning(heap1);
deba@1187
    48
      
deba@1187
    49
      heap.push(item, prio);
deba@1187
    50
deba@1187
    51
      prio = heap.prio();
deba@1187
    52
      item = heap.top();
deba@1187
    53
deba@1187
    54
      heap.pop();
deba@1187
    55
deba@1187
    56
      heap.set(item, prio);
deba@1187
    57
      heap.decrease(item, prio);
deba@1187
    58
      heap.increase(item, prio);
deba@1187
    59
      prio = heap[item];
deba@1187
    60
deba@1187
    61
      heap.erase(item);
deba@1187
    62
deba@1187
    63
      state = heap.state(item);
deba@1187
    64
deba@1187
    65
      state = _Heap::PRE_HEAP;
deba@1187
    66
      state = _Heap::IN_HEAP;
deba@1187
    67
      state = _Heap::POST_HEAP;
deba@1187
    68
    }
deba@1187
    69
    
deba@1187
    70
    _Heap& heap;
deba@1187
    71
    ItemIntMap& map;
alpar@1325
    72
alpar@1325
    73
    Constraints() : heap(0), map(0) {}
deba@1187
    74
  };
deba@1187
    75
};
deba@1187
    76
deba@1187
    77
int main() {
deba@1187
    78
deba@1187
    79
  typedef int Item;
deba@1187
    80
  typedef int Prio;
deba@1187
    81
  typedef IntIntMap ItemIntMap;
deba@1187
    82
deba@1187
    83
  typedef ListGraph Graph;
deba@1187
    84
deba@1187
    85
  typedef Graph::Edge Edge;
deba@1187
    86
  typedef Graph::Node Node;
deba@1187
    87
  typedef Graph::EdgeIt EdgeIt;
deba@1187
    88
  typedef Graph::NodeIt NodeIt;
deba@1187
    89
  typedef Graph::EdgeMap<int> LengthMap;
deba@1187
    90
deba@1187
    91
  Graph graph;
deba@1187
    92
  LengthMap length(graph);
deba@1187
    93
  Node start;
deba@1187
    94
deba@1206
    95
  /// \todo create own test graph
alpar@1215
    96
alpar@1215
    97
  std::string f_name;
alpar@1215
    98
  if( getenv("srcdir") )
alpar@1215
    99
    f_name = std::string(getenv("srcdir"));
alpar@1215
   100
  else f_name = ".";
alpar@1215
   101
  f_name += "/dijkstra_test.lgf";
alpar@1215
   102
  
alpar@1215
   103
  std::ifstream input(f_name.c_str());
alpar@1215
   104
  check(input, "Input file '" << f_name << "' not found.");
deba@1206
   105
  readGraph(input, graph, length, start);  
deba@1187
   106
 
deba@1187
   107
  {
deba@1187
   108
    std::cerr << "Checking Bin Heap" << std::endl;
deba@1187
   109
deba@1187
   110
    typedef BinHeap<Item, Prio, ItemIntMap> IntHeap;
deba@1187
   111
    checkConcept<HeapConcept<Item, Prio, ItemIntMap>, IntHeap>();
deba@1206
   112
    heapSortTest<IntHeap>(100);
deba@1206
   113
    heapIncreaseTest<IntHeap>(100);
deba@1187
   114
    
deba@1187
   115
    typedef FibHeap<Node, Prio, Graph::NodeMap<int> > NodeHeap;
deba@1187
   116
    checkConcept<HeapConcept<Node, Prio, Graph::NodeMap<int> >, NodeHeap>();
deba@1187
   117
    dijkstraHeapTest<Graph, LengthMap, NodeHeap>(graph, length, start);
deba@1187
   118
  }
deba@1187
   119
  {
deba@1187
   120
    std::cerr << "Checking Fib Heap" << std::endl;
deba@1187
   121
deba@1187
   122
    typedef FibHeap<Item, Prio, ItemIntMap> IntHeap;
deba@1187
   123
    checkConcept<HeapConcept<Item, Prio, ItemIntMap>, IntHeap>();
deba@1206
   124
    heapSortTest<IntHeap>(100);
deba@1206
   125
    heapIncreaseTest<IntHeap>(100);
deba@1187
   126
deba@1187
   127
    typedef FibHeap<Node, Prio, Graph::NodeMap<int> > NodeHeap;
deba@1187
   128
    checkConcept<HeapConcept<Node, Prio, Graph::NodeMap<int> >, NodeHeap>();
deba@1187
   129
    dijkstraHeapTest<Graph, LengthMap, NodeHeap>(graph, length, start);
deba@1187
   130
  }
deba@1187
   131
  {
deba@1187
   132
    std::cerr << "Checking Radix Heap" << std::endl;
deba@1187
   133
deba@1187
   134
    typedef RadixHeap<Item, ItemIntMap> IntHeap;
deba@1187
   135
    checkConcept<HeapConcept<Item, Prio, ItemIntMap>, IntHeap>();
deba@1206
   136
    heapSortTest<IntHeap>(100);
deba@1206
   137
    heapIncreaseTest<IntHeap>(100);
deba@1187
   138
deba@1187
   139
    typedef RadixHeap<Node, Graph::NodeMap<int> > NodeHeap;
deba@1187
   140
    checkConcept<HeapConcept<Node, Prio, Graph::NodeMap<int> >, NodeHeap>();
deba@1187
   141
    dijkstraHeapTest<Graph, LengthMap, NodeHeap>(graph, length, start);
deba@1187
   142
  }
deba@1187
   143
deba@1187
   144
  std::cout << __FILE__ ": All tests passed.\n";
deba@1187
   145
deba@1187
   146
  return 0;
deba@1187
   147
}