-
Notifications
You must be signed in to change notification settings - Fork 191
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
Geographical models #149
Comments
That is an interesting paper (and line of research) that I had not been aware of when I first implemented the great-circle distance. Do you happen to know how conclusive the research is overall with regards to that models in Euclidean space do not perform worse than models using the great circle distance? Then I have one suggestion: From what I understand, the Yadrenko model lifts the great circle distance back to Euclidean space and then uses those Eucliden distances (please correct me if I'm wrong). If the choice is made to use the Yadrenko model (seeing that paper it seems reasonable to me), I think it could make sense to skip the use of the great circle distance entirely by directly converting the geographic coordinates to Euclidean space even before the distances are computed. This would reduce code complexity by handling the coordinates very early on and might speed things up a bit, I guess. Maybe it could make sense compare the accuracy of both approaches. Best, Malte |
Hey Malte, |
Hey Sebastian, with the comment I was referring mostly to one sentence of the paper that you linked (p. 3):
Directly after this, there is an equation that equates the Euclidean or chordal distance to the expression Anyway, that was just to note that things may possibly be simplified from a conceptional point of view. Whether this will have an impact on performance remains speculation on my part. That being said, I think the point about the invalid covariance models is a great one and admittedly one that I have no experience with. |
Ahhh! Thanks for the enlightenment! This could change a lot of stuff. I need to think about that. |
I would suggest using the Yadrenko models as the standard interpretation for geo-coordinates. Then we can drop the whole haversine procedures and just calculate the fields in 3D (with a little memory overhead for the third positional dimension). This way we can ensure, that the used model is really a conditionally negative semi-definite (CNSD, abbreviation used by Webster 2007) one. As mentioned above, this will result in approximately equal results for "small" angles. For example, for an great-circle distance of This also means, that if the length scale parameter is less then What do you think @rth, @mjziebarth, @bsmurphy, @LSchueler? |
Hi Sebastian, to me this sounds good! I have two minor comments:
Best, Malte |
@mjziebarth : I would suggest doing this within the GS-Framework 2.0 project. |
This is now solved in GSTools and will be used in PyKrige in the future: |
This issue should also mention, that we need to implement geographic coordinates for universal kriging. |
#217 is related. |
It was shown, that the current approach of plugging in the great-circle distance directly into the covariance/variogram function does not automatically result in a valid covariance model on the sphere.
To overcome this flaw, we should use the so called Yadrenko Covariance Function (See here).
Starting with a valid isotropic model in 3D, where the covariance between two points is given as a function of their distance:
We can construct the related yadrenko model on the sphere, that takes the great-circle distance
zeta(x1, x2)
with the following modification:One should not, that
2 * sin(x / 2)
is approximatelyx
for small angles, which means, that the current approach in PyKrige is approximately correct for small angles.The text was updated successfully, but these errors were encountered: