Почему мой дебоузер не работает?
Я пытаюсь написать debouncer, который будет возвращать действительный аргумент (>0), если он был опровергнут (-1 четыре подпрыгивая). Я придумал это до сих пор, но он всегда возвращает -1, почему я задаюсь вопросом:
#include <stdio.h>
#include <time.h>
#include <unistd.h>
#define BOUNCETIME 500000000 //(500ms)
#define SetTime(x) clock_gettime(CLOCK_REALTIME, (x)); // set time
static struct timespec tset;
struct timespec tnow;
int DeBounce(unsigned int arg)
{
static int val = -1;
long long nsec = 0;
if (val < 0) {
val = arg;
SetTime(&tset);
return arg;
} else {
SetTime(&tnow);
if (tnow.tv_nsec < tset.tv_nsec)
nsec = tnow.tv_nsec + 1000000000;
else
nsec = tnow.tv_nsec;
if (tnow.tv_nsec - tset.tv_nsec > BOUNCETIME) {
printf("arg okay\n");
val = -1;
return arg;
}
else
printf("bounce, ignore!\n");
return -1;
}
}
int main (void)
{
printf("#1 %d\n",DeBounce(0));
usleep(1);
printf("#2 %d\n",DeBounce(1));
usleep(200);
printf("#3 %d\n",DeBounce(1));
sleep(1);
printf("#4 %d\n",DeBounce(1));
}
результат, который я получаю:
$ ./debounce
#1 0
bounce, ignore!
#2 -1
bounce, ignore!
#3 -1
bounce, ignore!
#4 -1
$
1 ответ
usleep(600);
составляет 600 микросекунд. Но ваш период отката составляет 500 миллисекунд.
более того tnow.tv_nsec - tset.tv_nsec
не правильно как tv_nsec
не полное значение времени, а только число наносекунд после секунды. Правильный способ подсчета истекшего времени в наносекундах примерно такой:
(tnow.tv_sec * 1.0e-9 + tnow.tv_nsec) - (tset.tv_sec * 1.0e-9 + tset.tv_nsec)