X-Git-Url: https://git.creatis.insa-lyon.fr/pubgit/?a=blobdiff_plain;f=common%2FclitkMemoryUsage.cxx;h=8ceff61a1e4c90cc55363de927b375e143ddb087;hb=109fbd68b9c171a4fa18d6c58b311718b418d181;hp=295ac2975e5d90e616c3a240211243cb4544a36a;hpb=62c08c838c8d824b37b908bbed67b996aaaa31ac;p=clitk.git diff --git a/common/clitkMemoryUsage.cxx b/common/clitkMemoryUsage.cxx index 295ac29..8ceff61 100644 --- a/common/clitkMemoryUsage.cxx +++ b/common/clitkMemoryUsage.cxx @@ -24,22 +24,30 @@ void clitk::PrintMemory(bool verbose, std::string s) { #if CLITK_MEMORY_INFO == 1 if (verbose) { - //sleep(1); // wait to refresh memory ? need to let the system refresh the mem - int * entries = new int; - sg_process_stats * stat = new sg_process_stats; - int i=0; - stat = sg_get_process_stats(entries); - // Search the current pid in the list of processes - while (stat[i].pid != getpid()) i++; - // Display total memory size - if (s != "") std::cout << "==> " << s << ": "; - static int previous=0; - int mem = stat[i].proc_size/1000/1000; // in Mb - std::cout << mem << "Mb (" << mem-previous << "Mb)" << std::endl; - previous = mem; - //DD(stat[i].proc_resident/1000/1000); - //DD(stat[i].pid); - } + static double previous=0; + double mem = GetMemoryUsageInMb(); + if (s != "") std::cout << "==> " << s << ": "; + std::cout << mem << "MB (" << mem-previous << "MB)" << std::endl; + previous = mem; + //DD(stat[i].proc_resident/1000/1000); + //DD(stat[i].pid); + } +#endif + } + +double clitk::GetMemoryUsageInMb() +{ +#if CLITK_MEMORY_INFO == 1 + //sleep(1); // wait to refresh memory ? need to let the system refresh the mem + int * entries = new int; + sg_process_stats * stat = new sg_process_stats; + int i=0; + stat = sg_get_process_stats(entries); + // Search the current pid in the list of processes + while (stat[i].pid != getpid()) i++; + // Display total memory size + double mem = stat[i].proc_resident/1024/1024; // in Mb + return mem; #endif }