mesytec-mnode/external/taskflow-3.8.0/docs/xml/classtf_1_1BoundedTaskQueue.xml
2025-01-04 01:25:05 +01:00

343 lines
18 KiB
XML

<?xml version='1.0' encoding='UTF-8' standalone='no'?>
<doxygen xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:noNamespaceSchemaLocation="compound.xsd" version="1.9.1" xml:lang="en-US">
<compounddef id="classtf_1_1BoundedTaskQueue" kind="class" language="C++" prot="public">
<compoundname>tf::BoundedTaskQueue</compoundname>
<includes refid="tsq_8hpp" local="no">taskflow/core/tsq.hpp</includes>
<templateparamlist>
<param>
<type>typename T</type>
</param>
<param>
<type>size_t</type>
<declname>LogSize</declname>
<defname>LogSize</defname>
<defval><ref refid="taskflow_8hpp_1a603f6f29f0f179ee85ecde7d5311a76e" kindref="member">TF_DEFAULT_BOUNDED_TASK_QUEUE_LOG_SIZE</ref></defval>
</param>
</templateparamlist>
<sectiondef kind="private-static-attrib">
<memberdef kind="variable" id="classtf_1_1BoundedTaskQueue_1a97122e789b0d024d4e1f98f46665c0d7" prot="private" static="yes" constexpr="yes" mutable="no">
<type>constexpr static int64_t</type>
<definition>constexpr static int64_t tf::BoundedTaskQueue&lt; T, LogSize &gt;::BufferSize</definition>
<argsstring></argsstring>
<name>BufferSize</name>
<initializer>= int64_t{1} &lt;&lt; LogSize</initializer>
<briefdescription>
</briefdescription>
<detaileddescription>
</detaileddescription>
<inbodydescription>
</inbodydescription>
<location file="taskflow/core/tsq.hpp" line="292" column="28" bodyfile="taskflow/core/tsq.hpp" bodystart="292" bodyend="-1"/>
</memberdef>
<memberdef kind="variable" id="classtf_1_1BoundedTaskQueue_1a98cf29c5be602b8951b9b10238c44900" prot="private" static="yes" constexpr="yes" mutable="no">
<type>constexpr static int64_t</type>
<definition>constexpr static int64_t tf::BoundedTaskQueue&lt; T, LogSize &gt;::BufferMask</definition>
<argsstring></argsstring>
<name>BufferMask</name>
<initializer>= (BufferSize - 1)</initializer>
<briefdescription>
</briefdescription>
<detaileddescription>
</detaileddescription>
<inbodydescription>
</inbodydescription>
<location file="taskflow/core/tsq.hpp" line="293" column="28" bodyfile="taskflow/core/tsq.hpp" bodystart="293" bodyend="-1"/>
</memberdef>
</sectiondef>
<sectiondef kind="private-attrib">
<memberdef kind="variable" id="classtf_1_1BoundedTaskQueue_1a51e4f79ae1957cde7b1208b2119246c6" prot="private" static="no" mutable="no">
<type><ref refid="cpp/atomic/atomic" kindref="compound" external="/home/thuang295/Code/taskflow/doxygen/cppreference-doxygen-web.tag.xml">std::atomic</ref>&lt; int64_t &gt;</type>
<definition>std::atomic&lt;int64_t&gt; tf::BoundedTaskQueue&lt; T, LogSize &gt;::_top</definition>
<argsstring></argsstring>
<name>_top</name>
<initializer>{0}</initializer>
<briefdescription>
</briefdescription>
<detaileddescription>
</detaileddescription>
<inbodydescription>
</inbodydescription>
<location file="taskflow/core/tsq.hpp" line="297" column="23" bodyfile="taskflow/core/tsq.hpp" bodystart="297" bodyend="-1"/>
</memberdef>
<memberdef kind="variable" id="classtf_1_1BoundedTaskQueue_1a4f6a86178138cff2f95243c2cc6b01e4" prot="private" static="no" mutable="no">
<type><ref refid="cpp/atomic/atomic" kindref="compound" external="/home/thuang295/Code/taskflow/doxygen/cppreference-doxygen-web.tag.xml">std::atomic</ref>&lt; int64_t &gt;</type>
<definition>std::atomic&lt;int64_t&gt; tf::BoundedTaskQueue&lt; T, LogSize &gt;::_bottom</definition>
<argsstring></argsstring>
<name>_bottom</name>
<initializer>{0}</initializer>
<briefdescription>
</briefdescription>
<detaileddescription>
</detaileddescription>
<inbodydescription>
</inbodydescription>
<location file="taskflow/core/tsq.hpp" line="298" column="23" bodyfile="taskflow/core/tsq.hpp" bodystart="298" bodyend="-1"/>
</memberdef>
<memberdef kind="variable" id="classtf_1_1BoundedTaskQueue_1ae1871b739c04078d56e2031c6cda8f59" prot="private" static="no" mutable="no">
<type><ref refid="cpp/atomic/atomic" kindref="compound" external="/home/thuang295/Code/taskflow/doxygen/cppreference-doxygen-web.tag.xml">std::atomic</ref>&lt; T &gt;</type>
<definition>std::atomic&lt;T&gt; tf::BoundedTaskQueue&lt; T, LogSize &gt;::_buffer[BufferSize]</definition>
<argsstring>[BufferSize]</argsstring>
<name>_buffer</name>
<briefdescription>
</briefdescription>
<detaileddescription>
</detaileddescription>
<inbodydescription>
</inbodydescription>
<location file="taskflow/core/tsq.hpp" line="299" column="23" bodyfile="taskflow/core/tsq.hpp" bodystart="299" bodyend="-1"/>
</memberdef>
</sectiondef>
<sectiondef kind="public-func">
<memberdef kind="function" id="classtf_1_1BoundedTaskQueue_1a4160bb42036d75bc60f95cc189792a3d" prot="public" static="no" const="no" explicit="no" inline="no" virt="non-virtual">
<type></type>
<definition>tf::BoundedTaskQueue&lt; T, LogSize &gt;::BoundedTaskQueue</definition>
<argsstring>()=default</argsstring>
<name>BoundedTaskQueue</name>
<briefdescription>
<para>constructs the queue with a given capacity </para>
</briefdescription>
<detaileddescription>
</detaileddescription>
<inbodydescription>
</inbodydescription>
<location file="taskflow/core/tsq.hpp" line="306" column="3"/>
</memberdef>
<memberdef kind="function" id="classtf_1_1BoundedTaskQueue_1a5811b32810d0e70a1572a8ef594eba7e" prot="public" static="no" const="no" explicit="no" inline="no" virt="non-virtual">
<type></type>
<definition>tf::BoundedTaskQueue&lt; T, LogSize &gt;::~BoundedTaskQueue</definition>
<argsstring>()=default</argsstring>
<name>~BoundedTaskQueue</name>
<briefdescription>
<para>destructs the queue </para>
</briefdescription>
<detaileddescription>
</detaileddescription>
<inbodydescription>
</inbodydescription>
<location file="taskflow/core/tsq.hpp" line="311" column="3"/>
</memberdef>
<memberdef kind="function" id="classtf_1_1BoundedTaskQueue_1ae64ab051e9ce597482cb602ce967d459" prot="public" static="no" const="yes" explicit="no" inline="no" noexcept="yes" virt="non-virtual">
<type>bool</type>
<definition>bool tf::BoundedTaskQueue&lt; T, LogSize &gt;::empty</definition>
<argsstring>() const noexcept</argsstring>
<name>empty</name>
<briefdescription>
<para>queries if the queue is empty at the time of this call </para>
</briefdescription>
<detaileddescription>
</detaileddescription>
<inbodydescription>
</inbodydescription>
<location file="taskflow/core/tsq.hpp" line="316" column="8" bodyfile="taskflow/core/tsq.hpp" bodystart="374" bodyend="378"/>
</memberdef>
<memberdef kind="function" id="classtf_1_1BoundedTaskQueue_1a76620d4f4a85eae9e4626b9d83c61cb3" prot="public" static="no" const="yes" explicit="no" inline="no" noexcept="yes" virt="non-virtual">
<type>size_t</type>
<definition>size_t tf::BoundedTaskQueue&lt; T, LogSize &gt;::size</definition>
<argsstring>() const noexcept</argsstring>
<name>size</name>
<briefdescription>
<para>queries the number of items at the time of this call </para>
</briefdescription>
<detaileddescription>
</detaileddescription>
<inbodydescription>
</inbodydescription>
<location file="taskflow/core/tsq.hpp" line="321" column="10" bodyfile="taskflow/core/tsq.hpp" bodystart="382" bodyend="386"/>
</memberdef>
<memberdef kind="function" id="classtf_1_1BoundedTaskQueue_1ae3c7315f59e60f806225ee9cf8d55229" prot="public" static="no" constexpr="yes" const="yes" explicit="no" inline="no" virt="non-virtual">
<type>constexpr size_t</type>
<definition>constexpr size_t tf::BoundedTaskQueue&lt; T, LogSize &gt;::capacity</definition>
<argsstring>() const</argsstring>
<name>capacity</name>
<briefdescription>
<para>queries the capacity of the queue </para>
</briefdescription>
<detaileddescription>
</detaileddescription>
<inbodydescription>
</inbodydescription>
<location file="taskflow/core/tsq.hpp" line="326" column="20" bodyfile="taskflow/core/tsq.hpp" bodystart="482" bodyend="484"/>
</memberdef>
<memberdef kind="function" id="classtf_1_1BoundedTaskQueue_1af52edec086b5e1a9c090eff6a6a76dae" prot="public" static="no" const="no" explicit="no" inline="no" virt="non-virtual">
<templateparamlist>
<param>
<type>typename O</type>
</param>
</templateparamlist>
<type>bool</type>
<definition>bool tf::BoundedTaskQueue&lt; T, LogSize &gt;::try_push</definition>
<argsstring>(O &amp;&amp;item)</argsstring>
<name>try_push</name>
<param>
<type>O &amp;&amp;</type>
<declname>item</declname>
</param>
<briefdescription>
<para>tries to insert an item to the queue </para>
</briefdescription>
<detaileddescription>
<para><parameterlist kind="templateparam"><parameteritem>
<parameternamelist>
<parametername>O</parametername>
</parameternamelist>
<parameterdescription>
<para>data type </para>
</parameterdescription>
</parameteritem>
</parameterlist>
<parameterlist kind="param"><parameteritem>
<parameternamelist>
<parametername>item</parametername>
</parameternamelist>
<parameterdescription>
<para>the item to perfect-forward to the queue </para>
</parameterdescription>
</parameteritem>
</parameterlist>
<simplesect kind="return"><para><computeroutput>true</computeroutput> if the insertion succeed or <computeroutput>false</computeroutput> (queue is full)</para>
</simplesect>
Only the owner thread can insert an item to the queue. </para>
</detaileddescription>
<inbodydescription>
</inbodydescription>
<location file="taskflow/core/tsq.hpp" line="339" column="8" bodyfile="taskflow/core/tsq.hpp" bodystart="391" bodyend="407"/>
</memberdef>
<memberdef kind="function" id="classtf_1_1BoundedTaskQueue_1a9b0c93adcdeb0a876869027a211fdf62" prot="public" static="no" const="no" explicit="no" inline="no" virt="non-virtual">
<templateparamlist>
<param>
<type>typename O</type>
</param>
<param>
<type>typename C</type>
</param>
</templateparamlist>
<type>void</type>
<definition>void tf::BoundedTaskQueue&lt; T, LogSize &gt;::push</definition>
<argsstring>(O &amp;&amp;item, C &amp;&amp;on_full)</argsstring>
<name>push</name>
<param>
<type>O &amp;&amp;</type>
<declname>item</declname>
</param>
<param>
<type>C &amp;&amp;</type>
<declname>on_full</declname>
</param>
<briefdescription>
<para>tries to insert an item to the queue or invoke the callable if fails </para>
</briefdescription>
<detaileddescription>
<para><parameterlist kind="templateparam"><parameteritem>
<parameternamelist>
<parametername>O</parametername>
</parameternamelist>
<parameterdescription>
<para>data type </para>
</parameterdescription>
</parameteritem>
<parameteritem>
<parameternamelist>
<parametername>C</parametername>
</parameternamelist>
<parameterdescription>
<para>callable type </para>
</parameterdescription>
</parameteritem>
</parameterlist>
<parameterlist kind="param"><parameteritem>
<parameternamelist>
<parametername>item</parametername>
</parameternamelist>
<parameterdescription>
<para>the item to perfect-forward to the queue </para>
</parameterdescription>
</parameteritem>
<parameteritem>
<parameternamelist>
<parametername>on_full</parametername>
</parameternamelist>
<parameterdescription>
<para>callable to invoke when the queue is faull (insertion fails)</para>
</parameterdescription>
</parameteritem>
</parameterlist>
Only the owner thread can insert an item to the queue. </para>
</detaileddescription>
<inbodydescription>
</inbodydescription>
<location file="taskflow/core/tsq.hpp" line="353" column="8" bodyfile="taskflow/core/tsq.hpp" bodystart="412" bodyend="427"/>
</memberdef>
<memberdef kind="function" id="classtf_1_1BoundedTaskQueue_1a2b9e1d2502b489656b89cb505e95e71b" prot="public" static="no" const="no" explicit="no" inline="no" virt="non-virtual">
<type>T</type>
<definition>T tf::BoundedTaskQueue&lt; T, LogSize &gt;::pop</definition>
<argsstring>()</argsstring>
<name>pop</name>
<briefdescription>
<para>pops out an item from the queue </para>
</briefdescription>
<detaileddescription>
<para>Only the owner thread can pop out an item from the queue. The return can be a <ulink url="https://en.cppreference.com/w/cpp/utility/optional/nullopt">std::nullopt</ulink> if this operation failed (empty queue). </para>
</detaileddescription>
<inbodydescription>
</inbodydescription>
<location file="taskflow/core/tsq.hpp" line="361" column="5" bodyfile="taskflow/core/tsq.hpp" bodystart="431" bodyend="457"/>
</memberdef>
<memberdef kind="function" id="classtf_1_1BoundedTaskQueue_1ad2b4f8d262b0093ce08dea92c00fae1b" prot="public" static="no" const="no" explicit="no" inline="no" virt="non-virtual">
<type>T</type>
<definition>T tf::BoundedTaskQueue&lt; T, LogSize &gt;::steal</definition>
<argsstring>()</argsstring>
<name>steal</name>
<briefdescription>
<para>steals an item from the queue </para>
</briefdescription>
<detaileddescription>
<para>Any threads can try to steal an item from the queue. The return can be a <ulink url="https://en.cppreference.com/w/cpp/utility/optional/nullopt">std::nullopt</ulink> if this operation failed (not necessary empty). </para>
</detaileddescription>
<inbodydescription>
</inbodydescription>
<location file="taskflow/core/tsq.hpp" line="369" column="5" bodyfile="taskflow/core/tsq.hpp" bodystart="461" bodyend="478"/>
</memberdef>
</sectiondef>
<briefdescription>
<para>class to create a lock-free bounded single-producer multiple-consumer queue </para>
</briefdescription>
<detaileddescription>
<para><parameterlist kind="templateparam"><parameteritem>
<parameternamelist>
<parametername>T</parametername>
</parameternamelist>
<parameterdescription>
<para>data type </para>
</parameterdescription>
</parameteritem>
<parameteritem>
<parameternamelist>
<parametername>LogSize</parametername>
</parameternamelist>
<parameterdescription>
<para>the base-2 logarithm of the queue size</para>
</parameterdescription>
</parameteritem>
</parameterlist>
This class implements the work-stealing queue described in the paper, &quot;Correct and Efficient Work-Stealing for Weak Memory Models,&quot; available at <ulink url="https://www.di.ens.fr/~zappa/readings/ppopp13.pdf">https://www.di.ens.fr/~zappa/readings/ppopp13.pdf</ulink>.</para>
<para>Only the queue owner can perform pop and push operations, while others can steal data from the queue. </para>
</detaileddescription>
<location file="taskflow/core/tsq.hpp" line="288" column="1" bodyfile="taskflow/core/tsq.hpp" bodystart="288" bodyend="370"/>
<listofallmembers>
<member refid="classtf_1_1BoundedTaskQueue_1a4f6a86178138cff2f95243c2cc6b01e4" prot="private" virt="non-virtual"><scope>tf::BoundedTaskQueue</scope><name>_bottom</name></member>
<member refid="classtf_1_1BoundedTaskQueue_1ae1871b739c04078d56e2031c6cda8f59" prot="private" virt="non-virtual"><scope>tf::BoundedTaskQueue</scope><name>_buffer</name></member>
<member refid="classtf_1_1BoundedTaskQueue_1a51e4f79ae1957cde7b1208b2119246c6" prot="private" virt="non-virtual"><scope>tf::BoundedTaskQueue</scope><name>_top</name></member>
<member refid="classtf_1_1BoundedTaskQueue_1a4160bb42036d75bc60f95cc189792a3d" prot="public" virt="non-virtual"><scope>tf::BoundedTaskQueue</scope><name>BoundedTaskQueue</name></member>
<member refid="classtf_1_1BoundedTaskQueue_1a98cf29c5be602b8951b9b10238c44900" prot="private" virt="non-virtual"><scope>tf::BoundedTaskQueue</scope><name>BufferMask</name></member>
<member refid="classtf_1_1BoundedTaskQueue_1a97122e789b0d024d4e1f98f46665c0d7" prot="private" virt="non-virtual"><scope>tf::BoundedTaskQueue</scope><name>BufferSize</name></member>
<member refid="classtf_1_1BoundedTaskQueue_1ae3c7315f59e60f806225ee9cf8d55229" prot="public" virt="non-virtual"><scope>tf::BoundedTaskQueue</scope><name>capacity</name></member>
<member refid="classtf_1_1BoundedTaskQueue_1ae64ab051e9ce597482cb602ce967d459" prot="public" virt="non-virtual"><scope>tf::BoundedTaskQueue</scope><name>empty</name></member>
<member refid="classtf_1_1BoundedTaskQueue_1a2b9e1d2502b489656b89cb505e95e71b" prot="public" virt="non-virtual"><scope>tf::BoundedTaskQueue</scope><name>pop</name></member>
<member refid="classtf_1_1BoundedTaskQueue_1a9b0c93adcdeb0a876869027a211fdf62" prot="public" virt="non-virtual"><scope>tf::BoundedTaskQueue</scope><name>push</name></member>
<member refid="classtf_1_1BoundedTaskQueue_1a76620d4f4a85eae9e4626b9d83c61cb3" prot="public" virt="non-virtual"><scope>tf::BoundedTaskQueue</scope><name>size</name></member>
<member refid="classtf_1_1BoundedTaskQueue_1ad2b4f8d262b0093ce08dea92c00fae1b" prot="public" virt="non-virtual"><scope>tf::BoundedTaskQueue</scope><name>steal</name></member>
<member refid="classtf_1_1BoundedTaskQueue_1af52edec086b5e1a9c090eff6a6a76dae" prot="public" virt="non-virtual"><scope>tf::BoundedTaskQueue</scope><name>try_push</name></member>
<member refid="classtf_1_1BoundedTaskQueue_1a5811b32810d0e70a1572a8ef594eba7e" prot="public" virt="non-virtual"><scope>tf::BoundedTaskQueue</scope><name>~BoundedTaskQueue</name></member>
</listofallmembers>
</compounddef>
</doxygen>