2017-12-06 05:23:22 +03:00
|
|
|
/*
|
|
|
|
NAME
|
|
|
|
revid - a testbed for re-muxing and re-directing video streams as MPEG-TS over various protocols.
|
|
|
|
|
|
|
|
DESCRIPTION
|
|
|
|
See Readme.md
|
|
|
|
|
|
|
|
AUTHOR
|
|
|
|
Alan Noble <anoble@gmail.com>
|
|
|
|
|
|
|
|
LICENSE
|
|
|
|
revid is Copyright (C) 2017 Alan Noble.
|
|
|
|
|
|
|
|
It is free software: you can redistribute it and/or modify them
|
|
|
|
under the terms of the GNU General Public License as published by the
|
|
|
|
Free Software Foundation, either version 3 of the License, or (at your
|
|
|
|
option) any later version.
|
|
|
|
|
|
|
|
It is distributed in the hope that it will be useful, but WITHOUT
|
|
|
|
ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
|
|
|
FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
|
|
|
for more details.
|
|
|
|
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
|
|
along with revid in gpl.txt. If not, see [GNU licenses](http://www.gnu.org/licenses).
|
|
|
|
*/
|
|
|
|
|
2017-12-04 09:37:39 +03:00
|
|
|
package bitrate
|
|
|
|
|
|
|
|
import (
|
2017-12-06 05:23:22 +03:00
|
|
|
"fmt"
|
|
|
|
"time"
|
2017-12-04 09:37:39 +03:00
|
|
|
)
|
|
|
|
|
2017-12-06 05:23:22 +03:00
|
|
|
// bitrateCalculator implements interface BitrateCalculator
|
2017-12-04 09:37:39 +03:00
|
|
|
type BitrateCalculator struct {
|
2017-12-06 05:23:22 +03:00
|
|
|
outputDelay int // sec
|
|
|
|
now time.Time
|
|
|
|
prev time.Time
|
|
|
|
startedBefore bool
|
|
|
|
elapsedTime time.Duration
|
|
|
|
lastDisplayTime time.Time
|
2017-12-04 09:37:39 +03:00
|
|
|
}
|
|
|
|
|
2017-12-06 05:23:22 +03:00
|
|
|
// Place this at the start of the code segment that you would like to time
|
|
|
|
func (bc *BitrateCalculator) Start(outputDelay int) {
|
|
|
|
if outputDelay >= 0{
|
|
|
|
bc.outputDelay = outputDelay
|
|
|
|
} else {
|
|
|
|
bc.outputDelay = 0
|
2017-12-04 09:37:39 +03:00
|
|
|
}
|
2017-12-06 05:23:22 +03:00
|
|
|
bc.prev = time.Now()
|
|
|
|
if !bc.startedBefore {
|
|
|
|
bc.startedBefore = true
|
|
|
|
bc.elapsedTime = time.Duration(0)
|
|
|
|
bc.lastDisplayTime = time.Now()
|
|
|
|
}
|
2017-12-04 09:37:39 +03:00
|
|
|
}
|
|
|
|
|
2017-12-06 05:23:22 +03:00
|
|
|
// Place this at the end of the code segment that you would like to time
|
|
|
|
func (bc *BitrateCalculator) Stop(noOfKB float64) (bitrate int64) {
|
|
|
|
bc.now = time.Now()
|
|
|
|
deltaTime := bc.now.Sub(bc.prev)
|
|
|
|
if bc.now.Sub(bc.lastDisplayTime) > time.Duration(bc.outputDelay)*time.Second {
|
|
|
|
bitrate = int64(noOfKB / float64(deltaTime/1e9))
|
|
|
|
fmt.Printf("Bitrate: %d kbps\n", bitrate)
|
|
|
|
bc.elapsedTime = time.Duration(0)
|
|
|
|
bc.lastDisplayTime = bc.now
|
|
|
|
}
|
|
|
|
return
|
2017-12-04 09:37:39 +03:00
|
|
|
}
|