Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

site and channel coord attribute #481

Open
pavlis opened this issue Jan 5, 2024 · 0 comments
Open

site and channel coord attribute #481

pavlis opened this issue Jan 5, 2024 · 0 comments

Comments

@pavlis
Copy link
Collaborator

pavlis commented Jan 5, 2024

In working on a new user manual section on MongoDB and MsPASS, I ran across a couple issues.

  1. First, we have a mistake in Database.save_inventory. We save the geographical location in site and channel to the attribute "coords" in the "legacy" georefence format for MongoDB. There is a mistake as we have the coordinates reversed. The pair should be lon,lat and we have lat,lon.
  2. In working through this when we fix 1 I think we should change the code to write geoJSON that MongoDB seems to much prefer for at least the past 5 years. Since I seriously doubt we have any users using that feature at this point that should have no impact.

The other side of this is I am having an extremely difficult time getting geographic queries to work. There are some very subtle issues in usage that are not particularly well documented. One I know for sure is that it is very very fussy about indexing. You can't do any geographic query without building an index, AND there are two different versions (2d and 2dsphere) that seem to be incompatible. For MsPASS the only rational choice is 2dsphere, by the way, but that is another reason to ditch legacy coordinates. As I read the documentation you cannot use 2dsphere with legacy coordinate data. The horrible experience I'm having getting any geographic query to work convinces me we really need to put something on our development agenda. That is, I think it will be helpful to write a few simple wrapper functions to make the queries easier. One's I would recommend are:

def select_by_distance(collection,center=[0.0,0.0],radius=1.0,lockey='location'): 
   """
   Return a cursor selecting documents in collection with geoJSON points linked to lockey using a 
   circular great circle distance (degrees) radius with center specified as a lon,lat pair.
   """
def select_in_polygon(collection,polydata,lockey='location'):
   """
   Does a search within a convex polygon specified by polydata assuming data associated with key 
  lockey are geoJSON  points,  
  """

We could do a rectangular lat-lon box function too, but that is pretty trivial. Maybe needed for consistency but it wouldn't wouldn't need the geoJSON points.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

1 participant