• Stars
    star
    1,655
  • Rank 28,254 (Top 0.6 %)
  • Language
    Go
  • License
    Apache License 2.0
  • Created almost 10 years ago
  • Updated over 1 year ago

Reviews

There are no reviews yet. Be the first to send feedback to the community and the maintainers!

Repository Details

S2 geometry library in Go

Overview

S2 is a library for spherical geometry that aims to have the same robustness, flexibility, and performance as the best planar geometry libraries.

This is a library for manipulating geometric shapes. Unlike many geometry libraries, S2 is primarily designed to work with spherical geometry, i.e., shapes drawn on a sphere rather than on a planar 2D map. (In fact, the name S2 is derived from the mathematical notation for the unit sphere SΒ².) This makes it especially suitable for working with geographic data.

More details about S2 in general are available on the S2 Geometry Website s2geometry.io.

Scope

The library provides the following:

  • Representations of angles, intervals, latitude-longitude points, unit vectors, and so on, and various operations on these types.

  • Geometric shapes over the unit sphere, such as spherical caps ("discs"), latitude-longitude rectangles, polylines, and polygons. These are collectively known as "regions".

  • A hierarchical decomposition of the sphere into regions called "cells". The hierarchy starts with the six faces of a projected cube and recursively subdivides them in a quadtree-like fashion.

  • Robust constructive operations (e.g., union) and boolean predicates (e.g., containment) for arbitrary collections of points, polylines, and polygons.

  • Fast in-memory indexing of collections of points, polylines, and polygons.

  • Algorithms for measuring distances and finding nearby objects.

  • Robust algorithms for snapping and simplifying geometry (with accuracy and topology guarantees).

  • A collection of efficient yet exact mathematical predicates for testing relationships among geometric objects.

  • Support for spatial indexing, including the ability to approximate regions as collections of discrete "S2 cells". This feature makes it easy to build large distributed spatial indexes.

On the other hand, the following are outside the scope of S2:

  • Planar geometry.

  • Conversions to/from common GIS formats.

Robustness

What do we mean by "robust"?

In the S2 library, the core operations are designed to be 100% robust. This means that each operation makes strict mathematical guarantees about its output, and is implemented in such a way that it meets those guarantees for all possible valid inputs. For example, if you compute the intersection of two polygons, not only is the output guaranteed to be topologically correct (up to the creation of degeneracies), but it is also guaranteed that the boundary of the output stays within a user-specified tolerance of true, mathematically exact result.

Robustness is very important when building higher-level algorithms, since unexpected results from low-level operations can be very difficult to handle. S2 achieves this goal using a combination of techniques from computational geometry, including conservative error bounds, exact geometric predicates, and snap rounding.

The implementation attempts to be precise both in terms of mathematical definitions (e.g. whether regions include their boundaries, and how degeneracies are handled) and numerical accuracy (e.g. minimizing cancellation error).

Note that the intent of this library is to represent geometry as a mathematical abstraction. For example, although the unit sphere is obviously a useful approximation for the Earth's surface, functions that are specifically related to geography are not part of the core library (e.g. easting/northing conversions, ellipsoid approximations, geodetic vs. geocentric coordinates, etc).

See http://godoc.org/github.com/golang/geo for specific package documentation.

For an analogous library in C++, see https://github.com/google/s2geometry, in Java, see https://github.com/google/s2-geometry-library-java, and Python, see https://github.com/google/s2geometry/tree/master/src/python

Status of the Go Library

This library is principally a port of the C++ S2 library, adapting to Go idioms where it makes sense. We detail the progress of this port below relative to that C++ library.

Legend:

  • βœ… - Feature Complete
  • 🟑 - Mostly Complete
  • ❌ - Not available

ℝ¹ - One-dimensional Cartesian coordinates

C++ Type Go
R1Interval βœ…

ℝ² - Two-dimensional Cartesian coordinates

C++ Type Go
R2Point βœ…
R2Rect βœ…

ℝ³ - Three-dimensional Cartesian coordinates

C++ Type Go
R3Vector βœ…
R3ExactVector βœ…
Matrix3x3 βœ…

SΒΉ - Circular Geometry

C++ Type Go
S1Angle βœ…
S1ChordAngle βœ…
S1Interval βœ…

SΒ² - Spherical Geometry

Basic Types

C++ Type Go
S2Cap βœ…
S2Cell βœ…
S2CellId βœ…
S2CellIdVector ❌
S2CellIndex 🟑
S2CellUnion βœ…
S2Coords βœ…
S2DensityTree ❌
S2DistanceTarget βœ…
S2EdgeVector βœ…
S2LatLng βœ…
S2LatLngRect βœ…
S2LaxLoop 🟑
S2LaxPolygon 🟑
S2LaxPolyline 🟑
S2Loop βœ…
S2PaddedCell βœ…
S2Point βœ…
S2PointIndex ❌
S2PointSpan ❌
S2PointRegion ❌
S2PointVector βœ…
S2Polygon 🟑
S2Polyline βœ…
S2R2Rect ❌
S2Region βœ…
S2RegionCoverer βœ…
S2RegionIntersection ❌
S2RegionUnion βœ…
S2Shape βœ…
S2ShapeIndex βœ…
S2ShapeIndexRegion ❌
EncodedLaxPolygon ❌
EncodedLaxPolyline ❌
EncodedShapeIndex ❌
EncodedStringVector ❌
EncodedUintVector ❌
IdSetLexicon ❌
ValueSetLexicon ❌
SequenceLexicon ❌
LaxClosedPolyline ❌
VertexIDLaxLoop ❌

Query Types

C++ Type Go
S2ChainInterpolation ❌
S2ClosestCell ❌
S2FurthestCell ❌
S2ClosestEdge βœ…
S2FurthestEdge βœ…
S2ClosestPoint ❌
S2FurthestPoint ❌
S2ContainsPoint βœ…
S2ContainsVertex βœ…
S2ConvexHull βœ…
S2CrossingEdge βœ…
S2HausdorffDistance ❌
S2ShapeNesting ❌

Supporting Types

C++ Type Go
S2BooleanOperation ❌
S2BufferOperation ❌
S2Builder ❌
S2BuilderClosedSetNormalizer ❌
S2BuilderFindPolygonDegeneracies ❌
S2BuilderGraph ❌
S2BuilderLayers ❌
S2BuilderSnapFunctions ❌
S2BuilderTesting ❌
S2Builderutil* ❌
S2Coder ❌
S2EdgeClipping βœ…
S2EdgeCrosser βœ…
S2EdgeCrossings βœ…
S2EdgeDistances βœ…
S2EdgeTessellator βœ…
S2LoopMeasures ❌
S2Measures βœ…
S2MemoryTracker ❌
S2Metrics ❌
S2PointUtil 🟑
S2PolygonBuilder ❌
S2PolylineAlignment ❌
S2PolylineMeasures βœ…
S2PolylineSimplifier ❌
S2Predicates βœ…
S2Projections ❌
S2rectBounder ❌
S2RegionTermIndexer ❌
S2ShapeIndexMeasures ❌
S2ShapeIndexUtil* 🟑
S2ShapeMeasures ❌
S2ShapeUtil* 🟑
S2Stats ❌
S2Testing βœ…
S2TextFormat βœ…
S2WedgeRelations βœ…
S2WindingOperation ❌

Encode/Decode

Encoding and decoding of S2 types is fully implemented and interoperable with C++ and Java.

More Repositories

1

go

The Go programming language
Go
121,832
star
2

groupcache

groupcache is a caching and cache-filling library, intended as a replacement for memcached in many cases.
Go
12,859
star
3

dep

Go dependency management tool experiment (deprecated)
Go
12,857
star
4

protobuf

Go support for Google's protocol buffers
Go
9,676
star
5

mock

GoMock is a mocking framework for the Go programming language.
Go
9,286
star
6

tools

[mirror] Go Tools
Go
7,321
star
7

mobile

[mirror] Go on Mobile
Go
5,768
star
8

oauth2

Go OAuth2
Go
5,270
star
9

lint

[mirror] This is a linter for Go source code. (deprecated)
Go
3,974
star
10

vscode-go

Go extension for Visual Studio Code
TypeScript
3,810
star
11

glog

Leveled execution logs for Go
Go
3,520
star
12

proposal

Go Project Design Documents
Go
3,312
star
13

crypto

[mirror] Go supplementary cryptography libraries
Go
2,982
star
14

net

[mirror] Go supplementary network libraries
Go
2,846
star
15

example

Go example projects
Go
2,526
star
16

tour

[mirror] A Tour of Go
Go
1,543
star
17

vgo

[mirror] Versioned Go Prototype
Go
1,519
star
18

snappy

The Snappy compression format in the Go programming language.
Go
1,512
star
19

sys

[mirror] Go packages for low-level interaction with the operating system
Go
1,253
star
20

pkgsite

[mirror] Home of the pkg.go.dev website
Go
1,148
star
21

leveldb

The LevelDB key-value database in the Go programming language.
Go
1,145
star
22

gddo

Go Doc Dot Org
Go
1,104
star
23

gofrontend

Go compiler frontend (gccgo)
Go
852
star
24

sync

[mirror] concurrency primitives
Go
848
star
25

exp

[mirror] Experimental and deprecated packages
Go
838
star
26

freetype

The Freetype font rasterizer in the Go programming language.
Go
783
star
27

text

[mirror] Go text processing support
Go
745
star
28

playground

[mirror] The Go Playground
Go
741
star
29

talks

Go talks
694
star
30

appengine

Go App Engine packages
Go
669
star
31

build

[mirror] Go's continuous build and release infrastructure (no stability promises)
Go
627
star
32

vulndb

[mirror] The Go Vulnerability Database
Go
555
star
33

image

[mirror] Go supplementary image libraries
Go
522
star
34

blog

[mirror] Go Blog (obsolete)
389
star
35

time

[mirror] Go supplementary time packages
Go
383
star
36

vuln

[mirror] the database client and tools for the Go vulnerability database
Go
376
star
37

perf

[mirror] Performance measurement, storage, and analysis.
Go
375
star
38

website

[mirror] Home of the go.dev and golang.org websites
HTML
373
star
39

sublime-build

The official Sublime Text package for Go build system integration.
Python
343
star
40

xerrors

Go
277
star
41

term

Go terminal and console support
Go
272
star
42

debug

[mirror] debugging tools
Go
230
star
43

dl

[mirror] go install golang.org/dl/go1.N@latest
Go
189
star
44

mod

[mirror] Go module mechanics libraries
Go
187
star
45

benchmarks

Benchmarks for the perf dashboard
Go
181
star
46

arch

[mirror] architecture code
Go
145
star
47

review

[mirror] Tool for working with Gerrit code reviews
Go
143
star
48

cwg

Community outreach Working Group
132
star
49

oscar

[mirror] Open source contributor agent architecture repo.
Go
90
star
50

govulncheck-action

[mirror] GitHub action for govulncheck
89
star
51

sublime-config

A library for Go environment configuration in Sublime Text
Python
85
star
52

winstrap

Bootstrapping tools for windows builders
Go
48
star
53

telemetry

[mirror] Go Telemetry services and libraries
Go
36
star
54

wiki

[mirror] Go Wiki
29
star
55

scratch

[mirror] repository used for testing
Go
28
star
56

pkgsite-metrics

Code to serve pkg.go.dev/metrics [mirror]
Go
13
star
57

go-get-issue-15410

go-get-issue-15410
Go
4
star
58

.github

2
star
59

.allstar

2
star