Sophie

Sophie

distrib > Mageia > 7 > armv7hl > media > core-release > by-pkgid > 0a67b807a02637f2cae68649d519a89d > files > 966

libcryptopp-devel-7.0.0-1.mga7.armv7hl.rpm

<!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.14"/>
<meta name="viewport" content="width=device-width, initial-scale=1"/>
<title>Crypto++: GFP2_ONB&lt; F &gt; Class Template Reference</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="doxygen.css" rel="stylesheet" type="text/css" />
</head>
<body>
<div id="top"><!-- do not remove this div, it is closed by doxygen! -->
<div id="titlearea">
<table cellspacing="0" cellpadding="0">
 <tbody>
 <tr style="height: 56px;">
  <td id="projectalign" style="padding-left: 0.5em;">
   <div id="projectname">Crypto++
   &#160;<span id="projectnumber">7.0</span>
   </div>
   <div id="projectbrief">Free&nbsp;C&#43;&#43;&nbsp;class&nbsp;library&nbsp;of&nbsp;cryptographic&nbsp;schemes</div>
  </td>
 </tr>
 </tbody>
</table>
</div>
<!-- end header part -->
<!-- Generated by Doxygen 1.8.14 -->
<script type="text/javascript" src="menudata.js"></script>
<script type="text/javascript" src="menu.js"></script>
<script type="text/javascript">
/* @license magnet:?xt=urn:btih:cf05388f2679ee054f2beb29a391d25f4e673ac3&amp;dn=gpl-2.0.txt GPL-v2 */
$(function() {
  initMenu('',false,false,'search.php','Search');
});
/* @license-end */</script>
<div id="main-nav"></div>
</div><!-- top -->
<div class="header">
  <div class="summary">
<a href="#pub-types">Public Types</a> &#124;
<a href="#pub-methods">Public Member Functions</a> &#124;
<a href="class_g_f_p2___o_n_b-members.html">List of all members</a>  </div>
  <div class="headertitle">
<div class="title">GFP2_ONB&lt; F &gt; Class Template Reference</div>  </div>
</div><!--header-->
<div class="contents">

<p>GF(p^2), optimal normal basis.  
 <a href="class_g_f_p2___o_n_b.html#details">More...</a></p>
<div id="dynsection-0" onclick="return toggleVisibility(this)" class="dynheader closed" style="cursor:pointer;">
  <img id="dynsection-0-trigger" src="closed.png" alt="+"/> Inheritance diagram for GFP2_ONB&lt; F &gt;:</div>
<div id="dynsection-0-summary" class="dynsummary" style="display:block;">
</div>
<div id="dynsection-0-content" class="dyncontent" style="display:none;">
 <div class="center">
  <img src="class_g_f_p2___o_n_b.png" usemap="#GFP2_5FONB_3C_20F_20_3E_map" alt=""/>
  <map id="GFP2_5FONB_3C_20F_20_3E_map" name="GFP2_5FONB_3C_20F_20_3E_map">
<area href="class_abstract_ring.html" alt="AbstractRing&lt; GFP2Element &gt;" shape="rect" coords="0,56,194,80"/>
<area href="class_abstract_group.html" alt="AbstractGroup&lt; GFP2Element &gt;" shape="rect" coords="0,0,194,24"/>
</map>
 </div></div>
<table class="memberdecls">
<tr class="heading"><td colspan="2"><h2 class="groupheader"><a name="pub-types"></a>
Public Types</h2></td></tr>
<tr class="memitem:ad3bffbe1a6c331daf56bb6ec51cbc294"><td class="memItemLeft" align="right" valign="top"><a id="ad3bffbe1a6c331daf56bb6ec51cbc294"></a>
typedef F&#160;</td><td class="memItemRight" valign="bottom"><b>BaseField</b></td></tr>
<tr class="separator:ad3bffbe1a6c331daf56bb6ec51cbc294"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="inherit_header pub_types_class_abstract_ring"><td colspan="2" onclick="javascript:toggleInherit('pub_types_class_abstract_ring')"><img src="closed.png" alt="-"/>&#160;Public Types inherited from <a class="el" href="class_abstract_ring.html">AbstractRing&lt; GFP2Element &gt;</a></td></tr>
<tr class="memitem:acd93e8ce4e2897173310c68fcb60f3e9 inherit pub_types_class_abstract_ring"><td class="memItemLeft" align="right" valign="top"><a id="acd93e8ce4e2897173310c68fcb60f3e9"></a>
typedef <a class="el" href="class_g_f_p2_element.html">GFP2Element</a>&#160;</td><td class="memItemRight" valign="bottom"><b>Element</b></td></tr>
<tr class="separator:acd93e8ce4e2897173310c68fcb60f3e9 inherit pub_types_class_abstract_ring"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="inherit_header pub_types_class_abstract_group"><td colspan="2" onclick="javascript:toggleInherit('pub_types_class_abstract_group')"><img src="closed.png" alt="-"/>&#160;Public Types inherited from <a class="el" href="class_abstract_group.html">AbstractGroup&lt; GFP2Element &gt;</a></td></tr>
<tr class="memitem:a4a2b3308fb5c13f70fcc5746be52ba7b inherit pub_types_class_abstract_group"><td class="memItemLeft" align="right" valign="top"><a id="a4a2b3308fb5c13f70fcc5746be52ba7b"></a>
typedef <a class="el" href="class_g_f_p2_element.html">GFP2Element</a>&#160;</td><td class="memItemRight" valign="bottom"><b>Element</b></td></tr>
<tr class="separator:a4a2b3308fb5c13f70fcc5746be52ba7b inherit pub_types_class_abstract_group"><td class="memSeparator" colspan="2">&#160;</td></tr>
</table><table class="memberdecls">
<tr class="heading"><td colspan="2"><h2 class="groupheader"><a name="pub-methods"></a>
Public Member Functions</h2></td></tr>
<tr class="memitem:a29804cd3d3063af5411b87683eaccbdc"><td class="memItemLeft" align="right" valign="top"><a id="a29804cd3d3063af5411b87683eaccbdc"></a>
&#160;</td><td class="memItemRight" valign="bottom"><b>GFP2_ONB</b> (const <a class="el" href="class_integer.html">Integer</a> &amp;p)</td></tr>
<tr class="separator:a29804cd3d3063af5411b87683eaccbdc"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a3a84528c019f87e690b2ee5c3e1516c1"><td class="memItemLeft" align="right" valign="top"><a id="a3a84528c019f87e690b2ee5c3e1516c1"></a>
const <a class="el" href="class_integer.html">Integer</a> &amp;&#160;</td><td class="memItemRight" valign="bottom"><b>GetModulus</b> () const</td></tr>
<tr class="separator:a3a84528c019f87e690b2ee5c3e1516c1"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a5c1e9463122f48d9db8a0c3bd284bad1"><td class="memItemLeft" align="right" valign="top"><a id="a5c1e9463122f48d9db8a0c3bd284bad1"></a>
<a class="el" href="class_g_f_p2_element.html">GFP2Element</a>&#160;</td><td class="memItemRight" valign="bottom"><b>ConvertIn</b> (const <a class="el" href="class_integer.html">Integer</a> &amp;a) const</td></tr>
<tr class="separator:a5c1e9463122f48d9db8a0c3bd284bad1"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a0a7633cc44f9b36efb1ace5cdd41579c"><td class="memItemLeft" align="right" valign="top"><a id="a0a7633cc44f9b36efb1ace5cdd41579c"></a>
<a class="el" href="class_g_f_p2_element.html">GFP2Element</a>&#160;</td><td class="memItemRight" valign="bottom"><b>ConvertIn</b> (const <a class="el" href="class_g_f_p2_element.html">GFP2Element</a> &amp;a) const</td></tr>
<tr class="separator:a0a7633cc44f9b36efb1ace5cdd41579c"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:ad5ec9517132671ca1fd5825c811e565d"><td class="memItemLeft" align="right" valign="top"><a id="ad5ec9517132671ca1fd5825c811e565d"></a>
<a class="el" href="class_g_f_p2_element.html">GFP2Element</a>&#160;</td><td class="memItemRight" valign="bottom"><b>ConvertOut</b> (const <a class="el" href="class_g_f_p2_element.html">GFP2Element</a> &amp;a) const</td></tr>
<tr class="separator:ad5ec9517132671ca1fd5825c811e565d"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:aab4d8f8eec60122c1f3e3ba2c9ad2673"><td class="memItemLeft" align="right" valign="top">bool&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_g_f_p2___o_n_b.html#aab4d8f8eec60122c1f3e3ba2c9ad2673">Equal</a> (const <a class="el" href="class_g_f_p2_element.html">GFP2Element</a> &amp;a, const <a class="el" href="class_g_f_p2_element.html">GFP2Element</a> &amp;b) const</td></tr>
<tr class="memdesc:aab4d8f8eec60122c1f3e3ba2c9ad2673"><td class="mdescLeft">&#160;</td><td class="mdescRight">Compare two elements for equality.  <a href="#aab4d8f8eec60122c1f3e3ba2c9ad2673">More...</a><br /></td></tr>
<tr class="separator:aab4d8f8eec60122c1f3e3ba2c9ad2673"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a386495ffc3d413f461a9001fe6f30642"><td class="memItemLeft" align="right" valign="top">const <a class="el" href="class_g_f_p2_element.html">Element</a> &amp;&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_g_f_p2___o_n_b.html#a386495ffc3d413f461a9001fe6f30642">Identity</a> () const</td></tr>
<tr class="memdesc:a386495ffc3d413f461a9001fe6f30642"><td class="mdescLeft">&#160;</td><td class="mdescRight">Provides the Identity element.  <a href="#a386495ffc3d413f461a9001fe6f30642">More...</a><br /></td></tr>
<tr class="separator:a386495ffc3d413f461a9001fe6f30642"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:abd707cb221dd44914e8cde2839ad90c7"><td class="memItemLeft" align="right" valign="top">const <a class="el" href="class_g_f_p2_element.html">Element</a> &amp;&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_g_f_p2___o_n_b.html#abd707cb221dd44914e8cde2839ad90c7">Add</a> (const <a class="el" href="class_g_f_p2_element.html">Element</a> &amp;a, const <a class="el" href="class_g_f_p2_element.html">Element</a> &amp;b) const</td></tr>
<tr class="memdesc:abd707cb221dd44914e8cde2839ad90c7"><td class="mdescLeft">&#160;</td><td class="mdescRight">Adds elements in the group.  <a href="#abd707cb221dd44914e8cde2839ad90c7">More...</a><br /></td></tr>
<tr class="separator:abd707cb221dd44914e8cde2839ad90c7"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:ac9fa7ce33239b3d7f88c9cac9c2d74d3"><td class="memItemLeft" align="right" valign="top">const <a class="el" href="class_g_f_p2_element.html">Element</a> &amp;&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_g_f_p2___o_n_b.html#ac9fa7ce33239b3d7f88c9cac9c2d74d3">Inverse</a> (const <a class="el" href="class_g_f_p2_element.html">Element</a> &amp;a) const</td></tr>
<tr class="memdesc:ac9fa7ce33239b3d7f88c9cac9c2d74d3"><td class="mdescLeft">&#160;</td><td class="mdescRight">Inverts the element in the group.  <a href="#ac9fa7ce33239b3d7f88c9cac9c2d74d3">More...</a><br /></td></tr>
<tr class="separator:ac9fa7ce33239b3d7f88c9cac9c2d74d3"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a39cef4f74a7bd5588a7293b1d364334e"><td class="memItemLeft" align="right" valign="top">const <a class="el" href="class_g_f_p2_element.html">Element</a> &amp;&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_g_f_p2___o_n_b.html#a39cef4f74a7bd5588a7293b1d364334e">Double</a> (const <a class="el" href="class_g_f_p2_element.html">Element</a> &amp;a) const</td></tr>
<tr class="memdesc:a39cef4f74a7bd5588a7293b1d364334e"><td class="mdescLeft">&#160;</td><td class="mdescRight">Doubles an element in the group.  <a href="#a39cef4f74a7bd5588a7293b1d364334e">More...</a><br /></td></tr>
<tr class="separator:a39cef4f74a7bd5588a7293b1d364334e"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:aedbcc151eca01f823b6d8c34f792fad9"><td class="memItemLeft" align="right" valign="top">const <a class="el" href="class_g_f_p2_element.html">Element</a> &amp;&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_g_f_p2___o_n_b.html#aedbcc151eca01f823b6d8c34f792fad9">Subtract</a> (const <a class="el" href="class_g_f_p2_element.html">Element</a> &amp;a, const <a class="el" href="class_g_f_p2_element.html">Element</a> &amp;b) const</td></tr>
<tr class="memdesc:aedbcc151eca01f823b6d8c34f792fad9"><td class="mdescLeft">&#160;</td><td class="mdescRight">Subtracts elements in the group.  <a href="#aedbcc151eca01f823b6d8c34f792fad9">More...</a><br /></td></tr>
<tr class="separator:aedbcc151eca01f823b6d8c34f792fad9"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a9ea72a20954c87db4467e14fdaa67037"><td class="memItemLeft" align="right" valign="top"><a class="el" href="class_g_f_p2_element.html">Element</a> &amp;&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_g_f_p2___o_n_b.html#a9ea72a20954c87db4467e14fdaa67037">Accumulate</a> (<a class="el" href="class_g_f_p2_element.html">Element</a> &amp;a, const <a class="el" href="class_g_f_p2_element.html">Element</a> &amp;b) const</td></tr>
<tr class="memdesc:a9ea72a20954c87db4467e14fdaa67037"><td class="mdescLeft">&#160;</td><td class="mdescRight">TODO.  <a href="#a9ea72a20954c87db4467e14fdaa67037">More...</a><br /></td></tr>
<tr class="separator:a9ea72a20954c87db4467e14fdaa67037"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:ac6d39d886f9ddc047fcc4c5adcc23db9"><td class="memItemLeft" align="right" valign="top"><a class="el" href="class_g_f_p2_element.html">Element</a> &amp;&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_g_f_p2___o_n_b.html#ac6d39d886f9ddc047fcc4c5adcc23db9">Reduce</a> (<a class="el" href="class_g_f_p2_element.html">Element</a> &amp;a, const <a class="el" href="class_g_f_p2_element.html">Element</a> &amp;b) const</td></tr>
<tr class="memdesc:ac6d39d886f9ddc047fcc4c5adcc23db9"><td class="mdescLeft">&#160;</td><td class="mdescRight">Reduces an element in the congruence class.  <a href="#ac6d39d886f9ddc047fcc4c5adcc23db9">More...</a><br /></td></tr>
<tr class="separator:ac6d39d886f9ddc047fcc4c5adcc23db9"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:ac0e339d3509a26757486bbc78e339910"><td class="memItemLeft" align="right" valign="top">bool&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_g_f_p2___o_n_b.html#ac0e339d3509a26757486bbc78e339910">IsUnit</a> (const <a class="el" href="class_g_f_p2_element.html">Element</a> &amp;a) const</td></tr>
<tr class="memdesc:ac0e339d3509a26757486bbc78e339910"><td class="mdescLeft">&#160;</td><td class="mdescRight">Determines whether an element is a unit in the group.  <a href="#ac0e339d3509a26757486bbc78e339910">More...</a><br /></td></tr>
<tr class="separator:ac0e339d3509a26757486bbc78e339910"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:aa1d3c030219de3c1635a72fbdf0c7228"><td class="memItemLeft" align="right" valign="top">const <a class="el" href="class_g_f_p2_element.html">Element</a> &amp;&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_g_f_p2___o_n_b.html#aa1d3c030219de3c1635a72fbdf0c7228">MultiplicativeIdentity</a> () const</td></tr>
<tr class="memdesc:aa1d3c030219de3c1635a72fbdf0c7228"><td class="mdescLeft">&#160;</td><td class="mdescRight">Retrieves the multiplicative identity.  <a href="#aa1d3c030219de3c1635a72fbdf0c7228">More...</a><br /></td></tr>
<tr class="separator:aa1d3c030219de3c1635a72fbdf0c7228"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:abe477db3d5bf5fdb72b9fcc832ff8bac"><td class="memItemLeft" align="right" valign="top">const <a class="el" href="class_g_f_p2_element.html">Element</a> &amp;&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_g_f_p2___o_n_b.html#abe477db3d5bf5fdb72b9fcc832ff8bac">Multiply</a> (const <a class="el" href="class_g_f_p2_element.html">Element</a> &amp;a, const <a class="el" href="class_g_f_p2_element.html">Element</a> &amp;b) const</td></tr>
<tr class="memdesc:abe477db3d5bf5fdb72b9fcc832ff8bac"><td class="mdescLeft">&#160;</td><td class="mdescRight">Multiplies elements in the group.  <a href="#abe477db3d5bf5fdb72b9fcc832ff8bac">More...</a><br /></td></tr>
<tr class="separator:abe477db3d5bf5fdb72b9fcc832ff8bac"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a42f1dfe03023fb5502843e326892850c"><td class="memItemLeft" align="right" valign="top">const <a class="el" href="class_g_f_p2_element.html">Element</a> &amp;&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_g_f_p2___o_n_b.html#a42f1dfe03023fb5502843e326892850c">MultiplicativeInverse</a> (const <a class="el" href="class_g_f_p2_element.html">Element</a> &amp;a) const</td></tr>
<tr class="memdesc:a42f1dfe03023fb5502843e326892850c"><td class="mdescLeft">&#160;</td><td class="mdescRight">Calculate the multiplicative inverse of an element in the group.  <a href="#a42f1dfe03023fb5502843e326892850c">More...</a><br /></td></tr>
<tr class="separator:a42f1dfe03023fb5502843e326892850c"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a41cd047c0fc625ecde993d839d8d86b7"><td class="memItemLeft" align="right" valign="top">const <a class="el" href="class_g_f_p2_element.html">Element</a> &amp;&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_g_f_p2___o_n_b.html#a41cd047c0fc625ecde993d839d8d86b7">Square</a> (const <a class="el" href="class_g_f_p2_element.html">Element</a> &amp;a) const</td></tr>
<tr class="memdesc:a41cd047c0fc625ecde993d839d8d86b7"><td class="mdescLeft">&#160;</td><td class="mdescRight"><a class="el" href="class_square.html" title="Square block cipher. ">Square</a> an element in the group.  <a href="#a41cd047c0fc625ecde993d839d8d86b7">More...</a><br /></td></tr>
<tr class="separator:a41cd047c0fc625ecde993d839d8d86b7"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:ad71eeac946b5f17fcb6645bd2f281d23"><td class="memItemLeft" align="right" valign="top"><a class="el" href="class_g_f_p2_element.html">Element</a>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_g_f_p2___o_n_b.html#ad71eeac946b5f17fcb6645bd2f281d23">Exponentiate</a> (const <a class="el" href="class_g_f_p2_element.html">Element</a> &amp;a, const <a class="el" href="class_integer.html">Integer</a> &amp;e) const</td></tr>
<tr class="memdesc:ad71eeac946b5f17fcb6645bd2f281d23"><td class="mdescLeft">&#160;</td><td class="mdescRight">Raises a base to an exponent in the group.  <a href="#ad71eeac946b5f17fcb6645bd2f281d23">More...</a><br /></td></tr>
<tr class="separator:ad71eeac946b5f17fcb6645bd2f281d23"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:ab021d919188fa3ea0d03db42c4d50435"><td class="memItemLeft" align="right" valign="top"><a id="ab021d919188fa3ea0d03db42c4d50435"></a>
const <a class="el" href="class_g_f_p2_element.html">Element</a> &amp;&#160;</td><td class="memItemRight" valign="bottom"><b>PthPower</b> (const <a class="el" href="class_g_f_p2_element.html">Element</a> &amp;a) const</td></tr>
<tr class="separator:ab021d919188fa3ea0d03db42c4d50435"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a8d563d65da20e3adabe773e428d85056"><td class="memItemLeft" align="right" valign="top"><a id="a8d563d65da20e3adabe773e428d85056"></a>
void&#160;</td><td class="memItemRight" valign="bottom"><b>RaiseToPthPower</b> (<a class="el" href="class_g_f_p2_element.html">Element</a> &amp;a) const</td></tr>
<tr class="separator:a8d563d65da20e3adabe773e428d85056"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:ad9dc81fa82afbc5a6e00406b7ccb24f0"><td class="memItemLeft" align="right" valign="top"><a id="ad9dc81fa82afbc5a6e00406b7ccb24f0"></a>
const <a class="el" href="class_g_f_p2_element.html">Element</a> &amp;&#160;</td><td class="memItemRight" valign="bottom"><b>SpecialOperation1</b> (const <a class="el" href="class_g_f_p2_element.html">Element</a> &amp;a) const</td></tr>
<tr class="separator:ad9dc81fa82afbc5a6e00406b7ccb24f0"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:ad09d21b2ea1ddf904ee596de07e58d94"><td class="memItemLeft" align="right" valign="top"><a id="ad09d21b2ea1ddf904ee596de07e58d94"></a>
const <a class="el" href="class_g_f_p2_element.html">Element</a> &amp;&#160;</td><td class="memItemRight" valign="bottom"><b>SpecialOperation2</b> (const <a class="el" href="class_g_f_p2_element.html">Element</a> &amp;x, const <a class="el" href="class_g_f_p2_element.html">Element</a> &amp;y, const <a class="el" href="class_g_f_p2_element.html">Element</a> &amp;z) const</td></tr>
<tr class="separator:ad09d21b2ea1ddf904ee596de07e58d94"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="inherit_header pub_methods_class_abstract_ring"><td colspan="2" onclick="javascript:toggleInherit('pub_methods_class_abstract_ring')"><img src="closed.png" alt="-"/>&#160;Public Member Functions inherited from <a class="el" href="class_abstract_ring.html">AbstractRing&lt; GFP2Element &gt;</a></td></tr>
<tr class="memitem:ae55c525c1aa75bf898907bd6949e2b64 inherit pub_methods_class_abstract_ring"><td class="memItemLeft" align="right" valign="top"><a id="ae55c525c1aa75bf898907bd6949e2b64"></a>
&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_abstract_ring.html#ae55c525c1aa75bf898907bd6949e2b64">AbstractRing</a> ()</td></tr>
<tr class="memdesc:ae55c525c1aa75bf898907bd6949e2b64 inherit pub_methods_class_abstract_ring"><td class="mdescLeft">&#160;</td><td class="mdescRight">Construct an <a class="el" href="class_abstract_ring.html" title="Abstract ring. ">AbstractRing</a>. <br /></td></tr>
<tr class="separator:ae55c525c1aa75bf898907bd6949e2b64 inherit pub_methods_class_abstract_ring"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:acc8afd5ce95e32e45d3c30a710bf36dc inherit pub_methods_class_abstract_ring"><td class="memItemLeft" align="right" valign="top">&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_abstract_ring.html#acc8afd5ce95e32e45d3c30a710bf36dc">AbstractRing</a> (const <a class="el" href="class_abstract_ring.html">AbstractRing</a> &amp;source)</td></tr>
<tr class="memdesc:acc8afd5ce95e32e45d3c30a710bf36dc inherit pub_methods_class_abstract_ring"><td class="mdescLeft">&#160;</td><td class="mdescRight">Copy construct an <a class="el" href="class_abstract_ring.html" title="Abstract ring. ">AbstractRing</a>.  <a href="class_abstract_ring.html#acc8afd5ce95e32e45d3c30a710bf36dc">More...</a><br /></td></tr>
<tr class="separator:acc8afd5ce95e32e45d3c30a710bf36dc inherit pub_methods_class_abstract_ring"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a26709c02c869d09d756653ae1129f8a9 inherit pub_methods_class_abstract_ring"><td class="memItemLeft" align="right" valign="top"><a class="el" href="class_abstract_ring.html">AbstractRing</a> &amp;&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_abstract_ring.html#a26709c02c869d09d756653ae1129f8a9">operator=</a> (const <a class="el" href="class_abstract_ring.html">AbstractRing</a> &amp;source)</td></tr>
<tr class="memdesc:a26709c02c869d09d756653ae1129f8a9 inherit pub_methods_class_abstract_ring"><td class="mdescLeft">&#160;</td><td class="mdescRight">Assign an <a class="el" href="class_abstract_ring.html" title="Abstract ring. ">AbstractRing</a>.  <a href="class_abstract_ring.html#a26709c02c869d09d756653ae1129f8a9">More...</a><br /></td></tr>
<tr class="separator:a26709c02c869d09d756653ae1129f8a9 inherit pub_methods_class_abstract_ring"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:aa7ce20a30d89a8257088930d1d06d0b7 inherit pub_methods_class_abstract_ring"><td class="memItemLeft" align="right" valign="top">virtual const <a class="el" href="class_g_f_p2_element.html">Element</a> &amp;&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_abstract_ring.html#aa7ce20a30d89a8257088930d1d06d0b7">Divide</a> (const <a class="el" href="class_g_f_p2_element.html">Element</a> &amp;a, const <a class="el" href="class_g_f_p2_element.html">Element</a> &amp;b) const</td></tr>
<tr class="memdesc:aa7ce20a30d89a8257088930d1d06d0b7 inherit pub_methods_class_abstract_ring"><td class="mdescLeft">&#160;</td><td class="mdescRight">Divides elements in the group.  <a href="class_abstract_ring.html#aa7ce20a30d89a8257088930d1d06d0b7">More...</a><br /></td></tr>
<tr class="separator:aa7ce20a30d89a8257088930d1d06d0b7 inherit pub_methods_class_abstract_ring"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:adb4d33ac59a8f8bff1752b75809136e6 inherit pub_methods_class_abstract_ring"><td class="memItemLeft" align="right" valign="top">virtual <a class="el" href="class_g_f_p2_element.html">Element</a>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_abstract_ring.html#adb4d33ac59a8f8bff1752b75809136e6">CascadeExponentiate</a> (const <a class="el" href="class_g_f_p2_element.html">Element</a> &amp;x, const <a class="el" href="class_integer.html">Integer</a> &amp;e1, const <a class="el" href="class_g_f_p2_element.html">Element</a> &amp;y, const <a class="el" href="class_integer.html">Integer</a> &amp;e2) const</td></tr>
<tr class="memdesc:adb4d33ac59a8f8bff1752b75809136e6 inherit pub_methods_class_abstract_ring"><td class="mdescLeft">&#160;</td><td class="mdescRight">TODO.  <a href="class_abstract_ring.html#adb4d33ac59a8f8bff1752b75809136e6">More...</a><br /></td></tr>
<tr class="separator:adb4d33ac59a8f8bff1752b75809136e6 inherit pub_methods_class_abstract_ring"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a63530b69e7bfa78e5ee7b072cc798f0a inherit pub_methods_class_abstract_ring"><td class="memItemLeft" align="right" valign="top">virtual void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_abstract_ring.html#a63530b69e7bfa78e5ee7b072cc798f0a">SimultaneousExponentiate</a> (<a class="el" href="class_g_f_p2_element.html">Element</a> *results, const <a class="el" href="class_g_f_p2_element.html">Element</a> &amp;base, const <a class="el" href="class_integer.html">Integer</a> *exponents, unsigned int exponentsCount) const</td></tr>
<tr class="memdesc:a63530b69e7bfa78e5ee7b072cc798f0a inherit pub_methods_class_abstract_ring"><td class="mdescLeft">&#160;</td><td class="mdescRight">Exponentiates a base to multiple exponents in the Ring.  <a href="class_abstract_ring.html#a63530b69e7bfa78e5ee7b072cc798f0a">More...</a><br /></td></tr>
<tr class="separator:a63530b69e7bfa78e5ee7b072cc798f0a inherit pub_methods_class_abstract_ring"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:ae19ef788f5ce5192e5867666ef38717f inherit pub_methods_class_abstract_ring"><td class="memItemLeft" align="right" valign="top">virtual const <a class="el" href="class_abstract_group.html">AbstractGroup</a>&lt; <a class="el" href="class_g_f_p2_element.html">GFP2Element</a> &gt; &amp;&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_abstract_ring.html#ae19ef788f5ce5192e5867666ef38717f">MultiplicativeGroup</a> () const</td></tr>
<tr class="memdesc:ae19ef788f5ce5192e5867666ef38717f inherit pub_methods_class_abstract_ring"><td class="mdescLeft">&#160;</td><td class="mdescRight">Retrieves the multiplicative group.  <a href="class_abstract_ring.html#ae19ef788f5ce5192e5867666ef38717f">More...</a><br /></td></tr>
<tr class="separator:ae19ef788f5ce5192e5867666ef38717f inherit pub_methods_class_abstract_ring"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="inherit_header pub_methods_class_abstract_group"><td colspan="2" onclick="javascript:toggleInherit('pub_methods_class_abstract_group')"><img src="closed.png" alt="-"/>&#160;Public Member Functions inherited from <a class="el" href="class_abstract_group.html">AbstractGroup&lt; GFP2Element &gt;</a></td></tr>
<tr class="memitem:a257836994abefe25b80293f4c6b10f60 inherit pub_methods_class_abstract_group"><td class="memItemLeft" align="right" valign="top">virtual bool&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_abstract_group.html#a257836994abefe25b80293f4c6b10f60">InversionIsFast</a> () const</td></tr>
<tr class="memdesc:a257836994abefe25b80293f4c6b10f60 inherit pub_methods_class_abstract_group"><td class="mdescLeft">&#160;</td><td class="mdescRight">Determine if inversion is fast.  <a href="class_abstract_group.html#a257836994abefe25b80293f4c6b10f60">More...</a><br /></td></tr>
<tr class="separator:a257836994abefe25b80293f4c6b10f60 inherit pub_methods_class_abstract_group"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:ac01536b91c4fa3d0e0f929917143595b inherit pub_methods_class_abstract_group"><td class="memItemLeft" align="right" valign="top">virtual <a class="el" href="class_g_f_p2_element.html">Element</a>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_abstract_group.html#ac01536b91c4fa3d0e0f929917143595b">ScalarMultiply</a> (const <a class="el" href="class_g_f_p2_element.html">Element</a> &amp;a, const <a class="el" href="class_integer.html">Integer</a> &amp;e) const</td></tr>
<tr class="memdesc:ac01536b91c4fa3d0e0f929917143595b inherit pub_methods_class_abstract_group"><td class="mdescLeft">&#160;</td><td class="mdescRight">Performs a scalar multiplication.  <a href="class_abstract_group.html#ac01536b91c4fa3d0e0f929917143595b">More...</a><br /></td></tr>
<tr class="separator:ac01536b91c4fa3d0e0f929917143595b inherit pub_methods_class_abstract_group"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a89bd24f1a83e62ac8cc5ad014cb5883e inherit pub_methods_class_abstract_group"><td class="memItemLeft" align="right" valign="top">virtual <a class="el" href="class_g_f_p2_element.html">Element</a>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_abstract_group.html#a89bd24f1a83e62ac8cc5ad014cb5883e">CascadeScalarMultiply</a> (const <a class="el" href="class_g_f_p2_element.html">Element</a> &amp;x, const <a class="el" href="class_integer.html">Integer</a> &amp;e1, const <a class="el" href="class_g_f_p2_element.html">Element</a> &amp;y, const <a class="el" href="class_integer.html">Integer</a> &amp;e2) const</td></tr>
<tr class="memdesc:a89bd24f1a83e62ac8cc5ad014cb5883e inherit pub_methods_class_abstract_group"><td class="mdescLeft">&#160;</td><td class="mdescRight">TODO.  <a href="class_abstract_group.html#a89bd24f1a83e62ac8cc5ad014cb5883e">More...</a><br /></td></tr>
<tr class="separator:a89bd24f1a83e62ac8cc5ad014cb5883e inherit pub_methods_class_abstract_group"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a9c73ab688612e76786f43e311376eb8d inherit pub_methods_class_abstract_group"><td class="memItemLeft" align="right" valign="top">virtual void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_abstract_group.html#a9c73ab688612e76786f43e311376eb8d">SimultaneousMultiply</a> (<a class="el" href="class_g_f_p2_element.html">Element</a> *results, const <a class="el" href="class_g_f_p2_element.html">Element</a> &amp;base, const <a class="el" href="class_integer.html">Integer</a> *exponents, unsigned int exponentsCount) const</td></tr>
<tr class="memdesc:a9c73ab688612e76786f43e311376eb8d inherit pub_methods_class_abstract_group"><td class="mdescLeft">&#160;</td><td class="mdescRight">Multiplies a base to multiple exponents in a group.  <a href="class_abstract_group.html#a9c73ab688612e76786f43e311376eb8d">More...</a><br /></td></tr>
<tr class="separator:a9c73ab688612e76786f43e311376eb8d inherit pub_methods_class_abstract_group"><td class="memSeparator" colspan="2">&#160;</td></tr>
</table>
<a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2>
<div class="textblock"><h3>template&lt;class F&gt;<br />
class GFP2_ONB&lt; F &gt;</h3>

<p>GF(p^2), optimal normal basis. </p>

<p class="definition">Definition at line <a class="el" href="xtr_8h_source.html#l00046">46</a> of file <a class="el" href="xtr_8h_source.html">xtr.h</a>.</p>
</div><h2 class="groupheader">Member Function Documentation</h2>
<a id="aab4d8f8eec60122c1f3e3ba2c9ad2673"></a>
<h2 class="memtitle"><span class="permalink"><a href="#aab4d8f8eec60122c1f3e3ba2c9ad2673">&#9670;&nbsp;</a></span>Equal()</h2>

<div class="memitem">
<div class="memproto">
<div class="memtemplate">
template&lt;class F&gt; </div>
<table class="mlabels">
  <tr>
  <td class="mlabels-left">
      <table class="memname">
        <tr>
          <td class="memname">bool <a class="el" href="class_g_f_p2___o_n_b.html">GFP2_ONB</a>&lt; F &gt;::Equal </td>
          <td>(</td>
          <td class="paramtype">const <a class="el" href="class_g_f_p2_element.html">GFP2Element</a> &amp;&#160;</td>
          <td class="paramname"><em>a</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">const <a class="el" href="class_g_f_p2_element.html">GFP2Element</a> &amp;&#160;</td>
          <td class="paramname"><em>b</em>&#160;</td>
        </tr>
        <tr>
          <td></td>
          <td>)</td>
          <td></td><td> const</td>
        </tr>
      </table>
  </td>
  <td class="mlabels-right">
<span class="mlabels"><span class="mlabel">inline</span><span class="mlabel">virtual</span></span>  </td>
  </tr>
</table>
</div><div class="memdoc">

<p>Compare two elements for equality. </p>
<dl class="params"><dt>Parameters</dt><dd>
  <table class="params">
    <tr><td class="paramname">a</td><td>first element </td></tr>
    <tr><td class="paramname">b</td><td>second element </td></tr>
  </table>
  </dd>
</dl>
<dl class="section return"><dt>Returns</dt><dd>true if the elements are equal, false otherwise</dd></dl>
<p><a class="el" href="class_g_f_p2___o_n_b.html#aab4d8f8eec60122c1f3e3ba2c9ad2673" title="Compare two elements for equality. ">Equal()</a> tests the elements for equality using <code>a==b</code> </p>

<p>Implements <a class="el" href="class_abstract_group.html#a0d72cb663566b7c056f846a561547bec">AbstractGroup&lt; GFP2Element &gt;</a>.</p>

<p class="definition">Definition at line <a class="el" href="xtr_8h_source.html#l00071">71</a> of file <a class="el" href="xtr_8h_source.html">xtr.h</a>.</p>

</div>
</div>
<a id="a386495ffc3d413f461a9001fe6f30642"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a386495ffc3d413f461a9001fe6f30642">&#9670;&nbsp;</a></span>Identity()</h2>

<div class="memitem">
<div class="memproto">
<div class="memtemplate">
template&lt;class F&gt; </div>
<table class="mlabels">
  <tr>
  <td class="mlabels-left">
      <table class="memname">
        <tr>
          <td class="memname">const <a class="el" href="class_g_f_p2_element.html">Element</a>&amp; <a class="el" href="class_g_f_p2___o_n_b.html">GFP2_ONB</a>&lt; F &gt;::Identity </td>
          <td>(</td>
          <td class="paramname"></td><td>)</td>
          <td> const</td>
        </tr>
      </table>
  </td>
  <td class="mlabels-right">
<span class="mlabels"><span class="mlabel">inline</span><span class="mlabel">virtual</span></span>  </td>
  </tr>
</table>
</div><div class="memdoc">

<p>Provides the Identity element. </p>
<dl class="section return"><dt>Returns</dt><dd>the Identity element </dd></dl>

<p>Implements <a class="el" href="class_abstract_group.html#a929ba4e6a7d7d80344946efad0456d5b">AbstractGroup&lt; GFP2Element &gt;</a>.</p>

<p class="definition">Definition at line <a class="el" href="xtr_8h_source.html#l00076">76</a> of file <a class="el" href="xtr_8h_source.html">xtr.h</a>.</p>

</div>
</div>
<a id="abd707cb221dd44914e8cde2839ad90c7"></a>
<h2 class="memtitle"><span class="permalink"><a href="#abd707cb221dd44914e8cde2839ad90c7">&#9670;&nbsp;</a></span>Add()</h2>

<div class="memitem">
<div class="memproto">
<div class="memtemplate">
template&lt;class F&gt; </div>
<table class="mlabels">
  <tr>
  <td class="mlabels-left">
      <table class="memname">
        <tr>
          <td class="memname">const <a class="el" href="class_g_f_p2_element.html">Element</a>&amp; <a class="el" href="class_g_f_p2___o_n_b.html">GFP2_ONB</a>&lt; F &gt;::Add </td>
          <td>(</td>
          <td class="paramtype">const <a class="el" href="class_g_f_p2_element.html">Element</a> &amp;&#160;</td>
          <td class="paramname"><em>a</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">const <a class="el" href="class_g_f_p2_element.html">Element</a> &amp;&#160;</td>
          <td class="paramname"><em>b</em>&#160;</td>
        </tr>
        <tr>
          <td></td>
          <td>)</td>
          <td></td><td> const</td>
        </tr>
      </table>
  </td>
  <td class="mlabels-right">
<span class="mlabels"><span class="mlabel">inline</span><span class="mlabel">virtual</span></span>  </td>
  </tr>
</table>
</div><div class="memdoc">

<p>Adds elements in the group. </p>
<dl class="params"><dt>Parameters</dt><dd>
  <table class="params">
    <tr><td class="paramname">a</td><td>first element </td></tr>
    <tr><td class="paramname">b</td><td>second element </td></tr>
  </table>
  </dd>
</dl>
<dl class="section return"><dt>Returns</dt><dd>the sum of <code>a</code> and <code>b</code> </dd></dl>

<p>Implements <a class="el" href="class_abstract_group.html#aa813430d9e4244de24c487d090eb5797">AbstractGroup&lt; GFP2Element &gt;</a>.</p>

<p class="definition">Definition at line <a class="el" href="xtr_8h_source.html#l00081">81</a> of file <a class="el" href="xtr_8h_source.html">xtr.h</a>.</p>

</div>
</div>
<a id="ac9fa7ce33239b3d7f88c9cac9c2d74d3"></a>
<h2 class="memtitle"><span class="permalink"><a href="#ac9fa7ce33239b3d7f88c9cac9c2d74d3">&#9670;&nbsp;</a></span>Inverse()</h2>

<div class="memitem">
<div class="memproto">
<div class="memtemplate">
template&lt;class F&gt; </div>
<table class="mlabels">
  <tr>
  <td class="mlabels-left">
      <table class="memname">
        <tr>
          <td class="memname">const <a class="el" href="class_g_f_p2_element.html">Element</a>&amp; <a class="el" href="class_g_f_p2___o_n_b.html">GFP2_ONB</a>&lt; F &gt;::Inverse </td>
          <td>(</td>
          <td class="paramtype">const <a class="el" href="class_g_f_p2_element.html">Element</a> &amp;&#160;</td>
          <td class="paramname"><em>a</em></td><td>)</td>
          <td> const</td>
        </tr>
      </table>
  </td>
  <td class="mlabels-right">
<span class="mlabels"><span class="mlabel">inline</span><span class="mlabel">virtual</span></span>  </td>
  </tr>
</table>
</div><div class="memdoc">

<p>Inverts the element in the group. </p>
<dl class="params"><dt>Parameters</dt><dd>
  <table class="params">
    <tr><td class="paramname">a</td><td>first element </td></tr>
  </table>
  </dd>
</dl>
<dl class="section return"><dt>Returns</dt><dd>the inverse of the element </dd></dl>

<p>Implements <a class="el" href="class_abstract_group.html#ab22563bc0dcb544399d7e22b3589e165">AbstractGroup&lt; GFP2Element &gt;</a>.</p>

<p class="definition">Definition at line <a class="el" href="xtr_8h_source.html#l00088">88</a> of file <a class="el" href="xtr_8h_source.html">xtr.h</a>.</p>

</div>
</div>
<a id="a39cef4f74a7bd5588a7293b1d364334e"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a39cef4f74a7bd5588a7293b1d364334e">&#9670;&nbsp;</a></span>Double()</h2>

<div class="memitem">
<div class="memproto">
<div class="memtemplate">
template&lt;class F&gt; </div>
<table class="mlabels">
  <tr>
  <td class="mlabels-left">
      <table class="memname">
        <tr>
          <td class="memname">const <a class="el" href="class_g_f_p2_element.html">Element</a>&amp; <a class="el" href="class_g_f_p2___o_n_b.html">GFP2_ONB</a>&lt; F &gt;::Double </td>
          <td>(</td>
          <td class="paramtype">const <a class="el" href="class_g_f_p2_element.html">Element</a> &amp;&#160;</td>
          <td class="paramname"><em>a</em></td><td>)</td>
          <td> const</td>
        </tr>
      </table>
  </td>
  <td class="mlabels-right">
<span class="mlabels"><span class="mlabel">inline</span><span class="mlabel">virtual</span></span>  </td>
  </tr>
</table>
</div><div class="memdoc">

<p>Doubles an element in the group. </p>
<dl class="params"><dt>Parameters</dt><dd>
  <table class="params">
    <tr><td class="paramname">a</td><td>the element </td></tr>
  </table>
  </dd>
</dl>
<dl class="section return"><dt>Returns</dt><dd>the element doubled </dd></dl>

<p>Reimplemented from <a class="el" href="class_abstract_group.html#afaceaf9c9c24606efc38d30fd8aff5ee">AbstractGroup&lt; GFP2Element &gt;</a>.</p>

<p class="definition">Definition at line <a class="el" href="xtr_8h_source.html#l00095">95</a> of file <a class="el" href="xtr_8h_source.html">xtr.h</a>.</p>

</div>
</div>
<a id="aedbcc151eca01f823b6d8c34f792fad9"></a>
<h2 class="memtitle"><span class="permalink"><a href="#aedbcc151eca01f823b6d8c34f792fad9">&#9670;&nbsp;</a></span>Subtract()</h2>

<div class="memitem">
<div class="memproto">
<div class="memtemplate">
template&lt;class F&gt; </div>
<table class="mlabels">
  <tr>
  <td class="mlabels-left">
      <table class="memname">
        <tr>
          <td class="memname">const <a class="el" href="class_g_f_p2_element.html">Element</a>&amp; <a class="el" href="class_g_f_p2___o_n_b.html">GFP2_ONB</a>&lt; F &gt;::Subtract </td>
          <td>(</td>
          <td class="paramtype">const <a class="el" href="class_g_f_p2_element.html">Element</a> &amp;&#160;</td>
          <td class="paramname"><em>a</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">const <a class="el" href="class_g_f_p2_element.html">Element</a> &amp;&#160;</td>
          <td class="paramname"><em>b</em>&#160;</td>
        </tr>
        <tr>
          <td></td>
          <td>)</td>
          <td></td><td> const</td>
        </tr>
      </table>
  </td>
  <td class="mlabels-right">
<span class="mlabels"><span class="mlabel">inline</span><span class="mlabel">virtual</span></span>  </td>
  </tr>
</table>
</div><div class="memdoc">

<p>Subtracts elements in the group. </p>
<dl class="params"><dt>Parameters</dt><dd>
  <table class="params">
    <tr><td class="paramname">a</td><td>first element </td></tr>
    <tr><td class="paramname">b</td><td>second element </td></tr>
  </table>
  </dd>
</dl>
<dl class="section return"><dt>Returns</dt><dd>the difference of <code>a</code> and <code>b</code>. The element <code>a</code> must provide a Subtract member function. </dd></dl>

<p>Reimplemented from <a class="el" href="class_abstract_group.html#aa19e1bef00198fb30eb01df3f7076717">AbstractGroup&lt; GFP2Element &gt;</a>.</p>

<p class="definition">Definition at line <a class="el" href="xtr_8h_source.html#l00102">102</a> of file <a class="el" href="xtr_8h_source.html">xtr.h</a>.</p>

</div>
</div>
<a id="a9ea72a20954c87db4467e14fdaa67037"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a9ea72a20954c87db4467e14fdaa67037">&#9670;&nbsp;</a></span>Accumulate()</h2>

<div class="memitem">
<div class="memproto">
<div class="memtemplate">
template&lt;class F&gt; </div>
<table class="mlabels">
  <tr>
  <td class="mlabels-left">
      <table class="memname">
        <tr>
          <td class="memname"><a class="el" href="class_g_f_p2_element.html">Element</a>&amp; <a class="el" href="class_g_f_p2___o_n_b.html">GFP2_ONB</a>&lt; F &gt;::Accumulate </td>
          <td>(</td>
          <td class="paramtype"><a class="el" href="class_g_f_p2_element.html">Element</a> &amp;&#160;</td>
          <td class="paramname"><em>a</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">const <a class="el" href="class_g_f_p2_element.html">Element</a> &amp;&#160;</td>
          <td class="paramname"><em>b</em>&#160;</td>
        </tr>
        <tr>
          <td></td>
          <td>)</td>
          <td></td><td> const</td>
        </tr>
      </table>
  </td>
  <td class="mlabels-right">
<span class="mlabels"><span class="mlabel">inline</span><span class="mlabel">virtual</span></span>  </td>
  </tr>
</table>
</div><div class="memdoc">

<p>TODO. </p>
<dl class="params"><dt>Parameters</dt><dd>
  <table class="params">
    <tr><td class="paramname">a</td><td>first element </td></tr>
    <tr><td class="paramname">b</td><td>second element </td></tr>
  </table>
  </dd>
</dl>
<dl class="section return"><dt>Returns</dt><dd>TODO </dd></dl>

<p>Reimplemented from <a class="el" href="class_abstract_group.html#ab03cc0a23f23c6aa1c003e11f9abb8c5">AbstractGroup&lt; GFP2Element &gt;</a>.</p>

<p class="definition">Definition at line <a class="el" href="xtr_8h_source.html#l00109">109</a> of file <a class="el" href="xtr_8h_source.html">xtr.h</a>.</p>

</div>
</div>
<a id="ac6d39d886f9ddc047fcc4c5adcc23db9"></a>
<h2 class="memtitle"><span class="permalink"><a href="#ac6d39d886f9ddc047fcc4c5adcc23db9">&#9670;&nbsp;</a></span>Reduce()</h2>

<div class="memitem">
<div class="memproto">
<div class="memtemplate">
template&lt;class F&gt; </div>
<table class="mlabels">
  <tr>
  <td class="mlabels-left">
      <table class="memname">
        <tr>
          <td class="memname"><a class="el" href="class_g_f_p2_element.html">Element</a>&amp; <a class="el" href="class_g_f_p2___o_n_b.html">GFP2_ONB</a>&lt; F &gt;::Reduce </td>
          <td>(</td>
          <td class="paramtype"><a class="el" href="class_g_f_p2_element.html">Element</a> &amp;&#160;</td>
          <td class="paramname"><em>a</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">const <a class="el" href="class_g_f_p2_element.html">Element</a> &amp;&#160;</td>
          <td class="paramname"><em>b</em>&#160;</td>
        </tr>
        <tr>
          <td></td>
          <td>)</td>
          <td></td><td> const</td>
        </tr>
      </table>
  </td>
  <td class="mlabels-right">
<span class="mlabels"><span class="mlabel">inline</span><span class="mlabel">virtual</span></span>  </td>
  </tr>
</table>
</div><div class="memdoc">

<p>Reduces an element in the congruence class. </p>
<dl class="params"><dt>Parameters</dt><dd>
  <table class="params">
    <tr><td class="paramname">a</td><td>element to reduce </td></tr>
    <tr><td class="paramname">b</td><td>the congruence class </td></tr>
  </table>
  </dd>
</dl>
<dl class="section return"><dt>Returns</dt><dd>the reduced element </dd></dl>

<p>Reimplemented from <a class="el" href="class_abstract_group.html#a40f7de55eddc193e07a7c3b5acad781a">AbstractGroup&lt; GFP2Element &gt;</a>.</p>

<p class="definition">Definition at line <a class="el" href="xtr_8h_source.html#l00116">116</a> of file <a class="el" href="xtr_8h_source.html">xtr.h</a>.</p>

</div>
</div>
<a id="ac0e339d3509a26757486bbc78e339910"></a>
<h2 class="memtitle"><span class="permalink"><a href="#ac0e339d3509a26757486bbc78e339910">&#9670;&nbsp;</a></span>IsUnit()</h2>

<div class="memitem">
<div class="memproto">
<div class="memtemplate">
template&lt;class F&gt; </div>
<table class="mlabels">
  <tr>
  <td class="mlabels-left">
      <table class="memname">
        <tr>
          <td class="memname">bool <a class="el" href="class_g_f_p2___o_n_b.html">GFP2_ONB</a>&lt; F &gt;::IsUnit </td>
          <td>(</td>
          <td class="paramtype">const <a class="el" href="class_g_f_p2_element.html">Element</a> &amp;&#160;</td>
          <td class="paramname"><em>a</em></td><td>)</td>
          <td> const</td>
        </tr>
      </table>
  </td>
  <td class="mlabels-right">
<span class="mlabels"><span class="mlabel">inline</span><span class="mlabel">virtual</span></span>  </td>
  </tr>
</table>
</div><div class="memdoc">

<p>Determines whether an element is a unit in the group. </p>
<dl class="params"><dt>Parameters</dt><dd>
  <table class="params">
    <tr><td class="paramname">a</td><td>the element </td></tr>
  </table>
  </dd>
</dl>
<dl class="section return"><dt>Returns</dt><dd>true if the element is a unit after reduction, false otherwise. </dd></dl>

<p>Implements <a class="el" href="class_abstract_ring.html#acc7079c244d980c670c329e483c4f107">AbstractRing&lt; GFP2Element &gt;</a>.</p>

<p class="definition">Definition at line <a class="el" href="xtr_8h_source.html#l00123">123</a> of file <a class="el" href="xtr_8h_source.html">xtr.h</a>.</p>

</div>
</div>
<a id="aa1d3c030219de3c1635a72fbdf0c7228"></a>
<h2 class="memtitle"><span class="permalink"><a href="#aa1d3c030219de3c1635a72fbdf0c7228">&#9670;&nbsp;</a></span>MultiplicativeIdentity()</h2>

<div class="memitem">
<div class="memproto">
<div class="memtemplate">
template&lt;class F&gt; </div>
<table class="mlabels">
  <tr>
  <td class="mlabels-left">
      <table class="memname">
        <tr>
          <td class="memname">const <a class="el" href="class_g_f_p2_element.html">Element</a>&amp; <a class="el" href="class_g_f_p2___o_n_b.html">GFP2_ONB</a>&lt; F &gt;::MultiplicativeIdentity </td>
          <td>(</td>
          <td class="paramname"></td><td>)</td>
          <td> const</td>
        </tr>
      </table>
  </td>
  <td class="mlabels-right">
<span class="mlabels"><span class="mlabel">inline</span><span class="mlabel">virtual</span></span>  </td>
  </tr>
</table>
</div><div class="memdoc">

<p>Retrieves the multiplicative identity. </p>
<dl class="section return"><dt>Returns</dt><dd>the multiplicative identity </dd></dl>

<p>Implements <a class="el" href="class_abstract_ring.html#a390832165268e39e2a1f3263e5b44627">AbstractRing&lt; GFP2Element &gt;</a>.</p>

<p class="definition">Definition at line <a class="el" href="xtr_8h_source.html#l00128">128</a> of file <a class="el" href="xtr_8h_source.html">xtr.h</a>.</p>

</div>
</div>
<a id="abe477db3d5bf5fdb72b9fcc832ff8bac"></a>
<h2 class="memtitle"><span class="permalink"><a href="#abe477db3d5bf5fdb72b9fcc832ff8bac">&#9670;&nbsp;</a></span>Multiply()</h2>

<div class="memitem">
<div class="memproto">
<div class="memtemplate">
template&lt;class F&gt; </div>
<table class="mlabels">
  <tr>
  <td class="mlabels-left">
      <table class="memname">
        <tr>
          <td class="memname">const <a class="el" href="class_g_f_p2_element.html">Element</a>&amp; <a class="el" href="class_g_f_p2___o_n_b.html">GFP2_ONB</a>&lt; F &gt;::Multiply </td>
          <td>(</td>
          <td class="paramtype">const <a class="el" href="class_g_f_p2_element.html">Element</a> &amp;&#160;</td>
          <td class="paramname"><em>a</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">const <a class="el" href="class_g_f_p2_element.html">Element</a> &amp;&#160;</td>
          <td class="paramname"><em>b</em>&#160;</td>
        </tr>
        <tr>
          <td></td>
          <td>)</td>
          <td></td><td> const</td>
        </tr>
      </table>
  </td>
  <td class="mlabels-right">
<span class="mlabels"><span class="mlabel">inline</span><span class="mlabel">virtual</span></span>  </td>
  </tr>
</table>
</div><div class="memdoc">

<p>Multiplies elements in the group. </p>
<dl class="params"><dt>Parameters</dt><dd>
  <table class="params">
    <tr><td class="paramname">a</td><td>the multiplicand </td></tr>
    <tr><td class="paramname">b</td><td>the multiplier </td></tr>
  </table>
  </dd>
</dl>
<dl class="section return"><dt>Returns</dt><dd>the product of a and b </dd></dl>

<p>Implements <a class="el" href="class_abstract_ring.html#a4ba8818fc72fa298cd52fd483bdd6ad4">AbstractRing&lt; GFP2Element &gt;</a>.</p>

<p class="definition">Definition at line <a class="el" href="xtr_8h_source.html#l00134">134</a> of file <a class="el" href="xtr_8h_source.html">xtr.h</a>.</p>

</div>
</div>
<a id="a42f1dfe03023fb5502843e326892850c"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a42f1dfe03023fb5502843e326892850c">&#9670;&nbsp;</a></span>MultiplicativeInverse()</h2>

<div class="memitem">
<div class="memproto">
<div class="memtemplate">
template&lt;class F&gt; </div>
<table class="mlabels">
  <tr>
  <td class="mlabels-left">
      <table class="memname">
        <tr>
          <td class="memname">const <a class="el" href="class_g_f_p2_element.html">Element</a>&amp; <a class="el" href="class_g_f_p2___o_n_b.html">GFP2_ONB</a>&lt; F &gt;::MultiplicativeInverse </td>
          <td>(</td>
          <td class="paramtype">const <a class="el" href="class_g_f_p2_element.html">Element</a> &amp;&#160;</td>
          <td class="paramname"><em>a</em></td><td>)</td>
          <td> const</td>
        </tr>
      </table>
  </td>
  <td class="mlabels-right">
<span class="mlabels"><span class="mlabel">inline</span><span class="mlabel">virtual</span></span>  </td>
  </tr>
</table>
</div><div class="memdoc">

<p>Calculate the multiplicative inverse of an element in the group. </p>
<dl class="params"><dt>Parameters</dt><dd>
  <table class="params">
    <tr><td class="paramname">a</td><td>the element </td></tr>
  </table>
  </dd>
</dl>

<p>Implements <a class="el" href="class_abstract_ring.html#aba109f4e7932d77a8251c1ec20627571">AbstractRing&lt; GFP2Element &gt;</a>.</p>

<p class="definition">Definition at line <a class="el" href="xtr_8h_source.html#l00148">148</a> of file <a class="el" href="xtr_8h_source.html">xtr.h</a>.</p>

</div>
</div>
<a id="a41cd047c0fc625ecde993d839d8d86b7"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a41cd047c0fc625ecde993d839d8d86b7">&#9670;&nbsp;</a></span>Square()</h2>

<div class="memitem">
<div class="memproto">
<div class="memtemplate">
template&lt;class F&gt; </div>
<table class="mlabels">
  <tr>
  <td class="mlabels-left">
      <table class="memname">
        <tr>
          <td class="memname">const <a class="el" href="class_g_f_p2_element.html">Element</a>&amp; <a class="el" href="class_g_f_p2___o_n_b.html">GFP2_ONB</a>&lt; F &gt;::<a class="el" href="class_square.html">Square</a> </td>
          <td>(</td>
          <td class="paramtype">const <a class="el" href="class_g_f_p2_element.html">Element</a> &amp;&#160;</td>
          <td class="paramname"><em>a</em></td><td>)</td>
          <td> const</td>
        </tr>
      </table>
  </td>
  <td class="mlabels-right">
<span class="mlabels"><span class="mlabel">inline</span><span class="mlabel">virtual</span></span>  </td>
  </tr>
</table>
</div><div class="memdoc">

<p><a class="el" href="class_square.html" title="Square block cipher. ">Square</a> an element in the group. </p>
<dl class="params"><dt>Parameters</dt><dd>
  <table class="params">
    <tr><td class="paramname">a</td><td>the element </td></tr>
  </table>
  </dd>
</dl>
<dl class="section return"><dt>Returns</dt><dd>the element squared </dd></dl>

<p>Reimplemented from <a class="el" href="class_abstract_ring.html#a54b38c3a067b893e0c87495bee7adcef">AbstractRing&lt; GFP2Element &gt;</a>.</p>

<p class="definition">Definition at line <a class="el" href="xtr_8h_source.html#l00153">153</a> of file <a class="el" href="xtr_8h_source.html">xtr.h</a>.</p>

</div>
</div>
<a id="ad71eeac946b5f17fcb6645bd2f281d23"></a>
<h2 class="memtitle"><span class="permalink"><a href="#ad71eeac946b5f17fcb6645bd2f281d23">&#9670;&nbsp;</a></span>Exponentiate()</h2>

<div class="memitem">
<div class="memproto">
<div class="memtemplate">
template&lt;class F&gt; </div>
<table class="mlabels">
  <tr>
  <td class="mlabels-left">
      <table class="memname">
        <tr>
          <td class="memname"><a class="el" href="class_g_f_p2_element.html">Element</a> <a class="el" href="class_g_f_p2___o_n_b.html">GFP2_ONB</a>&lt; F &gt;::Exponentiate </td>
          <td>(</td>
          <td class="paramtype">const <a class="el" href="class_g_f_p2_element.html">Element</a> &amp;&#160;</td>
          <td class="paramname"><em>a</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">const <a class="el" href="class_integer.html">Integer</a> &amp;&#160;</td>
          <td class="paramname"><em>e</em>&#160;</td>
        </tr>
        <tr>
          <td></td>
          <td>)</td>
          <td></td><td> const</td>
        </tr>
      </table>
  </td>
  <td class="mlabels-right">
<span class="mlabels"><span class="mlabel">inline</span><span class="mlabel">virtual</span></span>  </td>
  </tr>
</table>
</div><div class="memdoc">

<p>Raises a base to an exponent in the group. </p>
<dl class="params"><dt>Parameters</dt><dd>
  <table class="params">
    <tr><td class="paramname">a</td><td>the base </td></tr>
    <tr><td class="paramname">e</td><td>the exponent </td></tr>
  </table>
  </dd>
</dl>
<dl class="section return"><dt>Returns</dt><dd>the exponentiation </dd></dl>

<p>Reimplemented from <a class="el" href="class_abstract_ring.html#a0f011366054a4edb80be92f968083538">AbstractRing&lt; GFP2Element &gt;</a>.</p>

<p class="definition">Definition at line <a class="el" href="xtr_8h_source.html#l00161">161</a> of file <a class="el" href="xtr_8h_source.html">xtr.h</a>.</p>

</div>
</div>
<hr/>The documentation for this class was generated from the following file:<ul>
<li><a class="el" href="xtr_8h_source.html">xtr.h</a></li>
</ul>
</div><!-- contents -->
<!-- start footer part -->
<hr class="footer"/><address class="footer"><small>
Generated on Sun Sep 16 2018 07:58:35 for Crypto++ by &#160;<a href="http://www.doxygen.org/index.html">
<img class="footer" src="doxygen.png" alt="doxygen"/>
</a> 1.8.14
</small></address>
</body>
</html>