Determining if a point is "trapped" (enclosed) on a grid - arrays

I have a grid (example below) containing outside walls (marked as W), environment blocks (E), open space (o) and active points (A). Presently, this grid is stored in a [,] with all of the data associated with a given point. I'm trying to determine if an active point is enclosed (defined as being incapable of reaching the top of the grid because it's blocked by environment blocks), but I'm having difficulty finding a simple way of solving this problem. I know that I could implement A* and it would be more-or-less easy with all the sample code out there, but I don't think the performance hit would really be necessary or worth it for such a seemingly trivial operation.
W--Top Of Grid--W
W---------------W
W-EEAEE-----EEE-W
WEEEEEEE-EEEEAEEW
WEEEEEEE--EEEEEEW
WEEEEEEEE-AEEEEEW
WWWWWWWWWWWWWWWWW
The A on the third line down can draw a path to the top of the grid, as can the one on the last line, however the one on the fourth line down cannot. I don't care for the actual paths, I just need to determine if the object is trapped or not. What would be the optimal solution to this project?
For what it's worth, it's a C# project for a turn-based grid game if that helps at all.
Thank you in advance for any help you can offer, it's much appreciated.

I think a floodfill from the top grids will solve all the problem. Flood from the top, then check which 'A' are flooded :)
The algorithm guarantees to visit each node only once during the whole process, which can not be faster in worst case. And it's really easy to be implemented in any language.
Here's the algorithm from Wikipedia:
Flood-fill (node, target-color, replacement-color):
1. If the color of node is not equal to target-color, return.
2. Set the color of node to replacement-color.
3. Perform Flood-fill (one step to the west of node, target-color, replacement-color).
Perform Flood-fill (one step to the east of node, target-color, replacement-color).
Perform Flood-fill (one step to the north of node, target-color, replacement-color).
Perform Flood-fill (one step to the south of node, target-color, replacement-color).
4. Return.
...and it looks like: (from wiki)
In short:
flood from the top grids, with 'W' and 'E' blocking the flood (like the black cells in the picture)
after the flood, check how many places containing 'A' are flooded.

Related

Randomly generating a maze in winforms

So for a project I wanted to make a game which involves randomly generating a maze with some space in the middle of the maze with 2 entrances on opposing sides. The objective is for 2 players to spawn on each side of said maze and to make their way into the middle in which they fight. I've thought about a few ways to approach this:
using the graph class in c# to generate a grid of nodes - then generating a path through it
using an array to draw out the grid of nodes - and generating a path through it
In terms of the algorithm, I've decided to go with the recursive backtracking algorithm.
My problem is how would I implement this into either method and how would I be able to apply this to my game ie space in the middle with 2 entrances.
Any other methods for drawing out the maze are also welcome, I'm relatively new to coding so please give pointers.
So far all I've done is design the logic for this algorithm.
Any help is appreciated, Thanks.

Problem in designing an algorithm that moves structures in an array[][] in a certain way

I am a beginner C programmer.
I have been failing to find an algorythm that can solve the following problem:
On an array "board[x][y]" with two dimensions, which contains
following arranged elements:
Floor (white), Item (blue), Backpack (green) and Player (orange), the Player can move and can move Items by directly "touching" them, in a way that they move into the same direction and
stay attatched. "Touching" is defined by an Item being on either of
the four sides of the Player.
Graphic 1 describing predicted movement
If there is a Backpack attatched to the Player, the Backpack itself
acts as kind of a sticky attachment, moving all Items attached to that
Backpack, including other Backpacks.
Graphic 2 describing predicted movement
Is there an algorithm that can sucessfully move the resulting "structures" formable by the rules, only moving Items "attached"? If you can help me find a way or guide me on a path, I'd be very happy to learn about it.
Thank you in advance.
Store in a list the positions of the player and of the attached items and backpacks. When you perform a move, all elements in the list move. After the move, consider the player and backpacks in the list, and add the neighboring items or backpacks that are not already there.
[But see my second comment.]

Accessing or omitting non-existing data

I'm performing some geographical computations in a grid with squares (i.e. regions). I'm using Delphi, but the logic could probably be applied to C++ too. Let me first explain what I want to do.
The following image is a portion of my grid, which is represented by a two-dimensional array Square that denotes the centre point in each square, and the "movement through the layers":
The green square has an X and Y coordinate of 2, so that is Square[2,2]. The actual coordinates are stored in Square[2,2].Latitude and Square[2,2].Longitude as wel as extra information in e.g. Square[2,2].Info that I use for computations.
Now comes the purpose: I need to do some computations on the surrounding areas. How many of the surrounding areas can be called "neighbours", depends on how many "layers" I have defined. In the image above, I used two of these "layers". That means that when starting from the green cell, I go around it once (blue arrows) and then again in the second layer (red arrows).
Now comes the problem: if I would have started in Square[1,1] (green square) instead of Square[2,2] as in the image below, the second layer (in red) would try to access data on the left side and at the bottom that does not exist (i.e. in the "-1" column and row). See the image below. This problem occurs at all borders of course.
I probably can make exceptions with IF-statements for every scenario, but I was wondering if there are common programming "tricks" that can handle such situations where you try to access data does not exist.
For example, I imagine it would be very handy if I can follow the pattern of the arrows depicted in the first image to access all the neighbouring squares every single time, even if there are non-existing squares. So, looking at the first image, after Square[3,0] you'd go to something like Square[3,-1] etc. and then eventually come back into the "feasible" zone in Square[0,3].
To visit neighborhood, you can use some kind of BFS (breadth-first search).
But for sparse structure (like the last picture shows) it is worth to use some data structure to organize cells in a good way. Perhaps kd-tree is suitable - you add all existing cells in the tree and make range search around given cell to get other cells in its vicinity.
Also look at another spatial data structures (see list at the bottom of kd-tree page).

Occlusion culling 3D transformed 2D rectangles?

So, to start off, I'm not very good at computer graphics. I'm trying to implement a GUI toolkit where one of the features is being able to apply 3D transformations to 2D "layers". (a layer only has one Z coordinate, as pre-transform, it's a two dimensional axis aligned rectangle)
Now, this is pretty straightforward, until you come to 3D transformations that would push the layer back, requiring splitting the layer into several polygons in order to render it correctly, as illustrated here. And because we can have transparency, layers may not get completely occluded, while still requiring getting split.
So here is an illustration depicting the issue and the desired outcome. In this scenario, the blue layer (call it B) is on top of the red layer (R), while having the same Z position (but B was added after R). In this scenario, if we rotate B, its top two points will get a Z index lower than 0 while the bottom points will get an index higher than 0 (with the anchor point being the only point/line left as 0).
Can somebody suggest a good way of doing this on the CPU? I've struggled to find a suitable algorithm implementation (in C++ or C) that would be appropriate to this scenario.
Edit: To clarify myself, at this stage in the pipeline, there is no rendering yet. We just need to produce a set of polygons for each layer that would then represent the layer's transformed and occluded geometry. Then, if required, rendering (either software or hardware) is done if required, which is not always the case (for example, when doing hit testing).
Edit 2: I looked at binary space partitioning as an option of achieving this but I have only been able to find one implementation (in GL2PS), which I'm not sure how to use. I do have a vague understanding of how BSPs work, but I'm not sure how they can be used for occlusion culling.
Edit 3: I'm not trying to do colour and transparency blending at this stage. Just pure geometry. Transparency can be handled by the renderer, and overdraw is okay. In this case, the blue polygon can just be drawn under the red one, but with more complicated cases, depth sorting or even splitting up the polygons may be required (example of a scary case like that below). Although the viewport is fixed, because all layers can be transformed in 3D, creating a shape shown below is possible.
So what I'm really looking for is an algorithm that would geometrically split layer B into two blue shapes, one of which would be drawn "above" and one of which would be drawn below R. The part "below" would get overdraw, yes, but it's not a major issue. So B just need to be split into two polygons so it would appear to cut through R when those polygons are drawn in order. No need to worry about blending.
Edit 4: For the purpose of this, we cannot render anything at all. This all has to be done purely geometrically (producing 2D polygons). This is what I was originally getting at.
Edit 5: I should note that the overall number of quads per subscene is around 30 (average). Definitely won't go above 100. Unless the layers are 3D transformed (which is where this problem arises), they are just radix sorted by Z positions before being drawn. Layers with the same Z position are drawn in order in which they were added (first in, first out).
Sorry if I didn't make it clear in the original question.
If you "aren't good with computer graphics", Doing it on CPU (software rendering) will be extremely difficult for you, if polygons can be transparent.
The easiest way to do it is to use GPU rendering (OpenGL/Direct3D) with Depth Peeling technique.
Cpu solutions:
Soltuion #1 (extremely difficult):
(I forgot the name of this algorithm).
You need to split polygon B into two, - for example, using polygon A as clip plane, then render result using painter's algorithm.
To do that you'll need to change your rendering routines so they'll no longer use quads, but textured polygons, plus you'll have to write/debug clipping routines that'll split triangles present in scene in such way that they'll no longer break paitner's algorithm.
Big Problem: If you have many polygons, this solution can potentially split scene into infinite number of triangles. Also, writing texture rendering code yourself isn't much fun, so it is advised to use OpenGL/Direct3D.
This can be extremely difficult to get right. I think this method was discussed in "Computer Graphics Using OpenGL 2nd edition" by "Francis S. Hill" - somewhere in one of their excercises.
Also check wikipedia article on Hidden Surface Removal.
Solution #2 (simpler):
You need to implement multi-layered z-buffer that stores up to N transparent pixels and their depth.
Solution #3 (computationally expensive):
Just use ray-tracing. You'll get perfect rendering result (no limitations of depth peeling and cpu solution #2), but it'll be computationally expensive, so you'll need to optimize rendering routines a lot.
Bottom line:
If you're performing software rendering, use Solution #2 or #3. If you're rendering on hardware, use technique similar to depth-peeling, or implement raytracing on hardware.
--edit-1--
required knowledge for implementing #1 and #2 is "line-plane intersection". If you understand how to split line (in 3d space) into two using a plane, you can implement raytracing or clipping easily.
Required knowledge for #2 is "textured 3d triangle rendering" (algorithm). It is a fairly complex topic.
In order to implement GPU solution, you need to be able to find few OpenGL tutorials that deal with shaders.
--edit-2--
Transparency is relevant, because in order to get transparency right, you need to draw polygons from back to front (from farthest to closest) using painter's algorithms. Sorting polygons properly is impossible in certain situation, so they must be split, or you should use one of the listed techniques, otherwise in certain situations there will be artifacts/incorrectly rendered images.
If there's no transparency, you can implement standard zbuffer or draw using hardware OpenGL, which is a very trivial task.
--edit-3--
I should note that the overall number of quads per subscene is around 30 (average). Definitely won't go above 100.
If you will split polygons, it can easily go way above 100.
It might be possible to position polygons in such way that each polygon will split all others polygon.
Now, 2^29 is 536870912, however, it is not possible to split one surface with a plane in such way that during each split number of polygons would double. If one polygon is split 29 timse, you'll get 30 polygons in the best-case scenario, and probably several thousands in the worst case if splitting planes aren't parallel.
Here's rough algorithm outline that should work:
Prepare list of all triangles in scene.
Remove back-facing triangles.
Find all triangles that intersect each other in 3d space, and split them using line of intersection.
compute screen-space coordinates for all vertices of all triangles.
Sort by depth for painter's algorithm.
Prepare extra list for new primitives.
Find triangles that overlap in 2D (post projection) screen space.
For all overlapping triangles check their rendering order. Basically a triangle that is going to be rendered "below" another triangles should have no part that is above another triangle.
8.1. To do that, use camera origin point and triangle edges to split original triangles into several sub-regions, then check if regions conform to established sort order (prepared for painter's algorithm). Regions are created by splitting existing pair of triangles using 6 clip planes created by camera origin points and triangle edges.
8.2. If all regions conform to rendering order, leave triangles be. If they don't, remove triangles from list, and add them to the "new primitives" list.
IF there are any primitives in new primitives list, merge the list with triangle list, and go to #5.
By looking at that algorithm, you can easily understand why everybody uses Z-buffer nowadays.
Come to think about it, that's a good training exercise for universities that specialize in CG. The kind of exercise that might make your students hate you.
I am going to come out say give the simpler solution, which may not fit your problem. Why not just change your artwork to prevent this problem from occuring.
In problem 1, just divide the polys in Maya or whatever beforehand. For the 3 lines problem, again, divide your polys at the intersections to prevent fighting. Pre-computed solutions will always run faster than on the fly ones - especially on limited hardware. From profesional experience, I can say that it also does scale, well it scales ok. It just requires some tweaking from the art side and technical reviews to make sure nothing is created "ilegally." You may end up getting more polys doing it this way than rendering on the fly, but at least you won't have to do a ton of math on CPUs that may not be up to the task.
If you do not have control over the artwork pipeline, this won't work as writing some sort of a converter would take longer than getting a BSP sub-division routine up and running. Still, KISS is often the best solution.

Search techniques for a bot in a field

My field consists of open grid spaces and filled grid spaces. My bot can move on only open spaces. It can only detect if there is a filled grid space in any of its 8 neighbouring grids (i.e. up, down, left, right , and diagnol spaces). That is, it cannot look beyond the 8 neighbouring spaces. What would be the best search technique in such a grid? My aim, lets say, is to find the no of objects in the grid ( an object is a connected set of filled spaces)
I've tried the following, all have been pretty bad:
keeping a list of spaces visited ( by taking initial position as 0,0 and storing relative positions of the spaces visited). That is, I preferably visit those locations which have not been visited.
Initially go to the bottommost and leftmost point, then start searching exhaustively for 5 bottom rows, then the next 5 bottom rows, and so on...
I'm not entirely sure I understand your aim, but the most common (non-optimized) algorithm for general grid path-finding, grid flood-fill, etc. is A* (pronounced "A - Star"). Its most widespread application is grid-based path-finding with "open" and "closed" nodes; much like your "open" and "filled" grid spaces.
Check out
http://en.wikipedia.org/wiki/A*_search_algorithm
Hope that helps!
You don't describe why you consider your solutions "pretty bad", but I assume you observe inefficient search behavior. An attempt you might want to try is to label each space with "value of information" that is, how many previously undiscovered neighboring spaces will you discover when you would visit that space. This is your "reward". Your "cost" is the distance to travel to that particular space. Then you will have to find a devise a search strategy that maximizes (reward - cost).
Sounds like a partially observable markov decision process. Maybe have a look at reinforcement learning. There's a free online version of a book by Sutton and Barto.
I think the problem is too hard for reinforcement learning producing a good result and it is too uncertain for classical approaches (using logic).

Resources