-
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
GeoStat-Framework integration: PyKrige v2 #136
Comments
Thanks for taking this on, @MuellerSeb! A few quick thoughts on this... The tools for variogram estimation/modeling/etc in PyKrige are admittedly underdeveloped, so relying on your efforts in GSTools would be good I think. Probably won't be too hard to refactor the existing PyKrige code to use the GSTools variogram code. I think refactoring to ND kriging would be very valuable, and actually shouldn't be too hard in the existing PyKrige framework. And the existing universal kriging drift terms could then be extended into N dimensions. |
Thanks for the summary @MuellerSeb ! The plan sounds good to me as well.
One constrain is backward compatibility, and how to make that transition without breaking existing users code. Maybe adding GSTool variogram-models and adding a deprecation warning for some of the current options that would be changed in the future.
+1
That would be ideal indeed, though it would likely require some work. |
@rth : I would create a 1.5 version incorporating GSTools as proposed in #125 . We could add deprecation warnings there. Everything else should be done within a 2.0 release, where we can break backward-compatibility since the major version number changes. I would keep all the variogram models, just rescale them. So in the case, where the variogram was estimated, we should get same results. We are quite experienced with building wheels including cython code. @LSchueler will have a look at it, when he has some spare time. |
You are right, making these changes in 2.0 would probably be best. |
One problem, that comes up, when bringing the variogram models in line, is that all models in GSTools are stationary and assume a finite sill of the variogram. So these are incompatible ATM:
In GSTools, the linear model is a truncated one, to provide a finite length scale. Power models are also provided in a truncated way (finite superposition of models on different scales). We could circumvent this, by setting the length scale bigger than the field-size. |
Sorry for not commenting on this sooner. The linear and power variogram models in PyKrige aren't stationary as defined, and so I suppose then they're not true covariance functions (if I'm remembering the underlying mathematical formalism correctly). I originally included them in the code for completeness following the Kitanidis geostats text. But makes sense to have all variogram models be true covariance functions, so I think your idea @MuellerSeb sounds good. |
Hurray! PyKrige is now part of the GeoStat-Framework
Now we have to think about, how to smoothly integrate PyKrige into this Framework and how to organize the coexistence with GSTools.
With this PR: GeoStat-Framework/GSTools#67 in GSTools a set of kriging routines is introduced in GSTools:
All of these procedures work in 1D, 2D and 3D.
PyKrige could work as the extension for fancy kriging, like
I think it would be nice to collect stuff, that should be provided by PyKrige and things that could be out-sourced to GSTools to reduce redundancy.
TODOs ATM
develop
branch;master
should hold latest releaseProject
https://github.com/GeoStat-Framework/PyKrige/projects/1
What do you think? @rth @bsmurphy @LSchueler
The text was updated successfully, but these errors were encountered: