Files
qt4-x11/doc/html/demos-spectrum-3rdparty-fftreal-stopwatch-clockcyclecounter-cpp.html
2025-08-24 20:55:26 +08:00

455 lines
24 KiB
HTML

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en_US" lang="en_US">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>Qt 4.8: ClockCycleCounter.cpp Example File (demos/spectrum/3rdparty/fftreal/stopwatch/ClockCycleCounter.cpp)</title>
<link rel="stylesheet" type="text/css" href="style/style.css" />
<script src="scripts/jquery.js" type="text/javascript"></script>
<script src="scripts/functions.js" type="text/javascript"></script>
<link rel="stylesheet" type="text/css" href="style/superfish.css" />
<link rel="stylesheet" type="text/css" href="style/narrow.css" />
<!--[if IE]>
<meta name="MSSmartTagsPreventParsing" content="true">
<meta http-equiv="imagetoolbar" content="no">
<![endif]-->
<!--[if lt IE 7]>
<link rel="stylesheet" type="text/css" href="style/style_ie6.css">
<![endif]-->
<!--[if IE 7]>
<link rel="stylesheet" type="text/css" href="style/style_ie7.css">
<![endif]-->
<!--[if IE 8]>
<link rel="stylesheet" type="text/css" href="style/style_ie8.css">
<![endif]-->
<script src="scripts/superfish.js" type="text/javascript"></script>
<script src="scripts/narrow.js" type="text/javascript"></script>
</head>
<body class="" onload="CheckEmptyAndLoadList();">
<div class="header" id="qtdocheader">
<div class="content">
<div id="nav-logo">
<a href="index.html">Home</a></div>
<a href="index.html" class="qtref"><span>Qt Reference Documentation</span></a>
<div id="narrowsearch"></div>
<div id="nav-topright">
<ul>
<li class="nav-topright-home"><a href="http://qt.digia.com/">Qt HOME</a></li>
<li class="nav-topright-dev"><a href="http://qt-project.org/">DEV</a></li>
<li class="nav-topright-doc nav-topright-doc-active"><a href="http://qt-project.org/doc/">
DOC</a></li>
<li class="nav-topright-blog"><a href="http://blog.qt.digia.com/">BLOG</a></li>
</ul>
</div>
<div id="shortCut">
<ul>
<li class="shortCut-topleft-inactive"><span><a href="index.html">Qt 4.8</a></span></li>
<li class="shortCut-topleft-active"><a href="http://qt-project.org/doc/">ALL VERSIONS </a></li>
</ul>
</div>
<ul class="sf-menu" id="narrowmenu">
<li><a href="#">API Lookup</a>
<ul>
<li><a href="classes.html">Class index</a></li>
<li><a href="functions.html">Function index</a></li>
<li><a href="modules.html">Modules</a></li>
<li><a href="namespaces.html">Namespaces</a></li>
<li><a href="qtglobal.html">Global Declarations</a></li>
<li><a href="qdeclarativeelements.html">QML elements</a></li>
</ul>
</li>
<li><a href="#">Qt Topics</a>
<ul>
<li><a href="qt-basic-concepts.html">Programming with Qt</a></li>
<li><a href="qtquick.html">Device UIs &amp; Qt Quick</a></li>
<li><a href="qt-gui-concepts.html">UI Design with Qt</a></li>
<li><a href="supported-platforms.html">Supported Platforms</a></li>
<li><a href="technology-apis.html">Qt and Key Technologies</a></li>
<li><a href="best-practices.html">How-To's and Best Practices</a></li>
</ul>
</li>
<li><a href="#">Examples</a>
<ul>
<li><a href="all-examples.html">Examples</a></li>
<li><a href="tutorials.html">Tutorials</a></li>
<li><a href="demos.html">Demos</a></li>
<li><a href="qdeclarativeexamples.html">QML Examples</a></li>
</ul>
</li>
</ul>
</div>
</div>
<div class="wrapper">
<div class="hd">
<span></span>
</div>
<div class="bd group">
<div class="sidebar">
<div class="searchlabel">
Search index:</div>
<div class="search" id="sidebarsearch">
<form id="qtdocsearch" action="" onsubmit="return false;">
<fieldset>
<input type="text" name="searchstring" id="pageType" value="" />
<div id="resultdialog">
<a href="#" id="resultclose">Close</a>
<p id="resultlinks" class="all"><a href="#" id="showallresults">All</a> | <a href="#" id="showapiresults">API</a> | <a href="#" id="showarticleresults">Articles</a> | <a href="#" id="showexampleresults">Examples</a></p>
<p id="searchcount" class="all"><span id="resultcount"></span><span id="apicount"></span><span id="articlecount"></span><span id="examplecount"></span>&nbsp;results:</p>
<ul id="resultlist" class="all">
</ul>
</div>
</fieldset>
</form>
</div>
<div class="box first bottombar" id="lookup">
<h2 title="API Lookup"><span></span>
API Lookup</h2>
<div id="list001" class="list">
<ul id="ul001" >
<li class="defaultLink"><a href="classes.html">Class index</a></li>
<li class="defaultLink"><a href="functions.html">Function index</a></li>
<li class="defaultLink"><a href="modules.html">Modules</a></li>
<li class="defaultLink"><a href="namespaces.html">Namespaces</a></li>
<li class="defaultLink"><a href="qtglobal.html">Global Declarations</a></li>
<li class="defaultLink"><a href="qdeclarativeelements.html">QML elements</a></li>
</ul>
</div>
</div>
<div class="box bottombar" id="topics">
<h2 title="Qt Topics"><span></span>
Qt Topics</h2>
<div id="list002" class="list">
<ul id="ul002" >
<li class="defaultLink"><a href="qt-basic-concepts.html">Programming with Qt</a></li>
<li class="defaultLink"><a href="qtquick.html">Device UIs &amp; Qt Quick</a></li>
<li class="defaultLink"><a href="qt-gui-concepts.html">UI Design with Qt</a></li>
<li class="defaultLink"><a href="supported-platforms.html">Supported Platforms</a></li>
<li class="defaultLink"><a href="technology-apis.html">Qt and Key Technologies</a></li>
<li class="defaultLink"><a href="best-practices.html">How-To's and Best Practices</a></li>
</ul>
</div>
</div>
<div class="box" id="examples">
<h2 title="Examples"><span></span>
Examples</h2>
<div id="list003" class="list">
<ul id="ul003">
<li class="defaultLink"><a href="all-examples.html">Examples</a></li>
<li class="defaultLink"><a href="tutorials.html">Tutorials</a></li>
<li class="defaultLink"><a href="demos.html">Demos</a></li>
<li class="defaultLink"><a href="qdeclarativeexamples.html">QML Examples</a></li>
</ul>
</div>
</div>
</div>
<div class="wrap">
<div class="toolbar">
<div class="breadcrumb toolblock">
<ul>
<li class="first"><a href="index.html">Home</a></li>
<!-- Breadcrumbs go here -->
</ul>
</div>
<div class="toolbuttons toolblock">
<ul>
<li id="smallA" class="t_button">A</li>
<li id="medA" class="t_button active">A</li>
<li id="bigA" class="t_button">A</li>
<li id="print" class="t_button"><a href="javascript:this.print();">
<span>Print</span></a></li>
</ul>
</div>
</div>
<div class="content mainContent">
<h1 class="title">ClockCycleCounter.cpp Example File</h1>
<span class="small-subtitle">demos/spectrum/3rdparty/fftreal/stopwatch/ClockCycleCounter.cpp</span>
<!-- $$$demos/spectrum/3rdparty/fftreal/stopwatch/ClockCycleCounter.cpp-description -->
<div class="descr"> <a name="details"></a>
<pre class="cpp"> <span class="comment">/*****************************************************************************
ClockCycleCounter.cpp
Copyright (c) 2003 Laurent de Soras
--- Legal stuff ---
This library is free software; you can redistribute it and/or
modify it under the terms of the GNU Lesser General Public
License as published by the Free Software Foundation; either
version 2.1 of the License, or (at your option) any later version.
This library is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
Lesser General Public License for more details.
You should have received a copy of the GNU Lesser General Public
License along with this library; if not, write to the Free Software
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
*Tab=3***********************************************************************/</span>
<span class="preprocessor">#if defined (_MSC_VER)</span>
<span class="preprocessor">#pragma warning (1 : 4130) // &quot;'operator' : logical operation on address of string constant&quot;</span>
<span class="preprocessor">#pragma warning (1 : 4223) // &quot;nonstandard extension used : non-lvalue array converted to pointer&quot;</span>
<span class="preprocessor">#pragma warning (1 : 4705) // &quot;statement has no effect&quot;</span>
<span class="preprocessor">#pragma warning (1 : 4706) // &quot;assignment within conditional expression&quot;</span>
<span class="preprocessor">#pragma warning (4 : 4786) // &quot;identifier was truncated to '255' characters in the debug information&quot;</span>
<span class="preprocessor">#pragma warning (4 : 4800) // &quot;forcing value to bool 'true' or 'false' (performance warning)&quot;</span>
<span class="preprocessor">#pragma warning (4 : 4355) // &quot;'this' : used in base member initializer list&quot;</span>
<span class="preprocessor">#endif</span>
<span class="comment">/*\\\ INCLUDE FILES \\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\*/</span>
<span class="preprocessor">#include &quot;ClockCycleCounter.h&quot;</span>
<span class="preprocessor">#include &lt;cassert&gt;</span>
<span class="keyword">namespace</span> stopwatch
{
<span class="comment">/*\\\ PUBLIC \\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\*/</span>
<span class="comment">/*
==============================================================================
Name: ctor
Description:
The first object constructed initialise global data. This first
construction may be a bit slow.
Throws: Nothing
==============================================================================
*/</span>
ClockCycleCounter<span class="operator">::</span>ClockCycleCounter ()
: _start_time (<span class="number">0</span>)
<span class="operator">,</span> _state (<span class="number">0</span>)
<span class="operator">,</span> _best_score (<span class="operator">-</span><span class="number">1</span>)
{
<span class="keyword">if</span> (<span class="operator">!</span> _init_flag)
{
<span class="comment">// Should be executed in this order</span>
compute_clk_mul ();
compute_measure_time_total ();
compute_measure_time_lap ();
<span class="comment">// Restores object state</span>
_start_time <span class="operator">=</span> <span class="number">0</span>;
_state <span class="operator">=</span> <span class="number">0</span>;
_best_score <span class="operator">=</span> <span class="operator">-</span><span class="number">1</span>;
_init_flag <span class="operator">=</span> <span class="keyword">true</span>;
}
}
<span class="comment">/*
==============================================================================
Name: get_time_total
Description:
Gives the time elapsed between the latest stop_lap() and start() calls.
Returns:
The duration, in clock cycles.
Throws: Nothing
==============================================================================
*/</span>
Int64 ClockCycleCounter<span class="operator">::</span>get_time_total () <span class="keyword">const</span>
{
<span class="keyword">const</span> Int64 duration <span class="operator">=</span> _state <span class="operator">-</span> _start_time;
assert (duration <span class="operator">&gt;</span><span class="operator">=</span> <span class="number">0</span>);
<span class="keyword">const</span> Int64 t <span class="operator">=</span> max (
duration <span class="operator">-</span> _measure_time_total<span class="operator">,</span>
<span class="keyword">static_cast</span> <span class="operator">&lt;</span>Int64<span class="operator">&gt;</span> (<span class="number">0</span>)
);
<span class="keyword">return</span> (t <span class="operator">*</span> _clk_mul);
}
<span class="comment">/*
==============================================================================
Name: get_time_best_lap
Description:
Gives the smallest time between two consecutive stop_lap() or between
the stop_lap() and start(). The value is reset by a call to start().
Call this function only after a stop_lap().
The time is amputed from the duration of the stop_lap() call itself.
Returns:
The smallest duration, in clock cycles.
Throws: Nothing
==============================================================================
*/</span>
Int64 ClockCycleCounter<span class="operator">::</span>get_time_best_lap () <span class="keyword">const</span>
{
assert (_best_score <span class="operator">&gt;</span><span class="operator">=</span> <span class="number">0</span>);
<span class="keyword">const</span> Int64 t1 <span class="operator">=</span> max (
_best_score <span class="operator">-</span> _measure_time_lap<span class="operator">,</span>
<span class="keyword">static_cast</span> <span class="operator">&lt;</span>Int64<span class="operator">&gt;</span> (<span class="number">0</span>)
);
<span class="keyword">const</span> Int64 t <span class="operator">=</span> min (t1<span class="operator">,</span> get_time_total ());
<span class="keyword">return</span> (t <span class="operator">*</span> _clk_mul);
}
<span class="comment">/*\\\ PROTECTED \\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\*/</span>
<span class="comment">/*\\\ PRIVATE \\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\*/</span>
<span class="preprocessor">#if defined (__MACOS__)</span>
<span class="keyword">static</span> <span class="keyword">inline</span> <span class="type">double</span> stopwatch_ClockCycleCounter_get_time_s ()
{
<span class="keyword">const</span> Nanoseconds ns <span class="operator">=</span> AbsoluteToNanoseconds (UpTime ());
<span class="keyword">return</span> (ns<span class="operator">.</span>hi <span class="operator">*</span> <span class="number">4294967296e</span><span class="operator">-</span><span class="number">9</span> <span class="operator">+</span> ns<span class="operator">.</span>lo <span class="operator">*</span> <span class="number">1e</span><span class="operator">-</span><span class="number">9</span>);
}
<span class="preprocessor">#endif // __MACOS__</span>
<span class="comment">/*
==============================================================================
Name: compute_clk_mul
Description:
This function, only for PowerPC/MacOS computers, computes the multiplier
required to deduce clock cycles from the internal counter.
Throws: Nothing
==============================================================================
*/</span>
<span class="type">void</span> ClockCycleCounter<span class="operator">::</span>compute_clk_mul ()
{
assert (<span class="operator">!</span> _init_flag);
<span class="preprocessor">#if defined (__MACOS__)</span>
<span class="type">long</span> clk_speed_mhz <span class="operator">=</span> CurrentProcessorSpeed ();
<span class="keyword">const</span> Int64 clk_speed <span class="operator">=</span>
<span class="keyword">static_cast</span> <span class="operator">&lt;</span>Int64<span class="operator">&gt;</span> (clk_speed_mhz) <span class="operator">*</span> (<span class="number">1000L</span><span class="operator">*</span><span class="number">1000L</span>);
<span class="keyword">const</span> <span class="type">double</span> start_time_s <span class="operator">=</span> stopwatch_ClockCycleCounter_get_time_s ();
start ();
<span class="keyword">const</span> <span class="type">double</span> duration <span class="operator">=</span> <span class="number">0.01</span>; <span class="comment">// Seconds</span>
<span class="keyword">while</span> (stopwatch_ClockCycleCounter_get_time_s () <span class="operator">-</span> start_time_s <span class="operator">&lt;</span> duration)
{
<span class="keyword">continue</span>;
}
<span class="keyword">const</span> <span class="type">double</span> stop_time_s <span class="operator">=</span> stopwatch_ClockCycleCounter_get_time_s ();
stop ();
<span class="keyword">const</span> <span class="type">double</span> diff_time_s <span class="operator">=</span> stop_time_s <span class="operator">-</span> start_time_s;
<span class="keyword">const</span> <span class="type">double</span> nbr_cycles <span class="operator">=</span> diff_time_s <span class="operator">*</span> <span class="keyword">static_cast</span> <span class="operator">&lt;</span><span class="type">double</span><span class="operator">&gt;</span> (clk_speed);
<span class="keyword">const</span> Int64 diff_time_c <span class="operator">=</span> _state <span class="operator">-</span> _start_time;
<span class="keyword">const</span> <span class="type">double</span> clk_mul <span class="operator">=</span> nbr_cycles <span class="operator">/</span> <span class="keyword">static_cast</span> <span class="operator">&lt;</span><span class="type">double</span><span class="operator">&gt;</span> (diff_time_c);
_clk_mul <span class="operator">=</span> round_int (clk_mul);
<span class="preprocessor">#endif // __MACOS__</span>
}
<span class="type">void</span> ClockCycleCounter<span class="operator">::</span>compute_measure_time_total ()
{
start ();
spend_time ();
Int64 best_result <span class="operator">=</span> <span class="number">0x7FFFFFFFL</span>; <span class="comment">// Should be enough</span>
<span class="type">long</span> nbr_tests <span class="operator">=</span> <span class="number">100</span>;
<span class="keyword">for</span> (<span class="type">long</span> cnt <span class="operator">=</span> <span class="number">0</span>; cnt <span class="operator">&lt;</span> nbr_tests; <span class="operator">+</span><span class="operator">+</span>cnt)
{
start ();
stop_lap ();
<span class="keyword">const</span> Int64 duration <span class="operator">=</span> _state <span class="operator">-</span> _start_time;
best_result <span class="operator">=</span> min (best_result<span class="operator">,</span> duration);
}
_measure_time_total <span class="operator">=</span> best_result;
}
<span class="comment">/*
==============================================================================
Name: compute_measure_time_lap
Description:
Computes the duration of one stop_lap() call and store it. It will be used
later to get the real duration of the measured operation (by subtracting
the measurement duration).
Throws: Nothing
==============================================================================
*/</span>
<span class="type">void</span> ClockCycleCounter<span class="operator">::</span>compute_measure_time_lap ()
{
start ();
spend_time ();
<span class="type">long</span> nbr_tests <span class="operator">=</span> <span class="number">10</span>;
<span class="keyword">for</span> (<span class="type">long</span> cnt <span class="operator">=</span> <span class="number">0</span>; cnt <span class="operator">&lt;</span> nbr_tests; <span class="operator">+</span><span class="operator">+</span>cnt)
{
stop_lap ();
stop_lap ();
stop_lap ();
stop_lap ();
}
_measure_time_lap <span class="operator">=</span> _best_score;
}
<span class="type">void</span> ClockCycleCounter<span class="operator">::</span>spend_time ()
{
<span class="keyword">const</span> Int64 nbr_clocks <span class="operator">=</span> <span class="number">500</span>; <span class="comment">// Number of clock cycles to spend</span>
<span class="keyword">const</span> Int64 start <span class="operator">=</span> read_clock_counter ();
Int64 current;
<span class="keyword">do</span>
{
current <span class="operator">=</span> read_clock_counter ();
}
<span class="keyword">while</span> ((current <span class="operator">-</span> start) <span class="operator">*</span> _clk_mul <span class="operator">&lt;</span> nbr_clocks);
}
Int64 ClockCycleCounter<span class="operator">::</span>_measure_time_total <span class="operator">=</span> <span class="number">0</span>;
Int64 ClockCycleCounter<span class="operator">::</span>_measure_time_lap <span class="operator">=</span> <span class="number">0</span>;
<span class="type">int</span> ClockCycleCounter<span class="operator">::</span>_clk_mul <span class="operator">=</span> <span class="number">1</span>;
<span class="type">bool</span> ClockCycleCounter<span class="operator">::</span>_init_flag <span class="operator">=</span> <span class="keyword">false</span>;
} <span class="comment">// namespace stopwatch</span>
<span class="comment">/*\\\ EOF \\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\*/</span></pre>
</div>
<!-- @@@demos/spectrum/3rdparty/fftreal/stopwatch/ClockCycleCounter.cpp -->
</div>
</div>
</div>
<div class="ft">
<span></span>
</div>
</div>
<div class="footer">
<p>
<acronym title="Copyright">&copy;</acronym> 2015 The Qt Company Ltd.
Documentation contributions included herein are the copyrights of
their respective owners.</p>
<br />
<p>
The documentation provided herein is licensed under the terms of the
<a href="http://www.gnu.org/licenses/fdl.html">GNU Free Documentation
License version 1.3</a> as published by the Free Software Foundation.</p>
<p>
Documentation sources may be obtained from <a href="http://www.qt-project.org">
www.qt-project.org</a>.</p>
<br />
<p>
Qt and respective logos are trademarks of The Qt Company Ltd
in Finland and/or other countries worldwide. All other trademarks are property
of their respective owners. <a title="Privacy Policy"
href="http://en.gitorious.org/privacy_policy/">Privacy Policy</a></p>
</div>
<script src="scripts/functions.js" type="text/javascript"></script>
</body>
</html>