view libtests/0037/prog1.c @ 465:1030664df98c api-inversion

No more audioDB::index_allocate and audioDB::index_init_query No more SERVER_LSH_INDEX_SINGLETON, either; instead each adb_t contains a single cache of the last used in-core index. At the moment, this cache is unused by the server (and the previous cache code has been replaced by a comment), but I think that this way everyone can be allowed to benefit without anyone having to explicitly manage indexes themselves. I'm not going to say how long I wandered in a maze of valgrind before giving up and keeping the hacky workaround for loading the lsh tables [see the FIXME comment in audiodb_index_init_query()]; let's just say that it was long enough to find the extra bonus crashy close(lshfid) in audioDB::index_index_db. Also, delete the abstraction-inverting LSH stuff from query.cpp where we are making our reporters; the fix for that, which is presumably when creating small indexes for large datasets, is to implement space-efficient reporters. (The accumulator code, which is my second attempt, is more space-efficient than the reporters; inspiration may wish to be drawn...)
author mas01cr
date Tue, 30 Dec 2008 23:56:57 +0000
parents 9de6d0676907
children c26c5b7ef0d2
line wrap: on
line source
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <sysexits.h>
#include <fcntl.h>
#include <dirent.h>
#include <unistd.h>
#include <sys/stat.h>
/*
 *  * #define NDEBUG
 *   * */
#include <assert.h>

#include "../../audioDB_API.h"
#include "../test_utils_lib.h"

int main(int argc, char *argv[]) {
  char *dbname = "testdb";
  adb_t *adb;
  adb_insert_t *batch = 0;
  adb_status_t status;
  adb_query_t query = {0};
  adb_queryresult_t result;

  clean_remove_db(dbname);
  adb = audiodb_create("testdb", 0, 0, 0);
  if(!adb) {
    return 1;
  }

  maketestfile("testfeature01", (int[1]) {2}, (double[4]) {0,1,1,0}, 4);
  maketestfile("testfeature10", (int[1]) {2}, (double[4]) {1,0,0,1}, 4);

  batch = (adb_insert_t *) calloc(6, sizeof(adb_insert_t));
  if(!batch) {
    return 1;
  }
  batch[0].features = "testfeature01";
  batch[1].features = "testfeature01";
  batch[2].features = "testfeature10";
  batch[3].features = "testfeature10";
  batch[4].features = "testfeature01";
  batch[5].features = "testfeature10";
  
  audiodb_batchinsert(adb, batch, 6);

  if(audiodb_status(adb, &status)) {
    return 1;
  }
  if(status.numFiles != 2) {
    return 1;
  }

  if(audiodb_l2norm(adb)) {
    return 1;
  }

  maketestfile("testquery", (int [1]) {2}, (double[2]) {0, 0.5}, 2);
  return 14;
  /* can't do nsequence yet */
  /*
  query.querytype = "nsequence";
  query.sequencelength = "1";
  query.feature = "testquery";
  if(audiodb_query(adb, &query, &result)) {
    return 1;
  }
  if(result.sizeRlist != 2) {
    return 1;
  }
  if(testoneresult(&result, 0, "testfeature01" ...));
  return 104;
  */
}