免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 42595 | 回复: 0
打印 上一主题 下一主题

[C] 陀螺仪raw data 滤波 [复制链接]

论坛徽章:
14
巨蟹座
日期:2013-11-19 14:09:4615-16赛季CBA联赛之青岛
日期:2016-07-05 12:36:0515-16赛季CBA联赛之广东
日期:2016-06-29 11:45:542015亚冠之全北现代
日期:2015-07-22 08:09:472015年辞旧岁徽章
日期:2015-03-03 16:54:15巨蟹座
日期:2014-12-29 08:22:29射手座
日期:2014-12-05 08:20:39狮子座
日期:2014-11-05 12:33:52寅虎
日期:2014-08-13 09:01:31巳蛇
日期:2014-06-16 16:29:52技术图书徽章
日期:2014-04-15 08:44:01天蝎座
日期:2014-03-11 13:06:45
1 [报告]
发表于 2016-08-09 08:38 |显示全部楼层
每五笔做个平均
第一次数值是前五笔(1~5)数据平均值
第二次数值是2~7 数据平均值       ------ 按照规律,应该是 2-6 吧
第三次数值是3~8 数据平均值       ------ 按照规律,应该是 3-7 吧
  1. #include <stdio.h>
  2. #include <string.h>

  3. struct rawdata_buf
  4. {
  5.         double x[5], y[5], z[5];
  6.         double sum[3];
  7.         size_t index;
  8. };
  9. void rawdata_buf_append( struct rawdata_buf* raw, double x, double y, double z )
  10. {
  11.         raw->sum[0] += -raw->x[raw->index]+x;
  12.         raw->sum[1] += -raw->y[raw->index]+y;
  13.         raw->sum[2] += -raw->z[raw->index]+z;
  14.         raw->x[raw->index] = x;
  15.         raw->y[raw->index] = y;
  16.         raw->z[raw->index] = z;
  17.         raw->index = (raw->index+1)%5;
  18. }
  19. void rawdata_buf_average( struct rawdata_buf* raw, double* x, double* y, double* z )
  20. {
  21. #ifdef _DEBUG
  22.         for( size_t i=raw->index; i!=raw->index+5; ++i )
  23.                 printf( "(%g,%g,%g)", raw->x[i%5], raw->y[i%5], raw->z[i%5] );
  24.         putchar( '\n' );
  25. #endif

  26.         *x = raw->sum[0]/5;
  27.         *y = raw->sum[1]/5;
  28.         *z = raw->sum[2]/5;
  29. }

  30. int main( void )
  31. {
  32.         double avgx, avgy, avgz;

  33.         struct rawdata_buf buf = { 0 };
  34.         rawdata_buf_append( &buf, 0,0,0 );
  35.         rawdata_buf_append( &buf, 1,1,1 );
  36.         rawdata_buf_append( &buf, 2,2,2 );
  37.         rawdata_buf_append( &buf, 3,3,3 );
  38.         rawdata_buf_append( &buf, 4,4,4 );
  39.         rawdata_buf_average( &buf, &avgx, &avgy, &avgz );
  40.         printf( "avg = (%g,%g,%g)\n", avgx, avgy, avgz );

  41.         rawdata_buf_append( &buf, 5,5,5 );
  42.         rawdata_buf_average( &buf, &avgx, &avgy, &avgz );
  43.         printf( "avg = (%g,%g,%g)\n", avgx, avgy, avgz );

  44.         rawdata_buf_append( &buf, 6,6,6 );
  45.         rawdata_buf_average( &buf, &avgx, &avgy, &avgz );
  46.         printf( "avg = (%g,%g,%g)\n", avgx, avgy, avgz );

  47.         rawdata_buf_append( &buf, 7,7,7 );
  48.         rawdata_buf_average( &buf, &avgx, &avgy, &avgz );
  49.         printf( "avg = (%g,%g,%g)\n", avgx, avgy, avgz );

  50.         rawdata_buf_append( &buf, 8,8,8 );
  51.         rawdata_buf_average( &buf, &avgx, &avgy, &avgz );
  52.         printf( "avg = (%g,%g,%g)\n", avgx, avgy, avgz );

  53.         rawdata_buf_append( &buf, 9,9,9 );
  54.         rawdata_buf_average( &buf, &avgx, &avgy, &avgz );
  55.         printf( "avg = (%g,%g,%g)\n", avgx, avgy, avgz );

  56.         return 0;
  57. }
复制代码
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP