<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> <html><head><meta http-equiv="Content-Type" content="text/html;charset=UTF-8"> <title>VTK: dox/Filtering/vtkImplicitSum.h Source File</title> <link href="doxygen.css" rel="stylesheet" type="text/css"> <link href="tabs.css" rel="stylesheet" type="text/css"> </head><body> <!-- Generated by Doxygen 1.5.6 --> <div class="navigation" id="top"> <div class="tabs"> <ul> <li><a href="index.html"><span>Main Page</span></a></li> <li><a href="pages.html"><span>Related Pages</span></a></li> <li><a href="namespaces.html"><span>Namespaces</span></a></li> <li><a href="classes.html"><span>Classes</span></a></li> <li class="current"><a href="files.html"><span>Files</span></a></li> </ul> </div> <h1>dox/Filtering/vtkImplicitSum.h</h1><a href="a02291.html">Go to the documentation of this file.</a><div class="fragment"><pre class="fragment"><a name="l00001"></a>00001 <span class="comment">/*=========================================================================</span> <a name="l00002"></a>00002 <span class="comment"></span> <a name="l00003"></a>00003 <span class="comment"> Program: Visualization Toolkit</span> <a name="l00004"></a>00004 <span class="comment"> Module: $RCSfile: vtkImplicitSum.h,v $</span> <a name="l00005"></a>00005 <span class="comment"></span> <a name="l00006"></a>00006 <span class="comment"> Copyright (c) Ken Martin, Will Schroeder, Bill Lorensen</span> <a name="l00007"></a>00007 <span class="comment"> All rights reserved.</span> <a name="l00008"></a>00008 <span class="comment"> See Copyright.txt or http://www.kitware.com/Copyright.htm for details.</span> <a name="l00009"></a>00009 <span class="comment"></span> <a name="l00010"></a>00010 <span class="comment"> This software is distributed WITHOUT ANY WARRANTY; without even</span> <a name="l00011"></a>00011 <span class="comment"> the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR</span> <a name="l00012"></a>00012 <span class="comment"> PURPOSE. See the above copyright notice for more information.</span> <a name="l00013"></a>00013 <span class="comment"></span> <a name="l00014"></a>00014 <span class="comment">=========================================================================*/</span> <a name="l00028"></a>00028 <span class="preprocessor">#ifndef __vtkImplicitSum_h</span> <a name="l00029"></a>00029 <span class="preprocessor"></span><span class="preprocessor">#define __vtkImplicitSum_h</span> <a name="l00030"></a>00030 <span class="preprocessor"></span> <a name="l00031"></a>00031 <span class="preprocessor">#include "<a class="code" href="a02036.html">vtkImplicitFunction.h</a>"</span> <a name="l00032"></a>00032 <a name="l00033"></a>00033 <span class="keyword">class </span><a class="code" href="a00436.html" title="dynamic, self-adjusting array of double">vtkDoubleArray</a>; <a name="l00034"></a>00034 <span class="keyword">class </span><a class="code" href="a00856.html" title="maintain a list of implicit functions">vtkImplicitFunctionCollection</a>; <a name="l00035"></a>00035 <a name="l00036"></a><a class="code" href="a00864.html">00036</a> <span class="keyword">class </span><a class="code" href="a02170.html#95ced7977a6b6b1bf9f38bf04e3835b6">VTK_FILTERING_EXPORT</a> <a class="code" href="a00864.html" title="implicit sum of other implicit functions">vtkImplicitSum</a> : <span class="keyword">public</span> <a class="code" href="a00855.html" title="abstract interface for implicit functions">vtkImplicitFunction</a> <a name="l00037"></a>00037 { <a name="l00038"></a>00038 <span class="keyword">public</span>: <a name="l00039"></a>00039 <span class="keyword">static</span> <a class="code" href="a00864.html" title="implicit sum of other implicit functions">vtkImplicitSum</a> *<a class="code" href="a01084.html#4d5b227267c076d6f9e38483370b6612">New</a>(); <a name="l00040"></a>00040 <a name="l00041"></a><a class="code" href="a00864.html#2bbc7c020c9e4bef0519ec874d7fa61e">00041</a> vtkTypeRevisionMacro(<a class="code" href="a00864.html" title="implicit sum of other implicit functions">vtkImplicitSum</a>,<a class="code" href="a00855.html" title="abstract interface for implicit functions">vtkImplicitFunction</a>); <a name="l00042"></a>00042 <span class="keywordtype">void</span> <a class="code" href="a00855.html#c32b0c5b45c2fa479397dec6d9a6d3fa">PrintSelf</a>(ostream& os, <a class="code" href="a00869.html" title="a simple class to control print indentation">vtkIndent</a> indent); <a name="l00043"></a>00043 <a name="l00045"></a>00045 <a name="l00046"></a>00046 <span class="keywordtype">double</span> <a class="code" href="a00855.html#b911bac1b365fd74129611e3d26dcc3e">EvaluateFunction</a>(<span class="keywordtype">double</span> x[3]); <a name="l00047"></a><a class="code" href="a00864.html#b72c49f552c23812a6a12fc853f86d93">00047</a> <span class="keywordtype">double</span> <a class="code" href="a00855.html#b911bac1b365fd74129611e3d26dcc3e">EvaluateFunction</a>(<span class="keywordtype">double</span> x, <span class="keywordtype">double</span> y, <span class="keywordtype">double</span> z) <a name="l00048"></a>00048 {<span class="keywordflow">return</span> this-><a class="code" href="a00855.html#b911bac1b365fd74129611e3d26dcc3e">vtkImplicitFunction::EvaluateFunction</a>(x, y, z); } ; <a name="l00050"></a>00050 <a name="l00053"></a>00053 <span class="keywordtype">void</span> <a class="code" href="a00855.html#29ed340b0bf20f8b0cd090daa3107e70">EvaluateGradient</a>(<span class="keywordtype">double</span> x[3], <span class="keywordtype">double</span> g[3]); <a name="l00054"></a>00054 <a name="l00056"></a>00056 <span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> <a class="code" href="a00855.html#f35afc5c775ddca671ff33e14c7f7bc9">GetMTime</a>(); <a name="l00057"></a>00057 <a name="l00060"></a>00060 <span class="keywordtype">void</span> AddFunction(<a class="code" href="a00855.html" title="abstract interface for implicit functions">vtkImplicitFunction</a> *in, <span class="keywordtype">double</span> <a class="code" href="a03761.html#c6551f7bf833e8254b2b3ecdaea0d210bb2d78b6580449dd87039b05077e2f0d">weight</a>); <a name="l00061"></a>00061 <a name="l00064"></a><a class="code" href="a00864.html#4a139a0d06522c913fb6af047706a4b8">00064</a> <span class="keywordtype">void</span> AddFunction(<a class="code" href="a00855.html" title="abstract interface for implicit functions">vtkImplicitFunction</a> *in) { this->AddFunction(in, 1.0); } <a name="l00065"></a>00065 <a name="l00067"></a>00067 <span class="keywordtype">void</span> RemoveAllFunctions(); <a name="l00068"></a>00068 <a name="l00070"></a>00070 <span class="keywordtype">void</span> SetFunctionWeight(<a class="code" href="a00855.html" title="abstract interface for implicit functions">vtkImplicitFunction</a> *f, <span class="keywordtype">double</span> <a class="code" href="a03761.html#c6551f7bf833e8254b2b3ecdaea0d210bb2d78b6580449dd87039b05077e2f0d">weight</a>); <a name="l00071"></a>00071 <a name="l00073"></a>00073 <a name="l00078"></a>00078 vtkSetMacro(NormalizeByWeight, <span class="keywordtype">int</span>); <a name="l00079"></a>00079 vtkGetMacro(NormalizeByWeight, <span class="keywordtype">int</span>); <a name="l00080"></a>00080 vtkBooleanMacro(NormalizeByWeight, <span class="keywordtype">int</span>); <a name="l00082"></a>00082 <a name="l00083"></a>00083 <span class="keyword">protected</span>: <a name="l00084"></a>00084 <a class="code" href="a00864.html" title="implicit sum of other implicit functions">vtkImplicitSum</a>(); <a name="l00085"></a>00085 ~<a class="code" href="a00864.html" title="implicit sum of other implicit functions">vtkImplicitSum</a>(); <a name="l00086"></a>00086 <a name="l00087"></a><a class="code" href="a00864.html#b04687d2347c5779d6d4155c3ccd5b74">00087</a> <a class="code" href="a00856.html" title="maintain a list of implicit functions">vtkImplicitFunctionCollection</a> *FunctionList; <a name="l00088"></a><a class="code" href="a00864.html#b811e68fd11d1f2f19489dcfcb61c691">00088</a> <a class="code" href="a00436.html" title="dynamic, self-adjusting array of double">vtkDoubleArray</a> *Weights; <a name="l00089"></a><a class="code" href="a00864.html#77262bb3cef5f43a7e43bf75040810ac">00089</a> <span class="keywordtype">double</span> TotalWeight; <a name="l00090"></a>00090 <a name="l00091"></a>00091 <span class="keywordtype">void</span> CalculateTotalWeight(<span class="keywordtype">void</span>); <a name="l00092"></a><a class="code" href="a00864.html#007159ec8360e1ad7364d7d16d6e402d">00092</a> <span class="keywordtype">int</span> NormalizeByWeight; <a name="l00093"></a>00093 <a name="l00094"></a>00094 <span class="keyword">private</span>: <a name="l00095"></a>00095 <a class="code" href="a00864.html" title="implicit sum of other implicit functions">vtkImplicitSum</a>(<span class="keyword">const</span> <a class="code" href="a00864.html" title="implicit sum of other implicit functions">vtkImplicitSum</a>&); <span class="comment">// Not implemented.</span> <a name="l00096"></a>00096 <span class="keywordtype">void</span> operator=(<span class="keyword">const</span> <a class="code" href="a00864.html" title="implicit sum of other implicit functions">vtkImplicitSum</a>&); <span class="comment">// Not implemented.</span> <a name="l00097"></a>00097 }; <a name="l00098"></a>00098 <a name="l00099"></a>00099 <span class="preprocessor">#endif</span> </pre></div></div> <hr size="1"><address style="text-align: right;"><small>Generated on Wed Jun 3 18:35:16 2009 for VTK by <a href="http://www.doxygen.org/index.html"> <img src="doxygen.png" alt="doxygen" align="middle" border="0"></a> 1.5.6 </small></address> </body> </html>