benchmark/edge_lookup_test.h
changeset 2242 16523135943d
parent 2235 48801095a410
child 2252 133028e83940
equal deleted inserted replaced
0:98116cf386b5 1:77ee90753447
   187       return prev==INVALID?(*this)(s,t):INVALID;
   187       return prev==INVALID?(*this)(s,t):INVALID;
   188     }
   188     }
   189       
   189       
   190   };
   190   };
   191 
   191 
   192   template<class G>
   192 //   template<class G>
   193   class EdgeLookUp4
   193 //   class EdgeLookUp4
   194   {
   194 //   {
   195   public:
   195 //   public:
   196     GRAPH_TYPEDEFS(typename G)
   196 //     GRAPH_TYPEDEFS(typename G)
   197     typedef G Graph;
   197 //     typedef G Graph;
   198 
   198 
   199   private:
   199 //   private:
   200     const Graph &_g;
   200 //     const Graph &_g;
   201     typename Graph::template NodeMap<Edge*> _start;
   201 //     typename Graph::template NodeMap<Edge*> _start;
   202     typename Graph::template NodeMap<Edge*> _end;
   202 //     typename Graph::template NodeMap<Edge*> _end;
   203     std::vector<Edge> _edges;
   203 //     std::vector<Edge> _edges;
   204     
   204     
   205     class EdgeLess {
   205 //     class EdgeLess {
   206       const Graph &g;
   206 //       const Graph &g;
   207     public:
   207 //     public:
   208       EdgeLess(const Graph &_g) : g(_g) {}
   208 //       EdgeLess(const Graph &_g) : g(_g) {}
   209       bool operator()(Edge a,Edge b) const 
   209 //       bool operator()(Edge a,Edge b) const 
   210       {
   210 //       {
   211 	return g.target(a)<g.target(b);
   211 // 	return g.target(a)<g.target(b);
   212       }
   212 //       }
   213     };
   213 //     };
   214     
   214     
   215   public:
   215 //   public:
   216     
   216     
   217     ///Constructor
   217 //     ///Constructor
   218     EdgeLookUp4(const Graph &g) :_g(g),_start(g),_end(g) {refresh();}
   218 //     EdgeLookUp4(const Graph &g) :_g(g),_start(g),_end(g) {refresh();}
   219     
   219     
   220   public:
   220 //   public:
   221     ///Refresh the data structure at a node.
   221 //     ///Refresh the data structure at a node.
   222     void refresh(Node n) 
   222 //     void refresh(Node n) 
   223     {
   223 //     {
   224       const int bi = _start[n] = _edges.size();
   224 //       const int bi = _start[n] = _edges.size();
   225       for(OutEdgeIt e(_g,n);e!=INVALID;++e) _edges.push_back(e);
   225 //       for(OutEdgeIt e(_g,n);e!=INVALID;++e) _edges.push_back(e);
   226       const typename std::vector<Edge>::iterator ei=_edges.end();
   226 //       const typename std::vector<Edge>::iterator ei=_edges.end();
   227       _end[n]=_edges.size();
   227 //       _end[n]=_edges.size();
   228       std::sort(_edges.begin()+bi,ei,EdgeLess(_g));
   228 //       std::sort(_edges.begin()+bi,ei,EdgeLess(_g));
   229     }
   229 //     }
   230     ///Refresh the full data structure.
   230 //     ///Refresh the full data structure.
   231     void refresh() 
   231 //     void refresh() 
   232     {
   232 //     {
   233       _edges.resize(countEdges(_g));
   233 //       _edges.resize(countEdges(_g));
   234       int l=0;
   234 //       int l=0;
   235       for(NodeIt n(_g);n!=INVALID;++n)
   235 //       for(NodeIt n(_g);n!=INVALID;++n)
   236 	{
   236 // 	{
   237 	  int ls = l;
   237 // 	  int ls = l;
   238 	  _start[n]=&(_edges[l]);	
   238 // 	  _start[n]=&(_edges[l]);	
   239 	  for(OutEdgeIt e(_g,n);e!=INVALID;++e) _edges[l++]=e;
   239 // 	  for(OutEdgeIt e(_g,n);e!=INVALID;++e) _edges[l++]=e;
   240 	  _end[n]=&(_edges[l]);
   240 // 	  _end[n]=&(_edges[l]);
   241 	  std::sort(_edges.begin()+ls,_edges.begin()+l,EdgeLess(_g));
   241 // 	  std::sort(_edges.begin()+ls,_edges.begin()+l,EdgeLess(_g));
   242 	}
   242 // 	}
   243       
   243       
   244     }
   244 //     }
   245     
   245     
   246     ///Find an edge between two nodes.
   246 //     ///Find an edge between two nodes.
   247     
   247     
   248     ///Find an edge between two nodes.
   248 //     ///Find an edge between two nodes.
   249     ///\param s The source node
   249 //     ///\param s The source node
   250     ///\param t The target node
   250 //     ///\param t The target node
   251     ///\return An edge from \c s to \c t if there exists,
   251 //     ///\return An edge from \c s to \c t if there exists,
   252     ///\ref INVALID otherwise.
   252 //     ///\ref INVALID otherwise.
   253 
   253 
   254     Edge operator()(Node s, Node t) 
   254 //     Edge operator()(Node s, Node t) 
   255     {
   255 //     {
   256       Edge *a=_start[s];
   256 //       Edge *a=_start[s];
   257       Edge *b=_end[s];
   257 //       Edge *b=_end[s];
   258       while(a!=b) 
   258 //       while(a!=b) 
   259 	{
   259 // 	{
   260 	  Edge *m=(Edge*)(((unsigned int)a+(unsigned int)b)/2 & 0xfffffffc);
   260 // 	  Edge *m=(Edge*)(((unsigned int)a+(unsigned int)b)/2 & 0xfffffffc);
   261 	  Node tt = _g.target(*m);
   261 // 	  Node tt = _g.target(*m);
   262 	  if(tt==t) return *m;
   262 // 	  if(tt==t) return *m;
   263 	  else if(tt<t) a=m+1;
   263 // 	  else if(tt<t) a=m+1;
   264 	  else b=m;
   264 // 	  else b=m;
   265 	}
   265 // 	}
   266       return INVALID;
   266 //       return INVALID;
   267     }
   267 //     }
   268 
   268 
   269     ///Find the next edge
   269 //     ///Find the next edge
   270       
   270       
   271       ///\warning This function is unimplemented.
   271 //       ///\warning This function is unimplemented.
   272     Edge operator()(Node s, Node t, Edge prev) 
   272 //     Edge operator()(Node s, Node t, Edge prev) 
   273     {
   273 //     {
   274       return prev==INVALID?(*this)(s,t):INVALID;
   274 //       return prev==INVALID?(*this)(s,t):INVALID;
   275     }
   275 //     }
   276       
   276       
   277   };
   277 //   };
   278 
   278 
   279 }
   279 }
   280 
   280 
   281 #endif
   281 #endif