OBD talk:AKVA/0x24: Difference between revisions

Pathfinding grid tile types revisited
(another obervations)
(Pathfinding grid tile types revisited)
Line 83: Line 83:
==level14==
==level14==
==level18==
==level18==
==level19==
== EFFECTS of various pathfinding grid tile types ==




----
Based on empiric observations. Further exact informations about tile effects would be very, very appreciated. Header of each section contains ID of the tile, color code of the tile (in brackets color used by [[Onisplit]] grids as follows: ''hue'', ''saturation'', ''value'' | ''red'', ''green'', ''blue'') and internal name of the tile ripped from *.exe. Then, effects of the tile type are described.


THESE are some observations made with pathfinding grid for others to see, because adjusting of some BNVs is IMO neccessary part of modding levels and this info can help. Some statements may be wrong, so please correct mistakes if you find any.
:'''9 - red tiles (IMPASSABLE):'''
:* are ignored when AI2 is in MELE mode (AI2 character will chase you into "red field", that is some larger area filled with red tiles, if it is close enough to you to be in MELE mode). That is why sometimes happen that you are close behind wall and AI2 character desperately runs towards wall on the other side - red tiles, indicating some obstacle, are ignored as AI2 char is in MELE mode.
:* leave AI2 ability to fully run its MELE profile if it is in "red field" and you are close enough
:* block pathfinding completely (if you trap AI2 character somewhere in "red field" and you "teleport" away, it gets stuck and won't be able to chase you unless you come close enough to make it run some MELE move so it can move). This applies on both ''pathfinding'' (chasing enemy thanks to the dynamic flags) and ''vector-forced movement'' (so AI2 character can't dodge firing spreads if it is inside "red field")
:* if AI2 is not inside "red field" and you are not close enough (so AI2 is in ''pathfinding'' or ''patrol'' mode), then red (impassable) tiles work as a wall for AI2 chars. Where are red tiles there AI2 NEVER runs (again, never if you are NOT TOO CLOSE) and it tries to find its way around it if these red tiles are in the way. If no other way is possible, then AI2 simply stops right before the red line. That is what makes AI2 characters stop near wall (and stare into it until gunfire stops) when they are dodging projectile ranges/firing spreads. They want to go this direction but there is wall. Because pathfinding mode is not active when AI2 chars are dodging gunfire, they get stuck near wall as red tiles are in way and calculated vector of movement still points towards wall.
:* BUT if angle between vector of movement (for gunfire dodging) and these red tiles is small, AI2 can "slide along" the line of red tiles. I don't know how big this tolerance is ^_^.
ONLY a theory
:* Also it looks like these red tiles are taken as "wall" when it comes to projectiles/spreads. So maybe (unconfirmed) AI2s try to run so some line of red tiles is between them and shooter.
/ONLY a theory


:<u>ID: '''9''' color: '''<span style="color:red">red</span>''' (0, 100, 100 | 255, 0, 0) name: '''IMPASSABLE'''</u>
:* Serves as a "wall" mark.
:* When in pathfinding mode, A.I. characters will always avoid "red tiled area" and will never try to run into it. If red tiles completely block the path to the desired destination, A.I. character runs as close as possible to the edge of "red tiled area" and stops there.
:* When in "vector movement mode", that means for example active [[CMBT]] IfNoGun behavior '''retreat''' or firespread/projectile dodge, engine will attempt to navigate the A.I. character closely along the red tiled area if possible.
:* Sometimes A.I. characters won't stop in time (due to neccessity to finish playing [[TRAM]] animations) and "dive" into red tiled area. If the red tiled area is thin (two/tree standard-size tiles) and nothing is physically blocking the path (no colliding geometry), then A.I. character "tunnels" through the red tiled area and continues its run as if nothing special ever happened. if the red tiled area is thick, then A.I. character gets trapped and both pathfinding and vector movement modes won't work (character will keep standing, will only rotate).
:*The only "movement mode" which works deep inside red tiled area is [[MELE]] movmement, which means some enemy in close proximity (???extent length of attack TRAMs???) of the trapped A.I. character. Then this A.I. character will move in order to execute MELE techniques.


:'''8 - orange tiles (DANGER):'''
:* are NOT ignored when AI2 is in MELE mode (AI2 does some actions, read below)
:* restrict AI2 MELE abilities. According to pre-computed reach of technique (it must be stored somewhere), it is labeled as WORRY-FWD (so-so, AI2 will almost meet orange line if it executes it, these techniques have their weight watered down by engine, algorithm is unknown) or DANGER-FWD (AI2 will exceed orange line if it executes this technique, so engine disables it temporarily-weight 0 I guess).
:* if enemy is INSIDE "orange field" or BEHIND it and if AI2 character is close enough to enemy to have its MELE mode active, engine allows only jumping techniques to execute. Jumping techniques are those which have jumping position move in them ([OBD:BINA/OBJC/MELE/MoveList/Position]], numbers 4,5,6,7,8,16,17,18,19). If AI2 char is inside "orange field", then only jumping technques are allowed. If AI2 does not have any jumping technique, it will switch to pathfinding mode and then (inside orange field) it keeps switching between pathfinding and MELE. 
:* do NOT disable pathfinding. AI2 characters will try to avoid orange tiles same way as red tiles, but if there is no other way, they will go through. So you canot "trap" AI2 character in orange field, it WILL find its way out.
:* when it comes to gunfire dodging, orange tiles serve the same as red - if AI2 runs towards them while dodging, it stops and stares (if vector of movement still points toward orange tiles). Inside orange field AI2 can't dodge gunfire (same as red)


:<u>ID: '''8''' color: '''<span style="color:orange">orange</span>''' (39, 100, 100 | 255, 165, 0) name: '''DANGER'''</u>
:* Serves as a "danger of falling over the edge" mark.
:* When in pathfinding mode, A.I. characters will try to avoid "orange tiled area" as much as possible. However if orange tiles completely block the path to the desired destination and there is no other way, A.I. character will run through them. Thus A.I. cannot be "trapped" in orange tiled area.
:* When in "vector movement mode", that means for example active [[CMBT]] IfNoGun behavior '''retreat''' or firespread/projectile dodge, engine will attempt to navigate the A.I. character closely along the orange tiled area. However, unless some TRAM accident occurs, A.I. character in "vector movement mode" will not attempt to cross through orange tiled area.
:* In MELE mode, orange tile type affects technique weight. If a move within the technique would cause the A.I. character to come close to the orange tiled area or even to venture into it (the check is probably computed from extents of attack [[TRAM]]s in a  [[MELE]] technique), this technique is first labeled as WORRY-FWD and then as DANGER-FWD.
::*WORRY-FWD means that A.I. would end very close to the orange tiled area if this technique was executed. Under such conditions, engine waters down weight of the technique by some unknown multiplier. The guess is that the multiplier is not a constant but a dynamic value, ranging from "1.0" (no danger) down to "0.0" (technique would cause the A.I. to end in orange tiled area).
::*DANGER-FWD means that A.I. would end in a orange tiled area if it used the technique. Weight of such a technique is decreased to zero (0). This is done to prevent A.I. characters from behaving dumb, i.e. executing such techniques which would cause them to fall over the edge (which happens anyway ^_^).
::*Jumping techniques are excluded from WORRY/DANGER weight dimnish. That means if MELE profile contains techniques which utilize anyone of jump position moves (maneuver "jump" has unfortunately nothing to do with this feature), these techniques have a small chance to be executed, i.e. it is possible for A.I. characters to jump over small gaps. However, it looks like the code behind this gimmick is quite raw, so more than often A.I. characters either won't execute jump technique when they should or they try to execute it too late and first step into orange tiled area (which usually means they fall down ^_^).
:*SPECULATION - maybe [[MELE]] technique flag "Fearless" has something to do effects of this tile type.


:'''7 - dark green tiles (STAIRS):'''
:* seem to be ignored when AI2 is in MELE mode, it is probably patrol/pathfinding-only
:* AI2 tends to avoid them, but if no other way is possible, it goes through it (probably insurance that AI2 char will always choose the shortest way)
:* stop gunfire dodging the same way as red tiles do (but why? it is a bit weird)
:* probably serve as "here comes stairs" mark


:<u>ID: '''7''' color: '''<span style="color:DarkGreen">dark green</span>''' (120, 100, 150 | 0, 128, 0) name: '''STAIRS'''</u>
:* Serves as a transition tile type from slopes.
:* Forces A.I. character to go into vector movement mode. It is used to smoothen transition from slopes (staircases) to flat ground. Without this tile type used, A.I. characters often stop for a while when they come from slope to a flat ground. With this tile type used, A.I. characters keep moving.
:* A.I. characters tend to avoid dark green tiled areas in general, but if there is no other way, they go through. If dark green tiled area is large and there is no adjecent BNV nearby (as in case of transition from slope to flat ground), then there is a chance A.I. will get a bit stuck.
:* Dark green tiles are taken as sort of a weak obstacle for vector type movement. A.I. characters won't enter it on its own, but once inside (and in vector movement mode), they won't get stuck but keep moving.


:'''6 - dark blue tiles (BORDER 4):'''
:* seem to be ignored when AI2 is in MELE mode, it is probably patrol/pathfinding-only
:* serve as mark that some edge is right the step ahead. If AI2 needs to run somewhere (patrol/pathfinding mode!) and meets these tiles, it will try to run along them. if AI2 is already in "dark blue field", it will run out of it and will try not to go into it.
:* stop gunfire dodging the same way as red tiles do


:<u>ID: '''6''' color: '''<span style="color:Navy">dark blue</span>''' (240, 100, 50 | 0, 0, 128) name: '''BORDER4'''</u>
:* Serves as a strongest "edge border" mark.
:* If dark blue tiles are not surrounding orange tiles, they seem to be ignored by pathfinding movement mode.
:* If dark blue tiles do surround orange tiles, then A.I. tries to keep outside of dark blue tiled area and runs along it.
:* Dark blue tiles are taken as an obstacle for the vector type movement. A.I. characters won't enter it on its own, but once inside (and in vector movement mode), they won't get stuck but keep moving.


:'''5 - blue tiles (BORDER 3):'''
:* same as tiles 6 IMO, maybe it only tells AI2 that it is "quite close to the edge"


:<u>ID: '''5''' color: '''<span style="color:RoyalBlue">blue</span>''' (240, 100, 100 | 0, 0, 255) name: '''BORDER3'''</u>
:* Serves as a second strongest "edge border" mark.
:* If blue tiles are not surrounding orange tiles (or dark blue tiles which surround orange tiles), they seem to be ignored by pathfinding movement mode.
:* If blue tiles do surround orange tiles (or dark blue tiles which surround orange tiles), then A.I. tries to keep outside of the blue tiled area and runs along it.
:* From empiric point of view these are identical and have same effects on A.I. characters as BORDER4 tiles. But these probably have their meaning for A.I. to to tell it that it is getting close to the edge but is still not right at the edge.
:* If set in hierarchy as they are intended (orange, dark blue, blue), A.I. characters try to avoid this tile type and run along the edge of the blue tiled area (so they are at least one tile width away from the actual geometry edge).
:* Blue tiles are taken as an obstacle for the vector type movement. A.I. characters won't enter it on its own, but once inside (and in vector movement mode), they won't get stuck but keep moving.


:'''4 - green tiles (SEMIPASSABLE):'''
:* seem to be ignored when AI2 is in MELE mode, it is probably patrol/pathfinding-only
:* AI2 tries to avoid these tiles if it meets them, but if no other route is possible, it will cross these tiles without problems
:* do not limit gunfire dodging


:<u>ID: '''4''' color: '''<span style="color:LimeGreen">green</span>''' (120, 100, 100 | 0, 255, 0) name: '''SEMIPASSABLE'''</u>
:* Serves as a "wall border" mark.
:* If green tiles are not surrounding red tiles, they seem to be ignored by pathfinding movement mode.
:* If green tiles do surround red tiles, then A.I. tries to keep outside of green area and runs along it.
:* When in pathfinding mode, A.I. characters try to not cross green tiled areas. However if there is no other way or at sharp turns, A.I. has no problems with passing through green tiled areas.
:* Green tiles don't limit vector type movement. A.I. characters freely pass through green tiled areas while in vector movement mode.


:'''3 - lighter blue tiles (BORDER 2):'''
:* seem to be ignored when AI2 is in MELE mode, it is probably patrol/pathfinding only
:* AI2 can run straight through these without any problems, it does not limit gunfire dodging as well
:* probably they tell AI2 that "edge is close"


:<u>ID: '''3''' color: '''<span style="color:DodgerBlue">light blue</span>''' (203, 46, 98 | 135, 206, 250) name: '''BORDER2'''</u>
:* Serves as the second "weakest edge border" mark.
:* If light blue tiles are not surrounding orange tiles (or blue/dark blue tiles which surround orange tiles), they seem to be ignored by pathfinding movement mode.
:* If light blue tiles do surround orange tiles (or blue/dark blue tiles which surround orange tiles), then A.I. tries to keep outside of the light blue tiled area and runs along it.
:* If set in hierarchy as they are intended (orange, dark blue, blue, light blue), A.I. characters try to avoid this tile type and run along the edge of the light blue tiled area (so characters are at least two tile width away from the actual geometry edge).
:* Light blue tiles don't limit vector type movement. A.I. characters freely pass through light blue tiled areas while in vector movement mode.


:'''2 - lightest blue tiles (BORDER 1):'''
:* same as tiles 3 IMO, maybe it only tells AI2 that "edge is around"


:<u>ID: '''2''' color: '''<span style="color:SkyBlue">lightest blue</span>''' (195, 25, 90 | 173, 216, 230) name: '''BORDER1'''</u>
:* Serves as the weakest "edge border" mark.
:* If the lightest blue tiles are not surrounding orange tiles (or light blue/blue/dark blue tiles which surround orange tiles), they seem to be ignored by pathfinding movement mode.
:* If the lightest blue tiles do surround orange tiles (or light blue/blue/dark blue tiles which surround orange tiles), then A.I. tries to keep outside of the light blue tiled area and runs along it.
:* If set in hierarchy as they are intended (orange, dark blue, blue, light blue, lightest blue), A.I. characters try to avoid this tile type and run along the edge of the lightest blue tiled area (so characters are at least three tile width away from the actual geometry edge).
:* The lightest blue tiles don't limit vector type movement. A.I. characters freely pass through the lightest blue tiled areas while in vector movement mode.


:'''1 - lighter green tiles (NEARWALL):'''
:* seem to be ignored when AI2 is in MELE mode, it is probably patrol/pathfinding only
:* probably just tell AI2 that "obstacle is close", it can run through them without any problems
:* do not limit gunfire dodging


--[[User:Loser|Loser]] 09:11, 18 July 2008 (CEST)
:<u>ID: '''1''' color: '''<span style="color:LightGreen">light green</span>''' (120, 39, 93 | 144, 238, 144) name: '''NEARWALL'''</u>
:* Serves as a weaker "wall border" mark.
:* If light green tiles are not surrounding red tiles (or green tiles which surround red tiles), they seem to be ignored by pathfinding movement mode.
:* If light green tiles do surround red tiles (or green tiles which surround red tiles), then A.I. vaguely tries to keep outside of light green area and runs along it.
:* When in pathfinding mode, A.I. characters have no problem with crossing through light green tiled areas. However if there is no specific need, A.I. characters somehow lazily try to stay out of light green tiled areas.
:* Light green tiles don't limit vector type movement. A.I. characters freely pass through light green tiled areas while in vector movement mode.
 
 
:<u>ID: '''0''' color: '''<span style="color:Silver">white</span>''' (0, 0, 100 | 255, 255, 255) name: '''CLEAR'''</u>
:* Serves as a "clear space" mark.
:* No special restricting effects.
::<span style="color:Gainsboro">WHITE POWER!!! ^_^</span>
 
--[[User:Loser|Loser]] 20:36, 4 June 2012 (CEST)
271

edits