aboutsummaryrefslogtreecommitdiffstats
path: root/tests/encperf.cxx
diff options
context:
space:
mode:
authorDRC <information@virtualgl.org>2015-02-21 11:44:26 -0600
committerDRC <information@virtualgl.org>2015-02-25 13:54:35 -0600
commit77be929e03e859494a9172cb1723a4cfb8c79231 (patch)
treede8fc62fcfb282c86e5d65daacb0db6e39f3b40a /tests/encperf.cxx
parentb4c4a387e57968b7232ec3a935dcb39daa7214b5 (diff)
downloadtigervnc-77be929e03e859494a9172cb1723a4cfb8c79231.tar.gz
tigervnc-77be929e03e859494a9172cb1723a4cfb8c79231.zip
encperf: report encoded & raw-equivalent bytes
Report encoded and raw-equivalent bytes as well as compression ratio (I like to have these statistics so I can compute overall compression ratios for groups of datasets in a spreadsheet.)
Diffstat (limited to 'tests/encperf.cxx')
-rw-r--r--tests/encperf.cxx37
1 files changed, 24 insertions, 13 deletions
diff --git a/tests/encperf.cxx b/tests/encperf.cxx
index b3c4f5d1..4112a37e 100644
--- a/tests/encperf.cxx
+++ b/tests/encperf.cxx
@@ -1,4 +1,5 @@
/* Copyright 2015 Pierre Ossman <ossman@cendio.se> for Cendio AB
+ * Copyright (C) 2015 D. R. Commander. All Rights Reserved.
*
* This is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
@@ -79,7 +80,8 @@ public:
CConn(const char *filename);
~CConn();
- double getRatio();
+ void getStats(double& ratio, unsigned long long& bytes,
+ unsigned long long& rawEquivalent);
virtual void setDesktopSize(int w, int h);
virtual void setCursor(int, int, const rfb::Point&, void*, void*);
@@ -106,7 +108,7 @@ class Manager : public rfb::EncodeManager {
public:
Manager(class rfb::SConnection *conn);
- double getRatio();
+ void getStats(double&, unsigned long long&, unsigned long long&);
};
class SConn : public rfb::SConnection {
@@ -116,7 +118,7 @@ public:
void writeUpdate(const rfb::UpdateInfo& ui, const rfb::PixelBuffer* pb);
- double getRatio();
+ void getStats(double&, unsigned long long&, unsigned long long&);
virtual void setAccessRights(AccessRights ar);
@@ -199,9 +201,10 @@ CConn::~CConn()
delete decoders[i];
}
-double CConn::getRatio()
+void CConn::getStats(double& ratio, unsigned long long& bytes,
+ unsigned long long& rawEquivalent)
{
- return sc->getRatio();
+ sc->getStats(ratio, bytes, rawEquivalent);
}
void CConn::setDesktopSize(int w, int h)
@@ -266,7 +269,8 @@ Manager::Manager(class rfb::SConnection *conn) :
{
}
-double Manager::getRatio()
+void Manager::getStats(double& ratio, unsigned long long& encodedBytes,
+ unsigned long long& rawEquivalent)
{
StatsVector::iterator iter;
unsigned long long bytes, equivalent;
@@ -280,7 +284,9 @@ double Manager::getRatio()
}
}
- return (double)equivalent / bytes;
+ ratio = (double)equivalent / bytes;
+ encodedBytes = bytes;
+ rawEquivalent = equivalent;
}
SConn::SConn()
@@ -304,9 +310,10 @@ void SConn::writeUpdate(const rfb::UpdateInfo& ui, const rfb::PixelBuffer* pb)
manager->writeUpdate(ui, pb, NULL);
}
-double SConn::getRatio()
+void SConn::getStats(double& ratio, unsigned long long& bytes,
+ unsigned long long& rawEquivalent)
{
- return manager->getRatio();
+ manager->getStats(ratio, bytes, rawEquivalent);
}
void SConn::setAccessRights(AccessRights ar)
@@ -318,7 +325,8 @@ void SConn::setDesktopSize(int fb_width, int fb_height,
{
}
-static double runTest(const char *fn, double *ratio)
+static double runTest(const char *fn, double& ratio, unsigned long long& bytes,
+ unsigned long long& rawEquivalent)
{
CConn *cc;
double time;
@@ -335,7 +343,7 @@ static double runTest(const char *fn, double *ratio)
}
time = cc->encodeTime;
- *ratio = cc->getRatio();
+ cc->getStats(ratio, bytes, rawEquivalent);
delete cc;
@@ -378,6 +386,7 @@ int main(int argc, char **argv)
double times[runCount], dev[runCount];
double median, meddev, ratio;
+ unsigned long long bytes, equivalent;
fn = NULL;
for (i = 1; i < argc; i++) {
@@ -416,11 +425,11 @@ int main(int argc, char **argv)
}
// Warmup
- runTest(fn, &ratio);
+ runTest(fn, ratio, bytes, equivalent);
// Multiple runs to get a good average
for (i = 0; i < runCount; i++)
- times[i] = runTest(fn, &ratio);
+ times[i] = runTest(fn, ratio, bytes, equivalent);
// Calculate median and median deviation
sort(times, runCount);
@@ -433,6 +442,8 @@ int main(int argc, char **argv)
meddev = dev[runCount / 2];
printf("CPU time: %g s (+/- %g %)\n", median, meddev);
+ printf("Encoded bytes: %lld\n", bytes);
+ printf("Raw equivalent bytes: %lld\n", equivalent);
printf("Ratio: %g\n", ratio);
return 0;