shithub: aubio

ref: c7e5ee952fddcd23c7279b80fc3f5cc2c2935bc6
dir: /tests/src/test-cvec.c/

View raw version
#include "aubio.h"
#include "utils_tests.h"

int main (void)
{
  uint_t i, window_size = 16;
  cvec_t * complex_vector = new_cvec(window_size);
  cvec_t * other_cvector = new_cvec(window_size);

  assert(cvec_norm_get_data(complex_vector) == complex_vector->norm);
  assert(cvec_phas_get_data(complex_vector) == complex_vector->phas);
  assert(complex_vector->length == window_size / 2 + 1);

  // all elements are initialized to 0
  for ( i = 0; i < complex_vector->length; i++ ) {
    assert( complex_vector->norm[i] == 0. );
    assert( complex_vector->phas[i] == 0. );
  }

  cvec_norm_set_sample(complex_vector, 2., 1);
  assert(cvec_norm_get_sample(complex_vector, 1));

  cvec_phas_set_sample(complex_vector, 2., 1);
  assert(cvec_phas_get_sample(complex_vector, 1));

  cvec_print(complex_vector);

  // set all norm and phas elements to 0
  cvec_zeros(complex_vector);
  for ( i = 0; i < complex_vector->length; i++ ) {
    assert( complex_vector->norm[i] == 0. );
    assert( complex_vector->phas[i] == 0. );
  }

  // set all norm elements to 1
  cvec_norm_ones(complex_vector);
  for ( i = 0; i < complex_vector->length; i++ ) {
    assert( complex_vector->norm[i] == 1. );
  }

  // set all norm elements to 0
  cvec_norm_zeros(complex_vector);
  for ( i = 0; i < complex_vector->length; i++ ) {
    assert( complex_vector->norm[i] == 0. );
  }

  // set all phas elements to 1
  cvec_phas_ones(complex_vector);
  for ( i = 0; i < complex_vector->length; i++ ) {
    assert( complex_vector->phas[i] == 1. );
  }

  // set all phas elements to 0
  cvec_phas_zeros(complex_vector);
  for ( i = 0; i < complex_vector->length; i++ ) {
    assert( complex_vector->phas[i] == 0. );
  }

  cvec_copy(complex_vector, other_cvector);
  // copy to self
  cvec_copy(complex_vector, complex_vector);
  // copy to a different size fails
  del_cvec(other_cvector);
  other_cvector = new_cvec(window_size + 2);
  cvec_copy(complex_vector, other_cvector);

  if (complex_vector)
    del_cvec(complex_vector);
  if (other_cvector)
    del_cvec(other_cvector);

  // wrong parameters
  assert(new_cvec(-1) == NULL);
  assert(new_cvec(0) == NULL);

  return 0;
}