mirror of
https://github.com/NGSolve/netgen.git
synced 2025-01-24 03:40:34 +05:00
132 lines
3.0 KiB
C++
132 lines
3.0 KiB
C++
/**************************************************************************/
|
|
/* File: profiler.cpp */
|
|
/* Author: Joachim Schoeberl */
|
|
/* Date: 19. Apr. 2002 */
|
|
/**************************************************************************/
|
|
|
|
|
|
#include <myadt.hpp>
|
|
|
|
namespace netgen
|
|
{
|
|
//using namespace netgen;
|
|
|
|
long int NgProfiler::tottimes[SIZE];
|
|
long int NgProfiler::starttimes[SIZE];
|
|
long int NgProfiler::counts[SIZE];
|
|
string NgProfiler::names[SIZE];
|
|
int NgProfiler::usedcounter[SIZE];
|
|
|
|
|
|
NgProfiler :: NgProfiler()
|
|
{
|
|
for (int i = 0; i < SIZE; i++)
|
|
{
|
|
tottimes[i] = 0;
|
|
usedcounter[i] = 0;
|
|
}
|
|
|
|
total_timer = CreateTimer ("total CPU time");
|
|
StartTimer (total_timer);
|
|
}
|
|
|
|
NgProfiler :: ~NgProfiler()
|
|
{
|
|
#ifndef PARALLEL
|
|
StopTimer (total_timer);
|
|
#endif
|
|
|
|
//ofstream prof;
|
|
//prof.open("ng.prof");
|
|
|
|
// ofstream-constructor may be called after STL-stuff is destructed,
|
|
// which leads to an "order of destruction"-problem,
|
|
// thus we use the C-variant:
|
|
|
|
if (getenv ("NGPROFILE"))
|
|
{
|
|
char filename[100];
|
|
#ifdef PARALLEL
|
|
sprintf (filename, "netgen.prof.%d", id);
|
|
#else
|
|
sprintf (filename, "netgen.prof");
|
|
#endif
|
|
|
|
if (id == 0) printf ("write profile to file netgen.prof\n");
|
|
FILE *prof = fopen(filename,"w");
|
|
Print (prof);
|
|
fclose(prof);
|
|
}
|
|
}
|
|
|
|
|
|
// void NgProfiler :: Print (ostream & prof)
|
|
// {
|
|
// for (int i = 0; i < SIZE; i++)
|
|
// if (counts[i] != 0 || usedcounter[i] != 0)
|
|
// {
|
|
// prof.setf (ios::fixed, ios::floatfield);
|
|
// prof.setf (ios::showpoint);
|
|
|
|
// prof // << "job " << setw(3) << i
|
|
// << "calls " << setw(8) << counts[i]
|
|
// << ", time " << setprecision(2) << setw(6) << double(tottimes[i]) / CLOCKS_PER_SEC << " sec";
|
|
|
|
// if (usedcounter[i])
|
|
// prof << " " << names[i];
|
|
// else
|
|
// prof << " " << i;
|
|
|
|
// prof << endl;
|
|
// }
|
|
// }
|
|
|
|
|
|
void NgProfiler :: Print (FILE * prof)
|
|
{
|
|
for (int i = 0; i < SIZE; i++)
|
|
if (counts[i] != 0 || usedcounter[i] != 0)
|
|
{
|
|
//fprintf(prof,"job %3i calls %8i, time %6.2f sec",i,counts[i],double(tottimes[i]) / CLOCKS_PER_SEC);
|
|
#ifndef USE_TSC
|
|
fprintf(prof,"calls %8li, time %6.2f sec",counts[i],double(tottimes[i]) / CLOCKS_PER_SEC);
|
|
#else
|
|
fprintf(prof,"calls %8li, time %6.2f sec",counts[i],double(tottimes[i]) / 2.7e9);
|
|
#endif
|
|
if(usedcounter[i])
|
|
fprintf(prof," %s",names[i].c_str());
|
|
else
|
|
fprintf(prof," %i",i);
|
|
fprintf(prof,"\n");
|
|
}
|
|
}
|
|
|
|
int NgProfiler :: CreateTimer (const string & name)
|
|
{
|
|
for (int i = SIZE-1; i > 0; i--)
|
|
if(names[i] == name)
|
|
return i;
|
|
|
|
for (int i = SIZE-1; i > 0; i--)
|
|
if (!usedcounter[i])
|
|
{
|
|
usedcounter[i] = 1;
|
|
names[i] = name;
|
|
return i;
|
|
}
|
|
return -1;
|
|
}
|
|
|
|
|
|
void NgProfiler :: ClearTimers ()
|
|
{
|
|
for (int i = 0; i < SIZE; i++)
|
|
{
|
|
tottimes[i] = 0;
|
|
counts[i] = 0;
|
|
}
|
|
}
|
|
|
|
NgProfiler prof;
|
|
}
|