1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86
|
// $Id: stats.cpp 91670 2010-09-08 18:02:26Z johnnyw $
#include "stats.h"
Stats::Stats(int size) {
throughput_ = new float[size];
latency_ = new float[size];
thread_count_ = size;
init_fini_ = new Init_Fini_t[2*size];
for(int i = 0; i < size; i++)
throughput_[i] = latency_[i] = 0;
}
void Stats::log(int id, float throughput, float latency) {
throughput_[id] = throughput;
latency_[id] = latency;
}
// Unused for now.
void Stats::print(char *message) {
ACE_UNUSED_ARG (message);
// char time_buf[64];
// long ltime;
// time(<ime);
// ACE_OS::ctime_r(<ime, time_buf, sizeof time_buf);
// if(ACE_OS::gettimeofday() == -1) {
// perror("gettimeofday");
// }
// time_buf[strlen(time_buf)-1] = 0;
// printf("%010ld%09ld \t %s %s\n", tp.tv_sec, tp.tv_usec, time_buf, message);
}
int comp(const void *a, const void *b) {
Init_Fini_t *A = (Init_Fini_t *)a;
Init_Fini_t *B = (Init_Fini_t *)b;
return (A->timestamp < B->timestamp) ? -1 : (A->timestamp > B->timestamp);
}
void Stats::output() {
int i;
float tavg = 0, lavg = 0;
ACE_OS::qsort(init_fini_, 2*thread_count_, sizeof(Init_Fini_t), comp);
int max = 0,thread_peak = 0;
for(i = 0; i < 2*thread_count_; i++) {
// cerr << " " << ((init_fini_[i].type == THREAD_START) ? "START": "END") << " " << init_fini_[i].timestamp.sec() << "." << init_fini_[i].timestamp.usec() << endl;
if(init_fini_[i].type == THREAD_START) {
if(++thread_peak > max)
max = thread_peak;
}
else thread_peak--;
}
for(i = 0; i < thread_count_; i++) {
tavg += throughput_[i];
lavg += latency_[i];
}
cout << " " << tavg/thread_count_ << " " << lavg/thread_count_ << " " << max;
}
void Stats::i_have_started(int id) {
init_fini_[2*id].type = THREAD_START;
init_fini_[2*id].timestamp = ACE_OS::gettimeofday();
}
void Stats::i_am_done(int id) {
init_fini_[(2*id)+1].type = THREAD_END;
init_fini_[(2*id)+1].timestamp = ACE_OS::gettimeofday();
}
|