battery_monitor.cpp
Go to the documentation of this file.
1 /*
2  * Copyright (c) 2020, Richard Henrichsen
3  *
4  * All rights reserved.
5  *
6  * Redistribution and use in source and binary forms, with or without
7  * modification, are permitted provided that the following conditions are met:
8  *
9  * * Redistributions of source code must retain the above copyright notice, this
10  * list of conditions and the following disclaimer.
11  *
12  * * Redistributions in binary form must reproduce the above copyright notice,
13  * this list of conditions and the following disclaimer in the documentation
14  * and/or other materials provided with the distribution.
15  *
16  * * Neither the name of the copyright holder nor the names of its
17  * contributors may be used to endorse or promote products derived from
18  * this software without specific prior written permission.
19  *
20  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
21  * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
22  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
23  * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
24  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
25  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
26  * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
27  * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
28  * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
29  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
30  */
31 
32 #include "battery_monitor.h"
33 
36  float voltage_multiplier,
37  float current_multiplier)
38 {
41  voltage_multiplier_ = voltage_multiplier;
42  current_multiplier_ = current_multiplier;
43 }
45 {
46  return static_cast<float>(this->voltage_pin_.read()) * this->voltage_multiplier_;
47 }
49 {
50  return static_cast<float>(this->current_pin_.read()) * this->current_multiplier_;
51 }
52 
54 {
55  this->voltage_multiplier_ = multiplier;
56 }
57 
59 {
60  this->current_multiplier_ = multiplier;
61 }
62 
64 {
65  return (this->voltage_multiplier_ != 0);
66 }
67 
69 {
70  return (this->current_multiplier_ != 0);
71 }
float read_voltage() const
Read the current battery voltage.
GPIO_TypeDef * current_gpio
Definition: system.h:137
A driver for the analog-digital converters available on the microcontroller.
void set_voltage_multiplier(double multiplier)
Sets the voltage multiplier for the battery monitor.
AnalogPin voltage_pin_
float read_current() const
Read the current battery current.
double read() const
Get the last reading of the pin, in volts.
Definition: analog_pin.cpp:41
AnalogPin current_pin_
GPIO_TypeDef * voltage_gpio
Definition: system.h:134
void init(AnalogDigitalConverter *adc, GPIO_TypeDef *basePort, uint16_t pin, uint8_t adc_channel)
Initializes a pin to read analog values.
Definition: analog_pin.cpp:34
void set_current_multiplier(double multiplier)
Sets the current multiplier for the battery monitor.
void init(const BatteryMonitorHardwareStruct &def, AnalogDigitalConverter *adc, float voltage_multiplier=0, float current_multiplier=0)
Initialize the battery monitor.
bool has_voltage_sense() const
Checks if voltage sense is available. As there isn&#39;t hardware to detect this, this simply checks if t...
bool has_current_sense() const
Checks if current sense is available. As there isn&#39;t hardware to detect this, this simply checks if t...


rosflight_firmware
Author(s): Daniel Koch , James Jackson
autogenerated on Mon Feb 28 2022 23:36:07