Commit 7d7f24a5 authored by michael's avatar michael

Add clock_period parameter, this should makes the code easier to use.


git-svn-id: file:///var/local/repositories/ffmpeg/trunk@17845 9553f0bf-9b14-0410-a0b8-cfaf0461ba5b
parent e994a059
...@@ -35,10 +35,10 @@ struct TimeFilter { ...@@ -35,10 +35,10 @@ struct TimeFilter {
int count; int count;
}; };
TimeFilter * ff_timefilter_new(double feedback2_factor, double feedback3_factor) TimeFilter * ff_timefilter_new(double clock_period, double feedback2_factor, double feedback3_factor)
{ {
TimeFilter *self = av_mallocz(sizeof(TimeFilter)); TimeFilter *self = av_mallocz(sizeof(TimeFilter));
self->integrator2_state = 1.0; self->integrator2_state = clock_period;
self->feedback2_factor = feedback2_factor; self->feedback2_factor = feedback2_factor;
self->feedback3_factor = feedback3_factor; self->feedback3_factor = feedback3_factor;
return self; return self;
...@@ -98,7 +98,7 @@ main(){ ...@@ -98,7 +98,7 @@ main(){
for(par0= bestpar0*0.8; par0<=bestpar0*1.21; par0+=bestpar0*0.05){ for(par0= bestpar0*0.8; par0<=bestpar0*1.21; par0+=bestpar0*0.05){
for(par1= bestpar1*0.8; par1<=bestpar1*1.21; par1+=bestpar1*0.05){ for(par1= bestpar1*0.8; par1<=bestpar1*1.21; par1+=bestpar1*0.05){
double error=0; double error=0;
TimeFilter *tf= ff_timefilter_new(par0, par1); TimeFilter *tf= ff_timefilter_new(1, par0, par1);
for(i=0; i<SAMPLES; i++){ for(i=0; i<SAMPLES; i++){
double filtered; double filtered;
filtered= ff_timefilter_update(tf, samples[i], 1); filtered= ff_timefilter_update(tf, samples[i], 1);
......
...@@ -51,18 +51,22 @@ typedef struct TimeFilter TimeFilter; ...@@ -51,18 +51,22 @@ typedef struct TimeFilter TimeFilter;
* of the jitter, but also take a longer time for the loop to settle. A good * of the jitter, but also take a longer time for the loop to settle. A good
* starting point is something between 0.3 and 3 Hz. * starting point is something between 0.3 and 3 Hz.
* *
* @param clock_period period of the hardware clock in seconds
* (for example 1.0/44100)
*
* For more details about these parameters and background concepts please see: * For more details about these parameters and background concepts please see:
* http://www.kokkinizita.net/papers/usingdll.pdf * http://www.kokkinizita.net/papers/usingdll.pdf
*/ */
TimeFilter * ff_timefilter_new(double feedback2_factor, double feedback3_factor); TimeFilter * ff_timefilter_new(double clock_period, double feedback2_factor, double feedback3_factor);
/** /**
* Update the filter * Update the filter
* *
* This function must be called in real time, at each process cycle. * This function must be called in real time, at each process cycle.
* *
* period is the device cycle duration in seconds. For example, at * @param period the device cycle duration in clock_periods. For example, at
* 44.1Hz and a buffer size of 512 frames, period = 512 / 44100. * 44.1kHz and a buffer size of 512 frames, period = 512 when clock_period
* was 1.0/44100, or 512/44100 if clock_period was 1.
* *
* system_time, in seconds, should be the value of the system clock time, * system_time, in seconds, should be the value of the system clock time,
* at (or as close as possible to) the moment the device hardware interrupt * at (or as close as possible to) the moment the device hardware interrupt
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment