src/kdt/kdtquery.c

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    
    /* Gerris - The GNU Flow Solver
     * Copyright (C) 2010 National Institute of Water and Atmospheric Research
     *
     * This program is free software; you can redistribute it and/or
     * modify it under the terms of the GNU General Public License as
     * published by the Free Software Foundation; either version 2 of the
     * License, or (at your option) any later version.
     *
     * This program is distributed in the hope that it will be useful,
     * but WITHOUT ANY WARRANTY; without even the implied warranty of
     * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.	See the GNU
     * General Public License for more details.
     *
     * You should have received a copy of the GNU General Public License
     * along with this program; if not, write to the Free Software
     * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA
     * 02111-1307, USA.  
     */
    
    // #include <glib.h>
    #include <stdlib.h>
    #include <stdio.h>
    
    #include "kdt.h"
    
    int main (int argc, char * argv[])
    {
      if (argc != 2) {
        fprintf (stderr, "Usage: %s basename\n", argv[0]);
        return -1;
      }
    
      Kdt * kdt = kdt_new ();
      if (kdt_open (kdt, argv[1])) {
        fprintf (stderr, "%s: could not open `%s'\n", argv[0], argv[1]);
        return -1;
      }
    
      KdtRect query;
      int count = 0;
      //  GTimer * t = g_timer_new ();
      while (scanf ("%f %f %f %f", 
    		&query[0].l, &query[1].l, 
    		&query[0].h, &query[1].h) == 4) {
    #if 1
        fprintf (stderr, "%ld\n", kdt_query (kdt, query));
    #else
        KdtSum s;
        kdt_sum_init (&s);
        //    g_timer_start (t);
        long n = kdt_query_sum (kdt, (KdtCheck) kdt_includes, (KdtCheck) kdt_intersects, 
    			    query, query, &s);
        //    g_timer_stop (t);
        //    fprintf (stderr, "%d %g %g %g %g\n", n, s.H0, s.Hmax, s.Hmin, g_timer_elapsed (t, NULL));
        printf ("%ld %g %g %g\n", n, s.H0, s.H1, s.H2);
    #endif
        if (count > 0 && count % 1000 == 0)
          fprintf (stderr, "\r%d", count);
        count++;
      }
      if (count >= 1000)
        fputc ('\n', stderr);
    
      kdt_destroy (kdt);
      return 0;
    }