avr: adapt scaling factor in power calc to increased sampling freq [667Hz]
This commit is contained in:
parent
d80377ee19
commit
9c5842f262
2 changed files with 11 additions and 8 deletions
|
@ -280,14 +280,17 @@ void calculate_power(struct state_struct *pstate)
|
||||||
// Since the AVR has no dedicated floating-point hardware, we need
|
// Since the AVR has no dedicated floating-point hardware, we need
|
||||||
// to resort to fixed-point calculations for converting nWh/s to W.
|
// to resort to fixed-point calculations for converting nWh/s to W.
|
||||||
// 1W = 10^6/3.6 nWh/s
|
// 1W = 10^6/3.6 nWh/s
|
||||||
// value[watt] = 3.6/10^6 * rest[nWh/s]
|
// power[watt] = 3.6/10^6 * rest[nWh/s]
|
||||||
// value[watt] = 3.6/10^6 * 65536 * (rest[nWh/s] / 65536)
|
// power[watt] = 3.6/10^6 * 65536 * (rest[nWh/s] / 65536)
|
||||||
// value[watt] = 3.6/10^6 * 65536 * 262144 / 262144 * (rest[nWh/s] / 65536)
|
// power[watt] = 3.6/10^6 * 65536 * 262144 / 262144 * (rest[nWh/s] / 65536)
|
||||||
// value[watt] = 61847.53 / 262144 * (rest[nWh/s] / 65536)
|
// power[watt] = 61847.53 / 262144 * (rest[nWh/s] / 65536)
|
||||||
// We round the constant down to 61847 to prevent 'underflow' in the
|
// We have to correct for only using 666 samples iso 2000/3, so:
|
||||||
|
// power[watt] = 61847.53 * 1/666 * 2000/3 / 262144 * (rest[nWh/s] / 65536)
|
||||||
|
// power[watt] = 61909.44 / 262144 * (rest[nWh/s] / 65536)
|
||||||
|
// We round the constant down to 61909 to prevent 'underflow' in the
|
||||||
// consecutive else statement.
|
// consecutive else statement.
|
||||||
// The error introduced in the fixed-point rounding equals 8.6*10^-6.
|
// The error introduced in the fixed-point rounding equals 7.1*10^-6.
|
||||||
MacU16X16to32(power, (uint16_t)(labs(rest)/65536), 61847);
|
MacU16X16to32(power, (uint16_t)(labs(rest)/65536), 61909);
|
||||||
power /= 262144;
|
power /= 262144;
|
||||||
|
|
||||||
if (rest >= 0) {
|
if (rest >= 0) {
|
||||||
|
|
|
@ -22,7 +22,7 @@ struct sensor_struct {
|
||||||
};
|
};
|
||||||
|
|
||||||
# define WATT 1000000000
|
# define WATT 1000000000
|
||||||
# define SECOND 666 // 667Hz - 1
|
# define SECOND 665 // 666Hz - 1
|
||||||
|
|
||||||
#define STATE_PULSE 1
|
#define STATE_PULSE 1
|
||||||
#define STATE_SKIP 2
|
#define STATE_SKIP 2
|
||||||
|
|
Loading…
Reference in a new issue