|
|
|
|
@@ -106,6 +106,7 @@ $(function(){initNavTree('d9/d29/ground__to__ground__projectile__motion_8cpp.htm
|
|
|
|
|
<div class="header">
|
|
|
|
|
<div class="summary">
|
|
|
|
|
<a href="#namespaces">Namespaces</a> |
|
|
|
|
|
<a href="#define-members">Macros</a> |
|
|
|
|
|
<a href="#func-members">Functions</a> </div>
|
|
|
|
|
<div class="headertitle"><div class="title">ground_to_ground_projectile_motion.cpp File Reference</div></div>
|
|
|
|
|
</div><!--header-->
|
|
|
|
|
@@ -131,11 +132,18 @@ Namespaces</h2></td></tr>
|
|
|
|
|
<tr class="memdesc:d0/d20/namespaceground__to__ground__projectile__motion"><td class="mdescLeft"> </td><td class="mdescRight">Functions for the Ground to ground <a href="https://en.wikipedia.org/wiki/Projectile_motion" target="_blank">projectile motion</a> equation. <br /></td></tr>
|
|
|
|
|
<tr class="separator:"><td class="memSeparator" colspan="2"> </td></tr>
|
|
|
|
|
</table><table class="memberdecls">
|
|
|
|
|
<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="define-members" name="define-members"></a>
|
|
|
|
|
Macros</h2></td></tr>
|
|
|
|
|
<tr class="memitem:a525335710b53cb064ca56b936120431e" id="r_a525335710b53cb064ca56b936120431e"><td class="memItemLeft" align="right" valign="top"><a id="a525335710b53cb064ca56b936120431e" name="a525335710b53cb064ca56b936120431e"></a>
|
|
|
|
|
#define </td><td class="memItemRight" valign="bottom"><b>_USE_MATH_DEFINES</b></td></tr>
|
|
|
|
|
<tr class="memdesc:a525335710b53cb064ca56b936120431e"><td class="mdescLeft"> </td><td class="mdescRight">for assert() <br /></td></tr>
|
|
|
|
|
<tr class="separator:a525335710b53cb064ca56b936120431e"><td class="memSeparator" colspan="2"> </td></tr>
|
|
|
|
|
</table><table class="memberdecls">
|
|
|
|
|
<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="func-members" name="func-members"></a>
|
|
|
|
|
Functions</h2></td></tr>
|
|
|
|
|
<tr class="memitem:aba1d26faf6a5379c28cae458956241de" id="r_aba1d26faf6a5379c28cae458956241de"><td class="memItemLeft" align="right" valign="top">double </td><td class="memItemRight" valign="bottom"><a class="el" href="#aba1d26faf6a5379c28cae458956241de">physics::ground_to_ground_projectile_motion::degrees_to_radians</a> (double radian, double PI=3.14)</td></tr>
|
|
|
|
|
<tr class="memdesc:aba1d26faf6a5379c28cae458956241de"><td class="mdescLeft"> </td><td class="mdescRight">Convert radians to degrees. <br /></td></tr>
|
|
|
|
|
<tr class="separator:aba1d26faf6a5379c28cae458956241de"><td class="memSeparator" colspan="2"> </td></tr>
|
|
|
|
|
<tr class="memitem:ab00e9785fb2670f7af99d6f3d636f87c" id="r_ab00e9785fb2670f7af99d6f3d636f87c"><td class="memItemLeft" align="right" valign="top">double </td><td class="memItemRight" valign="bottom"><a class="el" href="#ab00e9785fb2670f7af99d6f3d636f87c">physics::ground_to_ground_projectile_motion::degrees_to_radians</a> (double degrees)</td></tr>
|
|
|
|
|
<tr class="memdesc:ab00e9785fb2670f7af99d6f3d636f87c"><td class="mdescLeft"> </td><td class="mdescRight">Convert radians to degrees. <br /></td></tr>
|
|
|
|
|
<tr class="separator:ab00e9785fb2670f7af99d6f3d636f87c"><td class="memSeparator" colspan="2"> </td></tr>
|
|
|
|
|
<tr class="memitem:a563e066975fed1b84750a0a47c3cbb37" id="r_a563e066975fed1b84750a0a47c3cbb37"><td class="memTemplParams" colspan="2">template<typename T > </td></tr>
|
|
|
|
|
<tr class="memitem:a563e066975fed1b84750a0a47c3cbb37"><td class="memTemplItemLeft" align="right" valign="top">T </td><td class="memTemplItemRight" valign="bottom"><a class="el" href="#a563e066975fed1b84750a0a47c3cbb37">physics::ground_to_ground_projectile_motion::time_of_flight</a> (T initial_velocity, T angle, double gravity=9.81)</td></tr>
|
|
|
|
|
<tr class="memdesc:a563e066975fed1b84750a0a47c3cbb37"><td class="mdescLeft"> </td><td class="mdescRight">Calculate the time of flight. <br /></td></tr>
|
|
|
|
|
@@ -160,8 +168,8 @@ Functions</h2></td></tr>
|
|
|
|
|
<p>Ground to ground projectile motion is when a projectile's trajectory starts at the ground, reaches the apex, then falls back on the ground.</p>
|
|
|
|
|
<dl class="section author"><dt>Author</dt><dd><a href="https://github.com/Focusucof" target="_blank">Focusucof</a> </dd></dl>
|
|
|
|
|
</div><h2 class="groupheader">Function Documentation</h2>
|
|
|
|
|
<a id="aba1d26faf6a5379c28cae458956241de" name="aba1d26faf6a5379c28cae458956241de"></a>
|
|
|
|
|
<h2 class="memtitle"><span class="permalink"><a href="#aba1d26faf6a5379c28cae458956241de">◆ </a></span>degrees_to_radians()</h2>
|
|
|
|
|
<a id="ab00e9785fb2670f7af99d6f3d636f87c" name="ab00e9785fb2670f7af99d6f3d636f87c"></a>
|
|
|
|
|
<h2 class="memtitle"><span class="permalink"><a href="#ab00e9785fb2670f7af99d6f3d636f87c">◆ </a></span>degrees_to_radians()</h2>
|
|
|
|
|
|
|
|
|
|
<div class="memitem">
|
|
|
|
|
<div class="memproto">
|
|
|
|
|
@@ -169,12 +177,8 @@ Functions</h2></td></tr>
|
|
|
|
|
<tr>
|
|
|
|
|
<td class="memname">double physics::ground_to_ground_projectile_motion::degrees_to_radians </td>
|
|
|
|
|
<td>(</td>
|
|
|
|
|
<td class="paramtype">double</td> <td class="paramname"><span class="paramname"><em>radian</em></span>, </td>
|
|
|
|
|
</tr>
|
|
|
|
|
<tr>
|
|
|
|
|
<td class="paramkey"></td>
|
|
|
|
|
<td class="paramtype">double</td> <td class="paramname"><span class="paramname"><em>degrees</em></span></td><td>)</td>
|
|
|
|
|
<td></td>
|
|
|
|
|
<td class="paramtype">double</td> <td class="paramname"><span class="paramname"><em>PI</em></span><span class="paramdefsep"> = </span><span class="paramdefval">3.14</span> )</td>
|
|
|
|
|
</tr>
|
|
|
|
|
</table>
|
|
|
|
|
</div><div class="memdoc">
|
|
|
|
|
@@ -183,18 +187,18 @@ Functions</h2></td></tr>
|
|
|
|
|
<dl class="params"><dt>Parameters</dt><dd>
|
|
|
|
|
<table class="params">
|
|
|
|
|
<tr><td class="paramname">radian</td><td>Angle in radians </td></tr>
|
|
|
|
|
<tr><td class="paramname">PI</td><td>The definition of the constant PI </td></tr>
|
|
|
|
|
</table>
|
|
|
|
|
</dd>
|
|
|
|
|
</dl>
|
|
|
|
|
<dl class="section return"><dt>Returns</dt><dd>Angle in degrees </dd></dl>
|
|
|
|
|
<div class="fragment"><div class="line"><span class="lineno"> 33</span> {</div>
|
|
|
|
|
<div class="line"><span class="lineno"> 34</span> <span class="keywordflow">return</span> (radian * (PI / 180));</div>
|
|
|
|
|
<div class="line"><span class="lineno"> 35</span>}</div>
|
|
|
|
|
<div class="fragment"><div class="line"><span class="lineno"> 34</span> {</div>
|
|
|
|
|
<div class="line"><span class="lineno"> 35</span> <span class="keywordtype">double</span> radians = degrees * (M_PI / 180);</div>
|
|
|
|
|
<div class="line"><span class="lineno"> 36</span> <span class="keywordflow">return</span> radians;</div>
|
|
|
|
|
<div class="line"><span class="lineno"> 37</span>}</div>
|
|
|
|
|
</div><!-- fragment --><div class="dynheader">
|
|
|
|
|
Here is the call graph for this function:</div>
|
|
|
|
|
<div class="dyncontent">
|
|
|
|
|
<div class="center"><iframe scrolling="no" frameborder="0" src="../../d9/d29/ground__to__ground__projectile__motion_8cpp_aba1d26faf6a5379c28cae458956241de_cgraph.svg" width="183" height="91"><p><b>This browser is not able to show SVG: try Firefox, Chrome, Safari, or Opera instead.</b></p></iframe></div>
|
|
|
|
|
<div class="center"><iframe scrolling="no" frameborder="0" src="../../d9/d29/ground__to__ground__projectile__motion_8cpp_ab00e9785fb2670f7af99d6f3d636f87c_cgraph.svg" width="183" height="91"><p><b>This browser is not able to show SVG: try Firefox, Chrome, Safari, or Opera instead.</b></p></iframe></div>
|
|
|
|
|
</div>
|
|
|
|
|
|
|
|
|
|
</div>
|
|
|
|
|
@@ -234,12 +238,12 @@ template<typename T > </div>
|
|
|
|
|
</dd>
|
|
|
|
|
</dl>
|
|
|
|
|
<dl class="section return"><dt>Returns</dt><dd>Horizontal distance that the projectile travels </dd></dl>
|
|
|
|
|
<div class="fragment"><div class="line"><span class="lineno"> 57</span> {</div>
|
|
|
|
|
<div class="line"><span class="lineno"> 58</span> <span class="keywordtype">double</span> Vix = initial_velocity * (<a class="code hl_functionRef" target="_blank" href="http://en.cppreference.com/w/cpp/numeric/math/cos.html">std::cos</a>(<a class="code hl_function" href="#aba1d26faf6a5379c28cae458956241de">degrees_to_radians</a>(angle))); <span class="comment">// calculate x component of the initial velocity</span></div>
|
|
|
|
|
<div class="line"><span class="lineno"> 59</span> <span class="keywordflow">return</span> Vix * <a class="code hl_functionRef" target="_blank" href="http://en.cppreference.com/w/cpp/chrono/c/time.html">time</a>;</div>
|
|
|
|
|
<div class="line"><span class="lineno"> 60</span>}</div>
|
|
|
|
|
<div class="fragment"><div class="line"><span class="lineno"> 59</span> {</div>
|
|
|
|
|
<div class="line"><span class="lineno"> 60</span> <span class="keywordtype">double</span> Vix = initial_velocity * (<a class="code hl_functionRef" target="_blank" href="http://en.cppreference.com/w/cpp/numeric/math/cos.html">std::cos</a>(<a class="code hl_function" href="#ab00e9785fb2670f7af99d6f3d636f87c">degrees_to_radians</a>(angle))); <span class="comment">// calculate x component of the initial velocity</span></div>
|
|
|
|
|
<div class="line"><span class="lineno"> 61</span> <span class="keywordflow">return</span> Vix * <a class="code hl_functionRef" target="_blank" href="http://en.cppreference.com/w/cpp/chrono/c/time.html">time</a>;</div>
|
|
|
|
|
<div class="line"><span class="lineno"> 62</span>}</div>
|
|
|
|
|
<div class="ttc" id="acos_html"><div class="ttname"><a href="http://en.cppreference.com/w/cpp/numeric/math/cos.html">std::cos</a></div><div class="ttdeci">T cos(T... args)</div></div>
|
|
|
|
|
<div class="ttc" id="aground__to__ground__projectile__motion_8cpp_html_aba1d26faf6a5379c28cae458956241de"><div class="ttname"><a href="#aba1d26faf6a5379c28cae458956241de">physics::ground_to_ground_projectile_motion::degrees_to_radians</a></div><div class="ttdeci">double degrees_to_radians(double radian, double PI=3.14)</div><div class="ttdoc">Convert radians to degrees.</div><div class="ttdef"><b>Definition</b> ground_to_ground_projectile_motion.cpp:33</div></div>
|
|
|
|
|
<div class="ttc" id="aground__to__ground__projectile__motion_8cpp_html_ab00e9785fb2670f7af99d6f3d636f87c"><div class="ttname"><a href="#ab00e9785fb2670f7af99d6f3d636f87c">physics::ground_to_ground_projectile_motion::degrees_to_radians</a></div><div class="ttdeci">double degrees_to_radians(double degrees)</div><div class="ttdoc">Convert radians to degrees.</div><div class="ttdef"><b>Definition</b> ground_to_ground_projectile_motion.cpp:34</div></div>
|
|
|
|
|
<div class="ttc" id="atime_html"><div class="ttname"><a href="http://en.cppreference.com/w/cpp/chrono/c/time.html">std::time</a></div><div class="ttdeci">T time(T... args)</div></div>
|
|
|
|
|
</div><!-- fragment --><div class="dynheader">
|
|
|
|
|
Here is the call graph for this function:</div>
|
|
|
|
|
@@ -266,11 +270,11 @@ Here is the call graph for this function:</div>
|
|
|
|
|
|
|
|
|
|
<p>Main function. </p>
|
|
|
|
|
<dl class="section return"><dt>Returns</dt><dd>0 on exit </dd></dl>
|
|
|
|
|
<div class="fragment"><div class="line"><span class="lineno"> 136</span> {</div>
|
|
|
|
|
<div class="line"><span class="lineno"> 137</span> <a class="code hl_function" href="#aa8dca7b867074164d5f45b0f3851269d">test</a>(); <span class="comment">// run self-test implementations</span></div>
|
|
|
|
|
<div class="line"><span class="lineno"> 138</span> <span class="keywordflow">return</span> 0;</div>
|
|
|
|
|
<div class="line"><span class="lineno"> 139</span>}</div>
|
|
|
|
|
<div class="ttc" id="aground__to__ground__projectile__motion_8cpp_html_aa8dca7b867074164d5f45b0f3851269d"><div class="ttname"><a href="#aa8dca7b867074164d5f45b0f3851269d">test</a></div><div class="ttdeci">static void test()</div><div class="ttdoc">Self-test implementations.</div><div class="ttdef"><b>Definition</b> ground_to_ground_projectile_motion.cpp:81</div></div>
|
|
|
|
|
<div class="fragment"><div class="line"><span class="lineno"> 138</span> {</div>
|
|
|
|
|
<div class="line"><span class="lineno"> 139</span> <a class="code hl_function" href="#aa8dca7b867074164d5f45b0f3851269d">test</a>(); <span class="comment">// run self-test implementations</span></div>
|
|
|
|
|
<div class="line"><span class="lineno"> 140</span> <span class="keywordflow">return</span> 0;</div>
|
|
|
|
|
<div class="line"><span class="lineno"> 141</span>}</div>
|
|
|
|
|
<div class="ttc" id="aground__to__ground__projectile__motion_8cpp_html_aa8dca7b867074164d5f45b0f3851269d"><div class="ttname"><a href="#aa8dca7b867074164d5f45b0f3851269d">test</a></div><div class="ttdeci">static void test()</div><div class="ttdoc">Self-test implementations.</div><div class="ttdef"><b>Definition</b> ground_to_ground_projectile_motion.cpp:83</div></div>
|
|
|
|
|
</div><!-- fragment --><div class="dynheader">
|
|
|
|
|
Here is the call graph for this function:</div>
|
|
|
|
|
<div class="dyncontent">
|
|
|
|
|
@@ -315,10 +319,10 @@ template<typename T > </div>
|
|
|
|
|
</dd>
|
|
|
|
|
</dl>
|
|
|
|
|
<dl class="section return"><dt>Returns</dt><dd>The max height that the projectile reaches </dd></dl>
|
|
|
|
|
<div class="fragment"><div class="line"><span class="lineno"> 70</span> {</div>
|
|
|
|
|
<div class="line"><span class="lineno"> 71</span> <span class="keywordtype">double</span> Viy = initial_velocity * (<a class="code hl_functionRef" target="_blank" href="http://en.cppreference.com/w/cpp/numeric/math/sin.html">std::sin</a>(<a class="code hl_function" href="#aba1d26faf6a5379c28cae458956241de">degrees_to_radians</a>(angle))); <span class="comment">// calculate y component of the initial velocity</span></div>
|
|
|
|
|
<div class="line"><span class="lineno"> 72</span> <span class="keywordflow">return</span> (<a class="code hl_functionRef" target="_blank" href="http://en.cppreference.com/w/cpp/numeric/math/pow.html">std::pow</a>(Viy, 2) / (2.0 * gravity));</div>
|
|
|
|
|
<div class="line"><span class="lineno"> 73</span>}</div>
|
|
|
|
|
<div class="fragment"><div class="line"><span class="lineno"> 72</span> {</div>
|
|
|
|
|
<div class="line"><span class="lineno"> 73</span> <span class="keywordtype">double</span> Viy = initial_velocity * (<a class="code hl_functionRef" target="_blank" href="http://en.cppreference.com/w/cpp/numeric/math/sin.html">std::sin</a>(<a class="code hl_function" href="#ab00e9785fb2670f7af99d6f3d636f87c">degrees_to_radians</a>(angle))); <span class="comment">// calculate y component of the initial velocity</span></div>
|
|
|
|
|
<div class="line"><span class="lineno"> 74</span> <span class="keywordflow">return</span> (<a class="code hl_functionRef" target="_blank" href="http://en.cppreference.com/w/cpp/numeric/math/pow.html">std::pow</a>(Viy, 2) / (2.0 * gravity));</div>
|
|
|
|
|
<div class="line"><span class="lineno"> 75</span>}</div>
|
|
|
|
|
<div class="ttc" id="apow_html"><div class="ttname"><a href="http://en.cppreference.com/w/cpp/numeric/math/pow.html">std::pow</a></div><div class="ttdeci">T pow(T... args)</div></div>
|
|
|
|
|
<div class="ttc" id="asin_html"><div class="ttname"><a href="http://en.cppreference.com/w/cpp/numeric/math/sin.html">std::sin</a></div><div class="ttdeci">T sin(T... args)</div></div>
|
|
|
|
|
</div><!-- fragment --><div class="dynheader">
|
|
|
|
|
@@ -354,56 +358,56 @@ Here is the call graph for this function:</div>
|
|
|
|
|
|
|
|
|
|
<p>Self-test implementations. </p>
|
|
|
|
|
<dl class="section return"><dt>Returns</dt><dd>void </dd></dl>
|
|
|
|
|
<div class="fragment"><div class="line"><span class="lineno"> 81</span> {</div>
|
|
|
|
|
<div class="line"><span class="lineno"> 82</span> <span class="comment">// initial input variables</span></div>
|
|
|
|
|
<div class="line"><span class="lineno"> 83</span> <span class="keywordtype">double</span> initial_velocity = 5.0; <span class="comment">// double initial_velocity input</span></div>
|
|
|
|
|
<div class="line"><span class="lineno"> 84</span> <span class="keywordtype">double</span> angle = 40.0; <span class="comment">// double angle input</span></div>
|
|
|
|
|
<div class="line"><span class="lineno"> 85</span> </div>
|
|
|
|
|
<div class="line"><span class="lineno"> 86</span> <span class="comment">// 1st test</span></div>
|
|
|
|
|
<div class="line"><span class="lineno"> 87</span> <span class="keywordtype">double</span> expected_time_of_flight = 0.655; <span class="comment">// expected time output</span></div>
|
|
|
|
|
<div class="line"><span class="lineno"> 88</span> <span class="keywordtype">double</span> flight_time_output =</div>
|
|
|
|
|
<div class="line"><span class="lineno"> 89</span> <a class="code hl_functionRef" target="_blank" href="http://en.cppreference.com/w/cpp/numeric/math/round.html">std::round</a>(physics::ground_to_ground_projectile_motion::time_of_flight(initial_velocity, angle) * 1000.0) /</div>
|
|
|
|
|
<div class="line"><span class="lineno"> 90</span> 1000.0; <span class="comment">// round output to 3 decimal places</span></div>
|
|
|
|
|
<div class="line"><span class="lineno"> 91</span> </div>
|
|
|
|
|
<div class="line"><span class="lineno"> 92</span> <a class="code hl_classRef" target="_blank" href="http://en.cppreference.com/w/cpp/io/basic_ostream.html">std::cout</a> << <span class="stringliteral">"Projectile Flight Time (double)"</span> << <a class="code hl_functionRef" target="_blank" href="http://en.cppreference.com/w/cpp/io/manip/endl.html">std::endl</a>;</div>
|
|
|
|
|
<div class="line"><span class="lineno"> 93</span> <a class="code hl_classRef" target="_blank" href="http://en.cppreference.com/w/cpp/io/basic_ostream.html">std::cout</a> << <span class="stringliteral">"Input Initial Velocity: "</span> << initial_velocity << <a class="code hl_functionRef" target="_blank" href="http://en.cppreference.com/w/cpp/io/manip/endl.html">std::endl</a>;</div>
|
|
|
|
|
<div class="line"><span class="lineno"> 94</span> <a class="code hl_classRef" target="_blank" href="http://en.cppreference.com/w/cpp/io/basic_ostream.html">std::cout</a> << <span class="stringliteral">"Input Angle: "</span> << angle << <a class="code hl_functionRef" target="_blank" href="http://en.cppreference.com/w/cpp/io/manip/endl.html">std::endl</a>;</div>
|
|
|
|
|
<div class="line"><span class="lineno"> 95</span> <a class="code hl_classRef" target="_blank" href="http://en.cppreference.com/w/cpp/io/basic_ostream.html">std::cout</a> << <span class="stringliteral">"Expected Output: "</span> << expected_time_of_flight << <a class="code hl_functionRef" target="_blank" href="http://en.cppreference.com/w/cpp/io/manip/endl.html">std::endl</a>;</div>
|
|
|
|
|
<div class="line"><span class="lineno"> 96</span> <a class="code hl_classRef" target="_blank" href="http://en.cppreference.com/w/cpp/io/basic_ostream.html">std::cout</a> << <span class="stringliteral">"Output: "</span> << flight_time_output << <a class="code hl_functionRef" target="_blank" href="http://en.cppreference.com/w/cpp/io/manip/endl.html">std::endl</a>;</div>
|
|
|
|
|
<div class="line"><span class="lineno"> 97</span> assert(flight_time_output == expected_time_of_flight);</div>
|
|
|
|
|
<div class="line"><span class="lineno"> 98</span> <a class="code hl_classRef" target="_blank" href="http://en.cppreference.com/w/cpp/io/basic_ostream.html">std::cout</a> << <span class="stringliteral">"TEST PASSED"</span> << <a class="code hl_functionRef" target="_blank" href="http://en.cppreference.com/w/cpp/io/manip/endl.html">std::endl</a> << <a class="code hl_functionRef" target="_blank" href="http://en.cppreference.com/w/cpp/io/manip/endl.html">std::endl</a>;</div>
|
|
|
|
|
<div class="line"><span class="lineno"> 99</span> </div>
|
|
|
|
|
<div class="line"><span class="lineno"> 100</span> <span class="comment">// 2nd test</span></div>
|
|
|
|
|
<div class="line"><span class="lineno"> 101</span> <span class="keywordtype">double</span> expected_horizontal_range = 2.51; <span class="comment">// expected range output</span></div>
|
|
|
|
|
<div class="line"><span class="lineno"> 102</span> <span class="keywordtype">double</span> horizontal_range_output =</div>
|
|
|
|
|
<div class="line"><span class="lineno"> 103</span> <a class="code hl_functionRef" target="_blank" href="http://en.cppreference.com/w/cpp/numeric/math/round.html">std::round</a>(physics::ground_to_ground_projectile_motion::horizontal_range(initial_velocity, angle,</div>
|
|
|
|
|
<div class="line"><span class="lineno"> 104</span> flight_time_output) *</div>
|
|
|
|
|
<div class="line"><span class="lineno"> 105</span> 100.0) /</div>
|
|
|
|
|
<div class="line"><span class="lineno"> 106</span> 100.0; <span class="comment">// round output to 2 decimal places</span></div>
|
|
|
|
|
<div class="line"><span class="lineno"> 107</span> </div>
|
|
|
|
|
<div class="line"><span class="lineno"> 108</span> <a class="code hl_classRef" target="_blank" href="http://en.cppreference.com/w/cpp/io/basic_ostream.html">std::cout</a> << <span class="stringliteral">"Projectile Horizontal Range (double)"</span> << <a class="code hl_functionRef" target="_blank" href="http://en.cppreference.com/w/cpp/io/manip/endl.html">std::endl</a>;</div>
|
|
|
|
|
<div class="line"><span class="lineno"> 109</span> <a class="code hl_classRef" target="_blank" href="http://en.cppreference.com/w/cpp/io/basic_ostream.html">std::cout</a> << <span class="stringliteral">"Input Initial Velocity: "</span> << initial_velocity << <a class="code hl_functionRef" target="_blank" href="http://en.cppreference.com/w/cpp/io/manip/endl.html">std::endl</a>;</div>
|
|
|
|
|
<div class="line"><span class="lineno"> 110</span> <a class="code hl_classRef" target="_blank" href="http://en.cppreference.com/w/cpp/io/basic_ostream.html">std::cout</a> << <span class="stringliteral">"Input Angle: "</span> << angle << <a class="code hl_functionRef" target="_blank" href="http://en.cppreference.com/w/cpp/io/manip/endl.html">std::endl</a>;</div>
|
|
|
|
|
<div class="line"><span class="lineno"> 111</span> <a class="code hl_classRef" target="_blank" href="http://en.cppreference.com/w/cpp/io/basic_ostream.html">std::cout</a> << <span class="stringliteral">"Input Time Of Flight: "</span> << flight_time_output << <a class="code hl_functionRef" target="_blank" href="http://en.cppreference.com/w/cpp/io/manip/endl.html">std::endl</a>;</div>
|
|
|
|
|
<div class="line"><span class="lineno"> 112</span> <a class="code hl_classRef" target="_blank" href="http://en.cppreference.com/w/cpp/io/basic_ostream.html">std::cout</a> << <span class="stringliteral">"Expected Output: "</span> << expected_horizontal_range << <a class="code hl_functionRef" target="_blank" href="http://en.cppreference.com/w/cpp/io/manip/endl.html">std::endl</a>;</div>
|
|
|
|
|
<div class="line"><span class="lineno"> 113</span> <a class="code hl_classRef" target="_blank" href="http://en.cppreference.com/w/cpp/io/basic_ostream.html">std::cout</a> << <span class="stringliteral">"Output: "</span> << horizontal_range_output << <a class="code hl_functionRef" target="_blank" href="http://en.cppreference.com/w/cpp/io/manip/endl.html">std::endl</a>;</div>
|
|
|
|
|
<div class="line"><span class="lineno"> 114</span> assert(horizontal_range_output == expected_horizontal_range);</div>
|
|
|
|
|
<div class="line"><span class="lineno"> 115</span> <a class="code hl_classRef" target="_blank" href="http://en.cppreference.com/w/cpp/io/basic_ostream.html">std::cout</a> << <span class="stringliteral">"TEST PASSED"</span> << <a class="code hl_functionRef" target="_blank" href="http://en.cppreference.com/w/cpp/io/manip/endl.html">std::endl</a> << <a class="code hl_functionRef" target="_blank" href="http://en.cppreference.com/w/cpp/io/manip/endl.html">std::endl</a>;</div>
|
|
|
|
|
<div class="line"><span class="lineno"> 116</span> </div>
|
|
|
|
|
<div class="line"><span class="lineno"> 117</span> <span class="comment">// 3rd test</span></div>
|
|
|
|
|
<div class="line"><span class="lineno"> 118</span> <span class="keywordtype">double</span> expected_max_height = 0.526; <span class="comment">// expected height output</span></div>
|
|
|
|
|
<div class="line"><span class="lineno"> 119</span> <span class="keywordtype">double</span> max_height_output =</div>
|
|
|
|
|
<div class="line"><span class="lineno"> 120</span> <a class="code hl_functionRef" target="_blank" href="http://en.cppreference.com/w/cpp/numeric/math/round.html">std::round</a>(physics::ground_to_ground_projectile_motion::max_height(initial_velocity, angle) * 1000.0) /</div>
|
|
|
|
|
<div class="line"><span class="lineno"> 121</span> 1000.0; <span class="comment">// round output to 3 decimal places</span></div>
|
|
|
|
|
<div class="line"><span class="lineno"> 122</span> </div>
|
|
|
|
|
<div class="line"><span class="lineno"> 123</span> <a class="code hl_classRef" target="_blank" href="http://en.cppreference.com/w/cpp/io/basic_ostream.html">std::cout</a> << <span class="stringliteral">"Projectile Max Height (double)"</span> << <a class="code hl_functionRef" target="_blank" href="http://en.cppreference.com/w/cpp/io/manip/endl.html">std::endl</a>;</div>
|
|
|
|
|
<div class="line"><span class="lineno"> 124</span> <a class="code hl_classRef" target="_blank" href="http://en.cppreference.com/w/cpp/io/basic_ostream.html">std::cout</a> << <span class="stringliteral">"Input Initial Velocity: "</span> << initial_velocity << <a class="code hl_functionRef" target="_blank" href="http://en.cppreference.com/w/cpp/io/manip/endl.html">std::endl</a>;</div>
|
|
|
|
|
<div class="line"><span class="lineno"> 125</span> <a class="code hl_classRef" target="_blank" href="http://en.cppreference.com/w/cpp/io/basic_ostream.html">std::cout</a> << <span class="stringliteral">"Input Angle: "</span> << angle << <a class="code hl_functionRef" target="_blank" href="http://en.cppreference.com/w/cpp/io/manip/endl.html">std::endl</a>;</div>
|
|
|
|
|
<div class="line"><span class="lineno"> 126</span> <a class="code hl_classRef" target="_blank" href="http://en.cppreference.com/w/cpp/io/basic_ostream.html">std::cout</a> << <span class="stringliteral">"Expected Output: "</span> << expected_max_height << <a class="code hl_functionRef" target="_blank" href="http://en.cppreference.com/w/cpp/io/manip/endl.html">std::endl</a>;</div>
|
|
|
|
|
<div class="line"><span class="lineno"> 127</span> <a class="code hl_classRef" target="_blank" href="http://en.cppreference.com/w/cpp/io/basic_ostream.html">std::cout</a> << <span class="stringliteral">"Output: "</span> << max_height_output << <a class="code hl_functionRef" target="_blank" href="http://en.cppreference.com/w/cpp/io/manip/endl.html">std::endl</a>;</div>
|
|
|
|
|
<div class="line"><span class="lineno"> 128</span> assert(max_height_output == expected_max_height);</div>
|
|
|
|
|
<div class="line"><span class="lineno"> 129</span> <a class="code hl_classRef" target="_blank" href="http://en.cppreference.com/w/cpp/io/basic_ostream.html">std::cout</a> << <span class="stringliteral">"TEST PASSED"</span> << <a class="code hl_functionRef" target="_blank" href="http://en.cppreference.com/w/cpp/io/manip/endl.html">std::endl</a> << <a class="code hl_functionRef" target="_blank" href="http://en.cppreference.com/w/cpp/io/manip/endl.html">std::endl</a>;</div>
|
|
|
|
|
<div class="line"><span class="lineno"> 130</span>}</div>
|
|
|
|
|
<div class="fragment"><div class="line"><span class="lineno"> 83</span> {</div>
|
|
|
|
|
<div class="line"><span class="lineno"> 84</span> <span class="comment">// initial input variables</span></div>
|
|
|
|
|
<div class="line"><span class="lineno"> 85</span> <span class="keywordtype">double</span> initial_velocity = 5.0; <span class="comment">// double initial_velocity input</span></div>
|
|
|
|
|
<div class="line"><span class="lineno"> 86</span> <span class="keywordtype">double</span> angle = 40.0; <span class="comment">// double angle input</span></div>
|
|
|
|
|
<div class="line"><span class="lineno"> 87</span> </div>
|
|
|
|
|
<div class="line"><span class="lineno"> 88</span> <span class="comment">// 1st test</span></div>
|
|
|
|
|
<div class="line"><span class="lineno"> 89</span> <span class="keywordtype">double</span> expected_time_of_flight = 0.655; <span class="comment">// expected time output</span></div>
|
|
|
|
|
<div class="line"><span class="lineno"> 90</span> <span class="keywordtype">double</span> flight_time_output =</div>
|
|
|
|
|
<div class="line"><span class="lineno"> 91</span> <a class="code hl_functionRef" target="_blank" href="http://en.cppreference.com/w/cpp/numeric/math/round.html">std::round</a>(physics::ground_to_ground_projectile_motion::time_of_flight(initial_velocity, angle) * 1000.0) /</div>
|
|
|
|
|
<div class="line"><span class="lineno"> 92</span> 1000.0; <span class="comment">// round output to 3 decimal places</span></div>
|
|
|
|
|
<div class="line"><span class="lineno"> 93</span> </div>
|
|
|
|
|
<div class="line"><span class="lineno"> 94</span> <a class="code hl_classRef" target="_blank" href="http://en.cppreference.com/w/cpp/io/basic_ostream.html">std::cout</a> << <span class="stringliteral">"Projectile Flight Time (double)"</span> << <a class="code hl_functionRef" target="_blank" href="http://en.cppreference.com/w/cpp/io/manip/endl.html">std::endl</a>;</div>
|
|
|
|
|
<div class="line"><span class="lineno"> 95</span> <a class="code hl_classRef" target="_blank" href="http://en.cppreference.com/w/cpp/io/basic_ostream.html">std::cout</a> << <span class="stringliteral">"Input Initial Velocity: "</span> << initial_velocity << <a class="code hl_functionRef" target="_blank" href="http://en.cppreference.com/w/cpp/io/manip/endl.html">std::endl</a>;</div>
|
|
|
|
|
<div class="line"><span class="lineno"> 96</span> <a class="code hl_classRef" target="_blank" href="http://en.cppreference.com/w/cpp/io/basic_ostream.html">std::cout</a> << <span class="stringliteral">"Input Angle: "</span> << angle << <a class="code hl_functionRef" target="_blank" href="http://en.cppreference.com/w/cpp/io/manip/endl.html">std::endl</a>;</div>
|
|
|
|
|
<div class="line"><span class="lineno"> 97</span> <a class="code hl_classRef" target="_blank" href="http://en.cppreference.com/w/cpp/io/basic_ostream.html">std::cout</a> << <span class="stringliteral">"Expected Output: "</span> << expected_time_of_flight << <a class="code hl_functionRef" target="_blank" href="http://en.cppreference.com/w/cpp/io/manip/endl.html">std::endl</a>;</div>
|
|
|
|
|
<div class="line"><span class="lineno"> 98</span> <a class="code hl_classRef" target="_blank" href="http://en.cppreference.com/w/cpp/io/basic_ostream.html">std::cout</a> << <span class="stringliteral">"Output: "</span> << flight_time_output << <a class="code hl_functionRef" target="_blank" href="http://en.cppreference.com/w/cpp/io/manip/endl.html">std::endl</a>;</div>
|
|
|
|
|
<div class="line"><span class="lineno"> 99</span> assert(flight_time_output == expected_time_of_flight);</div>
|
|
|
|
|
<div class="line"><span class="lineno"> 100</span> <a class="code hl_classRef" target="_blank" href="http://en.cppreference.com/w/cpp/io/basic_ostream.html">std::cout</a> << <span class="stringliteral">"TEST PASSED"</span> << <a class="code hl_functionRef" target="_blank" href="http://en.cppreference.com/w/cpp/io/manip/endl.html">std::endl</a> << <a class="code hl_functionRef" target="_blank" href="http://en.cppreference.com/w/cpp/io/manip/endl.html">std::endl</a>;</div>
|
|
|
|
|
<div class="line"><span class="lineno"> 101</span> </div>
|
|
|
|
|
<div class="line"><span class="lineno"> 102</span> <span class="comment">// 2nd test</span></div>
|
|
|
|
|
<div class="line"><span class="lineno"> 103</span> <span class="keywordtype">double</span> expected_horizontal_range = 2.51; <span class="comment">// expected range output</span></div>
|
|
|
|
|
<div class="line"><span class="lineno"> 104</span> <span class="keywordtype">double</span> horizontal_range_output =</div>
|
|
|
|
|
<div class="line"><span class="lineno"> 105</span> <a class="code hl_functionRef" target="_blank" href="http://en.cppreference.com/w/cpp/numeric/math/round.html">std::round</a>(physics::ground_to_ground_projectile_motion::horizontal_range(initial_velocity, angle,</div>
|
|
|
|
|
<div class="line"><span class="lineno"> 106</span> flight_time_output) *</div>
|
|
|
|
|
<div class="line"><span class="lineno"> 107</span> 100.0) /</div>
|
|
|
|
|
<div class="line"><span class="lineno"> 108</span> 100.0; <span class="comment">// round output to 2 decimal places</span></div>
|
|
|
|
|
<div class="line"><span class="lineno"> 109</span> </div>
|
|
|
|
|
<div class="line"><span class="lineno"> 110</span> <a class="code hl_classRef" target="_blank" href="http://en.cppreference.com/w/cpp/io/basic_ostream.html">std::cout</a> << <span class="stringliteral">"Projectile Horizontal Range (double)"</span> << <a class="code hl_functionRef" target="_blank" href="http://en.cppreference.com/w/cpp/io/manip/endl.html">std::endl</a>;</div>
|
|
|
|
|
<div class="line"><span class="lineno"> 111</span> <a class="code hl_classRef" target="_blank" href="http://en.cppreference.com/w/cpp/io/basic_ostream.html">std::cout</a> << <span class="stringliteral">"Input Initial Velocity: "</span> << initial_velocity << <a class="code hl_functionRef" target="_blank" href="http://en.cppreference.com/w/cpp/io/manip/endl.html">std::endl</a>;</div>
|
|
|
|
|
<div class="line"><span class="lineno"> 112</span> <a class="code hl_classRef" target="_blank" href="http://en.cppreference.com/w/cpp/io/basic_ostream.html">std::cout</a> << <span class="stringliteral">"Input Angle: "</span> << angle << <a class="code hl_functionRef" target="_blank" href="http://en.cppreference.com/w/cpp/io/manip/endl.html">std::endl</a>;</div>
|
|
|
|
|
<div class="line"><span class="lineno"> 113</span> <a class="code hl_classRef" target="_blank" href="http://en.cppreference.com/w/cpp/io/basic_ostream.html">std::cout</a> << <span class="stringliteral">"Input Time Of Flight: "</span> << flight_time_output << <a class="code hl_functionRef" target="_blank" href="http://en.cppreference.com/w/cpp/io/manip/endl.html">std::endl</a>;</div>
|
|
|
|
|
<div class="line"><span class="lineno"> 114</span> <a class="code hl_classRef" target="_blank" href="http://en.cppreference.com/w/cpp/io/basic_ostream.html">std::cout</a> << <span class="stringliteral">"Expected Output: "</span> << expected_horizontal_range << <a class="code hl_functionRef" target="_blank" href="http://en.cppreference.com/w/cpp/io/manip/endl.html">std::endl</a>;</div>
|
|
|
|
|
<div class="line"><span class="lineno"> 115</span> <a class="code hl_classRef" target="_blank" href="http://en.cppreference.com/w/cpp/io/basic_ostream.html">std::cout</a> << <span class="stringliteral">"Output: "</span> << horizontal_range_output << <a class="code hl_functionRef" target="_blank" href="http://en.cppreference.com/w/cpp/io/manip/endl.html">std::endl</a>;</div>
|
|
|
|
|
<div class="line"><span class="lineno"> 116</span> assert(horizontal_range_output == expected_horizontal_range);</div>
|
|
|
|
|
<div class="line"><span class="lineno"> 117</span> <a class="code hl_classRef" target="_blank" href="http://en.cppreference.com/w/cpp/io/basic_ostream.html">std::cout</a> << <span class="stringliteral">"TEST PASSED"</span> << <a class="code hl_functionRef" target="_blank" href="http://en.cppreference.com/w/cpp/io/manip/endl.html">std::endl</a> << <a class="code hl_functionRef" target="_blank" href="http://en.cppreference.com/w/cpp/io/manip/endl.html">std::endl</a>;</div>
|
|
|
|
|
<div class="line"><span class="lineno"> 118</span> </div>
|
|
|
|
|
<div class="line"><span class="lineno"> 119</span> <span class="comment">// 3rd test</span></div>
|
|
|
|
|
<div class="line"><span class="lineno"> 120</span> <span class="keywordtype">double</span> expected_max_height = 0.526; <span class="comment">// expected height output</span></div>
|
|
|
|
|
<div class="line"><span class="lineno"> 121</span> <span class="keywordtype">double</span> max_height_output =</div>
|
|
|
|
|
<div class="line"><span class="lineno"> 122</span> <a class="code hl_functionRef" target="_blank" href="http://en.cppreference.com/w/cpp/numeric/math/round.html">std::round</a>(physics::ground_to_ground_projectile_motion::max_height(initial_velocity, angle) * 1000.0) /</div>
|
|
|
|
|
<div class="line"><span class="lineno"> 123</span> 1000.0; <span class="comment">// round output to 3 decimal places</span></div>
|
|
|
|
|
<div class="line"><span class="lineno"> 124</span> </div>
|
|
|
|
|
<div class="line"><span class="lineno"> 125</span> <a class="code hl_classRef" target="_blank" href="http://en.cppreference.com/w/cpp/io/basic_ostream.html">std::cout</a> << <span class="stringliteral">"Projectile Max Height (double)"</span> << <a class="code hl_functionRef" target="_blank" href="http://en.cppreference.com/w/cpp/io/manip/endl.html">std::endl</a>;</div>
|
|
|
|
|
<div class="line"><span class="lineno"> 126</span> <a class="code hl_classRef" target="_blank" href="http://en.cppreference.com/w/cpp/io/basic_ostream.html">std::cout</a> << <span class="stringliteral">"Input Initial Velocity: "</span> << initial_velocity << <a class="code hl_functionRef" target="_blank" href="http://en.cppreference.com/w/cpp/io/manip/endl.html">std::endl</a>;</div>
|
|
|
|
|
<div class="line"><span class="lineno"> 127</span> <a class="code hl_classRef" target="_blank" href="http://en.cppreference.com/w/cpp/io/basic_ostream.html">std::cout</a> << <span class="stringliteral">"Input Angle: "</span> << angle << <a class="code hl_functionRef" target="_blank" href="http://en.cppreference.com/w/cpp/io/manip/endl.html">std::endl</a>;</div>
|
|
|
|
|
<div class="line"><span class="lineno"> 128</span> <a class="code hl_classRef" target="_blank" href="http://en.cppreference.com/w/cpp/io/basic_ostream.html">std::cout</a> << <span class="stringliteral">"Expected Output: "</span> << expected_max_height << <a class="code hl_functionRef" target="_blank" href="http://en.cppreference.com/w/cpp/io/manip/endl.html">std::endl</a>;</div>
|
|
|
|
|
<div class="line"><span class="lineno"> 129</span> <a class="code hl_classRef" target="_blank" href="http://en.cppreference.com/w/cpp/io/basic_ostream.html">std::cout</a> << <span class="stringliteral">"Output: "</span> << max_height_output << <a class="code hl_functionRef" target="_blank" href="http://en.cppreference.com/w/cpp/io/manip/endl.html">std::endl</a>;</div>
|
|
|
|
|
<div class="line"><span class="lineno"> 130</span> assert(max_height_output == expected_max_height);</div>
|
|
|
|
|
<div class="line"><span class="lineno"> 131</span> <a class="code hl_classRef" target="_blank" href="http://en.cppreference.com/w/cpp/io/basic_ostream.html">std::cout</a> << <span class="stringliteral">"TEST PASSED"</span> << <a class="code hl_functionRef" target="_blank" href="http://en.cppreference.com/w/cpp/io/manip/endl.html">std::endl</a> << <a class="code hl_functionRef" target="_blank" href="http://en.cppreference.com/w/cpp/io/manip/endl.html">std::endl</a>;</div>
|
|
|
|
|
<div class="line"><span class="lineno"> 132</span>}</div>
|
|
|
|
|
<div class="ttc" id="abasic_ostream_html"><div class="ttname"><a href="http://en.cppreference.com/w/cpp/io/basic_ostream.html">std::cout</a></div></div>
|
|
|
|
|
<div class="ttc" id="aendl_html"><div class="ttname"><a href="http://en.cppreference.com/w/cpp/io/manip/endl.html">std::endl</a></div><div class="ttdeci">T endl(T... args)</div></div>
|
|
|
|
|
<div class="ttc" id="around_html"><div class="ttname"><a href="http://en.cppreference.com/w/cpp/numeric/math/round.html">std::round</a></div><div class="ttdeci">T round(T... args)</div></div>
|
|
|
|
|
@@ -451,10 +455,10 @@ template<typename T > </div>
|
|
|
|
|
</dd>
|
|
|
|
|
</dl>
|
|
|
|
|
<dl class="section return"><dt>Returns</dt><dd>The time that the projectile is in the air for </dd></dl>
|
|
|
|
|
<div class="fragment"><div class="line"><span class="lineno"> 45</span> {</div>
|
|
|
|
|
<div class="line"><span class="lineno"> 46</span> <span class="keywordtype">double</span> Viy = initial_velocity * (<a class="code hl_functionRef" target="_blank" href="http://en.cppreference.com/w/cpp/numeric/math/sin.html">std::sin</a>(<a class="code hl_function" href="#aba1d26faf6a5379c28cae458956241de">degrees_to_radians</a>(angle))); <span class="comment">// calculate y component of the initial velocity</span></div>
|
|
|
|
|
<div class="line"><span class="lineno"> 47</span> <span class="keywordflow">return</span> 2.0 * Viy / gravity;</div>
|
|
|
|
|
<div class="line"><span class="lineno"> 48</span>}</div>
|
|
|
|
|
<div class="fragment"><div class="line"><span class="lineno"> 47</span> {</div>
|
|
|
|
|
<div class="line"><span class="lineno"> 48</span> <span class="keywordtype">double</span> Viy = initial_velocity * (<a class="code hl_functionRef" target="_blank" href="http://en.cppreference.com/w/cpp/numeric/math/sin.html">std::sin</a>(<a class="code hl_function" href="#ab00e9785fb2670f7af99d6f3d636f87c">degrees_to_radians</a>(angle))); <span class="comment">// calculate y component of the initial velocity</span></div>
|
|
|
|
|
<div class="line"><span class="lineno"> 49</span> <span class="keywordflow">return</span> 2.0 * Viy / gravity;</div>
|
|
|
|
|
<div class="line"><span class="lineno"> 50</span>}</div>
|
|
|
|
|
</div><!-- fragment --><div class="dynheader">
|
|
|
|
|
Here is the call graph for this function:</div>
|
|
|
|
|
<div class="dyncontent">
|
|
|
|
|
|