<div dir="ltr">Yes, this would tie in nicely with a precision model implementation.<div>So one question is whether to merge this in now as a utility function <span style="color:rgb(34,34,34);font-family:arial,sans-serif;font-size:small;font-style:normal;font-variant-ligatures:normal;font-variant-caps:normal;font-weight:400;letter-spacing:normal;text-align:start;text-indent:0px;text-transform:none;white-space:normal;word-spacing:0px;background-color:rgb(255,255,255);text-decoration-style:initial;text-decoration-color:initial;float:none;display:inline">(after tidying/documentation)</span>, or to wait and do it coherently as part of a precision implementation.</div><div><br></div><div>I think it makes sense to store precision at the geometry level. By default, any geometry would use full double precision unless it's explicitly lowered with a function call. So most users would never notice. Any overlay operation could then produce a result at the lowest precision of its inputs, and we wouldn't have to clutter the function signatures with an op_precision parameter like I did in my 2016? implementation.</div><div><br></div><div>We have one extra bit in the SRID, no? (There are 21 bits set aside for SRID, but 2^20 > SRID_MAXIMUM). So we could combine this extra bit with the 3 spare bits after the SRID and represent all meaningful values of precision (1-15).</div><div>Or we could store precision only in the 3 bits after the SRID, and not allow all values of precision (there's little value in 1, 2, 3, 4, 12, 13, and 14 in my opinion). We could also steal a bit from the flags ("readonly" does not appear to be used).</div><div><br></div><div>This all assumes that we want an implementation of precision based around significant digits. That's convenient for this use case, but I'd guess many users expect precision in the sense of grid spacing, as is used (I think) with the topology functions.</div><div><br></div><div>Dan</div><div class="gmail_extra"><br><div class="gmail_quote">On Fri, Feb 16, 2018 at 9:46 AM, Paul Ramsey <span dir="ltr"><<a href="mailto:pramsey@cleverelephant.ca" target="_blank">pramsey@cleverelephant.ca</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">That's quite diabolical, and a nice freebie... and it brings us right<br>
back to discussions of precision models.<br>
Are they global, by table, by function call?<br>
Smaller objects will make for faster access, so it's a win, I think we<br>
should bring it in.<br>
Incidentally, I've been doing some point-in-polygon benchmarking, and<br>
the amount of time we spend just decompressing a toasted tuple in a<br>
p-i-p calculation with a large polygon can be 95% of the CPU. Over and<br>
over and over. Decompress it, check to see if it matches what's<br>
cached, repeat.<br>
For that use case, using "external" storage with a uncompressed header<br>
and compressed payload would be a big win. Small is good.<br>
P<br>
<div><div class="m_-7027232148705029415m_6065404151622378863m_-6357238201067873000h5"><br>
<br>
<br>
On Fri, Feb 16, 2018 at 6:38 AM, Daniel Baston <<a href="mailto:dbaston@gmail.com" target="_blank">dbaston@gmail.com</a>> wrote:<br>
> Hi,<br>
><br>
> I've been experimenting with a cool technique to reduce the size of PostGIS<br>
> geometries by setting insignificant bits to zero, which makes the geometry<br>
> objects more compressible.<br>
><br>
> I described the technique in a post here, which shows some test results:<br>
> <a href="http://www.danbaston.com/posts/2018/02/15/optimizing-postgis-geometries.html" rel="noreferrer" target="_blank">http://www.danbaston.com/posts<wbr>/2018/02/15/optimizing-postgis<wbr>-geometries.html</a><br>
><br>
> I'm on the fence about whether something like this has a place in the<br>
> PostGIS core, but am leaning towards "yes." What do others think?<br>
><br>
> Dan<br>
><br>
><br>
</div></div>> ______________________________<wbr>_________________<br>
> postgis-devel mailing list<br>
> <a href="mailto:postgis-devel@lists.osgeo.org" target="_blank">postgis-devel@lists.osgeo.org</a><br>
> <a href="https://lists.osgeo.org/mailman/listinfo/postgis-devel" rel="noreferrer" target="_blank">https://lists.osgeo.org/mailma<wbr>n/listinfo/postgis-devel</a><br>
______________________________<wbr>_________________<br>
postgis-devel mailing list<br>
<a href="mailto:postgis-devel@lists.osgeo.org" target="_blank">postgis-devel@lists.osgeo.org</a><br>
<a href="https://lists.osgeo.org/mailman/listinfo/postgis-devel" rel="noreferrer" target="_blank">https://lists.osgeo.org/mailma<wbr>n/listinfo/postgis-devel</a></blockquote></div><br></div></div>