?automatic rail-placing? aka A* algorithm

Topics and discussion about specific mods
drs9999
Filter Inserter
Filter Inserter
Posts: 831
Joined: Wed Mar 06, 2013 11:16 pm
Contact:

?automatic rail-placing? aka A* algorithm

Post by drs9999 »

I had some freetime this weekend, so I spent it with some proof-of-concept modding.
I finally programmed a pathfinding-module.
The basic idea was/ is to make placing rails much more comfortable.

Anyway I am quite sure that a lot of work needs to be done until this target is reached and I will not have the time for it in the near future. So I thought it would be a good idea to upload it here, so everyone who might try it has a basic-foundation.

The uploaded file includes an example mod to try the pathfinding-module.
All functions that are related to the algorithm can be found in the a-star.lua file
a_star.png
a_star.png (746.49 KiB) Viewed 17533 times
The most important function is calcPath() it needs the start-/currentposition, the targetposition and (optional) a mode-parameter which defines what obstacles should be took into consideration.

The function will return the currentNode (which can be passed as startposition in the next iteration) while the path is calculated. If there is no possible path to the target e.g. target is on an island the function returns nil.
If a path was found it returns a list of positions that leads to the target.

As a note: It is relative simple to modify the function to calculate the complete path in a single shot ( using a while-loop instead "if #openlist > 0") but at least on my pc the algorithm is a big performance sink , so the game will freeze completly until the calculation is done then, that is why I "split" the calculation over time.

Also you might want to look at the H-value-calculation ( calcH()). The H-value is used to estimate the distance between the currentPosition and the target. Like it is now, it calculate the Manhatten-Distance and multiplies it with an arbitrary value, which I call "weight". From my observation this "weight" has a huge impact on the performance, a higher value speeds up the whole process a lot, as a downside the algorithm might not return the shortest path between start and targetposition.
Just to show how big the impact is, I tested it with an "weight"- value of 1 and 10. With 1 the whole calculation needs 2:30 mins whereas the other calculation just needs 15 sec.


Feel free to ask if anything is unclear or you have any suggestions.
Attachments
UtilityMarker.zip
A* example mod
(27.51 KiB) Downloaded 307 times
Last edited by drs9999 on Mon Jan 13, 2014 10:59 am, edited 1 time in total.
Nirahiel
Filter Inserter
Filter Inserter
Posts: 351
Joined: Mon Sep 23, 2013 2:18 pm
Contact:

Re: ?automatic rail-placing? aka A*

Post by Nirahiel »

Mind if I .. "steal" your code for my mod ?
I want to implement some sort of vehicle that'll automatically go to destination, and your algo seems perfect for that :)
drs9999
Filter Inserter
Filter Inserter
Posts: 831
Joined: Wed Mar 06, 2013 11:16 pm
Contact:

Re: ?automatic rail-placing? aka A* algorithm

Post by drs9999 »

Meh, that is why I posted it here ;) Feel free use it everywhere you might think it fits.

I also expanded the OP a bit.
SilverWarior
Filter Inserter
Filter Inserter
Posts: 559
Joined: Mon Mar 04, 2013 9:23 am
Contact:

Re: ?automatic rail-placing? aka A*

Post by SilverWarior »

Nirahiel wrote:Mind if I .. "steal" your code for my mod ?
I want to implement some sort of vehicle that'll automatically go to destination, and your algo seems perfect for that :)
In your place I would rather request developers to give access to ingame pahtfinding algorithm as it already has some optimizations done based on games needs.
Also drs9999 algorithm doesn't seem to work corectly. it would seem that it only supports only horizontal and vertical movments.
Or is one of those "optimized" A* algorithmy which only keep limited amont of already scanned node information in it as a way to lower memory imprint. But this could unfortunately lead to pathfinding algorithm of making much larger routes in certain conditions.

@drs9999
If you want I can make you a few test cases for testing of your lagorithm. I use theese mysel since I'm reimplementing Heuristic A* pathfinding algorithm in Object Pascal to be used with one of my future games.
drs9999
Filter Inserter
Filter Inserter
Posts: 831
Joined: Wed Mar 06, 2013 11:16 pm
Contact:

Re: ?automatic rail-placing? aka A* algorithm

Post by drs9999 »

drs9999 wrote:Also drs9999 algorithm doesn't seem to work corectly. it would seem that it only supports only horizontal and vertical movments.
Nope, it works correctly, because I implemented it that way ;)
Anyway, it is simple to modify. You just have to expand the findNeighbours - function that it will check the "diagonal" nodes as well.

And no I am not using an "optimized" algorithm, as far as I know (just basic wikipedia knowledge), the modified ones only lower the needed memory, but also decrease the performance. And the speed/ amount of time to find the solution is already the bottleneck here.

Test-cases are appreciated ;)
What I did so far was to create a sand-box game ( this one with god-controller) save it and calculate the exact path every time while tweaking some values/ functions.
User avatar
FreeER
Smart Inserter
Smart Inserter
Posts: 1266
Joined: Mon Feb 18, 2013 4:26 am
Contact:

Re: ?automatic rail-placing? aka A* algorithm

Post by FreeER »

Well this took longer for me to understand than it should have :lol:
The main issue (and this might be minor, I've never done any pathfinding) is to actually incorporate the 'size' of the rails. For instance, in the image you have you'd never be able to get a track from a to b along the path calculated. The easiest solution (I think) would likely be to calculate straight paths (high weight to any direction changes), and at direction changes move backwards by seven (I think, since for a right turn you need 2 curved rails with 2 straight rails inbetween, also check if possible to place these, otherwise straight continue until you can?) and start new path with the start position being the ending position of the second curved track needed for turning....not entirely sure if that would work and it wouldn't be the most optimal but...
It should be noted that after clicking 'build bridge' and then 'cancel' you can press 'build bridge' again even though the markers are destroyed. Which leads to an entity target is zero crash, that is for some reason unclickable (have to close factorio window)...
Also, scenario, I placed the ending marker near a tree (imagine train stop though), infinite search initiated when using 'avoid entities and water'. (btw, changing mode and reclicking build path seems to have no effect, I didn't check the code for that yet though).
Could also have a way to avoid resources (though that's easy enough).

I'll play with this more when I have time, though not sure what else I'd use it for right now it's definitely interesting (to me) :)
drs9999
Filter Inserter
Filter Inserter
Posts: 831
Joined: Wed Mar 06, 2013 11:16 pm
Contact:

Re: ?automatic rail-placing? aka A* algorithm

Post by drs9999 »

Yes you are absolutly right. Anyway it took me a whole afternoon to create a function that creates a rail from point A to B without searching for obstacles or water. Just a horizontal, a vertical and a curve. So I discarded that aproach and started with the simplest implementation of the algorithm.

But sure that would be the next step. But like I said, I am afraid that I will not have the time, bachelor-thesis, other university projects, important exams, yalla yalla :D

And yes I was aware that the other stuff will not work well. Nevertheless it is more a proof of concept than a "real" mod. So I would say it is sufficient ;)
User avatar
rk84
Filter Inserter
Filter Inserter
Posts: 556
Joined: Wed Feb 13, 2013 9:15 am
Contact:

Re: ?automatic rail-placing? aka A* algorithm

Post by rk84 »

I think this Railnetwork.zip is close to this thread. So I just drop in here before I make a proper mod, if I make.
I guess you could call it semi-automatic since you need player to steer it, but rail building is automatic.

Usage:
  • Place locomotive on straight rail and jump in.
  • Code: Select all

    remote.call("railnetwork", "start")
  • Start driving
If you make a loop, try the remote call again.

edit: I forgot to you are free to use it or parts of it for the A*. I imagine that aiming towards certain coord might be challenging though. :)
Test mode
Searching Flashlight
[WIP]Fluid handling expansion
[WIP]PvP gamescript
[WIP]Rocket Express
Autofill: The torch has been pass to Nexela
drs9999
Filter Inserter
Filter Inserter
Posts: 831
Joined: Wed Mar 06, 2013 11:16 pm
Contact:

Re: ?automatic rail-placing? aka A* algorithm

Post by drs9999 »

I tested it and there is one thing that really bothers me...

It is so awesome that it does not deserve to be buried here, so PLEASE continue and make it a proper mod :D
Eclipse
Manual Inserter
Manual Inserter
Posts: 1
Joined: Thu May 29, 2014 8:19 pm
Contact:

Re: ?automatic rail-placing? aka A* algorithm

Post by Eclipse »

Would love to test this mod, but I am getting an error I cant really make heads or tails of.

when attempting to run the scenario "base/sandbox" (and any other scenario) with base 9.8 and v 0.1.0 of this mod, I get the error
-"Error while running the oninit: ...\mods\UtilityMarker|control.lua:35; attempt to index global 'hf' (a boolean value)"

Given Im not proficient in lua any help would be greatly appreciated!
User avatar
FreeER
Smart Inserter
Smart Inserter
Posts: 1266
Joined: Mon Feb 18, 2013 4:26 am
Contact:

Re: ?automatic rail-placing? aka A* algorithm

Post by FreeER »

Eclipse wrote:Would love to test this mod
It's really not a mod and if you want to work with it you're going to want/need to learn some Lua fairly well...but, here's a self-contained (does not require the blueprint mod), loadable version for 0.9.8: UtilityMarker.zip
<I'm really not active any more so these may not be up to date>
~FreeER=Factorio Modding
- Factorio Wiki
- My Factorio Modding Guide
- Wiki Modding Guide
Feel free to pm me :)
Or drop into #factorio on irc.esper.net
User avatar
StanFear
Fast Inserter
Fast Inserter
Posts: 236
Joined: Sun Dec 15, 2013 2:49 pm
Contact:

Re: ?automatic rail-placing? aka A* algorithm

Post by StanFear »

mind if I ask you why you stopped your idea of automatic rail placement ?
from what I saw in your code, you put some work into it !

would you mind me using your idea to try to make a whole mod (I've got some ideas of how to do it !)?
User avatar
StanFear
Fast Inserter
Fast Inserter
Posts: 236
Joined: Sun Dec 15, 2013 2:49 pm
Contact:

Re: ?automatic rail-placing? aka A* algorithm

Post by StanFear »

well, actually, I just read the FARL thread,
my idea is preety much already done so ...
Post Reply

Return to “Mods”