-
Notifications
You must be signed in to change notification settings - Fork 15
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
strange paths, operator() called with UINT_MAX #6
Comments
Yes, -1 can happen as the search underflows when going out-of-bounds. This is expected and you're supposed to handle this in your grid check. (You could implement wrap-around easily this way, if that's your thing) Note that in your case the part Aside from this your code looks correct and I'm not sure why you're getting "crazy paths", whatever that means. If you could give an example that shows your problem that would be great (image, coordinate point list, whatever). The coordinates are unsigned on purpose, so that you can simplify your grid check by taking advantage of unsigned underflow (which is perfectly fine according to the C/C++ standard). Something like this:
If your map absolutely wants signed coordinates all you need to do is to use those unsigned x, y as signed and check both minimum and maximum, then do the grid lookup. If everything fails try this version: https://github.com/fgenesis/tinypile/blob/9893d8fe68ef5360f097f23f3a7e6ff0c772c21d/jps.hh (note the slight API change between this and current HEAD!) |
Thanks for the reply! Sure, here's an example:
In the pictures, red highlighted squares are 9 (not walkable) notice in the incorrect versions the first step is way off from where the actual starting location was. It seems like when the path is going in one direction (maybe negative x and negative y?) it works fine, but any other direction it gets wonky I'll give the other version a shot and see what happens, thanks! |
Update: the old version you linked seems to be working! Although from my logs it looks like some of the searches are failing for some reason, but the workers are still getting paths... hmm... https://i.imgur.com/qpnYHgP.jpg Update2: seems to be failing because start or end node are obstructed - I'll figure that out on my end thanks again for the help! Update3: fixed the start node being obstructed, was a float->int rounding error |
Eh, so i DID introduce a bug in the meantime, yes? The newer rev adds a bunch of flags, JPS_Flag_NoStartCheck and JPS_Flag_NoEndCheck that might also do what you want, but i haven't tested those extensively yet, so beware. |
I can't confirm there's a bug, but I would assume there is since swapping in the old version you linked has been working perfectly |
Just fixed a bug. Pull + try again now. |
Hi,
I'm sure I'm doing something wrong here, but I'm stumped as to what
In my game, I replaced the normal A* pathfinder with your JPS version, and half the time the paths generated are perfect, but the other half of the time they're crazy. I started adding debugging and checks everywhere I could think of, and I noticed that operator() gets called with x and y being UINT_MAX (or -1 as a signed integer)
Is this expected behavior?
(Note the "< 9" part is because this was originally used in a variable cost pathfinding solution, but I just put in "< 9" for use with yours)
`inline bool teMapModule::operator()(unsigned int x, unsigned int y) const
{
bool canwalk = ((x < 512) && (y < 512) && (x >= 0) && (y >= 0));
}
bool teMapModule::findJPSPath(int startingX, int startingY, int goalX, int goalY, std::vector<xzCoordsStruct>& resultingPath)
{
}`
Can you see any obvious errors or have any idea why I'm getting crazy paths half the time?
Thanks for any suggestions you might have!
The text was updated successfully, but these errors were encountered: