mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2024-12-29 04:50:03 +01:00
57f6081960
Change the API to use int32_t instead of int, to allow for greater flexibility on 8- and 16-bit platforms. Removed limitation on input arguments that min < max. Times where it can be useful to have min > max is when measuring a sensor where a higher measured voltage means a lower physical value. For example a thermistor can be connected so that the measured voltage goes down when the temperature goes up.
73 lines
1.8 KiB
C
73 lines
1.8 KiB
C
/*
|
|
* Copyright (C) 2018 Eistec AB
|
|
* Copyright (C) 2015 Freie Universität Berlin
|
|
*
|
|
* This file is subject to the terms and conditions of the GNU Lesser
|
|
* General Public License v2.1. See the file LICENSE in the top level
|
|
* directory for more details.
|
|
*/
|
|
|
|
/**
|
|
* @ingroup sys_analog_util
|
|
* @{
|
|
*
|
|
* @file
|
|
* @brief ADC utility function implementation
|
|
*
|
|
* @author Hauke Petersen <hauke.petersen@fu-berlin.de>
|
|
* @author Joakim Nohlgård <joakim.nohlgard@eistec.se>
|
|
*
|
|
* @}
|
|
*/
|
|
|
|
#include <stdint.h>
|
|
#include <inttypes.h>
|
|
|
|
#include "cpu.h"
|
|
#include "periph/adc.h"
|
|
#include "analog_util.h"
|
|
#include "assert.h"
|
|
|
|
#define ENABLE_DEBUG (0)
|
|
#include "debug.h"
|
|
|
|
/**
|
|
* @brief Convert adc_res_t resolution setting into numeric bit count
|
|
*/
|
|
static unsigned int _adc_res_bits(adc_res_t res)
|
|
{
|
|
switch (res) {
|
|
case ADC_RES_6BIT:
|
|
return 6;
|
|
case ADC_RES_8BIT:
|
|
return 8;
|
|
case ADC_RES_10BIT:
|
|
return 10;
|
|
case ADC_RES_12BIT:
|
|
return 12;
|
|
case ADC_RES_14BIT:
|
|
return 14;
|
|
case ADC_RES_16BIT:
|
|
return 16;
|
|
default:
|
|
/* Unsupported ADC resolution, modify your application to use a
|
|
* different resolution, or add it above */
|
|
assert(0 == 1);
|
|
return 0;
|
|
}
|
|
}
|
|
|
|
int32_t adc_util_map(int sample, adc_res_t res, int32_t min, int32_t max)
|
|
{
|
|
/* Using 64 bit signed int as intermediate to prevent overflow when range
|
|
* multiplied by sample requires more than 32 bits */
|
|
int32_t scaled = (((int64_t)(max - min) * sample) >> _adc_res_bits(res));
|
|
DEBUG("scaled: %" PRId32 "\n", scaled);
|
|
return (min + scaled);
|
|
}
|
|
|
|
float adc_util_mapf(int sample, adc_res_t res, float min, float max)
|
|
{
|
|
return ((((max - min) * sample) / ((int32_t)1L << _adc_res_bits(res))) + min);
|
|
}
|