亚洲av成人无遮挡网站在线观看,少妇性bbb搡bbb爽爽爽,亚洲av日韩精品久久久久久,兔费看少妇性l交大片免费,无码少妇一区二区三区

  免費(fèi)注冊(cè) 查看新帖 |

Chinaunix

  平臺(tái) 論壇 博客 文庫(kù)
最近訪問板塊 發(fā)新帖
查看: 42754 | 回復(fù): 5
打印 上一主題 下一主題

[C] 陀螺儀raw data 濾波 [復(fù)制鏈接]

論壇徽章:
1
2015年迎新春徽章
日期:2015-03-04 09:49:03
跳轉(zhuǎn)到指定樓層
1 [收藏(0)] [報(bào)告]
發(fā)表于 2016-08-09 02:07 |只看該作者 |倒序?yàn)g覽
本帖最后由 shihyu 于 2016-08-09 02:08 編輯

我想把 陀螺儀raw data 做濾波 , 每五筆做個(gè)平均
陀螺儀raw data 每筆數(shù)據(jù)有 x , y, z 三個(gè)軸的數(shù)值

第一次數(shù)值是前五筆(1~5)數(shù)據(jù)平均值
第二次數(shù)值是2~7 數(shù)據(jù)平均值
第三次數(shù)值是3~8 數(shù)據(jù)平均值
之后依此類推

陀螺儀raw data 是不斷更新進(jìn)來(lái) , 五筆不斷更新搬動(dòng)數(shù)據(jù) , 如果用 array 存放搬動(dòng)數(shù)據(jù)感覺效率 , 會(huì)是用 linked list

因?yàn)榇a要放在 stm32 板子上所以需要考量到效率問題 , 不知道怎么更新存放這些數(shù)據(jù)效率比較好?

論壇徽章:
5
2015年辭舊歲徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:53:172015亞冠之水原三星
日期:2015-06-02 16:34:202015年亞冠紀(jì)念徽章
日期:2015-10-19 18:13:37程序設(shè)計(jì)版塊每日發(fā)帖之星
日期:2015-11-08 06:20:00
2 [報(bào)告]
發(fā)表于 2016-08-09 08:07 |只看該作者
Round Robin

論壇徽章:
14
巨蟹座
日期:2013-11-19 14:09:4615-16賽季CBA聯(lián)賽之青島
日期:2016-07-05 12:36:0515-16賽季CBA聯(lián)賽之廣東
日期:2016-06-29 11:45:542015亞冠之全北現(xiàn)代
日期: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技術(shù)圖書徽章
日期:2014-04-15 08:44:01天蝎座
日期:2014-03-11 13:06:45
3 [報(bào)告]
發(fā)表于 2016-08-09 08:38 |只看該作者
每五筆做個(gè)平均
第一次數(shù)值是前五筆(1~5)數(shù)據(jù)平均值
第二次數(shù)值是2~7 數(shù)據(jù)平均值       ------ 按照規(guī)律,應(yīng)該是 2-6 吧
第三次數(shù)值是3~8 數(shù)據(jù)平均值       ------ 按照規(guī)律,應(yīng)該是 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. }
復(fù)制代碼

論壇徽章:
1
2015年迎新春徽章
日期:2015-03-04 09:49:03
4 [報(bào)告]
發(fā)表于 2016-08-09 09:28 |只看該作者
五筆是最新五筆 ,太舊數(shù)據(jù)就捨棄

論壇徽章:
13
程序設(shè)計(jì)版塊每日發(fā)帖之星
日期:2016-06-29 06:20:00每日論壇發(fā)貼之星
日期:2016-08-14 06:20:00操作系統(tǒng)版塊每日發(fā)帖之星
日期:2016-08-14 06:20:00每日論壇發(fā)貼之星
日期:2016-08-13 06:20:00數(shù)據(jù)庫(kù)技術(shù)版塊每日發(fā)帖之星
日期:2016-08-13 06:20:00程序設(shè)計(jì)版塊每日發(fā)帖之星
日期:2016-08-13 06:20:00IT運(yùn)維版塊每日發(fā)帖之星
日期:2016-08-13 06:20:00每日論壇發(fā)貼之星
日期:2016-08-12 06:20:00數(shù)據(jù)庫(kù)技術(shù)版塊每日發(fā)帖之星
日期:2016-08-12 06:20:00程序設(shè)計(jì)版塊每日發(fā)帖之星
日期:2016-08-12 06:20:00操作系統(tǒng)版塊每日發(fā)帖之星
日期:2016-08-12 06:20:00綜合交流區(qū)版塊每日發(fā)帖之星
日期:2016-08-09 06:20:00
5 [報(bào)告]
發(fā)表于 2016-08-09 10:46 |只看該作者
路過幫頂~~~

論壇徽章:
36
子鼠
日期:2013-08-28 22:23:29黃金圣斗士
日期:2015-12-01 11:37:51程序設(shè)計(jì)版塊每日發(fā)帖之星
日期:2015-12-14 06:20:00CU十四周年紀(jì)念徽章
日期:2015-12-22 16:50:40IT運(yùn)維版塊每日發(fā)帖之星
日期:2016-01-25 06:20:0015-16賽季CBA聯(lián)賽之深圳
日期:2016-01-27 10:31:172016猴年福章徽章
日期:2016-02-18 15:30:3415-16賽季CBA聯(lián)賽之福建
日期:2016-04-07 11:25:2215-16賽季CBA聯(lián)賽之青島
日期:2016-04-29 18:02:5915-16賽季CBA聯(lián)賽之北控
日期:2016-06-20 17:38:50技術(shù)圖書徽章
日期:2016-07-19 13:54:03程序設(shè)計(jì)版塊每日發(fā)帖之星
日期:2016-08-21 06:20:00
6 [報(bào)告]
發(fā)表于 2016-08-09 10:57 |只看該作者
  1. float calc(float a[], int size, int newNum)
  2. {
  3.         static bool inited = false;
  4.         static float sum = 0;
  5.         static int idx = 0;

  6.         if(!inited)
  7.         {
  8.                 for(int i = 0; i < size; i++)
  9.                 {
  10.                         sum += a[i];
  11.                 }
  12.                 inited = true;
  13.         }
  14.         else
  15.         {
  16.                 sum -= (a[idx] - newNum);
  17.                 a[idx++] = newNum;
  18.                 idx %= size;
  19.         }

  20.         return sum / size;
  21. }
復(fù)制代碼
您需要登錄后才可以回帖 登錄 | 注冊(cè)

本版積分規(guī)則 發(fā)表回復(fù)

  

北京盛拓優(yōu)訊信息技術(shù)有限公司. 版權(quán)所有 京ICP備16024965號(hào)-6 北京市公安局海淀分局網(wǎng)監(jiān)中心備案編號(hào):11010802020122 niuxiaotong@pcpop.com 17352615567
未成年舉報(bào)專區(qū)
中國(guó)互聯(lián)網(wǎng)協(xié)會(huì)會(huì)員  聯(lián)系我們:huangweiwei@itpub.net
感謝所有關(guān)心和支持過ChinaUnix的朋友們 轉(zhuǎn)載本站內(nèi)容請(qǐng)注明原作者名及出處

清除 Cookies - ChinaUnix - Archiver - WAP - TOP