#include <CGAL/box_intersection_d.h>
#include <vector>
#include <algorithm>
#include <iterator>
#include <cassert>
struct Box {
    typedef int            NT;
    typedef std::ptrdiff_t ID;
    int lo[2], hi[2];
    Box( int lo0, int lo1, int hi0, int hi1) { lo[0]=lo0; lo[1]=lo1; hi[0]=hi0; hi[1]=hi1;}
    static int dimension() { return 2; }
    int min_coord(int dim) const { return lo[dim]; }
    int max_coord(int dim) const { return hi[dim]; }
    
    
    std::ptrdiff_t id() const { return (std::ptrdiff_t)(this); }
};
Box boxes[9] = { Box( 0,0,1,1),  Box( 1,0,2,1),  Box( 2,0,3,1), 
                 Box( 0,1,1,2),  Box( 1,1,2,2),  Box( 2,1,3,2), 
                 Box( 0,2,1,3),  Box( 1,2,2,3),  Box( 2,2,3,3)};
Box query[2] = { Box( 1,1,2,2),  Box( 2,2,3,3)};
Box* b_ptr[9] = { boxes,   boxes+1, boxes+2, boxes+3, boxes+4, boxes+5,
                  boxes+6, boxes+7, boxes+8};
Box* q_ptr[2] = { query,   query+1};
template <class OutputIterator>
struct Report {
    
    
    void operator()( const Box* a, const Box*) {
        *it++ = ( reinterpret_cast<Box*>(a->id()) - boxes);
    }
};
template <class Iter> 
Report<Iter> report( Iter it) { return Report<Iter>(it); }
int main() {
    
    std::vector<std::size_t> result;
                              report( std::back_inserter( result)),
                              std::ptrdiff_t(0));
    
    std::sort( result.begin(), result.end());
    std::size_t chk[13] = {0,1,2,3,4,4,5,5,6,7,7,8,8};
    assert( result.size()==13 && std::equal(chk,chk+13,result.begin()));
    return 0;
}