3582
- 收藏
- 点赞
- 分享
- 举报
HISI3531A定时精度很不准确
各位好:
本人在使用定时操作时发现其定时的精度很不准确,下面是本人的测试例子:
include
#include
#include
#include
#include
#include
#define user_gettimeofday(a, b) do{struct timespec res;clock_gettime(CLOCK_MONOTONIC, &res); (a)->tv_sec = res.tv_sec; (a)->tv_usec = res.tv_nsec/1000;}while(0)
int delay(unsigned ms)
{
struct timeval tv;
tv.tv_sec = ms/1000;
tv.tv_usec = (ms%1000)*1000;
return select(0, NULL, NULL, NULL, &tv);
}
int main(int argc, char **argv)
{
unsigned int InterlaceTime = atoi(argv[1]);
printf("InterlaceTime %u\n", InterlaceTime);
struct timeval CurTime;
while(1) {
//gettimeofday(&CurTime, NULL);
user_gettimeofday(&CurTime, NULL);
unsigned int a = CurTime.tv_sec*1000 + CurTime.tv_usec/1000;
printf("select return %d\n", delay(InterlaceTime));
//usleep(InterlaceTime);
//gettimeofday(&CurTime, NULL);
user_gettimeofday(&CurTime, NULL);
unsigned int b = CurTime.tv_sec*1000 + CurTime.tv_usec/1000;
printf("%u - %u = %u\n", b, a, b-a);
}
return 0;
}
测试结果:
定时30毫秒,实际通过计算得到的定时间隔是40ms;
经多次验证,发现其精度仅10毫秒;
问题:
该芯片的精度这么低???
本人在使用定时操作时发现其定时的精度很不准确,下面是本人的测试例子:
include
#include
#include
#include
#include
#include
#define user_gettimeofday(a, b) do{struct timespec res;clock_gettime(CLOCK_MONOTONIC, &res); (a)->tv_sec = res.tv_sec; (a)->tv_usec = res.tv_nsec/1000;}while(0)
int delay(unsigned ms)
{
struct timeval tv;
tv.tv_sec = ms/1000;
tv.tv_usec = (ms%1000)*1000;
return select(0, NULL, NULL, NULL, &tv);
}
int main(int argc, char **argv)
{
unsigned int InterlaceTime = atoi(argv[1]);
printf("InterlaceTime %u\n", InterlaceTime);
struct timeval CurTime;
while(1) {
//gettimeofday(&CurTime, NULL);
user_gettimeofday(&CurTime, NULL);
unsigned int a = CurTime.tv_sec*1000 + CurTime.tv_usec/1000;
printf("select return %d\n", delay(InterlaceTime));
//usleep(InterlaceTime);
//gettimeofday(&CurTime, NULL);
user_gettimeofday(&CurTime, NULL);
unsigned int b = CurTime.tv_sec*1000 + CurTime.tv_usec/1000;
printf("%u - %u = %u\n", b, a, b-a);
}
return 0;
}
测试结果:
定时30毫秒,实际通过计算得到的定时间隔是40ms;
经多次验证,发现其精度仅10毫秒;
问题:
该芯片的精度这么低???
我来回答
回答11个
时间排序
认可量排序
认可0
认可0
认可0
认可0
认可0
认可0
认可0
认可0
认可0
认可0
认可0
或将文件直接拖到这里
悬赏:
E币
网盘
* 网盘链接:
* 提取码:
悬赏:
E币
Markdown 语法
- 加粗**内容**
- 斜体*内容*
- 删除线~~内容~~
- 引用> 引用内容
- 代码`代码`
- 代码块```编程语言↵代码```
- 链接[链接标题](url)
- 无序列表- 内容
- 有序列表1. 内容
- 缩进内容
- 图片
相关问答
-
2016-07-20 11:41:30
-
2016-07-20 11:45:40
-
2016-11-28 16:33:39
-
2019-01-03 09:38:05
-
42018-06-09 15:31:27
-
2019-01-03 15:23:22
-
2023-07-13 15:58:31
-
2018-12-10 13:49:22
-
2019-01-22 14:19:32
-
2016-04-15 14:46:24
-
2016-10-19 15:12:58
-
2020-11-06 11:35:39
-
2021-01-09 16:02:40
-
2018-12-24 10:56:36
-
2017-05-19 16:28:28
-
2019-07-23 17:25:48
-
2021-01-04 10:51:51
-
172025-01-06 08:50:59
-
2020-07-09 19:17:48
无更多相似问答 去提问
点击登录
-- 积分
-- E币
提问
—
收益
—
被采纳
—
我要提问
切换马甲
上一页
下一页
悬赏问答
-
10svp nnn目标检测不全
-
10hi35169dv500平台使用http协议推拉流UVC摄像头,帧率问题
-
10hi3516cv610关于YOLO优化和调优问题
-
10hi_mpi_vpss_get_chn_frame err:0xa0078016报错
-
5gk7205v200(hisi3516ev200)如何接入b656?
-
30pipe管道创建失败
-
10atc转换模型失败
-
20拍摄静止画面显示正常,拍摄运动的画面出现马赛克显示
-
100hi3516cv610 通过易百纳官方SDK中编译出的uboot env kernel,移植到自己的工程中,MPP初始化时出现内核拷贝数据到用户端时出现错误导致内核进入pain模式进而时内核重启
-
5hisi3519 gs2972 bt1120 转sdi 无法正常显示问题
举报反馈
举报类型
- 内容涉黄/赌/毒
- 内容侵权/抄袭
- 政治相关
- 涉嫌广告
- 侮辱谩骂
- 其他
详细说明
提醒
你的问题还没有最佳答案,是否结题,结题后将扣除20%的悬赏金
取消
确认
提醒
你的问题还没有最佳答案,是否结题,结题后将根据回答情况扣除相应悬赏金(1回答=1E币)
取消
确认

微信扫码分享
QQ好友