📄 hp100.c,v
字号:
head 1.2;access;symbols;locks; strict;comment @ * @;1.2date 96.08.20.20.28.05; author jaf; state Exp;branches;next 1.1;1.1date 96.08.19.22.32.04; author jaf; state Exp;branches;next ;desc@@1.2log@Removed all static local variables that were SAVE'd in the Fortrancode, and put them in struct lpc10_encoder_state that is passed as anargument.Removed init function, since all initialization is now done ininit_lpc10_encoder_state().@text@/*$Log: hp100.c,v $ * Revision 1.1 1996/08/19 22:32:04 jaf * Initial revision **/#ifdef P_R_O_T_O_T_Y_P_E_Sextern int hp100_(real *speech, integer *start, integer *end, struct lpc10_encoder_state *st);extern int inithp100_(void);#endif/* -- translated by f2c (version 19951025). You must link the resulting object file with the libraries: -lf2c -lm (in that order)*/#include "f2c.h"/* ********************************************************************* *//* HP100 Version 55 *//* $Log: hp100.c,v $ * Revision 1.1 1996/08/19 22:32:04 jaf * Initial revision * *//* Revision 1.6 1996/03/15 16:45:25 jaf *//* Rearranged a few comments. *//* Revision 1.5 1996/03/14 23:20:54 jaf *//* Added comments about when INITHP100 should be used. *//* Revision 1.4 1996/03/14 23:08:08 jaf *//* Added an entry named INITHP100 that initializes the local state of *//* subroutine HP100. *//* Revision 1.3 1996/03/14 22:09:20 jaf *//* Comments added explaining which of the local variables of this *//* subroutine need to be saved from one invocation to the next, and which *//* do not. *//* Revision 1.2 1996/02/12 15:05:54 jaf *//* Added lots of comments explaining why I changed one line, which was a *//* declaration with initializations. *//* Revision 1.1 1996/02/07 14:47:12 jaf *//* Initial revision *//* ********************************************************************* *//* 100 Hz High Pass Filter *//* Jan 92 - corrected typo (1.937148 to 1.935715), *//* rounded coefficients to 7 places, *//* corrected and merged gain (.97466**4), *//* merged numerator into first two sections. *//* Input: *//* start, end - Range of samples to filter *//* Input/Output: *//* speech(end) - Speech data. *//* Indices start through end are read and modified. *//* This subroutine maintains local state from one call to the next. If *//* you want to switch to using a new audio stream for this filter, or *//* reinitialize its state for any other reason, call the ENTRY *//* INITHP100. *//* Subroutine */ int hp100_(real *speech, integer *start, integer *end, struct lpc10_encoder_state *st){ /* Temporary local copies of variables in lpc10_encoder_state. I've only created these because it might cause the loop below to execute a bit faster to access local variables, rather than variables in the lpc10_encoder_state structure. It is just a guess that it will be faster. */ real z11; real z21; real z12; real z22; /* System generated locals */ integer i__1; /* Local variables */ integer i__; real si, err;/* Arguments *//* Local variables that need not be saved *//* Local state */ /* Parameter adjustments */ if (speech) { --speech; } /* Function Body */ z11 = st->z11; z21 = st->z21; z12 = st->z12; z22 = st->z22; i__1 = *end; for (i__ = *start; i__ <= i__1; ++i__) { si = speech[i__]; err = si + z11 * 1.859076f - z21 * .8648249f; si = err - z11 * 2.f + z21; z21 = z11; z11 = err; err = si + z12 * 1.935715f - z22 * .9417004f; si = err - z12 * 2.f + z22; z22 = z12; z12 = err; speech[i__] = si * .902428f; } st->z11 = z11; st->z21 = z21; st->z12 = z12; st->z22 = z22; return 0;} /* hp100_ */@1.1log@Initial revision@text@d3 4a6 1$Log$d11 2a12 1extern int hp100_(real *speech, integer *start, integer *end);d27 4a30 1/* $Log: hp100.f,v $ */d73 2a74 2/* Subroutine */ int hp100_0_(int n__, real *speech, integer *start, integer * end)d76 10a85 1 /* Initialized data */a86 5 static real z11 = 0.f; static real z21 = 0.f; static real z12 = 0.f; static real z22 = 0.f;d103 5a107 3 switch(n__) { case 1: goto L_inithp100; }d122 5a126 1 return 0;a127 5L_inithp100: z11 = 0.f; z21 = 0.f; z12 = 0.f; z22 = 0.f;a129 11/* Subroutine */ int hp100_(real *speech, integer *start, integer *end){ return hp100_0_(0, speech, start, end); }/* Subroutine */ int inithp100_(void){ return hp100_0_(1, (real *)0, (integer *)0, (integer *)0); }@
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -