<div dir="ltr">All,<div><br></div><div>It looks like rply just uses fprintf with %g (<a href="https://github.com/PDAL/PDAL/blob/master/vendor/rply-1.1.3/rply.c#L1303">https://github.com/PDAL/PDAL/blob/master/vendor/rply-1.1.3/rply.c#L1303</a>) when doing ascii output. Looks like we'd have to patch the vendored rply code to change that.</div><div><br></div><div>IMO ply's ascii output isn't very useful, as it's very space-inefficient. If folks need to print out point values as text they should probably use the text writer (which does provide a mechanism for specifying decimal precision, <a href="https://github.com/PDAL/PDAL/blob/master/io/text/TextWriter.cpp#L114">https://github.com/PDAL/PDAL/blob/master/io/text/TextWriter.cpp#L114</a>). <span style="line-height:1.5">Maybe we should remove the ascii option for the ply writer to avoid this problem in the future? Thoughts?</span></div><div><br></div><div>-Pete</div></div><br><div class="gmail_quote"><div dir="ltr">On Mon, Sep 28, 2015 at 10:38 AM <<a href="mailto:James.V.Greenlee.ctr@nga.mil">James.V.Greenlee.ctr@nga.mil</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">Classification: UNCLASSIFIED<br>
======================================================<br>
<br>
Hi Howard,<br>
<br>
I work with Dean.<br>
<br>
Actually, we're getting errors when reading the pdal produced ply files into Meshlab. This may not be a pdal problem, though, so I'm not going to detail that error. However, in trying to diagnose, we implimented the "ascii" instead of "little endian" storage mode (i.e., <Option name="storage_mode">ascii</Option>), so our pipeline is more like this:<br>
<br>
<?xml version="1.0" encoding="utf-8"?><br>
<Pipeline version="1.0"><br>
<Writer type="writers.ply"><br>
<Option name="filename">/mydir/outputfile.ply</Option><br>
<Option name="storage_mode">ascii</Option><br>
<Option name="spatialreference">EPSG:4326</Option><br>
<Reader type="readers.pgpointcloud"><br>
<Option name="connection">host='localhost' dbname='lidar' user='pramsey'</Option><br>
<Option name="table">pcgen</Option><br>
<Option name="column">pa</Option><br>
<Option name="where">PC_Intersects(pa, ST_MakeEnvelope(56.003736, 51.1484645, 56.266731, 51.1894324, 4326))</Option><br>
</Reader><br>
</Writer><br>
</Pipeline><br>
<br>
When we import an LAS file into QT Modeler that was created by using writers.las instead of writers.ply in the above pipeline (with some scaling options), the point cloud data looks fine, so we know that the point cloud database has the necessary level of precision. But, when we use the writers.ply (with ascii storage_mode), the output ply file has only 4 digits of precision following the decimal point as follows:<br>
<br>
ply<br>
format ascii 1.0<br>
element vertex 12345<br>
property float64 X<br>
property float64 Y<br>
property float64 Z<br>
property uint16 Intensity<br>
...<br>
end_header<br>
56.0037 51.1484 12.123 25 ...<br>
56.0037 51.1484 13.423 28 ...<br>
56.0037 51.1485 15.153 40 ...<br>
56.0038 51.1485 33.126 37 ...<br>
56.0038 51.1485 12.723 125 ...<br>
56.0038 51.1486 12.183 115 ...<br>
<br>
By the way, we also have a simialr problem when trying to output a CSV file using writers.text except in that case there are only 3 digits of precision following the decimal, so output is like:<br>
<br>
"X","Y","Z","Intensity",...<br>
56.004,51.148,12.123,25.000,...<br>
56.004,51.148,13.423,28.000,...<br>
56.004,51.149,15.153,40.000,...<br>
56.004,51.149,33.126,37.000,...<br>
56.004,51.149,12.723,125.00,...<br>
56.004,51.149,12.183,115.00,...<br>
<br>
We need at least 6 digits of precision for the X and Y values in both of these scenarios (yielding 0.1 meter resolution for EPSG 4326 values), but having an option to define the precision for the various columns would be optimal.<br>
<br>
-Jim<br>
<br>
-----Original Message-----<br>
From: Hand Dean NGA-II USA CTR<br>
Sent: Friday, September 25, 2015 3:02 PM<br>
To: Greenlee James -Jim- V NGA-IIG USA CTR<br>
Subject: FW: [pgpointcloud] ply and laz<br>
<br>
Classification: UNCLASSIFIED<br>
======================================================<br>
<br>
<br>
<br>
-----Original Message-----<br>
From: Hand Dean NGA-II USA CTR<br>
Sent: Friday, September 25, 2015 2:29 PM<br>
To: 'Howard Butler'<br>
Cc: <a href="mailto:pgpointcloud@lists.osgeo.org" target="_blank">pgpointcloud@lists.osgeo.org</a><mailto:<a href="mailto:pgpointcloud@lists.osgeo.org" target="_blank">pgpointcloud@lists.osgeo.org</a>>; pdal<br>
Subject: RE: [pgpointcloud] ply and laz<br>
<br>
Classification: UNCLASSIFIED<br>
======================================================<br>
<br>
We are using PDAL. There is a writers.ply, but did doesn't say what readers it will support. We are using something similar to this xml:<br>
<br>
<?xml version="1.0" encoding="utf-8"?><br>
<Pipeline version="1.0"><Pipeline version="1.0"><br>
<Writer type="writers.ply"><br>
<Option name="filename">outputfile.ply</Option><br>
<Option name="storage_mode">little endian</Option><br>
<Reader type="readers.pgpointcloud"><br>
<Option name="connection">dbname='lidar' user='user'</Option><br>
<Option name="table">lidar</Option><br>
<Option name="column">pa</Option><br>
<Option name="spatialreference">EPSG:26910</Option><br>
<Option name="where"><br>
PC_Intersects(pa, ST_MakeEnvelope(560037.36, 5114846.45, 562667.31, 5118943.24, 26910))<br>
</Option><br>
</Reader><br>
</Writer><br>
</Pipeline><br>
<br>
-----Original Message-----<br>
From: Howard Butler [mailto:<a href="mailto:howard@hobu.co" target="_blank">howard@hobu.co</a>]<br>
Sent: Friday, September 25, 2015 2:21 PM<br>
To: Hand Dean NGA-II USA CTR<br>
Cc: <a href="mailto:pgpointcloud@lists.osgeo.org" target="_blank">pgpointcloud@lists.osgeo.org</a><mailto:<a href="mailto:pgpointcloud@lists.osgeo.org" target="_blank">pgpointcloud@lists.osgeo.org</a>>; pdal<br>
Subject: Re: [pgpointcloud] ply and laz<br>
<br>
<br>
> On Sep 25, 2015, at 2:04 PM, <a href="mailto:Dean.Hand.ctr@nga.mil" target="_blank">Dean.Hand.ctr@nga.mil</a><mailto:<a href="mailto:Dean.Hand.ctr@nga.mil" target="_blank">Dean.Hand.ctr@nga.mil</a>> wrote:<br>
><br>
> Classification: UNCLASSIFIED<br>
> ======================================================<br>
><br>
> Hi Howard,<br>
><br>
> When trying to pgpointcloud to write as either a ply we're experiencing an issue. For ply files, the x and y coordinates are only 3 digits in length. I don't see anything in our docs to explain this...<br>
><br>
> Can you please help?<br>
<br>
I don't think pgpointcloud supports writing natively as ply? Are you using PDAL?<br>
<br>
If so:<br>
<br>
* What do you mean by "digits"? Do you mean digits after the decimal point?<br>
* What was original source data format before it went into pgpointcloud? LAS<br>
* It is possible that the PDAL ply driver could be modified to support overriding the output precision, but some investigation would need to be done into the rply code that PDAL uses to read/write PLY. Quickly looking at the PDAL source. this feature doesn't appear to exist yet.<br>
<br>
Howard<br>
<br>
<br>
======================================================<br>
Classification: UNCLASSIFIED<br>
<br>
======================================================<br>
Classification: UNCLASSIFIED<br>
<br>
======================================================<br>
Classification: UNCLASSIFIED<br>
<br>
<br>
_______________________________________________<br>
pdal mailing list<br>
<a href="mailto:pdal@lists.osgeo.org" target="_blank">pdal@lists.osgeo.org</a><br>
<a href="http://lists.osgeo.org/mailman/listinfo/pdal" rel="noreferrer" target="_blank">http://lists.osgeo.org/mailman/listinfo/pdal</a><br>
</blockquote></div><div dir="ltr">-- <br></div><div dir="ltr">Pete Gadomski<div>Physical Scientist</div><div>Cold Regions Research and Engineering Laboratory</div><div><span id="gc-number-14" class="gc-cs-link" title="Call with Google Voice">530.440.4630</span></div><div><a href="mailto:pete.gadomski@gmail.com">pete.gadomski@gmail.com</a></div></div>