Refine the pps.

pull/2199/head
winlin 4 years ago
parent a46debb4bb
commit 99b4866717

@ -43,6 +43,15 @@ SrsRateSample* SrsRateSample::update(int64_t nn, srs_utime_t t, int k)
return this;
}
void srs_pps_update(SrsRateSample& sample, int64_t nn, srs_utime_t now)
{
int pps = (int)((nn - sample.total) * 1000 / srsu2ms(now - sample.time));
if (pps == 0 && nn > sample.total) {
pps = 1; // For pps in (0, 1), we set to 1.
}
sample.update(nn, now, pps);
}
SrsPps::SrsPps(SrsWallClock* c)
{
clk_ = c;
@ -76,24 +85,19 @@ void SrsPps::update(int64_t nn)
}
if (now - sample_10s_.time >= 10 * SRS_UTIME_SECONDS) {
int kps = (int)((nn - sample_10s_.total) * 1000 / srsu2ms(now - sample_10s_.time));
sample_10s_.update(nn, now, kps);
srs_pps_update(sample_10s_, nn, now);
}
if (now - sample_30s_.time >= 30 * SRS_UTIME_SECONDS) {
int kps = (int)((nn - sample_30s_.total) * 1000 / srsu2ms(now - sample_30s_.time));
sample_30s_.update(nn, now, kps);
srs_pps_update(sample_30s_, nn, now);
}
if (now - sample_1m_.time >= 60 * SRS_UTIME_SECONDS) {
int kps = (int)((nn - sample_1m_.total) * 1000 / srsu2ms(now - sample_1m_.time));
sample_1m_.update(nn, now, kps);
srs_pps_update(sample_1m_, nn, now);
}
if (now - sample_5m_.time >= 300 * SRS_UTIME_SECONDS) {
int kps = (int)((nn - sample_5m_.total) * 1000 / srsu2ms(now - sample_5m_.time));
sample_5m_.update(nn, now, kps);
srs_pps_update(sample_5m_, nn, now);
}
if (now - sample_60m_.time >= 3600 * SRS_UTIME_SECONDS) {
int kps = (int)((nn - sample_60m_.total) * 1000 / srsu2ms(now - sample_60m_.time));
sample_60m_.update(nn, now, kps);
srs_pps_update(sample_60m_, nn, now);
}
}

Loading…
Cancel
Save