Fix compilation for non-AVX2 machines

master
Xavier Arteaga 4 years ago committed by Xavier Arteaga
parent 2c4aa1e379
commit 15356b3ec8

@ -44,7 +44,7 @@ set_target_properties(ldpc_enc_test ldpc_dec_test ldpc_dec_s_test ldpc_dec_c_tes
RUNTIME_OUTPUT_DIRECTORY "${PROJECT_SOURCE_DIR}/tests/ldpc" RUNTIME_OUTPUT_DIRECTORY "${PROJECT_SOURCE_DIR}/tests/ldpc"
) )
if(NOT DISABLE_SIMD) if(HAVE_AVX2)
add_executable(ldpc_enc_avx2_test ldpc_enc_avx2_test.c) add_executable(ldpc_enc_avx2_test ldpc_enc_avx2_test.c)
target_link_libraries(ldpc_enc_avx2_test srslte_phy) target_link_libraries(ldpc_enc_avx2_test srslte_phy)
@ -55,7 +55,7 @@ if(NOT DISABLE_SIMD)
PROPERTIES PROPERTIES
RUNTIME_OUTPUT_DIRECTORY "${PROJECT_SOURCE_DIR}/tests/ldpc" RUNTIME_OUTPUT_DIRECTORY "${PROJECT_SOURCE_DIR}/tests/ldpc"
) )
endif(NOT DISABLE_SIMD) endif(HAVE_AVX2)
add_custom_command( add_custom_command(
OUTPUT ${PROJECT_SOURCE_DIR}/tests/ldpc/examplesBG1.dat OUTPUT ${PROJECT_SOURCE_DIR}/tests/ldpc/examplesBG1.dat

@ -251,14 +251,17 @@ int main(int argc, char** argv)
double elapsed_time_dec_s = 0; double elapsed_time_dec_s = 0;
double elapsed_time_dec_c = 0; double elapsed_time_dec_c = 0;
double elapsed_time_dec_c_flood = 0; double elapsed_time_dec_c_flood = 0;
double elapsed_time_dec_avx = 0;
double elapsed_time_dec_avx_flood = 0;
int n_error_words_f = 0; int n_error_words_f = 0;
int n_error_words_s = 0; int n_error_words_s = 0;
int n_error_words_c = 0; int n_error_words_c = 0;
int n_error_words_c_flood = 0; int n_error_words_c_flood = 0;
#ifdef LV_HAVE_AVX
double elapsed_time_dec_avx = 0;
double elapsed_time_dec_avx_flood = 0;
int n_error_words_avx = 0; int n_error_words_avx = 0;
int n_error_words_avx_flood = 0; int n_error_words_avx_flood = 0;
#endif // LV_HAVE_AVX2
float noise_std_dev = srslte_convert_dB_to_amplitude(-snr); float noise_std_dev = srslte_convert_dB_to_amplitude(-snr);

@ -314,14 +314,17 @@ int main(int argc, char** argv)
double elapsed_time_dec_s = 0; double elapsed_time_dec_s = 0;
double elapsed_time_dec_c = 0; double elapsed_time_dec_c = 0;
double elapsed_time_dec_c_flood = 0; double elapsed_time_dec_c_flood = 0;
double elapsed_time_dec_avx = 0;
double elapsed_time_dec_avx_flood = 0;
int n_error_words_f = 0; int n_error_words_f = 0;
int n_error_words_s = 0; int n_error_words_s = 0;
int n_error_words_c = 0; int n_error_words_c = 0;
int n_error_words_c_flood = 0; int n_error_words_c_flood = 0;
#ifdef LV_HAVE_AVX
double elapsed_time_dec_avx = 0;
double elapsed_time_dec_avx_flood = 0;
int n_error_words_avx = 0; int n_error_words_avx = 0;
int n_error_words_avx_flood = 0; int n_error_words_avx_flood = 0;
#endif // LV_HAVE_AVX2
float noise_std_dev = srslte_convert_dB_to_amplitude(-snr); float noise_std_dev = srslte_convert_dB_to_amplitude(-snr);

@ -181,7 +181,6 @@ int main(int argc, char** argv)
double var[SNR_POINTS + 1]; double var[SNR_POINTS + 1];
double snr_db_vec[SNR_POINTS + 1]; double snr_db_vec[SNR_POINTS + 1];
int i = 0;
int j = 0; int j = 0;
int snr_points = 0; int snr_points = 0;
@ -189,7 +188,10 @@ int main(int argc, char** argv)
int errors_symb = 0; int errors_symb = 0;
int errors_symb_s = 0; int errors_symb_s = 0;
int errors_symb_c = 0; int errors_symb_c = 0;
#ifdef LV_HAVE_AVX
int errors_symb_c_avx2 = 0; int errors_symb_c_avx2 = 0;
#endif // LV_HAVE_AVX
int n_error_words[SNR_POINTS + 1]; int n_error_words[SNR_POINTS + 1];
int n_error_words_s[SNR_POINTS + 1]; int n_error_words_s[SNR_POINTS + 1];
@ -212,7 +214,9 @@ int main(int argc, char** argv)
int8_t inf8 = (1U << 7U) - 1; int8_t inf8 = (1U << 7U) - 1;
float gain_s = NAN; float gain_s = NAN;
float gain_c = NAN; float gain_c = NAN;
#ifdef LV_HAVE_AVX
float gain_c_avx2 = NAN; float gain_c_avx2 = NAN;
#endif // LV_HAVE_AVX2
srslte_polar_sets_t sets; srslte_polar_sets_t sets;
srslte_subchn_alloc_t subch; srslte_subchn_alloc_t subch;
@ -380,7 +384,7 @@ int main(int argc, char** argv)
} }
#else #else
for (i = 0; i < BATCH_SIZE; i++) { for (uint32_t i = 0; i < BATCH_SIZE; i++) {
for (j = 0; j < message_size; j++) { for (j = 0; j < message_size; j++) {
data_tx[i * message_size + j] = srslte_random_uniform_int_dist(random_gen, 0, 1); data_tx[i * message_size + j] = srslte_random_uniform_int_dist(random_gen, 0, 1);
} }
@ -388,7 +392,7 @@ int main(int argc, char** argv)
#endif #endif
// subchannel_allocation block // subchannel_allocation block
for (i = 0; i < BATCH_SIZE; i++) { for (uint32_t i = 0; i < BATCH_SIZE; i++) {
srslte_subchannel_allocation(&subch, data_tx + i * message_size, input_enc + i * code_size); srslte_subchannel_allocation(&subch, data_tx + i * message_size, input_enc + i * code_size);
} }
@ -417,7 +421,7 @@ int main(int argc, char** argv)
// check encoders have the same output. // check encoders have the same output.
// check errors with respect the output of the pipeline encoder // check errors with respect the output of the pipeline encoder
for (i = 0; i < BATCH_SIZE; i++) { for (uint32_t i = 0; i < BATCH_SIZE; i++) {
if (srslte_bit_diff(output_enc + i * code_size, output_enc_avx2 + i * code_size, code_size) != 0) { if (srslte_bit_diff(output_enc + i * code_size, output_enc_avx2 + i * code_size, code_size) != 0) {
printf("ERROR: Wrong avx2 encoder output. SNR= %f, Batch: %d\n", snr_db_vec[i_snr], i); printf("ERROR: Wrong avx2 encoder output. SNR= %f, Batch: %d\n", snr_db_vec[i_snr], i);
exit(-1); exit(-1);
@ -455,7 +459,7 @@ int main(int argc, char** argv)
} }
// check errors - float decpder // check errors - float decpder
for (i = 0; i < BATCH_SIZE; i++) { for (uint32_t i = 0; i < BATCH_SIZE; i++) {
errors_symb = srslte_bit_diff(data_tx + i * message_size, data_rx + i * message_size, message_size); errors_symb = srslte_bit_diff(data_tx + i * message_size, data_rx + i * message_size, message_size);
if (errors_symb != 0) { if (errors_symb != 0) {
@ -488,7 +492,7 @@ int main(int argc, char** argv)
} }
// check errors 16-bit decoder // check errors 16-bit decoder
for (i = 0; i < BATCH_SIZE; i++) { for (uint32_t i = 0; i < BATCH_SIZE; i++) {
errors_symb_s = srslte_bit_diff(data_tx + i * message_size, data_rx_s + i * message_size, message_size); errors_symb_s = srslte_bit_diff(data_tx + i * message_size, data_rx_s + i * message_size, message_size);
if (errors_symb_s != 0) { if (errors_symb_s != 0) {
@ -519,7 +523,7 @@ int main(int argc, char** argv)
} }
// check errors 8-bits decoder // check errors 8-bits decoder
for (i = 0; i < BATCH_SIZE; i++) { for (uint32_t i = 0; i < BATCH_SIZE; i++) {
errors_symb_c = srslte_bit_diff(data_tx + i * message_size, data_rx_c + i * message_size, message_size); errors_symb_c = srslte_bit_diff(data_tx + i * message_size, data_rx_c + i * message_size, message_size);
@ -552,7 +556,7 @@ int main(int argc, char** argv)
} }
// check errors 8-bits decoder // check errors 8-bits decoder
for (i = 0; i < BATCH_SIZE; i++) { for (uint32_t i = 0; i < BATCH_SIZE; i++) {
errors_symb_c_avx2 = errors_symb_c_avx2 =
srslte_bit_diff(data_tx + i * message_size, data_rx_c_avx2 + i * message_size, message_size); srslte_bit_diff(data_tx + i * message_size, data_rx_c_avx2 + i * message_size, message_size);
@ -780,7 +784,7 @@ int main(int argc, char** argv)
); );
} else { } else {
for (int i_snr = 0; i_snr < snr_points; i_snr++) { for (i_snr = 0; i_snr < snr_points; i_snr++) {
if (n_error_words_s[i_snr] > 10 * n_error_words[i_snr]) { if (n_error_words_s[i_snr] > 10 * n_error_words[i_snr]) {
perror("16-bit performance at SNR = %d too low!"); perror("16-bit performance at SNR = %d too low!");
exit(-1); exit(-1);

Loading…
Cancel
Save