Hi,<br><br>If you&#39;re using VTK master to create your VTR files you can use the SetHeaderTypeToUInt64() method to write out these large data sets. ParaView master will be able to read them in properly. Unfortunately though this has been fixed since the 3.14.1 release so it won&#39;t work there. We&#39;re working on fixing this limitation properly for the next ParaView release.<br>
<br>Andy<br><br><div class="gmail_quote">On Wed, Jul 25, 2012 at 3:47 AM, Paul McIntosh <span dir="ltr">&lt;<a href="mailto:paul.mcintosh@internetscooter.com" target="_blank">paul.mcintosh@internetscooter.com</a>&gt;</span> wrote:<br>
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">Hi All,<br>
<br>
How does one go about writing large rectilinear data files (vtr) that are<br>
suitable for reading by ParaView?<br>
<br>
I have been trying using VTK and found that there is a size limit(?).<br>
Googling showed that there was a bug in 2005 that should have been fixed but<br>
I am still getting an error when I go above a certain size (even with 3.14<br>
64bit precompiled). I have adapted a VTK example and reproduced the problem<br>
- below is the error message followed by the code. &quot;size = 1000&quot; works,<br>
&quot;size = 1200&quot; produced the error message, &quot;size = 2000&quot; ParaView just<br>
segfaults.<br>
<br>
Do I have to change it to use parallel writers?<br>
<br>
Cheers,<br>
<br>
Paul<br>
---<br>
<a href="http://www.internetscooter.com" target="_blank">www.internetscooter.com</a><br>
<br>
ERROR: In<br>
/usr/local/src/PARAVIEW/3.14.0/ParaView-3.14.0-Source/VTK/IO/vtkXMLStructure<br>
dDataReader.cxx, line 325<br>
vtkXMLRectilinearGridReader (0x1b2b54b0): Error reading extent 0 1199 0 1199<br>
0 1199 from piece 0<br>
<br>
<br>
ERROR: In<br>
/usr/local/src/PARAVIEW/3.14.0/ParaView-3.14.0-Source/VTK/IO/vtkXMLDataReade<br>
r.cxx, line 510<br>
vtkXMLRectilinearGridReader (0x1b2b54b0): Cannot read point data array &quot;Da&quot;<br>
from PointData in piece 0.  The data array in the element may be too short.<br>
<br>
<br>
ERROR: In<br>
/usr/local/src/PARAVIEW/3.14.0/ParaView-3.14.0-Source/VTK/IO/vtkXMLStructure<br>
dDataReader.cxx, line 325<br>
vtkXMLRectilinearGridReader (0x1b2b54b0): Error reading extent 0 1199 0 1199<br>
0 1199 from piece 0<br>
<br>
<br>
ERROR: In<br>
/usr/local/src/PARAVIEW/3.14.0/ParaView-3.14.0-Source/VTK/IO/vtkXMLDataReade<br>
r.cxx, line 510<br>
vtkXMLRectilinearGridReader (0x1b2b54b0): Cannot read point data array &quot;Da&quot;<br>
from PointData in piece 0.  The data array in the element may be too short.<br>
<br>
<br>
ERROR: In<br>
/usr/local/src/PARAVIEW/3.14.0/ParaView-3.14.0-Source/VTK/IO/vtkXMLStructure<br>
dDataReader.cxx, line 325<br>
vtkXMLRectilinearGridReader (0x1b2b54b0): Error reading extent 0 1199 0 1199<br>
0 1199 from piece 0<br>
<br>
<br>
ERROR: In<br>
/usr/local/src/PARAVIEW/3.14.0/ParaView-3.14.0-Source/VTK/IO/vtkXMLDataReade<br>
r.cxx, line 510<br>
vtkXMLRectilinearGridReader (0x1b2b54b0): Cannot read point data array &quot;Da&quot;<br>
from PointData in piece 0.  The data array in the element may be too short.<br>
<br>
<br>
ERROR: In<br>
/usr/local/src/PARAVIEW/3.14.0/ParaView-3.14.0-Source/VTK/IO/vtkXMLStructure<br>
dDataReader.cxx, line 325<br>
vtkXMLRectilinearGridReader (0x1b2b54b0): Error reading extent 0 1199 0 1199<br>
0 1199 from piece 0<br>
<br>
<br>
ERROR: In<br>
/usr/local/src/PARAVIEW/3.14.0/ParaView-3.14.0-Source/VTK/IO/vtkXMLDataReade<br>
r.cxx, line 510<br>
vtkXMLRectilinearGridReader (0x1b2b54b0): Cannot read point data array &quot;Da&quot;<br>
from PointData in piece 0.  The data array in the element may be too short.<br>
<br>
// Qt (used for other code - not relevant here)<br>
#include &lt;QCoreApplication&gt;<br>
#include &lt;QtEndian&gt;<br>
#include &lt;QDebug&gt;<br>
#include &lt;QStringList&gt;<br>
<br>
// C++<br>
#include &lt;list&gt;<br>
#include &lt;iostream&gt;<br>
#include &lt;fstream&gt;<br>
using namespace std;<br>
<br>
// VTK<br>
#include &lt;vtkVersion.h&gt;<br>
#include &lt;vtkSmartPointer.h&gt;<br>
#include &lt;vtkDoubleArray.h&gt;<br>
#include &lt;vtkFloatArray.h&gt;<br>
#include &lt;vtkPointData.h&gt;<br>
#include &lt;vtkCellData.h&gt;<br>
#include &lt;vtkStructuredGrid.h&gt;<br>
#include &lt;vtkRectilinearGrid.h&gt;<br>
#include &lt;vtkXMLRectilinearGridWriter.h&gt;<br>
#include &lt;vtkDataSetMapper.h&gt;<br>
#include &lt;vtkXMLStructuredGridWriter.h&gt;<br>
#include &lt;vtkXMLRectilinearGridReader.h&gt;<br>
#include &lt;vtkSmartPointer.h&gt;<br>
#include &lt;vtkProperty.h&gt;<br>
#include &lt;vtkDataSetMapper.h&gt;<br>
#include &lt;vtkXMLRectilinearGridReader.h&gt;<br>
#include &lt;vtkRectilinearGridGeometryFilter.h&gt;<br>
#include &lt;vtkRenderWindow.h&gt;<br>
#include &lt;vtkRenderWindowInteractor.h&gt;<br>
#include &lt;vtkRenderer.h&gt;<br>
<br>
#include &lt;vtkDataSetMapper.h&gt;<br>
#include &lt;vtkActor.h&gt;<br>
#include &lt;vtkRenderWindow.h&gt;<br>
#include &lt;vtkRenderer.h&gt;<br>
#include &lt;vtkRenderWindowInteractor.h&gt;<br>
<br>
<br>
int main(int, char *[])<br>
{<br>
  long int size = 1200;<br>
  // Create a grid<br>
  vtkSmartPointer&lt;vtkRectilinearGrid&gt; grid =<br>
vtkSmartPointer&lt;vtkRectilinearGrid&gt;::New();<br>
<br>
  grid-&gt;SetDimensions(size,size,size);<br>
<br>
  vtkSmartPointer&lt;vtkDoubleArray&gt; xArray =<br>
vtkSmartPointer&lt;vtkDoubleArray&gt;::New();<br>
  xArray-&gt;SetNumberOfComponents(1);<br>
  vtkSmartPointer&lt;vtkDoubleArray&gt; yArray =<br>
vtkSmartPointer&lt;vtkDoubleArray&gt;::New();<br>
  yArray-&gt;SetNumberOfComponents(1);<br>
  vtkSmartPointer&lt;vtkDoubleArray&gt; zArray =<br>
vtkSmartPointer&lt;vtkDoubleArray&gt;::New();<br>
  zArray-&gt;SetNumberOfComponents(1);<br>
<br>
  // Container for data<br>
  vtkSmartPointer&lt;vtkFloatArray&gt; DaArray =<br>
vtkSmartPointer&lt;vtkFloatArray&gt;::New();<br>
  DaArray-&gt;SetNumberOfComponents(1);<br>
  DaArray-&gt;SetName(&quot;Da&quot;);<br>
<br>
  for (long int i = 0; i &lt; size; i++)<br>
  {<br>
      xArray-&gt;InsertNextValue(i);<br>
      yArray-&gt;InsertNextValue(i);<br>
      zArray-&gt;InsertNextValue(i);<br>
  }<br>
<br>
  grid-&gt;SetXCoordinates(xArray);<br>
  grid-&gt;SetYCoordinates(yArray);<br>
  grid-&gt;SetZCoordinates(zArray);<br>
<br>
  for (long int i = 0; i &lt; size*size*size; i++)<br>
  {<br>
        DaArray-&gt;InsertNextValue(i);<br>
  }<br>
  grid-&gt;GetPointData()-&gt;SetScalars(DaArray);<br>
<br>
  std::cout &lt;&lt; &quot;There are &quot; &lt;&lt; grid-&gt;GetNumberOfPoints()<br>
            &lt;&lt; &quot; points.&quot; &lt;&lt; std::endl;<br>
  std::cout &lt;&lt; &quot;There are &quot; &lt;&lt; grid-&gt;GetNumberOfCells()<br>
            &lt;&lt; &quot; cells.&quot; &lt;&lt; std::endl;<br>
<br>
  vtkSmartPointer&lt;vtkXMLRectilinearGridWriter&gt; writer =<br>
vtkSmartPointer&lt;vtkXMLRectilinearGridWriter&gt;::New();<br>
  //writer-&gt;SetFileName(&quot;rectilineargrid.vtr&quot;);<br>
  writer-&gt;SetFileName(&quot;test.vtr&quot;);<br>
  writer-&gt;SetInputConnection(grid-&gt;GetProducerPort());<br>
  cout &lt;&lt; &quot;Writing &quot; &lt;&lt; &quot;test.vtr&quot; &lt;&lt; &quot;...&quot; &lt;&lt; endl;<br>
  writer-&gt;Write();<br>
  cout &lt;&lt; &quot;Wrote!&quot; &lt;&lt; endl;<br>
<br>
  // Create a mapper and actor<br>
  vtkSmartPointer&lt;vtkDataSetMapper&gt; mapper =<br>
vtkSmartPointer&lt;vtkDataSetMapper&gt;::New();<br>
  mapper-&gt;SetInputConnection(grid-&gt;GetProducerPort());<br>
<br>
  vtkSmartPointer&lt;vtkActor&gt; actor = vtkSmartPointer&lt;vtkActor&gt;::New();<br>
  actor-&gt;SetMapper(mapper);<br>
<br>
  // Visualize<br>
  vtkSmartPointer&lt;vtkRenderer&gt; renderer =<br>
vtkSmartPointer&lt;vtkRenderer&gt;::New();<br>
  vtkSmartPointer&lt;vtkRenderWindow&gt; renderWindow =<br>
vtkSmartPointer&lt;vtkRenderWindow&gt;::New();<br>
  renderWindow-&gt;AddRenderer(renderer);<br>
  vtkSmartPointer&lt;vtkRenderWindowInteractor&gt; renderWindowInteractor =<br>
vtkSmartPointer&lt;vtkRenderWindowInteractor&gt;::New();<br>
  renderWindowInteractor-&gt;SetRenderWindow(renderWindow);<br>
<br>
  renderer-&gt;AddActor(actor);<br>
  renderer-&gt;SetBackground(.3, .6, .3); // Background color green<br>
<br>
  renderWindow-&gt;Render();<br>
  renderWindowInteractor-&gt;Start();<br>
<br>
  return EXIT_SUCCESS;<br>
}<br>
<br>
_______________________________________________<br>
Powered by <a href="http://www.kitware.com" target="_blank">www.kitware.com</a><br>
<br>
Visit other Kitware open-source projects at <a href="http://www.kitware.com/opensource/opensource.html" target="_blank">http://www.kitware.com/opensource/opensource.html</a><br>
<br>
Please keep messages on-topic and check the ParaView Wiki at: <a href="http://paraview.org/Wiki/ParaView" target="_blank">http://paraview.org/Wiki/ParaView</a><br>
<br>
Follow this link to subscribe/unsubscribe:<br>
<a href="http://www.paraview.org/mailman/listinfo/paraview" target="_blank">http://www.paraview.org/mailman/listinfo/paraview</a><br>
</blockquote></div><br>