diff --git a/README.md b/README.md
index bb592d7..8f6f949 100644
--- a/README.md
+++ b/README.md
@@ -58,7 +58,7 @@ Options
* -f: Delete the mbtiles file if it already exists instead of giving an error
* -r rate: Rate at which dots are dropped at lower zoom levels (default 2.5)
* -b pixels: Buffer size where features are duplicated from adjacent tiles (default 5)
- * -g gamma: Rate at which especially dense dots are dropped (default 1, for no effect). A gamma of 2 reduces the number of dots less than a pixel apart to the square root of their original number.
+ * -g gamma: Rate at which especially dense dots are dropped (default 0, for no effect). A gamma of 2 reduces the number of dots less than a pixel apart to the square root of their original number.
Example
-------
diff --git a/geojson.c b/geojson.c
index e17912a..cb21d17 100644
--- a/geojson.c
+++ b/geojson.c
@@ -901,7 +901,7 @@ int main(int argc, char **argv) {
int minzoom = 0;
int force = 0;
double droprate = 2.5;
- double gamma = 1;
+ double gamma = 0;
int buffer = 5;
const char *tmpdir = "/tmp";
diff --git a/tile.cc b/tile.cc
index 48abeca..fb9ec65 100644
--- a/tile.cc
+++ b/tile.cc
@@ -489,11 +489,11 @@ long long write_tile(char **geoms, char *metabase, unsigned *file_bbox, int z, u
continue;
}
- if (t == VT_POINT && z < feature_minzoom && gamma == 0) {
+ if (t == VT_POINT && z < feature_minzoom && gamma < 0) {
continue;
}
- if (t == VT_POINT && gamma != 0) {
+ if (t == VT_POINT && gamma >= 0) {
seq++;
if (seq >= 0) {
seq -= interval;
@@ -501,32 +501,34 @@ long long write_tile(char **geoms, char *metabase, unsigned *file_bbox, int z, u
continue;
}
- unsigned long long index = encode(bbox[0] / 2 + bbox[2] / 2, bbox[1] / 2 + bbox[3] / 2);
- if (gap > 0) {
- if (index == previndex) {
- continue; // Exact duplicate: can't fulfil the gap requirement
+ if (gamma > 0) {
+ unsigned long long index = encode(bbox[0] / 2 + bbox[2] / 2, bbox[1] / 2 + bbox[3] / 2);
+ if (gap > 0) {
+ if (index == previndex) {
+ continue; // Exact duplicate: can't fulfil the gap requirement
+ }
+
+ if (exp(log((index - previndex) / scale) * gamma) >= gap) {
+ // Dot is further from the previous than the nth root of the gap,
+ // so produce it, and choose a new gap at the next point.
+ gap = 0;
+ } else {
+ continue;
+ }
+ } else {
+ gap = (index - previndex) / scale;
+
+ if (gap == 0) {
+ continue; // Exact duplicate: skip
+ } else if (gap < 1) {
+ continue; // Narrow dot spacing: need to stretch out
+ } else {
+ gap = 0; // Wider spacing than minimum: so pass through unchanged
+ }
}
- if (exp(log((index - previndex) / scale) * gamma) >= gap) {
- // Dot is further from the previous than the nth root of the gap,
- // so produce it, and choose a new gap at the next point.
- gap = 0;
- } else {
- continue;
- }
- } else {
- gap = (index - previndex) / scale;
-
- if (gap == 0) {
- continue; // Exact duplicate: skip
- } else if (gap < 1) {
- continue; // Narrow dot spacing: need to stretch out
- } else {
- gap = 0; // Wider spacing than minimum: so pass through unchanged
- }
+ previndex = index;
}
-
- previndex = index;
}
bool reduced = false;