void object::test<7>() { std::string wkt0("LINESTRING (" "665.7317504882812500 133.0762634277343700," "1774.4752197265625000 19.9391822814941410," "756.2413940429687500 466.8306579589843700," "626.1337890625000000 1898.0147705078125000," "433.8007202148437500 404.6052856445312500)"); geom1_ = GEOSGeomFromWKT(wkt0.c_str()); ensure( 0 != geom1_ ); double width = 57.164000837203; // left-sided { geom2_ = GEOSOffsetCurve(geom1_, width, 8, GEOSBUF_JOIN_MITRE, 5.57); ensure( 0 != geom2_ ); // likely, 5 >= 5 ensure(GEOSGeomGetNumPoints(geom2_) >= GEOSGeomGetNumPoints(geom1_)); wkt_ = GEOSWKTWriter_write(wktw_, geom2_); //ensure_equals(std::string(wkt_), ...); } // right-sided { width = -width; geom2_ = GEOSOffsetCurve(geom1_, width, 8, GEOSBUF_JOIN_MITRE, 5.57); ensure( 0 != geom2_ ); // likely, 5 >= 7 ensure(GEOSGeomGetNumPoints(geom2_) >= GEOSGeomGetNumPoints(geom1_)); wkt_ = GEOSWKTWriter_write(wktw_, geom2_); //ensure_equals(std::string(wkt_), ...); } }
void object::test<1> () { std::string wkt0("LINESTRING(99739.70596 -2239218.0625,99739.85604 -2239218.21258,99739.85605 -2239218.21258, 99739.85605 -2239218.21258,99739.86851 -2239218.21258,99739.86851 -2239218.20012, 99739.86851 -2239218.20012,99739.86851 -2239218.04, 99739.95848 -2239218.11015,99739.86851 -2239218.20012, 99739.86851 -2239218.20012,99739.85605 -2239218.21258, 99739.85605 -2239218.21258,99739.80901 -2239218.25961, 99739.80901 -2239218.25961,99739.68863 -2239218.38, 99739.86204 -2239218.31264,99739.80901 -2239218.25961, 99739.80901 -2239218.25961,99739.66841 -2239218.11901)"); SegStrVct nodable; getSegmentStrings(wkt0, nodable); ensure_equals(nodable.size(), 1u); PrecisionModel pm(1e-5); MCIndexSnapRounder noder(pm); ensure_equals(nodable.size(), 1u); noder.computeNodes(&nodable); std::unique_ptr<SegStrVct> noded(noder.getNodedSubstrings()); ensure_equals("1e-5", noded->size(), 178u); freeSegmentStrings(*noded); freeSegmentStrings(nodable); }