/* * This file is part of the libsigrok project. * * Copyright (C) 2017 Soeren Apel * * 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, see . */ /** * @file * * Conversion helper functions. */ #include #include "libsigrok-internal.h" /** @cond PRIVATE */ #define LOG_PREFIX "conv" /** @endcond */ /** * Convert analog values to logic values by using a fixed threshold. * * @param[in] analog The analog input values. * @param[in] threshold The threshold to use. * @param[out] output The converted output values; either 0 or 1. Must provide * space for count bytes. * @param[in] count The number of samples to process. * * @return SR_OK on success or SR_ERR on failure. */ SR_API int sr_a2l_threshold(const struct sr_datafeed_analog *analog, float threshold, uint8_t *output, uint64_t count) { float *input; if (!analog->encoding->is_float) { input = g_try_malloc(sizeof(float) * count); if (!input) return SR_ERR; sr_analog_to_float(analog, input); } else input = analog->data; for (uint64_t i = 0; i < count; i++) output[i] = (input[i] >= threshold) ? 1 : 0; if (!analog->encoding->is_float) g_free(input); return SR_OK; } /** * Convert analog values to logic values by using a Schmitt-trigger algorithm. * * @param analog The analog input values. * @param lo_thr The low threshold - result becomes 0 below it. * @param hi_thr The high threshold - result becomes 1 above it. * @param state The internal converter state. Must contain the state of logic * sample n-1, will contain the state of logic sample n+count upon exit. * @param output The converted output values; either 0 or 1. Must provide * space for count bytes. * @param count The number of samples to process. * * @return SR_OK on success or SR_ERR on failure. */ SR_API int sr_a2l_schmitt_trigger(const struct sr_datafeed_analog *analog, float lo_thr, float hi_thr, uint8_t *state, uint8_t *output, uint64_t count) { float *input; if (!analog->encoding->is_float) { input = g_try_malloc(sizeof(float) * count); if (!input) return SR_ERR; sr_analog_to_float(analog, input); } else input = analog->data; for (uint64_t i = 0; i < count; i++) { if (input[i] < lo_thr) *state = 0; else if (input[i] > hi_thr) *state = 1; output[i] = *state; } if (!analog->encoding->is_float) g_free(input); return SR_OK; }