After playing around a little bit, I have come up with the following that&#39;s not currently working.  Could you please advise me why this isn&#39;t working.<div><br></div><div>Thanks</div><div><br></div><div>put() {</div>
<div>        // Organ data contains a list of char[]</div><div><div>        final char[] storedCharArray = organData.get(imageNumber);</div><div>        final char[] binaryCharArray = getCharArray(binaryOrgan);</div><div>
<br></div><div>        int i=0;</div><div>        for (char binaryData : binaryCharArray) {</div><div>            char storedData = storedCharArray[i];</div><div>            if (binaryData == 0)</div><div>                storedData &amp;= ~(1 &lt;&lt; bitNumber);</div>
<div>            else</div><div>                storedData |= (1 &lt;&lt; bitNumber);</div><div>            storedCharArray[i] = storedData;</div><div>            ++i;</div><div>        }</div><div><br></div><div>get() {</div>
<div><div>        vtkImageData binaryImage = // Get blank image of correct dimensions, orientation, spacing, etc.</div><div>        final char[] storedCharArray = organData.get(imageNumber);</div><div>        final char[] binaryCharArray = getCharArray(binaryImage);</div>
<div><br></div><div>        int i=0;</div><div>        for (char storedData : storedCharArray) {</div><div>            binaryCharArray[i] = (char)((storedData &gt;&gt; bitNumber) &amp; 1);</div><div>            ++i;</div>
<div>        }</div><div>        setCharArray(binaryImage, binaryCharArray);</div></div><div><br></div><div><div>private void setCharArray(vtkImageData image, char[] array) {</div><div>        ((vtkCharArray)image.GetPointData().GetScalars()).SetJavaArray(array);</div>
<div>    }</div><div><br></div><div>    private char[] getCharArray(vtkImageData image) {</div><div>        vtkPointData points = image.GetPointData();</div><div>        vtkCharArray ca = (vtkCharArray)points.GetScalars();</div>
<div>        char[] chars = ca.GetJavaArray();</div><div>        return chars;</div><div>    }</div></div><div><br></div><br><div class="gmail_quote">On Fri, Mar 25, 2011 at 12:48 PM, David Gobbi <span dir="ltr">&lt;<a href="mailto:david.gobbi@gmail.com">david.gobbi@gmail.com</a>&gt;</span> wrote:<br>
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex;">In python it is possible to access the VTK data arrays directly via<br>
python&#39;s buffer interface, so that&#39;s what I use when I want to quickly<br>
move pixel data back and forth from python to VTK.  It allows me to<br>
use a VTK array (including the one that the image uses to store its<br>
pixels) as if it was a native python array.<br>
<br>
I have a feeling that the only way you will be able to rapidly do VTK<br>
pixel operations of any kind from Java, is if someone adds a similar<br>
feature to the Java wrappers.<br>
<font color="#888888"><br>
 - David<br>
</font><div><div></div><div class="h5"><br>
<br>
On Fri, Mar 25, 2011 at 1:31 PM, Jonathan Morra &lt;<a href="mailto:jonmorra@gmail.com">jonmorra@gmail.com</a>&gt; wrote:<br>
&gt; Your understanding is correct, however I cannot<br>
&gt; use GetScalarComponentAsDouble and SetScalarComponentAsDouble because they<br>
&gt; are way too slow in Java.  Do you have any other suggestions for how to do<br>
&gt; this or will I have to write it myself in C++?<br>
&gt;<br>
&gt; On Fri, Mar 25, 2011 at 12:29 PM, David Gobbi &lt;<a href="mailto:david.gobbi@gmail.com">david.gobbi@gmail.com</a>&gt; wrote:<br>
&gt;&gt;<br>
&gt;&gt; Hi Jonathan,<br>
&gt;&gt;<br>
&gt;&gt; If I understand correctly, you have several binary images with exactly<br>
&gt;&gt; the same dimensions.  And you want to collapse them into a single<br>
&gt;&gt; image, by storing a bitfield in the pixels of that image.  So:<br>
&gt;&gt;<br>
&gt;&gt; To set bit &quot;i&quot; in pixel &quot;xyz&quot; (C++ code):<br>
&gt;&gt; int a = int(image.GetScalarComponentAsDouble(x, y, z, 0));<br>
&gt;&gt; a |= (1 &lt;&lt; i);<br>
&gt;&gt; image.SetScalarComponentAsDouble(x, y, z, a);<br>
&gt;&gt;<br>
&gt;&gt; To clear bit &quot;i&quot; in pixel &quot;xyz&quot;:<br>
&gt;&gt; int a = int(image.GetScalarComponentAsDouble(x, y, z, 0));<br>
&gt;&gt; a &amp;= ~(1 &lt;&lt; i);<br>
&gt;&gt; image.SetScalarComponentAsDouble(x, y, z, a);<br>
&gt;&gt;<br>
&gt;&gt; To test bit &quot;i&quot; in pixel &quot;xyz&quot;:<br>
&gt;&gt; int a = int(image.GetScalarComponentAsDouble(x, y, z, 0));<br>
&gt;&gt; return ((a &gt;&gt; i) &amp; 1);<br>
&gt;&gt;<br>
&gt;&gt; But I&#39;m not sure if this is what you are trying to do.  I didn&#39;t fully<br>
&gt;&gt; understand your pseudocode.<br>
&gt;&gt;<br>
&gt;&gt;  - David<br>
&gt;&gt;<br>
&gt;&gt;<br>
&gt;&gt;<br>
&gt;&gt; On Fri, Mar 25, 2011 at 1:08 PM, Jonathan Morra &lt;<a href="mailto:jonmorra@gmail.com">jonmorra@gmail.com</a>&gt;<br>
&gt;&gt; wrote:<br>
&gt;&gt; &gt; I&#39;m in Java and storing a large number of binary vtkImageData&#39;s.  I know<br>
&gt;&gt; &gt; this is inefficient, and am searching for a better way to store them.<br>
&gt;&gt; &gt;  Right<br>
&gt;&gt; &gt; now I have a hash of the vtkImageData&#39;s and a get/put function.<br>
&gt;&gt; &gt;  Basically I<br>
&gt;&gt; &gt; want to mimic this get/put but with better storage.  I was thinking one<br>
&gt;&gt; &gt; way<br>
&gt;&gt; &gt; to do this is to use bitwise logical operations to store the information<br>
&gt;&gt; &gt; in<br>
&gt;&gt; &gt; the binary masks.  For instance, if we have 2 binary images, then we<br>
&gt;&gt; &gt; could<br>
&gt;&gt; &gt; store that information in 1 vtkImageData using the following pseudo<br>
&gt;&gt; &gt; code.<br>
&gt;&gt; &gt; private static final int IMAGE1_BIT_CHANNEL = 0;<br>
&gt;&gt; &gt; private static final int IMAGE2_BIT_CHANNEL = 1;<br>
&gt;&gt; &gt; private vtkImageData storedImage;<br>
&gt;&gt; &gt; vtkImageData get(String image)  {<br>
&gt;&gt; &gt;     int channel = image eq &quot;image1&quot; ? IMAGE1_BIT_CHANNEL :<br>
&gt;&gt; &gt; IMAGE2_BIT_CHANNEL;<br>
&gt;&gt; &gt;     vtkImageData return = new vtkImageData();<br>
&gt;&gt; &gt;     foreach (pixel in storedImage)<br>
&gt;&gt; &gt;         if (pixel at bit channel)<br>
&gt;&gt; &gt;             return[pixel] = 1;<br>
&gt;&gt; &gt;         else<br>
&gt;&gt; &gt;             return[pixel] = 0;<br>
&gt;&gt; &gt;     return return;<br>
&gt;&gt; &gt; }<br>
&gt;&gt; &gt; void put(String image, vtkImageData binaryImage) {<br>
&gt;&gt; &gt;     int channel = image eq &quot;image1&quot; ? IMAGE1_BIT_CHANNEL :<br>
&gt;&gt; &gt; IMAGE2_BIT_CHANNEL;<br>
&gt;&gt; &gt;     foreach (pixel in binaryImage)<br>
&gt;&gt; &gt;         if (pixel)<br>
&gt;&gt; &gt;             storedImage at bit in channel = 1;<br>
&gt;&gt; &gt;         else<br>
&gt;&gt; &gt;             storedImage at bit in channel = 0;<br>
&gt;&gt; &gt; }<br>
&gt;&gt; &gt; This could be extended easily for 8 channels for a char image for<br>
&gt;&gt; &gt; instance.<br>
&gt;&gt; &gt;  This operation would have to be very fast though cause it is done often<br>
&gt;&gt; &gt; on<br>
&gt;&gt; &gt; the UI thread.<br>
&gt;&gt; &gt; 1.  Is there a way to do this in VTK with Java?<br>
&gt;&gt; &gt; 2.  Is this the best scheme for accomplishing my goal?<br>
&gt;&gt; &gt; 3.  Is there a better scheme for doing this?<br>
&gt;&gt; &gt; Thanks.<br>
&gt;&gt; &gt; _______________________________________________<br>
&gt;&gt; &gt; Powered by <a href="http://www.kitware.com" target="_blank">www.kitware.com</a><br>
&gt;&gt; &gt;<br>
&gt;&gt; &gt; Visit other Kitware open-source projects at<br>
&gt;&gt; &gt; <a href="http://www.kitware.com/opensource/opensource.html" target="_blank">http://www.kitware.com/opensource/opensource.html</a><br>
&gt;&gt; &gt;<br>
&gt;&gt; &gt; Please keep messages on-topic and check the VTK FAQ at:<br>
&gt;&gt; &gt; <a href="http://www.vtk.org/Wiki/VTK_FAQ" target="_blank">http://www.vtk.org/Wiki/VTK_FAQ</a><br>
&gt;&gt; &gt;<br>
&gt;&gt; &gt; Follow this link to subscribe/unsubscribe:<br>
&gt;&gt; &gt; <a href="http://www.vtk.org/mailman/listinfo/vtkusers" target="_blank">http://www.vtk.org/mailman/listinfo/vtkusers</a><br>
&gt;&gt; &gt;<br>
&gt;&gt; &gt;<br>
&gt;<br>
&gt;<br>
</div></div></blockquote></div><br></div>