<div dir="ltr">Hey Brad,<div><br></div><div style>The same errors with 3D, 2D and 1D.</div><div style><br></div><div style>Cheers,</div><div style>Phil</div></div><div class="gmail_extra"><br><br><div class="gmail_quote">On 22 April 2013 22:56, Bradley Lowekamp <span dir="ltr">&lt;<a href="mailto:blowekamp@mail.nih.gov" target="_blank">blowekamp@mail.nih.gov</a>&gt;</span> wrote:<br>
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">Hello,<br>
<br>
Do you get the same error with just a 3D image?<br>
<br>
Brad<br>
<div><div class="h5"><br>
On Apr 21, 2013, at 11:02 PM, Phillip George Dayan Ward &lt;<a href="mailto:pgwar1@student.monash.edu">pgwar1@student.monash.edu</a>&gt; wrote:<br>
<br>
&gt; Hey ITK,<br>
&gt;<br>
&gt; I&#39;m attempting to use the convolution filter, on a complex image, with a complex kernel. Both the kernel and image have 4 dimensions.<br>
&gt;<br>
&gt; I feel like I either missed a warning saying complex type is not supported, or I have failed to implement it properly.<br>
&gt;<br>
&gt; I&#39;m receiving the following error during the compile process just from instantiating the filter with the type std::complex&lt;float&gt;<br>
&gt;<br>
&gt; ITK/Modules/Core/Common/include/itkPixelTraits.h:49:60: error: no member<br>
&gt;       named &#39;Length&#39; in &#39;std::complex&lt;double&gt;&#39;<br>
&gt;   itkStaticConstMacro(Dimension, unsigned int, TPixelType::Length);<br>
&gt;<br>
&gt; I&#39;m also receiving:<br>
&gt;<br>
&gt; ITK/Modules/Core/Common/include/itkPixelTraits.h:52:32: error: no type named<br>
&gt;       &#39;ValueType&#39; in &#39;std::complex&lt;double&gt;&#39;<br>
&gt;   typedef typename TPixelType::ValueType ValueType;<br>
&gt;<br>
&gt; ITK/Modules/Core/Common/include/itkNeighborhoodInnerProduct.hxx:52:7: error:<br>
&gt;       cannot convert &#39;const std::complex&lt;double&gt;&#39; to &#39;OutputPixelValueType&#39; (aka &#39;double&#39;) without a conversion<br>
&gt;       operator<br>
&gt;       static_cast&lt; OutputPixelValueType &gt;( *o_it ) *<br>
&gt;<br>
&gt; ITK/Modules/Filtering/ImageStatistics/include/itkStatisticsImageFilter.hxx:288:51: error:<br>
&gt;       invalid operands to binary expression (&#39;RealType&#39; (aka &#39;complex&lt;double&gt;&#39;) and &#39;int&#39;)<br>
&gt;              / ( static_cast&lt; RealType &gt;( count ) - 1 );<br>
&gt;<br>
&gt; ITK/Modules/Filtering/ImageStatistics/include/itkStatisticsImageFilter.hxx:329:16: error:<br>
&gt;       invalid operands to binary expression (&#39;PixelType&#39; (aka &#39;std::complex&lt;double&gt;&#39;) and &#39;PixelType&#39;)<br>
&gt;     if ( value &gt; max )<br>
&gt;<br>
&gt; code:<br>
&gt;           typedef itk::Image&lt; std::complex&lt;double&gt;, 4&gt; ComplexImageType;<br>
&gt;<br>
&gt;           ComplexImageType::RegionType region;<br>
&gt;           region.SetSize(0,15);<br>
&gt;           region.SetSize(1,30);<br>
&gt;           region.SetSize(2,100);<br>
&gt;           region.SetSize(3,100);<br>
&gt;<br>
&gt;           ComplexImageType::RegionType kernelRegion;<br>
&gt;           kernelRegion.SetSize(0,1);<br>
&gt;           kernelRegion.SetSize(1,30);<br>
&gt;           kernelRegion.SetSize(2,100);<br>
&gt;           kernelRegion.SetSize(3,100);<br>
&gt;<br>
&gt;           ComplexImageType::Pointer image = ComplexImageType::New();<br>
&gt;           image-&gt;SetRegions(region);<br>
&gt;           image-&gt;Allocate();<br>
&gt;           image-&gt;FillBuffer(std::complex&lt;double&gt;(1.0,1.0));<br>
&gt;<br>
&gt;           ComplexImageType::Pointer kernel = ComplexImageType::New();<br>
&gt;           kernel-&gt;SetRegions(kernelRegion);<br>
&gt;           kernel-&gt;Allocate();<br>
&gt;           kernel-&gt;FillBuffer(std::complex&lt;double&gt;(1.0,1.0));<br>
&gt;<br>
&gt;           typedef itk::ConvolutionImageFilter&lt;ComplexImageType&gt; ConvolutionFilterType;<br>
&gt;           ConvolutionFilterType::Pointer convolutionFilter = ConvolutionFilterType::New();<br>
&gt;           convolutionFilter-&gt;SetInput(image);<br>
&gt;           convolutionFilter-&gt;SetKernelImage(kernel);<br>
&gt;           convolutionFilter-&gt;Update();<br>
&gt;<br>
&gt; Cheers,<br>
&gt; Phil<br>
</div></div>&gt; _____________________________________<br>
&gt; Powered by <a href="http://www.kitware.com" target="_blank">www.kitware.com</a><br>
&gt;<br>
&gt; Visit other Kitware open-source projects at<br>
&gt; <a href="http://www.kitware.com/opensource/opensource.html" target="_blank">http://www.kitware.com/opensource/opensource.html</a><br>
&gt;<br>
&gt; Kitware offers ITK Training Courses, for more information visit:<br>
&gt; <a href="http://www.kitware.com/products/protraining.php" target="_blank">http://www.kitware.com/products/protraining.php</a><br>
&gt;<br>
&gt; Please keep messages on-topic and check the ITK FAQ at:<br>
&gt; <a href="http://www.itk.org/Wiki/ITK_FAQ" target="_blank">http://www.itk.org/Wiki/ITK_FAQ</a><br>
&gt;<br>
&gt; Follow this link to subscribe/unsubscribe:<br>
&gt; <a href="http://www.itk.org/mailman/listinfo/insight-users" target="_blank">http://www.itk.org/mailman/listinfo/insight-users</a><br>
<br>
</blockquote></div><br></div>