GitXplorerGitXplorer
R

h3net

public
27 stars
10 forks
2 issues

Commits

List of commits on branch Primary.
Unverified
691ae70b364f6960e9a3298d64b8506453b7384a

Merge tag '3.7.2' of https://github.com/RichardVasquez/h3net into 3.7.2

RRichardVasquez committed 3 years ago
Unverified
e49149cf376e1bf89206e311d339efd9deffdb7b

Hopefully multi targeted now for .Net 4.6.1, .Net Core 3, and .Net 5

RRichardVasquez committed 3 years ago
Verified
8d335bfa09fc5709ce0d26bb1fc49982fe003843

Update Readme.md

RRichardVasquez committed 3 years ago
Verified
11c232e35c4e47ec50e9d5727de78edeedec33de

Update Readme.md

RRichardVasquez committed 3 years ago
Verified
87d0a59e47f9d6028b3ae75004fc8eb1bde379f2

Merge pull request #15 from RichardVasquez/3.7.2

RRichardVasquez committed 3 years ago
Unverified
692b67cfc0b5a7b61ecead8f9fff16e09fcdce66

Added code to match 3.7.2 and new unit tests.

RRichardVasquez committed 3 years ago

README

The README file for this repository.

H3NET: A Hexagonal Hierarchical Geospatial Indexing System In C#

H3Net is a geospatial indexing system using hexagonal grid that can be (approximately) subdivided into finer and finer hexagonal grids, combining the benefits of a hexagonal grid with S2 hierarchical subdivisions, mostly translated from the original C code from Uber's H3 project. h3net logo

Why? There's already a version in C!

The short version:

I'm working on a project that needs H3 capabilities in C#. When I first started this, I could make the bindings work on desktop, but not mobile, so I wrote the 3.1.1 version. Working with it in my project over the past couple of years, along with some of the new things in H3, I came back to it to work with 3.7.1 capabilities.

That's what's here now. I'm still working on it, but it's now at a usable, albeit lightly documented state. You really should check out the H3 link I placed before, if you want to know what's involved here.

History

  • Current (3rd round) - Currently has the same capability as 3.7.2, if not exactly the same syntax.
  • Version 2 - A horrible attempt to implement H3 v3.2.1, and I've removed the branch for it.
  • Version 1 - According to my Git repository, I pushed it on November 16, 2018. It has the capability of Uber H3 3.1.1, but it has a horrible API.

Caveat Emptor

This doesn't work exactly like H3, especially under the hood, but it's close enough for most work, I feel.

Right now, you can probably work your way through the syntax in Api.cs in the lib directory. For actual use, I've got a fluid API to chain commands together, though most of that is being used internally.

I'm also going to be closing off access to the internals shortly so that functionality reflecting the API will be the only direct access to the code.

At this point, the only comprehensive documentation is the auto-generated file at H3Lib/Documentation. Keep an eye on that directory as I'll be cleaning that up next.

Input

I'm going to be doing the following:

  • Cleaning up the code, including some of the brute force translations
  • Extracting/writing documentation for the library
  • Probably adding a few unit tests for the modifications I've made.

You can help too. Fork and make a PR, and we'll go from there.

Caveat Emptor II

I wanted to get this done in a month. I have. It's nowhere near the polished state I want it to be, but it works, and it passes 200+ unit tests. It's now ready to be played with.

Don't go crazy with it just yet, as I'm going to clean it up some more, work on documentation, deal with TODO's in the code, and so forth. At some point after that, I'll have an actual release.

Testing

For the most part, I've converted the unit tests from the original H3 project to work in h3net. They were extremely helpful with the architecture change going from 3.1.1 to 3.7.1.

Some corner cases weren't convertible as they tested for null objects while h3net uses primarily extension methods on readonly structs. Where this has come up, I've documented it in the appropriate unit test file.

Version

I will be keeping the version number the same as the functionality of H3 that I'm matching.

Currently: 3.7.2

Previous: 3.7.1

Badges

.NET Maintainability JetBrains Rider H3 3.7.2 Burma Shave

Fin

Hexagons are the bestagons