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

Access values in hgv storage as bytes rather than shorts #1183

Merged
merged 2 commits into from
Jun 15, 2022

Conversation

aoles
Copy link
Member

@aoles aoles commented Jun 8, 2022

Pull Request Checklist

  • 1. I have [rebased][rebase] the latest version of the master branch into my feature branch and all conflicts
    have been resolved.
  • 2. I have added information about the change/addition to functionality to the CHANGELOG.md file under the
    [Unreleased] heading.
  • 3. I have documented my code using JDocs tags.
  • 4. I have removed unnecessary commented out code, imports and System.out.println statements.
  • 5. I have written JUnit tests for any new methods/classes and ensured that they pass.
  • 6. I have created API tests for any new functionality exposed to the API.
  • 7. If changes/additions are made to the ors-config.json file, I have added these to the [ors config documentation][config]
    along with a short description of what it is for, and documented this in the Pull Request (below).
  • 8. I have built graphs with my code of the Heidelberg.osm.gz file and run the api-tests with all test passing
  • 9. I have referenced the Issue Number in the Pull Request (if the changes were from an issue).
  • 10. For new features or changes involving building of graphs, I have tested on a larger dataset
    (at least Germany), and the graphs build without problems (i.e. no out-of-memory errors).
  • 11. For new features or changes involving the graphbuilding process (i.e. changing encoders, updating the
    importer etc.), I have generated longer distance routes for the affected profiles with different options
    (avoid features, max weight etc.) and compared these with the routes of the same parameters and start/end
    points generated from the current live ORS.
    If there are differences then the reasoning for these MUST be documented in the pull request.
  • 12. I have written in the Pull Request information about the changes made including their intended usage
    and why the change was needed.
  • 13. For changes touching the API documentation, I have tested that the API playground [renders correctly][api].

Fixes #1181.

Information about the changes

This addresses a memory alignment issue in HGV extended storage which occasionally caused ArrayIndexOutOfBoundsException. The problem originated from the fact that HGV storage entries are 11 bytes long. As this length is not a multiple of 2 it can happen that the two bytes constituting a short value get distributed over two different byte array segments. However, unlike the byte-reading/writing methods the methods to directly access shorts do not allow them to be split between segments.

… shorts

This addresses a possible memory alignment issue caused by the fact that hgv storage entries are 11 bytes long. As this lenght is not a multiple of 2 it can happen that the two bytes constituting a short value get distributed over two different byte array segments. However, unlike the byte-reading/writing methods the methods to directly access shorts do not allow them to be split between segments.
Copy link
Contributor

@takb takb left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

looks good to me.

@takb takb merged commit b909c0a into master Jun 15, 2022
@takb takb deleted the bugfix#1181-address_data_alignment_issue_in_hgv_storage branch June 15, 2022 13:30
@DavidPerezIngeniero
Copy link

DavidPerezIngeniero commented Jul 17, 2023

Does latest version of openroutes (7.1.0) include this correction?.
I've looked at the release notes of latest versions and see nothing.

@MichaelsJP
Copy link
Member

MichaelsJP commented Jul 17, 2023

@DavidPerezIngeniero Thanks for getting back on this. It was included in release 6.8.0 the first time, without correctly showing it in the release notes. We took care of that and the release notes are now more reliably generated. Just look at it . Way better now, I hope! 😉

In 7.1.0 the first change from the PR can be found here.
With the latest changes it moved here .

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

Successfully merging this pull request may close these issues.

ArrayIndexOutOfBoundsException during core graph preparation for hgv
4 participants