You've already forked FFmpeg
							
							
				mirror of
				https://github.com/FFmpeg/FFmpeg.git
				synced 2025-10-30 23:18:11 +02:00 
			
		
		
		
	various resampling fixes
Originally committed as revision 3271 to svn://svn.ffmpeg.org/ffmpeg/trunk
This commit is contained in:
		| @@ -175,7 +175,7 @@ int audio_resample(ReSampleContext *s, short *output, short *input, int nb_sampl | ||||
|     short *buftmp2[2], *buftmp3[2]; | ||||
|     int lenout; | ||||
|  | ||||
|     if (s->input_channels == s->output_channels && s->ratio == 1.0) { | ||||
|     if (s->input_channels == s->output_channels && s->ratio == 1.0 && 0) { | ||||
|         /* nothing to do */ | ||||
|         memcpy(output, input, nb_samples * s->input_channels * sizeof(short)); | ||||
|         return nb_samples; | ||||
|   | ||||
| @@ -123,8 +123,8 @@ AVResampleContext *av_resample_init(int out_rate, int in_rate){ | ||||
|     c->filter_length= ceil(16.0/factor); | ||||
|     c->filter_bank= av_mallocz(c->filter_length*(PHASE_COUNT+1)*sizeof(short)); | ||||
|     av_build_filter(c->filter_bank, factor, c->filter_length, PHASE_COUNT, 1<<FILTER_SHIFT, 1); | ||||
|     c->filter_bank[c->filter_length*PHASE_COUNT + (c->filter_length-1) + 1]= (1<<FILTER_SHIFT)-1; | ||||
|     c->filter_bank[c->filter_length*PHASE_COUNT + (c->filter_length-1) + 2]= 1; | ||||
|     c->filter_bank[c->filter_length*PHASE_COUNT + (c->filter_length-1)/2 + 1]= (1<<FILTER_SHIFT)-1; | ||||
|     c->filter_bank[c->filter_length*PHASE_COUNT + (c->filter_length-1)/2 + 2]= 1; | ||||
|  | ||||
|     c->src_incr= out_rate; | ||||
|     c->ideal_dst_incr= c->dst_incr= in_rate * PHASE_COUNT; | ||||
| @@ -170,7 +170,7 @@ int av_resample(AVResampleContext *c, short *dst, short *src, int *consumed, int | ||||
|          | ||||
|         if(sample_index < 0){ | ||||
|             for(i=0; i<c->filter_length; i++) | ||||
|                 val += src[ABS(sample_index + i)] * filter[i]; | ||||
|                 val += src[ABS(sample_index + i) % src_size] * filter[i]; | ||||
|         }else if(sample_index + c->filter_length > src_size){ | ||||
|             break; | ||||
|         }else{ | ||||
| @@ -199,6 +199,9 @@ int av_resample(AVResampleContext *c, short *dst, short *src, int *consumed, int | ||||
|             index++; | ||||
|         } | ||||
|     } | ||||
|     *consumed= FFMAX(index, 0) >> PHASE_SHIFT; | ||||
|     index= FFMIN(index, 0); | ||||
|  | ||||
|     if(update_ctx){ | ||||
|         if(c->compensation_distance){ | ||||
|             c->compensation_distance -= dst_index; | ||||
| @@ -206,9 +209,8 @@ int av_resample(AVResampleContext *c, short *dst, short *src, int *consumed, int | ||||
|                 c->dst_incr= c->ideal_dst_incr; | ||||
|         } | ||||
|         c->frac= frac; | ||||
|         c->index=0; | ||||
|         c->index= index; | ||||
|     } | ||||
|     *consumed= index >> PHASE_SHIFT; | ||||
| #if 0     | ||||
|     if(update_ctx && !c->compensation_distance){ | ||||
| #undef rand | ||||
|   | ||||
		Reference in New Issue
	
	Block a user