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/structuredData/trisurfaceStructure/triangleFunctions.hpp 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('triangleFunctions_8hpp_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" > triangleFunctions.hpp< / div > < / div >
< / div > <!-- header -->
< div class = "contents" >
< a href = "triangleFunctions_8hpp.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 >   < span class = "preprocessor" > #ifndef __triangleFunctions_hpp__< / span > < / div >
< div class = "line" > < a name = "l00022" > < / a > < span class = "lineno" > 22< / span >   < span class = "preprocessor" > #define __triangleFunctions_hpp__< / 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" > 24< / span >   < span class = "preprocessor" > #include " < a class = "code" href = "types_8hpp.html" > types.hpp< / a > " < / span > < / div >
< div class = "line" > < a name = "l00025" > < / a > < span class = "lineno" > 25< / span >   < / div >
< div class = "line" > < a name = "l00026" > < / a > < span class = "lineno" > < a class = "line" href = "namespacepFlow_1_1triangleFunctions.html" > 26< / a > < / span >   < span class = "keyword" > namespace < / span > < a class = "code" href = "namespacepFlow_1_1triangleFunctions.html" > pFlow::triangleFunctions< / a > < / div >
< div class = "line" > < a name = "l00027" > < / a > < span class = "lineno" > 27< / span >   {< / div >
< div class = "line" > < a name = "l00028" > < / a > < span class = "lineno" > 28< / span >   < / div >
< div class = "line" > < a name = "l00029" > < / a > < span class = "lineno" > 29< / span >   < a class = "code" href = "pFlowMacros_8hpp.html#a8e2f73fa5c113f21c9c9edb67a974f5e" > INLINE_FUNCTION_HD< / a > < / div >
< div class = "line" > < a name = "l00030" > < / a > < span class = "lineno" > < a class = "line" href = "namespacepFlow_1_1triangleFunctions.html#a2074ab5b90f47b0ec593414c80923362" > 30< / a > < / span >   < a class = "code" href = "namespacepFlow.html#a6192191c0e9c178a44ee1ac350fde476" > real< / a > < a class = "code" href = "namespacepFlow_1_1triangleFunctions.html#a2074ab5b90f47b0ec593414c80923362" > triangleSurface< / a > ( < span class = "keyword" > const< / span > < a class = "code" href = "classpFlow_1_1triple.html" > realx3< / a > & p1, < span class = "keyword" > const< / span > < a class = "code" href = "classpFlow_1_1triple.html" > realx3< / a > & p2, < span class = "keyword" > const< / span > < a class = "code" href = "classpFlow_1_1triple.html" > realx3< / a > & p3)< / 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 >   < a class = "code" href = "classpFlow_1_1triple.html" > realx3< / a > V1 = p2 - p1;< / div >
< div class = "line" > < a name = "l00033" > < / a > < span class = "lineno" > 33< / span >   < a class = "code" href = "classpFlow_1_1triple.html" > realx3< / a > V2 = p3 - p1;< / div >
< div class = "line" > < a name = "l00034" > < / a > < span class = "lineno" > 34< / span >   < span class = "keywordflow" > return< / span > < a class = "code" href = "namespacepFlow.html#a62ab5f54018a48f829abd2cca13d75b2" > abs< / a > ((< a class = "code" href = "tripleFwd_8hpp.html#a7a724b824f9e21a646a965a99fff4b04" > cross< / a > (V1,V2)).< a class = "code" href = "tripleFwd_8hpp.html#ae1449f1d56abab2ec4d0f00b685fc478" > length< / a > () / < span class = "keyword" > static_cast< < / span > < a class = "code" href = "namespacepFlow.html#a6192191c0e9c178a44ee1ac350fde476" > real< / a > < span class = "keyword" > > < / span > (2.0)); < / 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 >   < / 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 >   < / div >
< div class = "line" > < a name = "l00039" > < / a > < span class = "lineno" > 39< / span >   < span class = "preprocessor" > #endif < / span > < / div >
< / div > <!-- fragment --> < / div > <!-- contents -->
< / div > <!-- doc - content -->
< 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#l00046" > builtinTypes.hpp:46< / a > < / div > < / div >
< div class = "ttc" id = "atypes_8hpp_html" > < div class = "ttname" > < a href = "types_8hpp.html" > types.hpp< / a > < / div > < / div >
< div class = "ttc" id = "anamespacepFlow_1_1triangleFunctions_html_a2074ab5b90f47b0ec593414c80923362" > < div class = "ttname" > < a href = "namespacepFlow_1_1triangleFunctions.html#a2074ab5b90f47b0ec593414c80923362" > pFlow::triangleFunctions::triangleSurface< / a > < / div > < div class = "ttdeci" > INLINE_FUNCTION_HD real triangleSurface(const realx3 & p1, const realx3 & p2, const realx3 & p3)< / div > < div class = "ttdef" > < b > Definition:< / b > < a href = "triangleFunctions_8hpp_source.html#l00030" > triangleFunctions.hpp:30< / a > < / div > < / div >
< div class = "ttc" id = "atripleFwd_8hpp_html_a7a724b824f9e21a646a965a99fff4b04" > < div class = "ttname" > < a href = "tripleFwd_8hpp.html#a7a724b824f9e21a646a965a99fff4b04" > cross< / a > < / div > < div class = "ttdeci" > INLINE_FUNCTION_HD triple< T > cross(const triple< T > & v1, const triple< T > & v2)< / div > < / div >
< div class = "ttc" id = "atripleFwd_8hpp_html_ae1449f1d56abab2ec4d0f00b685fc478" > < div class = "ttname" > < a href = "tripleFwd_8hpp.html#ae1449f1d56abab2ec4d0f00b685fc478" > length< / a > < / div > < div class = "ttdeci" > INLINE_FUNCTION_HD T length(const triple< T > & v1)< / div > < / div >
< div class = "ttc" id = "anamespacepFlow_html_a62ab5f54018a48f829abd2cca13d75b2" > < div class = "ttname" > < a href = "namespacepFlow.html#a62ab5f54018a48f829abd2cca13d75b2" > pFlow::abs< / a > < / div > < div class = "ttdeci" > INLINE_FUNCTION_HD real abs(real x)< / div > < div class = "ttdef" > < b > Definition:< / b > < a href = "math_8hpp_source.html#l00043" > math.hpp:43< / a > < / div > < / div >
< div class = "ttc" id = "apFlowMacros_8hpp_html_a8e2f73fa5c113f21c9c9edb67a974f5e" > < div class = "ttname" > < a href = "pFlowMacros_8hpp.html#a8e2f73fa5c113f21c9c9edb67a974f5e" > INLINE_FUNCTION_HD< / a > < / div > < div class = "ttdeci" > #define INLINE_FUNCTION_HD< / div > < div class = "ttdef" > < b > Definition:< / b > < a href = "pFlowMacros_8hpp_source.html#l00051" > pFlowMacros.hpp:51< / a > < / div > < / div >
< div class = "ttc" id = "aclasspFlow_1_1triple_html" > < div class = "ttname" > < a href = "classpFlow_1_1triple.html" > pFlow::triple< real > < / a > < / div > < / div >
< div class = "ttc" id = "anamespacepFlow_1_1triangleFunctions_html" > < div class = "ttname" > < a href = "namespacepFlow_1_1triangleFunctions.html" > pFlow::triangleFunctions< / a > < / div > < div class = "ttdef" > < b > Definition:< / b > < a href = "triangleFunctions_8hpp_source.html#l00026" > triangleFunctions.hpp:26< / a > < / div > < / div >
< 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_0b265ec0eb5bc5fbad75b6fd7b5b024b.html" > structuredData< / a > < / li > < li class = "navelem" > < a class = "el" href = "dir_cb566f9a80a0a346c3a6366e4b888b7d.html" > trisurfaceStructure< / a > < / li > < li class = "navelem" > < a class = "el" href = "triangleFunctions_8hpp.html" > triangleFunctions.hpp< / 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 >