Mercurial > hg > audiodb
view libtests/0010/prog1.c @ 597:fac63f65753e
Remove LIBGSL from library link stage
At present, the library doesn't depend on libgsl. If Windows porting
goes faster than APIs for sample and index, removing libgsl from the
link equation will help.
author | mas01cr |
---|---|
date | Tue, 11 Aug 2009 21:57:46 +0000 |
parents | 342822c2d49a |
children | bcc7a6ddb2c8 |
line wrap: on
line source
#include "audioDB_API.h" #include "test_utils_lib.h" int main(int argc, char **argv) { adb_t *adb; clean_remove_db(TESTDB); if(!(adb = audiodb_create(TESTDB, 0, 0, 0))) return 1; adb_datum_t datum1 = {1, 2, "testfeature01", (double[2]) {0, 1}}; adb_datum_t datum2 = {1, 2, "testfeature10", (double[2]) {1, 0}}; if(audiodb_insert_datum(adb, &datum1)) return 1; if(audiodb_insert_datum(adb, &datum2)) return 1; if(audiodb_l2norm(adb)) return 1; adb_datum_t query = {1, 2, "testquery", (double[2]) {0, 0.5}}; adb_query_id_t qid = {0}; qid.datum = &query; qid.sequence_length = 1; qid.sequence_start = 0; adb_query_parameters_t parms = {ADB_ACCUMULATION_PER_TRACK, ADB_DISTANCE_EUCLIDEAN_NORMED, 10, 10}; adb_query_refine_t refine = {0}; refine.flags |= ADB_REFINE_RADIUS; refine.radius = 5; refine.hopsize = 1; adb_query_spec_t spec; spec.qid = qid; spec.params = parms; spec.refine = refine; adb_query_results_t *results = audiodb_query_spec(adb, &spec); if(!results || results->nresults != 2) return 1; result_present_or_fail(results, "testfeature01", 0, 0, 0); result_present_or_fail(results, "testfeature10", 2, 0, 0); audiodb_query_free_results(adb, &spec, results); /* the test in the original test suite for * audioDB-the-command-line-program alters the parms.ntracks, which * is not very meaningful in this context (given that we don't do * aggregation, but simply return valid points); here instead we * check that radius filtering works. */ spec.refine.radius = 1; results = audiodb_query_spec(adb, &spec); if(!results || results->nresults != 1) return 1; result_present_or_fail(results, "testfeature01", 0, 0, 0); audiodb_query_free_results(adb, &spec, results); spec.qid.datum->data = (double[2]) {0.5, 0}; spec.refine.radius = 5; results = audiodb_query_spec(adb, &spec); if(!results || results->nresults != 2) return 1; result_present_or_fail(results, "testfeature10", 0, 0, 0); result_present_or_fail(results, "testfeature01", 2, 0, 0); audiodb_query_free_results(adb, &spec, results); spec.refine.radius = 1; results = audiodb_query_spec(adb, &spec); if(!results || results->nresults != 1) return 1; result_present_or_fail(results, "testfeature10", 0, 0, 0); audiodb_query_free_results(adb, &spec, results); audiodb_close(adb); return 104; }