📄 dc_filter.s43
字号:
//--------------------------------------------------------------------------
//
// Software for MSP430 based e-meters.
//
// THIS PROGRAM IS PROVIDED "AS IS". TI MAKES NO WARRANTIES OR
// REPRESENTATIONS, EITHER EXPRESS, IMPLIED OR STATUTORY,
// INCLUDING ANY IMPLIED WARRANTIES OF MERCHANTABILITY, FITNESS
// FOR A PARTICULAR PURPOSE, LACK OF VIRUSES, ACCURACY OR
// COMPLETENESS OF RESPONSES, RESULTS AND LACK OF NEGLIGENCE.
// TI DISCLAIMS ANY WARRANTY OF TITLE, QUIET ENJOYMENT, QUIET
// POSSESSION, AND NON-INFRINGEMENT OF ANY THIRD PARTY
// INTELLECTUAL PROPERTY RIGHTS WITH REGARD TO THE PROGRAM OR
// YOUR USE OF THE PROGRAM.
//
// IN NO EVENT SHALL TI BE LIABLE FOR ANY SPECIAL, INCIDENTAL,
// CONSEQUENTIAL OR INDIRECT DAMAGES, HOWEVER CAUSED, ON ANY
// THEORY OF LIABILITY AND WHETHER OR NOT TI HAS BEEN ADVISED
// OF THE POSSIBILITY OF SUCH DAMAGES, ARISING IN ANY WAY OUT
// OF THIS AGREEMENT, THE PROGRAM, OR YOUR USE OF THE PROGRAM.
// EXCLUDED DAMAGES INCLUDE, BUT ARE NOT LIMITED TO, COST OF
// REMOVAL OR REINSTALLATION, COMPUTER TIME, LABOR COSTS, LOSS
// OF GOODWILL, LOSS OF PROFITS, LOSS OF SAVINGS, OR LOSS OF
// USE OR INTERRUPTION OF BUSINESS. IN NO EVENT WILL TI'S
// AGGREGATE LIABILITY UNDER THIS AGREEMENT OR ARISING OUT OF
// YOUR USE OF THE PROGRAM EXCEED FIVE HUNDRED DOLLARS
// (U.S.$500).
//
// Unless otherwise stated, the Program written and copyrighted
// by Texas Instruments is distributed as "freeware". You may,
// only under TI's copyright in the Program, use and modify the
// Program without any charge or restriction. You may
// distribute to third parties, provided that you transfer a
// copy of this license to the third party and the third party
// agrees to these terms by its first use of the Program. You
// must reproduce the copyright notice and any other legend of
// ownership on each copy or partial copy, of the Program.
//
// You acknowledge and agree that the Program contains
// copyrighted material, trade secrets and other TI proprietary
// information and is protected by copyright laws,
// international copyright treaties, and trade secret laws, as
// well as other intellectual property laws. To protect TI's
// rights in the Program, you agree not to decompile, reverse
// engineer, disassemble or otherwise translate any object code
// versions of the Program to a human-readable form. You agree
// that in no event will you alter, remove or destroy any
// copyright notice included in the Program. TI reserves all
// rights not specifically granted under this license. Except
// as specifically provided herein, nothing in this agreement
// shall be construed as conferring by implication, estoppel,
// or otherwise, upon you, any license or other right under any
// TI patents, copyrights or trade secrets.
//
// You may not use the Program in non-TI devices.
//
// File: shift48.s43
//
// Steve Underwood <steve-underwood@ti.com>
// Texas Instruments Hong Kong Ltd.
//
// $Id$
//
//--------------------------------------------------------------------------
#include "io.h"
/* A routine to filter away the DC content from an AC mains waveform
signal. It does this my using a heavily damped integrator to estimate
the DC level. The current DC level is then subtracted from the signal. */
/* One would like to estimate DC by something like:
z += ((((int32_t) x << 15) - z) >> 14);
return x - (z >> 15);
but this:
z += ((((int32_t) x << 16) - z) >> 14);
return x - (z >> 16);
is a bit faster, and the shift by 16 will never
cause an overflow in this application. However,
remember this is not a generic DC filter! */
;int16_t dc_filter(register int32_t *p, register int16_t x)
public dc_filter
RSEG CODE
dc_filter
#if defined(__MSP430_HAS_MSP430X_CPU__)
pushm.w #2,R9
#else
push.w R8
push.w R9
#endif
clr R9
mov R14,R8
sub 0(R12),R9 ; subtract filter_state from (sample << 16)
subc 2(R12),R8
rla R9 ; >> 14
rlc R8
jc dc_filter_1
rlc R9
rlc R8
rlc R9
and #0x0003,R9
jmp dc_filter_2
dc_filter_1
rlc R9
rlc R8
rlc R9
bis #0xFFFC,R9
dc_filter_2
add 0(R12),R8 ; + filter_state
addc 2(R12),R9
mov R8,0(R12) ; save new filter_state
mov R9,2(R12)
sub R9,R14 ; sample - filter_state
mov R14,R12
#if defined(__MSP430_HAS_MSP430X_CPU__)
popm.w #2,R9
reta
#else
pop.w R9
pop.w R8
ret
#endif
end
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -