欧美极品高清xxxxhd,国产日产欧美最新,无码AV国产东京热AV无码,国产精品人与动性XXX,国产传媒亚洲综合一区二区,四库影院永久国产精品,毛片免费免费高清视频,福利所导航夜趣136

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 2616|回復: 0
打印 上一主題 下一主題
收起左側

針對16位非負數的滑動濾波函數

[復制鏈接]
跳轉到指定樓層
樓主
ID:65608 發表于 2014-8-31 02:28 | 只看該作者 回帖獎勵 |倒序瀏覽 |閱讀模式
介紹一個個人編寫的滑動濾波函數:
#define OHG_BUF_IDX_MOV_STEP          1U
#define OHG_BUF_FLG_FULL              1U
#define OHG_BUF_FLG_NOT_FULL          0U
#define OHG_BUF_IDX_RESET             0U
typedef struct _T_OHG_FILTER
{
    INT16U u16_mFilterRult;
    INT32U u32_mDataSum;
    INT8U  u8_mBufIndex;
    INT8U  u8_mBufFullFlg;
    INT8U  u8_mSampFactor;
}T_OHG_FILTER_TYP;
函數原型:


void hOverHeat_vMovFilter(INT16U sampData, T_OHG_FILTER_TYP *pMovFliterObj, INT16U *pBuf)
{
    pMovFliterObj->u32_mDataSum += sampData;
   
    pBuf[pMovFliterObj->u8_mBufIndex] = sampData;                              
    pMovFliterObj->u8_mBufIndex = (INT8U)((pMovFliterObj->u8_mBufIndex + OHG_BUF_IDX_MOV_STEP) % (pMovFliterObj->u8_mSampFactor));
   
    if (pMovFliterObj->u8_mBufFullFlg != OHG_BUF_FLG_NOT_FULL)                  
    {
        pMovFliterObj->u32_mDataSum -= pBuf[pMovFliterObj->u8_mBufIndex];
      
        pMovFliterObj->u16_mFilterRult = (INT16U)(pMovFliterObj->u32_mDataSum / (pMovFliterObj->u8_mSampFactor));
    }
    else
    {
        if (pMovFliterObj->u8_mBufIndex == OHG_BUF_IDX_RESET)
        {
            pMovFliterObj->u8_mBufFullFlg = OHG_BUF_FLG_FULL;                    
           
            pMovFliterObj->u16_mFilterRult = (INT16U)(pMovFliterObj->u32_mDataSum / (pMovFliterObj->u8_mSampFactor));
        }
        else                                                                     
        {
            pMovFliterObj->u16_mFilterRult = (INT16U)(pMovFliterObj->u32_mDataSum / pMovFliterObj->u8_mBufIndex);
        }
    }
}
用法:
1:定義對象和軟件緩沖區:
static T_OHG_FILTER_TYP  STC_CurMovFilterObj;
#define OHG_CUR_SAMP_FACTOR  10u      
static INT16U hOverHeat_aCurFilterBuf[OHG_CUR_SAMP_FACTOR];
2:初始化對象
    for(i=0; i
    {
        hOverHeat_aCurFilterBuf = 0U;
    }
   
    STC_CurMovFilterObj.u16_mFilterRult = 0U;
   
    STC_CurMovFilterObj.u32_mDataSum = 0U;
   
    STC_CurMovFilterObj.u8_mBufIndex = OHG_BUF_IDX_RESET;
    STC_CurMovFilterObj.u8_mBufFullFlg = OHG_BUF_FLG_NOT_FULL;
   
    STC_CurMovFilterObj.u8_mSampFactor = OHG_CUR_SAMP_FACTOR;
3:周期調用濾波函數:
hOverHeat_vMovFilter(((INT16U)MotorActualCur), &STC_CurMovFilterObj, hOverHeat_aCurFilterBuf);
4:需要時讀取結果:
hOverHeat_u16SysCurrent = STC_CurMovFilterObj.u16_mFilterRult;

分享到:  QQ好友和群QQ好友和群 QQ空間QQ空間 騰訊微博騰訊微博 騰訊朋友騰訊朋友
收藏收藏 分享淘帖 頂 踩
回復

使用道具 舉報

您需要登錄后才可以回帖 登錄 | 立即注冊

本版積分規則

小黑屋|51黑電子論壇 |51黑電子論壇6群 QQ 管理員QQ:125739409;技術交流QQ群281945664

Powered by 單片機教程網

快速回復 返回頂部 返回列表