diff --git a/pkg/jitter/jitter.go b/pkg/jitter/jitter.go index 87f0dc2..a1a5246 100644 --- a/pkg/jitter/jitter.go +++ b/pkg/jitter/jitter.go @@ -27,6 +27,8 @@ func (f *Factory) CreateBuffer() Buffer { return NewJitter(f.minLatency, f.maxLatency, f.window, f.defaultTickInterval, f.listener) } +const negativeThreshold = 2 + type deltaWithSampleCnt struct { delta int64 sampleCnt int64 @@ -89,7 +91,7 @@ func (b *Jitter) Put(p *Packet) { b.listener.OnPacketEnqueue(b.targetTime(), b.sumRemainingTs(), p) - if !b.marked || math.Abs(float64(p.Timestamp-b.currentTime())) > float64(b.maxLatency) { + if !b.marked || b.shouldReSyncWith(p) { oldCurrent := b.currentTime() b.init(p.Timestamp) newCurrent := b.currentTime() @@ -106,6 +108,17 @@ func (b *Jitter) Put(p *Packet) { } } +func (b *Jitter) shouldReSyncWith(p *Packet) bool { + gap := p.Timestamp - b.currentTime() + if gap < 0 && gap <= -negativeThreshold*b.defaultTickInterval { + return true + } + if gap > 0 && gap >= b.maxLatency { + return true + } + return false +} + func (b *Jitter) Get() ([]*Packet, bool) { b.Lock() defer b.Unlock()