Planet
navi homePPSaboutscreenshotsdownloaddevelopmentforum

source: downloads/boost_1_34_1/libs/preprocessor/doc/ref/mul.html @ 29

Last change on this file since 29 was 29, checked in by landauf, 16 years ago

updated boost from 1_33_1 to 1_34_1

File size: 2.4 KB
Line 
1<html>
2<head>
3        <title>BOOST_PP_MUL</title>
4        <link rel="stylesheet" type="text/css" href="../styles.css">
5</head>
6<body>
7        <div style="margin-left:  0px;">
8                The <b>BOOST_PP_MUL</b> macro expands to the product of its arguments.
9        </div>
10        <h4>Usage</h4>
11                <div class="code">
12                        <b>BOOST_PP_MUL</b>(<i>x</i>, <i>y</i>)
13                </div>
14        <h4>Arguments</h4>
15                <dl>
16                        <dt>x</dt>
17                        <dd>
18                                The multiplicand of the operation.&nbsp;
19                                Valid values range from <i>0</i> to <b>BOOST_PP_LIMIT_MAG</b>.
20                        </dd>
21                        <dt>y</dt>
22                        <dd>
23                                The multiplier of the operation.&nbsp;
24                                Valid values range from <i>0</i> to <b>BOOST_PP_LIMIT_MAG</b>.
25                        </dd>
26                </dl>
27        <h4>Remarks</h4>
28                <div>
29                        If the product of <i>x</i> and <i>y</i> is greater than <b>BOOST_PP_LIMIT_MAG</b>, the result is saturated to <b>BOOST_PP_LIMIT_MAG</b>.
30                </div>
31                <div>
32                        Previously, this macro could not be used inside <b>BOOST_PP_WHILE</b>.&nbsp;
33                        There is no longer any such restriction.&nbsp;
34                        It is more efficient, however, to use <b>BOOST_PP_MUL_D</b> in such a situation.
35                </div>
36                <div>
37                        This macro is the most efficient when <i>x</i> is less than or equal to <i>y</i>.&nbsp;
38                        However, the efficiency gain is not worth actually comparing the two arguments prior to invocation.&nbsp;
39                        In other words, <i>x</i> should be the value that is <i>most likely</i> to be the largest of the two operands.
40                </div>
41        <h4>See Also</h4>
42                <ul>
43                        <li><a href="limit_mag.html">BOOST_PP_LIMIT_MAG</a></li>
44                        <li><a href="mul_d.html">BOOST_PP_MUL_D</a></li>
45                </ul>
46        <h4>Requirements</h4>
47                <div>
48                        <b>Header:</b> &nbsp;<a href="../headers/arithmetic/mul.html">&lt;boost/preprocessor/arithmetic/mul.hpp&gt;</a>
49                </div>
50        <h4>Sample Code</h4>
51<div><pre>
52#include &lt;<a href="../headers/arithmetic/mul.html">boost/preprocessor/arithmetic/mul.hpp</a>&gt;
53
54<a href="mul.html">BOOST_PP_MUL</a>(4, 4) // expands to 16
55</pre></div>
56        <hr size="1">
57        <div style="margin-left: 0px;">
58                <i>© Copyright <a href="http://www.housemarque.com" target="_top">Housemarque Oy</a> 2002</i>
59                </br><i>© Copyright Paul Mensonides 2002</i>
60        </div>
61        <div style="margin-left: 0px;">
62                <p><small>Distributed under the Boost Software License, Version 1.0. (See
63                accompanying file <a href="../../../../LICENSE_1_0.txt">LICENSE_1_0.txt</a> or
64                copy at <a href=
65                "http://www.boost.org/LICENSE_1_0.txt">www.boost.org/LICENSE_1_0.txt</a>)</small></p>
66        </div>
67</body>
68</html>
Note: See TracBrowser for help on using the repository browser.