2023-03-27 10:16:23 -07:00
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
< html xmlns = "http://www.w3.org/1999/xhtml" >
< head >
< meta http-equiv = "Content-Type" content = "text/xhtml;charset=UTF-8" / >
< meta http-equiv = "X-UA-Compatible" content = "IE=9" / >
< meta name = "generator" content = "Doxygen 1.8.17" / >
2023-04-23 12:52:57 -07:00
< meta name = "description" content = "PhasicFlow is an open-source parallel DEM (discrete element method) package for simulating granular flow. It is developed in C++ and can be exectued on both GPU (like CUDA) and CPU." >
2023-03-27 10:16:23 -07:00
< title > PhasicFlow: src/phasicFlow/Timer/Timers.cpp Source File< / title >
< link href = "tabs.css" rel = "stylesheet" type = "text/css" / >
< script type = "text/javascript" src = "jquery.js" > < / script >
< script type = "text/javascript" src = "dynsections.js" > < / script >
< link href = "navtree.css" rel = "stylesheet" type = "text/css" / >
< script type = "text/javascript" src = "resize.js" > < / script >
< script type = "text/javascript" src = "navtreedata.js" > < / script >
< script type = "text/javascript" src = "navtree.js" > < / script >
< link href = "search/search.css" rel = "stylesheet" type = "text/css" / >
< script type = "text/javascript" src = "search/searchdata.js" > < / script >
< script type = "text/javascript" src = "search/search.js" > < / script >
< script type = "text/javascript" >
/* @license magnet:?xt=urn:btih:cf05388f2679ee054f2beb29a391d25f4e673ac3& dn=gpl-2.0.txt GPL-v2 */
$(document).ready(function() { init_search(); });
/* @license-end */
< / script >
2023-04-02 11:35:43 -07:00
< script type = "text/x-mathjax-config" >
MathJax.Hub.Config({
extensions: ["tex2jax.js"],
jax: ["input/TeX","output/HTML-CSS"],
});
< / script >
< script type = "text/javascript" async = "async" src = "http://cdn.mathjax.org/mathjax/latest/MathJax.js" > < / script >
2023-03-27 10:16:23 -07:00
< link href = "doxygen.css" rel = "stylesheet" type = "text/css" / >
< link href = "customdoxygen.css" rel = "stylesheet" type = "text/css" / >
< / head >
< body >
< div id = "top" > <!-- do not remove this div, it is closed by doxygen! -->
< div id = "titlearea" >
2023-04-14 10:28:41 -07:00
< table cellspacing = "0" >
2023-03-27 10:16:23 -07:00
< tbody >
2023-04-14 10:28:41 -07:00
< tr >
< td id = "projectlogo" > < a href = "https://github.com/PhasicFlow" > < img alt = "Logo" src = "phasicFlow_logo.png" > < / a > < / td >
2023-03-27 10:16:23 -07:00
< td > < div id = "MSearchBox" class = "MSearchBoxInactive" >
< span class = "left" >
< img id = "MSearchSelect" src = "search/mag_sel.png"
onmouseover="return searchBox.OnSearchSelectShow()"
onmouseout="return searchBox.OnSearchSelectHide()"
alt=""/>
< input type = "text" id = "MSearchField" value = "Search" accesskey = "S"
onfocus="searchBox.OnSearchFieldFocus(true)"
onblur="searchBox.OnSearchFieldFocus(false)"
onkeyup="searchBox.OnSearchFieldChange(event)"/>
< / span > < span class = "right" >
< a id = "MSearchClose" href = "javascript:searchBox.CloseResultsWindow()" > < img id = "MSearchCloseImg" border = "0" src = "search/close.png" alt = "" / > < / a >
< / span >
< / div >
< / td >
< / tr >
2023-04-14 10:28:41 -07:00
< tr >
< td id = "projectbrief" >
< a href = "https://https://cemf.ir" > www.cemf.ir< / a >
< / td >
< / tr >
2023-03-27 10:16:23 -07:00
< / tbody >
< / table >
< / div >
<!-- end header part -->
<!-- Generated by Doxygen 1.8.17 -->
< script type = "text/javascript" >
/* @license magnet:?xt=urn:btih:cf05388f2679ee054f2beb29a391d25f4e673ac3& dn=gpl-2.0.txt GPL-v2 */
var searchBox = new SearchBox("searchBox", "search",false,'Search');
/* @license-end */
< / script >
< / div > <!-- top -->
< div id = "side-nav" class = "ui-resizable side-nav-resizable" >
< div id = "nav-tree" >
< div id = "nav-tree-contents" >
< div id = "nav-sync" class = "sync" > < / div >
< / div >
< / div >
< div id = "splitbar" style = "-moz-user-select:none;"
class="ui-resizable-handle">
< / div >
< / div >
< script type = "text/javascript" >
/* @license magnet:?xt=urn:btih:cf05388f2679ee054f2beb29a391d25f4e673ac3& dn=gpl-2.0.txt GPL-v2 */
$(document).ready(function(){initNavTree('Timers_8cpp_source.html',''); initResizable(); });
/* @license-end */
< / script >
< div id = "doc-content" >
<!-- window showing the filter options -->
< div id = "MSearchSelectWindow"
onmouseover="return searchBox.OnSearchSelectShow()"
onmouseout="return searchBox.OnSearchSelectHide()"
onkeydown="return searchBox.OnSearchSelectKey(event)">
< / div >
<!-- iframe showing the search results (closed by default) -->
< div id = "MSearchResultsWindow" >
< iframe src = "javascript:void(0)" frameborder = "0"
name="MSearchResults" id="MSearchResults">
< / iframe >
< / div >
< div class = "header" >
< div class = "headertitle" >
< div class = "title" > Timers.cpp< / div > < / div >
< / div > <!-- header -->
< div class = "contents" >
< a href = "Timers_8cpp.html" > Go to the documentation of this file.< / a > < div class = "fragment" > < div class = "line" > < a name = "l00001" > < / a > < span class = "lineno" > 1< / span >   < span class = "comment" > /*------------------------------- phasicFlow ---------------------------------< / span > < / div >
< div class = "line" > < a name = "l00002" > < / a > < span class = "lineno" > 2< / span >   < span class = "comment" > O C enter of< / span > < / div >
< div class = "line" > < a name = "l00003" > < / a > < span class = "lineno" > 3< / span >   < span class = "comment" > O O E ngineering and< / span > < / div >
< div class = "line" > < a name = "l00004" > < / a > < span class = "lineno" > 4< / span >   < span class = "comment" > O O M ultiscale modeling of< / span > < / div >
< div class = "line" > < a name = "l00005" > < / a > < span class = "lineno" > 5< / span >   < span class = "comment" > OOOOOOO F luid flow < / span > < / div >
< div class = "line" > < a name = "l00006" > < / a > < span class = "lineno" > 6< / span >   < span class = "comment" > ------------------------------------------------------------------------------< / span > < / div >
< div class = "line" > < a name = "l00007" > < / a > < span class = "lineno" > 7< / span >   < span class = "comment" > Copyright (C): www.cemf.ir< / span > < / div >
< div class = "line" > < a name = "l00008" > < / a > < span class = "lineno" > 8< / span >   < span class = "comment" > email: hamid.r.norouzi AT gmail.com< / span > < / div >
< div class = "line" > < a name = "l00009" > < / a > < span class = "lineno" > 9< / span >   < span class = "comment" > ------------------------------------------------------------------------------ < / span > < / div >
< div class = "line" > < a name = "l00010" > < / a > < span class = "lineno" > 10< / span >   < span class = "comment" > Licence:< / span > < / div >
< div class = "line" > < a name = "l00011" > < / a > < span class = "lineno" > 11< / span >   < span class = "comment" > This file is part of phasicFlow code. It is a free software for simulating < / span > < / div >
< div class = "line" > < a name = "l00012" > < / a > < span class = "lineno" > 12< / span >   < span class = "comment" > granular and multiphase flows. You can redistribute it and/or modify it under< / span > < / div >
< div class = "line" > < a name = "l00013" > < / a > < span class = "lineno" > 13< / span >   < span class = "comment" > the terms of GNU General Public License v3 or any other later versions. < / span > < / div >
< div class = "line" > < a name = "l00014" > < / a > < span class = "lineno" > 14< / span >   < span class = "comment" > < / span > < / div >
< div class = "line" > < a name = "l00015" > < / a > < span class = "lineno" > 15< / span >   < span class = "comment" > phasicFlow is distributed to help others in their research in the field of < / span > < / div >
< div class = "line" > < a name = "l00016" > < / a > < span class = "lineno" > 16< / span >   < span class = "comment" > granular and multiphase flows, but WITHOUT ANY WARRANTY; without even the< / span > < / div >
< div class = "line" > < a name = "l00017" > < / a > < span class = "lineno" > 17< / span >   < span class = "comment" > implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.< / span > < / div >
< div class = "line" > < a name = "l00018" > < / a > < span class = "lineno" > 18< / span >   < span class = "comment" > < / span > < / div >
< div class = "line" > < a name = "l00019" > < / a > < span class = "lineno" > 19< / span >   < span class = "comment" > -----------------------------------------------------------------------------*/< / span > < / div >
< div class = "line" > < a name = "l00020" > < / a > < span class = "lineno" > 20< / span >   < / div >
< div class = "line" > < a name = "l00021" > < / a > < span class = "lineno" > 21< / span >   < / div >
< div class = "line" > < a name = "l00022" > < / a > < span class = "lineno" > 22< / span >   < span class = "preprocessor" > #include " < a class = "code" href = "Timers_8hpp.html" > Timers.hpp< / a > " < / span > < / div >
< div class = "line" > < a name = "l00023" > < / a > < span class = "lineno" > 23< / span >   < / div >
< div class = "line" > < a name = "l00024" > < / a > < span class = "lineno" > < a class = "line" href = "classpFlow_1_1Timers.html#abe5703bd8255f2ec21ffe5d82dfee164" > 24< / a > < / span >   < a class = "code" href = "namespacepFlow.html#a6192191c0e9c178a44ee1ac350fde476" > pFlow::real< / a > < a class = "code" href = "classpFlow_1_1Timers.html#abe5703bd8255f2ec21ffe5d82dfee164" > pFlow::Timers::accTimersTotal< / a > ()< span class = "keyword" > const< / span > < / div >
< div class = "line" > < a name = "l00025" > < / a > < span class = "lineno" > 25< / span >   < span class = "keyword" > < / span > {< / div >
< div class = "line" > < a name = "l00026" > < / a > < span class = "lineno" > 26< / span >   < span class = "comment" > // first this timer< / span > < / div >
< div class = "line" > < a name = "l00027" > < / a > < span class = "lineno" > 27< / span >   < a class = "code" href = "namespacepFlow.html#a6192191c0e9c178a44ee1ac350fde476" > real< / a > total = 0;< / div >
< div class = "line" > < a name = "l00028" > < / a > < span class = "lineno" > 28< / span >   < span class = "keywordflow" > if< / span > (this-> < a class = "code" href = "classpFlow_1_1Timer.html#ac5b452503492dd1c556ff406c28bbb70" > timerActive< / a > ()) total += this-> < a class = "code" href = "classpFlow_1_1Timer.html#ae1a67a10b75d89b83ecb3f3598f8d395" > totalTime< / a > ();< / div >
< div class = "line" > < a name = "l00029" > < / a > < span class = "lineno" > 29< / span >   < / div >
< div class = "line" > < a name = "l00030" > < / a > < span class = "lineno" > 30< / span >   < span class = "keywordflow" > for< / span > (< span class = "keyword" > const< / span > < span class = "keyword" > auto< / span > tmr:< a class = "code" href = "classpFlow_1_1Timers.html#a53ea8ded64b447e76f1f27b0f6e9d394" > timers_< / a > )< / div >
< div class = "line" > < a name = "l00031" > < / a > < span class = "lineno" > 31< / span >   {< / div >
< div class = "line" > < a name = "l00032" > < / a > < span class = "lineno" > 32< / span >   < span class = "keywordflow" > if< / span > (tmr -> < a class = "code" href = "classpFlow_1_1Timers.html#ab7f3740f07fc01cc6949fa5e5aab87f0" > master< / a > ())< / div >
< div class = "line" > < a name = "l00033" > < / a > < span class = "lineno" > 33< / span >   {< / div >
< div class = "line" > < a name = "l00034" > < / a > < span class = "lineno" > 34< / span >   total += < span class = "keyword" > dynamic_cast< < / span > < span class = "keyword" > const < / span > < a class = "code" href = "classpFlow_1_1Timers.html" > Timers< / a > *< span class = "keyword" > > < / span > (tmr)-> < a class = "code" href = "classpFlow_1_1Timers.html#abe5703bd8255f2ec21ffe5d82dfee164" > accTimersTotal< / a > ();< / div >
< div class = "line" > < a name = "l00035" > < / a > < span class = "lineno" > 35< / span >   }< / div >
< div class = "line" > < a name = "l00036" > < / a > < span class = "lineno" > 36< / span >   < span class = "keywordflow" > else< / span > < span class = "keywordflow" > if< / span > (tmr-> timerActive())< / div >
< div class = "line" > < a name = "l00037" > < / a > < span class = "lineno" > 37< / span >   {< / div >
< div class = "line" > < a name = "l00038" > < / a > < span class = "lineno" > 38< / span >   total += tmr-> totalTime();< / div >
< div class = "line" > < a name = "l00039" > < / a > < span class = "lineno" > 39< / span >   }< / div >
< div class = "line" > < a name = "l00040" > < / a > < span class = "lineno" > 40< / span >   }< / div >
< div class = "line" > < a name = "l00041" > < / a > < span class = "lineno" > 41< / span >   < / div >
< div class = "line" > < a name = "l00042" > < / a > < span class = "lineno" > 42< / span >   < span class = "keywordflow" > return< / span > total;< / div >
< div class = "line" > < a name = "l00043" > < / a > < span class = "lineno" > 43< / span >   }< / div >
< div class = "line" > < a name = "l00044" > < / a > < span class = "lineno" > 44< / span >   < / div >
< div class = "line" > < a name = "l00045" > < / a > < span class = "lineno" > 45< / span >   < / div >
< div class = "line" > < a name = "l00046" > < / a > < span class = "lineno" > < a class = "line" href = "classpFlow_1_1Timers.html#a268ef46f8b8bdbc5512d1ce25b177136" > 46< / a > < / span >   < span class = "keywordtype" > bool< / span > < a class = "code" href = "classpFlow_1_1Timers.html#a268ef46f8b8bdbc5512d1ce25b177136" > pFlow::Timers::write< / a > (< a class = "code" href = "classpFlow_1_1iOstream.html" > iOstream< / a > & os, < span class = "keywordtype" > bool< / span > subTree)< span class = "keyword" > const< / span > < / div >
< div class = "line" > < a name = "l00047" > < / a > < span class = "lineno" > 47< / span >   < span class = "keyword" > < / span > {< / div >
< div class = "line" > < a name = "l00048" > < / a > < span class = "lineno" > 48< / span >   < span class = "keywordflow" > if< / span > (level() == 0 )os< < < span class = "stringliteral" > " \n" < / span > ;< / div >
< div class = "line" > < a name = "l00049" > < / a > < span class = "lineno" > 49< / span >   < a class = "code" href = "classpFlow_1_1Timer.html#a878f1a2a8b65bc9bdf57f7c1a3f90a09" > Timer::write< / a > (os, subTree);< / div >
< div class = "line" > < a name = "l00050" > < / a > < span class = "lineno" > 50< / span >   < span class = "keywordflow" > if< / span > (subTree)< / div >
< div class = "line" > < a name = "l00051" > < / a > < span class = "lineno" > 51< / span >   {< / div >
< div class = "line" > < a name = "l00052" > < / a > < span class = "lineno" > 52< / span >   < / div >
< div class = "line" > < a name = "l00053" > < / a > < span class = "lineno" > 53< / span >   < span class = "keywordflow" > for< / span > (< span class = "keyword" > const< / span > < span class = "keyword" > auto< / span > & < a class = "code" href = "classpFlow_1_1Timer.html#aad52d0d8782bcf92a17c7e91d3d54051" > timer< / a > :timers_)< / div >
< div class = "line" > < a name = "l00054" > < / a > < span class = "lineno" > 54< / span >   {< / div >
< div class = "line" > < a name = "l00055" > < / a > < span class = "lineno" > 55< / span >   < a class = "code" href = "classpFlow_1_1Timer.html#aad52d0d8782bcf92a17c7e91d3d54051" > timer< / a > -> write(os, subTree);< / div >
< div class = "line" > < a name = "l00056" > < / a > < span class = "lineno" > 56< / span >   }< / div >
< div class = "line" > < a name = "l00057" > < / a > < span class = "lineno" > 57< / span >   < / div >
< div class = "line" > < a name = "l00058" > < / a > < span class = "lineno" > 58< / span >   }< / div >
< div class = "line" > < a name = "l00059" > < / a > < span class = "lineno" > 59< / span >   < span class = "keywordflow" > if< / span > (level() == 0 )os< < < span class = "stringliteral" > " \n" < / span > ;< / div >
< div class = "line" > < a name = "l00060" > < / a > < span class = "lineno" > 60< / span >   < span class = "keywordflow" > return< / span > < span class = "keyword" > true< / span > ;< / div >
< div class = "line" > < a name = "l00061" > < / a > < span class = "lineno" > 61< / span >   }< / div >
< / div > <!-- fragment --> < / div > <!-- contents -->
< / div > <!-- doc - content -->
2025-01-10 13:02:07 +03:30
< div class = "ttc" id = "anamespacepFlow_html_a6192191c0e9c178a44ee1ac350fde476" > < div class = "ttname" > < a href = "namespacepFlow.html#a6192191c0e9c178a44ee1ac350fde476" > pFlow::real< / a > < / div > < div class = "ttdeci" > float real< / div > < div class = "ttdef" > < b > Definition:< / b > < a href = "builtinTypes_8hpp_source.html#l00045" > builtinTypes.hpp:45< / a > < / div > < / div >
< div class = "ttc" id = "aclasspFlow_1_1Timer_html_ae1a67a10b75d89b83ecb3f3598f8d395" > < div class = "ttname" > < a href = "classpFlow_1_1Timer.html#ae1a67a10b75d89b83ecb3f3598f8d395" > pFlow::Timer::totalTime< / a > < / div > < div class = "ttdeci" > real totalTime() const< / div > < div class = "ttdef" > < b > Definition:< / b > < a href = "Timer_8hpp_source.html#l00151" > Timer.hpp:151< / a > < / div > < / div >
< div class = "ttc" id = "aclasspFlow_1_1Timers_html_ab7f3740f07fc01cc6949fa5e5aab87f0" > < div class = "ttname" > < a href = "classpFlow_1_1Timers.html#ab7f3740f07fc01cc6949fa5e5aab87f0" > pFlow::Timers::master< / a > < / div > < div class = "ttdeci" > virtual bool master() const< / div > < div class = "ttdef" > < b > Definition:< / b > < a href = "Timers_8hpp_source.html#l00092" > Timers.hpp:92< / a > < / div > < / div >
< div class = "ttc" id = "aclasspFlow_1_1Timer_html_a878f1a2a8b65bc9bdf57f7c1a3f90a09" > < div class = "ttname" > < a href = "classpFlow_1_1Timer.html#a878f1a2a8b65bc9bdf57f7c1a3f90a09" > pFlow::Timer::write< / a > < / div > < div class = "ttdeci" > virtual bool write(iOstream & os, bool subTree) const< / div > < div class = "ttdef" > < b > Definition:< / b > < a href = "Timer_8cpp_source.html#l00059" > Timer.cpp:59< / a > < / div > < / div >
< div class = "ttc" id = "aclasspFlow_1_1Timers_html" > < div class = "ttname" > < a href = "classpFlow_1_1Timers.html" > pFlow::Timers< / a > < / div > < div class = "ttdef" > < b > Definition:< / b > < a href = "Timers_8hpp_source.html#l00032" > Timers.hpp:32< / a > < / div > < / div >
2023-03-27 10:16:23 -07:00
< div class = "ttc" id = "aTimers_8hpp_html" > < div class = "ttname" > < a href = "Timers_8hpp.html" > Timers.hpp< / a > < / div > < / div >
< div class = "ttc" id = "aclasspFlow_1_1Timers_html_abe5703bd8255f2ec21ffe5d82dfee164" > < div class = "ttname" > < a href = "classpFlow_1_1Timers.html#abe5703bd8255f2ec21ffe5d82dfee164" > pFlow::Timers::accTimersTotal< / a > < / div > < div class = "ttdeci" > real accTimersTotal() const override< / div > < div class = "ttdef" > < b > Definition:< / b > < a href = "Timers_8cpp_source.html#l00024" > Timers.cpp:24< / a > < / div > < / div >
2025-01-10 13:02:07 +03:30
< div class = "ttc" id = "aclasspFlow_1_1Timer_html_aad52d0d8782bcf92a17c7e91d3d54051" > < div class = "ttname" > < a href = "classpFlow_1_1Timer.html#aad52d0d8782bcf92a17c7e91d3d54051" > pFlow::Timer::timer< / a > < / div > < div class = "ttdeci" > std::chrono::high_resolution_clock timer< / div > < div class = "ttdef" > < b > Definition:< / b > < a href = "Timer_8hpp_source.html#l00037" > Timer.hpp:37< / a > < / div > < / div >
2023-03-27 10:16:23 -07:00
< div class = "ttc" id = "aclasspFlow_1_1Timers_html_a268ef46f8b8bdbc5512d1ce25b177136" > < div class = "ttname" > < a href = "classpFlow_1_1Timers.html#a268ef46f8b8bdbc5512d1ce25b177136" > pFlow::Timers::write< / a > < / div > < div class = "ttdeci" > virtual bool write(iOstream & os, bool subTree=true) const< / div > < div class = "ttdef" > < b > Definition:< / b > < a href = "Timers_8cpp_source.html#l00046" > Timers.cpp:46< / a > < / div > < / div >
2025-01-10 13:02:07 +03:30
< div class = "ttc" id = "aclasspFlow_1_1Timer_html_ac5b452503492dd1c556ff406c28bbb70" > < div class = "ttname" > < a href = "classpFlow_1_1Timer.html#ac5b452503492dd1c556ff406c28bbb70" > pFlow::Timer::timerActive< / a > < / div > < div class = "ttdeci" > bool timerActive() const< / div > < div class = "ttdef" > < b > Definition:< / b > < a href = "Timer_8hpp_source.html#l00139" > Timer.hpp:139< / a > < / div > < / div >
< div class = "ttc" id = "aclasspFlow_1_1iOstream_html" > < div class = "ttname" > < a href = "classpFlow_1_1iOstream.html" > pFlow::iOstream< / a > < / div > < div class = "ttdoc" > Interface class for any output stream.< / div > < div class = "ttdef" > < b > Definition:< / b > < a href = "iOstream_8hpp_source.html#l00059" > iOstream.hpp:59< / a > < / div > < / div >
< div class = "ttc" id = "aclasspFlow_1_1Timers_html_a53ea8ded64b447e76f1f27b0f6e9d394" > < div class = "ttname" > < a href = "classpFlow_1_1Timers.html#a53ea8ded64b447e76f1f27b0f6e9d394" > pFlow::Timers::timers_< / a > < / div > < div class = "ttdeci" > List< pFlow::Timer * > timers_< / div > < div class = "ttdef" > < b > Definition:< / b > < a href = "Timers_8hpp_source.html#l00038" > Timers.hpp:38< / a > < / div > < / div >
2023-03-27 10:16:23 -07:00
< div id = "nav-path" class = "navpath" > <!-- id is needed for treeview function! -->
< ul >
< li class = "navelem" > < a class = "el" href = "dir_68267d1309a1af8e8297ef4c3efbcdba.html" > src< / a > < / li > < li class = "navelem" > < a class = "el" href = "dir_cd7a5046d028e114fc17b2ebc2bd02d2.html" > phasicFlow< / a > < / li > < li class = "navelem" > < a class = "el" href = "dir_d08d2b79f34083bef6f49ca610481fd2.html" > Timer< / a > < / li > < li class = "navelem" > < a class = "el" href = "Timers_8cpp.html" > Timers.cpp< / a > < / li >
< li class = "footer" > Generated by
< a href = "http://www.doxygen.org/index.html" >
< img class = "footer" src = "doxygen.png" alt = "doxygen" / > < / a > 1.8.17 < / li >
< / ul >
< / div >
< / body >
< / html >