I need to implement the following:

1) I have a database of ~100 mil records.

Each record is of type key/value.

The key is an internal ID of type: "123456789".
The value is a kml with geographic boundary in form of lat/lon coordinates:

                 <?xml version=\"1.0\" encoding=\"UTF-8\"?>
                 <kml xmlns=\"http://www.opengis.net/kml/2.2\";>
                   <Placemark>
                       <Polygon>
                             <outerBoundaryIs>
                                     <LinearRing>
                                               <coordinates>
                                              
-117.587174583104,33.6437620515745 
                                              
-117.587083176312,33.6437891755388 
                                              
-117.587016626677,33.6438098355405 
                                              
-117.586923617992,33.6435949397585 
                                              
-117.587051757569,33.643539681552 
                                              
-117.587079610599,33.6435348310862 
                                              
-117.587174583104,33.6437620515745
                                               </coordinates>
                                     </LinearRing>      
                              </outerBoundaryIs>    
                        </Polygon>  
                    </Placemark>
                  </kml>


2) Input values are of type lat/lon like -117.11111,33.2222

The usage is having an input lat/lon to find the boundary in which it is 
located and return the key (the internal ID).

The closest solution I found is using Google S2 geometry library:
https://github.com/golang/geo
and this library:
https://github.com/akhenakh/regionagogo

This implementation is using an in memory index with Segment Tree 
<https://en.wikipedia.org/wiki/Segment_tree> datastructure:
github.com/Workiva/go-datastructures/augmentedtree
and BoltDB.

I need to create persistent  key/value database on the disk (it would be 
big like ~100GB) using
RocksDB key/value store with key Segment Tree 
<https://en.wikipedia.org/wiki/Segment_tree> datastructure.

It should get CellID from lat/lon and find the S2 interval where it resides.

How is the best way to implement it?







-- 
You received this message because you are subscribed to the Google Groups 
"golang-nuts" group.
To unsubscribe from this group and stop receiving emails from it, send an email 
to golang-nuts+unsubscr...@googlegroups.com.
For more options, visit https://groups.google.com/d/optout.

Reply via email to