-
Notifications
You must be signed in to change notification settings - Fork 1
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
Progress update #1
Comments
@adl1995 Thanks for the update! Note that there are formulas about series expansions / maxima scripts / Horner and Clenshaw summation in other places of the library, most notably here: area_formulas.hpp That could be useful to your project. Also feel free to propose a place for all of these utilities to avoid duplicates, geometry/util/math.hpp could be such a place or better geometry/util/series_expansions.hpp or similar. |
Update 19/05/2018:
@vissarion Thanks for the suggestion. I looked through area_formulas.hpp, however, the series expansions I've currently used are different from the one present there. But, I will reuse them if I find a duplication. Also, I have moved the series expansions from formulas/karney_direct.hpp to util/series_expansion.hpp. |
Indeed series for area are different but it is good to keep the same or similar format and eventually move everything related to series in the same folder. I just remembered that I have a prototype implementation for direct formula here. Feel free to use/modify/test it if you like. |
Update 25/05/2018: Commits:
The implementation for the direct problem is complete. I'm now working on adding the test cases. The dataset I'm using is GeodTest associated with GeographicLib. It contains 500,000 entries for nearly antipodal points. However, I'm not sure where the current dataset in direct_cases.hpp is collected from. It contains three separate results for Thomas, Vincenty, and Karney's method. In this case, Thomas and Vincenty's method won't provide correct results, so should I only test this against Karney's method? @vissarion, @awulkiew - can you please comment on this? Also, does Boost Geometry follow a convention for passing / returning data in degrees or in radians? I noticed in the test cases that returned data is converted into degrees before the actual comparison is performed. I'm not sure if user has the ability to specify this as part of the function call. |
direct_cases.hpp contains data created by Adam. For the cases of nearly antipodal points there is no need to test against Thomas and Vincenty.
As far as I understand, there is no issue here since formulas are internal i.e. users have access to algorithms. For the inverse case there is distance algorithm that takes a strategy as input and the strategy calls either Andoyer or Thomas or Vincenty formula. For the direct case a similar algorithm is needed. |
Update 01/06/2018: Commits:
Other work:
@vissarion Thanks for pointing that out! So, for each direct case i.e. Thomas, Vincenty, and Karney, I will introduce a strategy and add a Also, is there a way to run CircleCI builds for pull requests in the main Boost Geometry repository? I wasn't able to resolve the issue related with running builds on this fork. |
To be consistent with the distance case (i.e. inverse formula) the default should be Andoyer. However, there is no Andoyer equivalent formula for the direct case. To closest choice could be Thomas with 1st order series (instead of 2nd order) see boostorg#431 For now I would suggest to focus on inverse problem for nearly antipodal points and when is done return back on this. I will try to remove some formulas that appear to be redundant in boostorg#431 and submit a new PL.
I think you cannot run on main BG repo. One workaround (a bit inconvenient) is to fork on your account and run CircleCI tests on that fork. @awulkiew what do you think? |
Are you talking about your PR: boostorg#486? It seems that the test was performed even though you used Side note. Running tests on branches different than develop and master is disabled (see: https://github.com/boostorg/geometry/blob/develop/circle.yml#L10). It's because running all of the Boost.Geometry tests takes long time and we share CircleCI containers with all other Boost libraries so we could interfere with others. But also because the sript is sending info about code coverage manually to a single Coveralls account using $COVERALLS_REPO_TOKEN defined in CircleCI by me. This is why the tests for PRs are not performed. This could be changed, i.e. we should execute a lighter test for other branches and not send info about coverage. |
I see on the PR page that you pushed more commits yet the tests were not performed. Why the test were performed before I don't know. Maybe it was some CircleCI anomaly. |
@awulkiew I actually ran that build manually from CircleCI dashboard. I've tried running tests on BoostGSoC18/geometry and adl1995/geometry before, but they both fail due to the lack of I will try tweaking the |
@vissarion For the inverse problem, should I handle the case for meridional and equatorial points? Or, is this functionality already implemented in formulas/elliptic_arc_length.hpp? |
It would be better to implement a version of meridional and equatorial that is consistent with the new general method, if possible. Then we can test against the current implementation. |
@adl1995 I have created the PR mentioned above with some direct formulas picked from an old PR. You can have a look here: boostorg#489 |
Update 06/07/2018: Commits (inverse problem):
The implementation of the inverse method is nearly complete. I'm currently trying to resolve inaccuracies in the calculation, which leads some test cases to failure. |
Update 13/07/2018: Commits (inverse problem):
This completes the implementation of Karney's inverse method. I will now add a strategy for this method, similar to currently available methods in Boost Geometry i.e. Vincenty, Thomas, and Andoyer. |
Update 20/07/2018: Commits (inverse problem): |
@vissarion, @awulkiew - Since the Karney's direct and inverse method are now implemented (Cf. #486, #500), I'm trying to find other useful features to add. Listed below are the features I think might benefit the Boost Geometry library:
Do you think either of these would be a useful addition to the library? If you have other feature requests that might be useful, please let me know. |
What you propose make sense as potential useful features. Regarding strategies for direct formulas I am not sure if it is needed since strategies are used by algorithms, so there should be an algorithm that need such a strategy. Maybe the most useful feature related to your work is to make andoyer and/or thomas formulas work with antipodal points. I do not know whether this is a hard task but I think it worth a try. |
Since Karney's method is tightly coupled with rest of the code, figuring out which portion to replace in Andoyer, Thomas, or Vincenty's method might be challenging, but I will check the paper and see if it provides a solution to modify existing formulas. Instead, would it be beneficial if the general distance function (for inverse methods) checks if the points passed to it are antipodal (we can find a general threshold through trial-and-error)? And if so, it can call Karney's method to produce the correct result. |
That would cause inconsistencies. Assume that you use distance with andoyer formula and you use the method you propose for antipodal. Then the distances for two points nearly antipodal and two points close to the threshold of being nearly antipodal but out of the "nearly antipodal region" will have a large difference in accuracy. |
Update 27/07/2018: Commits: @vissarion, @awulkiew - Regarding the issue for updating Andoyer, Thomas, and Vincenty's method to work well with nearly antipodal points. From what I understand, the implementation of Karney's method starts off differently from other methods i.e. it involves computing series expansion of integrals and relies on modified equations from numerous geodesic algorithms. Given this, I don't think there is a plug-in solution for existing methods in Boost Geometry to produce accurate results for nearly antipodal points. I think the documentation in the library could be improved by mentioning the pros and cons for using either of the geodesic algorithms, and notifying the users to only use Karney's method for nearly antipodal points. Would this be useful? Please let me know if this is already mentioned somewhere. As only two weeks are remaining for this GSoC, I want to utilize them by doing something productive. During the next week, I will do benchmarking between the available geodesic algorithms and report their efficiency and accuracy. If you have any other suggestions, please let me know. |
Sure, you can work on documentation (see also the relevant discussion here: boostorg#490). Benchmarks sounds very interesting to me. Looking forward to see the results. You can find some old benchmarks here: boostorg#431 |
@vissarion - Thanks for the links. I looked through boostorg#431. I am first benchmarking the inverse methods against Karney. Following your benchmarks, for the error you report in the table, is the difference between the expected distance and the resulting distance using the algorithm (maximized over all runs)? Is there any other useful performance metric that I could report except for accuracy and time? Also, do you think (https://github.com/awulkiew/benchmark-geometry) would fit this use-case? I could export the results to JSON format and create graphs similar to this: https://awulkiew.github.io/benchmark-geometry. |
Update 03/08/2018: This week I performed performance benchmarks of geodesic methods (Cf. #3). For now, I have mainly compared the execution times of direct and inverse methods and showed them in tabular format. During the next week, I will try to visualize the benchmarks using graphs, and also prepare my GSoC final evaluation report. I plan on making a blog post, similar to what I did for the previous GSoC. |
@vissarion, @awulkiew - I will use this issue for providing updates on my progress. I believe this will make it convenient for you to provide feedback / review code.
During the community bonding period I
feature/geodesic_direct
branch in this repository. I initially started implementing the inverse problem, but found that it was more complex and required additional steps, whereas, the direct problem is simpler and non-iterative. Since the inverse problem builds upon the direct problem, this implementation will allow me to better understand the mathematical details involved (such as series expansion). This is also how I proposed to do so in my project timeline;As I mentioned in #421, there is some preprocessing involved in the approach proposed by Karney. For now, I'm including these functions in geometry/util/math.hpp, as these can be reused in the inverse problem.
Currently, the code is available in
karney_direct.hpp
file, once this is complete, I will try and bundle this with Vincenty.The text was updated successfully, but these errors were encountered: