Hex is done and working

This commit is contained in:
2020-12-16 04:50:21 -07:00
parent f8ce6d0c83
commit e8ffbd3151
19 changed files with 1123 additions and 282 deletions

View File

@@ -7,9 +7,11 @@
<e p="Bootstrapper.cs" t="Include" /> <e p="Bootstrapper.cs" t="Include" />
<e p="ConsoleApp.csproj" t="IncludeRecursive" /> <e p="ConsoleApp.csproj" t="IncludeRecursive" />
<e p="CoreModule.cs" t="Include" /> <e p="CoreModule.cs" t="Include" />
<e p="HexPlot.py" t="Include" />
<e p="IJsonDeserializor.cs" t="Include" /> <e p="IJsonDeserializor.cs" t="Include" />
<e p="IModule.cs" t="Include" /> <e p="IModule.cs" t="Include" />
<e p="ISimRunner.cs" t="Include" /> <e p="ISimRunner.cs" t="Include" />
<e p="ISimulationResults.cs" t="Include" />
<e p="IUserConsole.cs" t="Include" /> <e p="IUserConsole.cs" t="Include" />
<e p="JsonDeserializor.cs" t="Include" /> <e p="JsonDeserializor.cs" t="Include" />
<e p="Maps" t="Include"> <e p="Maps" t="Include">
@@ -35,10 +37,10 @@
</e> </e>
</e> </e>
<e p="Output" t="Include"> <e p="Output" t="Include">
<e p="DetectedMines.txt" t="Include" /> <e p="Data.txt" t="Include" />
<e p="Mines.txt" t="Include" /> <e p="HexDetectedMines.txt" t="Include" />
<e p="SavedList.txt" t="Include" /> <e p="HexPath.txt" t="Include" />
<e p="test.png" t="Include" /> <e p="HexTest.png" t="Include" />
</e> </e>
<e p="PathPlanners" t="Include"> <e p="PathPlanners" t="Include">
<e p="IPathPlanner.cs" t="Include" /> <e p="IPathPlanner.cs" t="Include" />
@@ -46,7 +48,6 @@
<e p="PathPlanner.cs" t="Include" /> <e p="PathPlanner.cs" t="Include" />
<e p="ReactivePathPlanner.cs" t="Include" /> <e p="ReactivePathPlanner.cs" t="Include" />
</e> </e>
<e p="plot.py" t="Include" />
<e p="Program.cs" t="Include" /> <e p="Program.cs" t="Include" />
<e p="Sim" t="Include"> <e p="Sim" t="Include">
<e p="DetectionHead.cs" t="Include" /> <e p="DetectionHead.cs" t="Include" />
@@ -56,6 +57,7 @@
<e p="VehicleConfiguration.json" t="Include" /> <e p="VehicleConfiguration.json" t="Include" />
</e> </e>
<e p="SimRunner.cs" t="Include" /> <e p="SimRunner.cs" t="Include" />
<e p="SimulationResults.cs" t="Include" />
<e p="UserConsole.cs" t="Include" /> <e p="UserConsole.cs" t="Include" />
</e> </e>
<e p="packages" t="ExcludeRecursive" /> <e p="packages" t="ExcludeRecursive" />

View File

@@ -18,29 +18,21 @@
</component> </component>
<component name="ChangeListManager"> <component name="ChangeListManager">
<list default="true" id="dafcaeb7-80aa-43a3-a480-786fafb78c0b" name="Default Changelist" comment=""> <list default="true" id="dafcaeb7-80aa-43a3-a480-786fafb78c0b" name="Default Changelist" comment="">
<change afterPath="$PROJECT_DIR$/ConsoleApp/plot.py" afterDir="false" /> <change afterPath="$PROJECT_DIR$/ConsoleApp/ISimulationResults.cs" afterDir="false" />
<change afterPath="$PROJECT_DIR$/ConsoleApp/SimulationResults.cs" afterDir="false" />
<change beforePath="$PROJECT_DIR$/.idea/.idea.RobotIntelFinal/.idea/contentModel.xml" beforeDir="false" afterPath="$PROJECT_DIR$/.idea/.idea.RobotIntelFinal/.idea/contentModel.xml" afterDir="false" /> <change beforePath="$PROJECT_DIR$/.idea/.idea.RobotIntelFinal/.idea/contentModel.xml" beforeDir="false" afterPath="$PROJECT_DIR$/.idea/.idea.RobotIntelFinal/.idea/contentModel.xml" afterDir="false" />
<change beforePath="$PROJECT_DIR$/.idea/.idea.RobotIntelFinal/.idea/workspace.xml" beforeDir="false" afterPath="$PROJECT_DIR$/.idea/.idea.RobotIntelFinal/.idea/workspace.xml" afterDir="false" /> <change beforePath="$PROJECT_DIR$/.idea/.idea.RobotIntelFinal/.idea/workspace.xml" beforeDir="false" afterPath="$PROJECT_DIR$/.idea/.idea.RobotIntelFinal/.idea/workspace.xml" afterDir="false" />
<change beforePath="$PROJECT_DIR$/ConsoleApp/ConsoleApp.csproj" beforeDir="false" afterPath="$PROJECT_DIR$/ConsoleApp/ConsoleApp.csproj" afterDir="false" /> <change beforePath="$PROJECT_DIR$/ConsoleApp/ConsoleApp.csproj" beforeDir="false" afterPath="$PROJECT_DIR$/ConsoleApp/ConsoleApp.csproj" afterDir="false" />
<change beforePath="$PROJECT_DIR$/ConsoleApp/Maps/HexMap.cs" beforeDir="false" afterPath="$PROJECT_DIR$/ConsoleApp/Maps/HexMap.cs" afterDir="false" /> <change beforePath="$PROJECT_DIR$/ConsoleApp/CoreModule.cs" beforeDir="false" afterPath="$PROJECT_DIR$/ConsoleApp/CoreModule.cs" afterDir="false" />
<change beforePath="$PROJECT_DIR$/ConsoleApp/Maps/IHexMap.cs" beforeDir="false" afterPath="$PROJECT_DIR$/ConsoleApp/Maps/IHexMap.cs" afterDir="false" />
<change beforePath="$PROJECT_DIR$/ConsoleApp/Maps/IMapFactory.cs" beforeDir="false" afterPath="$PROJECT_DIR$/ConsoleApp/Maps/IMapFactory.cs" afterDir="false" />
<change beforePath="$PROJECT_DIR$/ConsoleApp/Maps/IMineMap.cs" beforeDir="false" afterPath="$PROJECT_DIR$/ConsoleApp/Maps/IMineMap.cs" afterDir="false" /> <change beforePath="$PROJECT_DIR$/ConsoleApp/Maps/IMineMap.cs" beforeDir="false" afterPath="$PROJECT_DIR$/ConsoleApp/Maps/IMineMap.cs" afterDir="false" />
<change beforePath="$PROJECT_DIR$/ConsoleApp/Maps/MapExtensions.cs" beforeDir="false" afterPath="$PROJECT_DIR$/ConsoleApp/Maps/MapExtensions.cs" afterDir="false" />
<change beforePath="$PROJECT_DIR$/ConsoleApp/Maps/MapFactory.cs" beforeDir="false" afterPath="$PROJECT_DIR$/ConsoleApp/Maps/MapFactory.cs" afterDir="false" />
<change beforePath="$PROJECT_DIR$/ConsoleApp/Maps/MineMap.cs" beforeDir="false" afterPath="$PROJECT_DIR$/ConsoleApp/Maps/MineMap.cs" afterDir="false" /> <change beforePath="$PROJECT_DIR$/ConsoleApp/Maps/MineMap.cs" beforeDir="false" afterPath="$PROJECT_DIR$/ConsoleApp/Maps/MineMap.cs" afterDir="false" />
<change beforePath="$PROJECT_DIR$/ConsoleApp/Maps/SquareMap.cs" beforeDir="false" afterPath="$PROJECT_DIR$/ConsoleApp/Maps/SquareMap.cs" afterDir="false" /> <change beforePath="$PROJECT_DIR$/ConsoleApp/Output/DetectedMines.txt" beforeDir="false" afterPath="$PROJECT_DIR$/ConsoleApp/Output/DetectedMines.txt" afterDir="false" />
<change beforePath="$PROJECT_DIR$/ConsoleApp/PathPlanners/IReactivePathPlanner.cs" beforeDir="false" afterPath="$PROJECT_DIR$/ConsoleApp/PathPlanners/IReactivePathPlanner.cs" afterDir="false" /> <change beforePath="$PROJECT_DIR$/ConsoleApp/Output/Mines.txt" beforeDir="false" afterPath="$PROJECT_DIR$/ConsoleApp/Output/Mines.txt" afterDir="false" />
<change beforePath="$PROJECT_DIR$/ConsoleApp/PathPlanners/PathPlanner.cs" beforeDir="false" afterPath="$PROJECT_DIR$/ConsoleApp/PathPlanners/PathPlanner.cs" afterDir="false" /> <change beforePath="$PROJECT_DIR$/ConsoleApp/Output/SavedList.txt" beforeDir="false" afterPath="$PROJECT_DIR$/ConsoleApp/Output/SavedList.txt" afterDir="false" />
<change beforePath="$PROJECT_DIR$/ConsoleApp/PathPlanners/ReactivePathPlanner.cs" beforeDir="false" afterPath="$PROJECT_DIR$/ConsoleApp/PathPlanners/ReactivePathPlanner.cs" afterDir="false" /> <change beforePath="$PROJECT_DIR$/ConsoleApp/Output/test.png" beforeDir="false" afterPath="$PROJECT_DIR$/ConsoleApp/Output/test.png" afterDir="false" />
<change beforePath="$PROJECT_DIR$/ConsoleApp/Program.cs" beforeDir="false" afterPath="$PROJECT_DIR$/ConsoleApp/Program.cs" afterDir="false" /> <change beforePath="$PROJECT_DIR$/ConsoleApp/Program.cs" beforeDir="false" afterPath="$PROJECT_DIR$/ConsoleApp/Program.cs" afterDir="false" />
<change beforePath="$PROJECT_DIR$/ConsoleApp/Sim/DetectionHead.cs" beforeDir="false" afterPath="$PROJECT_DIR$/ConsoleApp/Sim/DetectionHead.cs" afterDir="false" />
<change beforePath="$PROJECT_DIR$/ConsoleApp/Sim/IVehicle.cs" beforeDir="false" afterPath="$PROJECT_DIR$/ConsoleApp/Sim/IVehicle.cs" afterDir="false" />
<change beforePath="$PROJECT_DIR$/ConsoleApp/Sim/Vehicle.cs" beforeDir="false" afterPath="$PROJECT_DIR$/ConsoleApp/Sim/Vehicle.cs" afterDir="false" />
<change beforePath="$PROJECT_DIR$/ConsoleApp/Sim/VehicleConfiguration.cs" beforeDir="false" afterPath="$PROJECT_DIR$/ConsoleApp/Sim/VehicleConfiguration.cs" afterDir="false" />
<change beforePath="$PROJECT_DIR$/ConsoleApp/Sim/VehicleConfiguration.json" beforeDir="false" afterPath="$PROJECT_DIR$/ConsoleApp/Sim/VehicleConfiguration.json" afterDir="false" />
<change beforePath="$PROJECT_DIR$/ConsoleApp/SimRunner.cs" beforeDir="false" afterPath="$PROJECT_DIR$/ConsoleApp/SimRunner.cs" afterDir="false" /> <change beforePath="$PROJECT_DIR$/ConsoleApp/SimRunner.cs" beforeDir="false" afterPath="$PROJECT_DIR$/ConsoleApp/SimRunner.cs" afterDir="false" />
<change beforePath="$PROJECT_DIR$/ConsoleApp/UserConsole.cs" beforeDir="false" afterPath="$PROJECT_DIR$/ConsoleApp/UserConsole.cs" afterDir="false" /> <change beforePath="$PROJECT_DIR$/ConsoleApp/plot.py" beforeDir="false" afterPath="$PROJECT_DIR$/ConsoleApp/HexPlot.py" afterDir="false" />
</list> </list>
<option name="SHOW_DIALOG" value="false" /> <option name="SHOW_DIALOG" value="false" />
<option name="HIGHLIGHT_CONFLICTS" value="true" /> <option name="HIGHLIGHT_CONFLICTS" value="true" />
@@ -129,7 +121,6 @@
<option value="$PROJECT_DIR$/ConsoleApp/Maps/ICell.cs" /> <option value="$PROJECT_DIR$/ConsoleApp/Maps/ICell.cs" />
<option value="$PROJECT_DIR$/ConsoleApp/PathPlanners/IPathPlanner.cs" /> <option value="$PROJECT_DIR$/ConsoleApp/PathPlanners/IPathPlanner.cs" />
<option value="$PROJECT_DIR$/ConsoleApp/ConsoleApp.csproj" /> <option value="$PROJECT_DIR$/ConsoleApp/ConsoleApp.csproj" />
<option value="$PROJECT_DIR$/ConsoleApp/CoreModule.cs" />
<option value="$PROJECT_DIR$/ConsoleApp/Maps/CellExtensions.cs" /> <option value="$PROJECT_DIR$/ConsoleApp/Maps/CellExtensions.cs" />
<option value="$PROJECT_DIR$/ConsoleApp/Maps/MapExtensions.cs" /> <option value="$PROJECT_DIR$/ConsoleApp/Maps/MapExtensions.cs" />
<option value="$PROJECT_DIR$/ConsoleApp/Sim/IVehicle.cs" /> <option value="$PROJECT_DIR$/ConsoleApp/Sim/IVehicle.cs" />
@@ -138,19 +129,22 @@
<option value="$PROJECT_DIR$/ConsoleApp/UserConsole.cs" /> <option value="$PROJECT_DIR$/ConsoleApp/UserConsole.cs" />
<option value="$PROJECT_DIR$/ConsoleApp/Maps/SquareMap.cs" /> <option value="$PROJECT_DIR$/ConsoleApp/Maps/SquareMap.cs" />
<option value="$PROJECT_DIR$/ConsoleApp/Maps/HexMap.cs" /> <option value="$PROJECT_DIR$/ConsoleApp/Maps/HexMap.cs" />
<option value="$PROJECT_DIR$/ConsoleApp/Maps/IMineMap.cs" />
<option value="$PROJECT_DIR$/ConsoleApp/Maps/MapFactory.cs" /> <option value="$PROJECT_DIR$/ConsoleApp/Maps/MapFactory.cs" />
<option value="$PROJECT_DIR$/ConsoleApp/Maps/IMapFactory.cs" /> <option value="$PROJECT_DIR$/ConsoleApp/Maps/IMapFactory.cs" />
<option value="$PROJECT_DIR$/ConsoleApp/Sim/VehicleConfiguration.cs" /> <option value="$PROJECT_DIR$/ConsoleApp/Sim/VehicleConfiguration.cs" />
<option value="$PROJECT_DIR$/ConsoleApp/Sim/Vehicle.cs" /> <option value="$PROJECT_DIR$/ConsoleApp/Sim/Vehicle.cs" />
<option value="$PROJECT_DIR$/ConsoleApp/Sim/VehicleConfiguration.json" /> <option value="$PROJECT_DIR$/ConsoleApp/Sim/VehicleConfiguration.json" />
<option value="$PROJECT_DIR$/ConsoleApp/Sim/DetectionHead.cs" /> <option value="$PROJECT_DIR$/ConsoleApp/Sim/DetectionHead.cs" />
<option value="$PROJECT_DIR$/ConsoleApp/Program.cs" />
<option value="$PROJECT_DIR$/ConsoleApp/Maps/MineMap.cs" />
<option value="$PROJECT_DIR$/ConsoleApp/plot.py" />
<option value="$PROJECT_DIR$/ConsoleApp/PathPlanners/PathPlanner.cs" /> <option value="$PROJECT_DIR$/ConsoleApp/PathPlanners/PathPlanner.cs" />
<option value="$PROJECT_DIR$/ConsoleApp/PathPlanners/ReactivePathPlanner.cs" /> <option value="$PROJECT_DIR$/ConsoleApp/PathPlanners/ReactivePathPlanner.cs" />
<option value="$PROJECT_DIR$/ConsoleApp/CoreModule.cs" />
<option value="$PROJECT_DIR$/ConsoleApp/plot.py" />
<option value="$PROJECT_DIR$/ConsoleApp/Maps/MineMap.cs" />
<option value="$PROJECT_DIR$/ConsoleApp/Maps/IMineMap.cs" />
<option value="$PROJECT_DIR$/ConsoleApp/SimRunner.cs" /> <option value="$PROJECT_DIR$/ConsoleApp/SimRunner.cs" />
<option value="$PROJECT_DIR$/ConsoleApp/ISimulationResults.cs" />
<option value="$PROJECT_DIR$/ConsoleApp/Program.cs" />
<option value="$PROJECT_DIR$/ConsoleApp/SimulationResults.cs" />
</changedPaths> </changedPaths>
</component> </component>
<component name="ProjectId" id="1lIZ7IfsUjzqV2Jb1obOFvGFAfp" /> <component name="ProjectId" id="1lIZ7IfsUjzqV2Jb1obOFvGFAfp" />
@@ -228,7 +222,7 @@
<workItem from="1607982179018" duration="634000" /> <workItem from="1607982179018" duration="634000" />
<workItem from="1607983288378" duration="86000" /> <workItem from="1607983288378" duration="86000" />
<workItem from="1607983862958" duration="7777000" /> <workItem from="1607983862958" duration="7777000" />
<workItem from="1607993290571" duration="69552000" /> <workItem from="1607993290571" duration="72449000" />
</task> </task>
<servers /> <servers />
</component> </component>

View File

@@ -22,7 +22,7 @@
<None Update="Sim\VehicleConfiguration.json"> <None Update="Sim\VehicleConfiguration.json">
<CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory> <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
</None> </None>
<None Update="plot.py"> <None Update="HexPlot.py">
<CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory> <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
</None> </None>
</ItemGroup> </ItemGroup>

View File

@@ -15,6 +15,7 @@ namespace ConsoleApp
container.Register<IJsonDeserializor, JsonDeserializor>(Reuse.Singleton); container.Register<IJsonDeserializor, JsonDeserializor>(Reuse.Singleton);
container.Register<IPathPlanner, PathPlanner>(Reuse.Singleton); container.Register<IPathPlanner, PathPlanner>(Reuse.Singleton);
container.Register<IReactivePathPlanner, ReactivePathPlanner>(Reuse.Singleton); container.Register<IReactivePathPlanner, ReactivePathPlanner>(Reuse.Singleton);
container.Register<ISimulationResults, SimulationResults>(Reuse.Singleton);
} }

View File

@@ -10,7 +10,7 @@ if __name__ == "__main__":
ym = [] ym = []
xf = [] xf = []
yf = [] yf = []
with open("/Users/brady.bodily/Documents/Repositories/CS5890_Robot_Intelligence/RobotIntelFinal/ConsoleApp/Output/SavedList.txt") as c: with open("/Users/brady.bodily/Documents/Repositories/CS5890_Robot_Intelligence/RobotIntelFinal/ConsoleApp/Output/HexPath.txt") as c:
for line in c: for line in c:
x, y = line.split() x, y = line.split()
xc.append(int(x)) xc.append(int(x))
@@ -22,7 +22,7 @@ if __name__ == "__main__":
xm.append(int(x)) xm.append(int(x))
ym.append(int(y)) ym.append(int(y))
with open("/Users/brady.bodily/Documents/Repositories/CS5890_Robot_Intelligence/RobotIntelFinal/ConsoleApp/Output/DetectedMines.txt") as f: with open("/Users/brady.bodily/Documents/Repositories/CS5890_Robot_Intelligence/RobotIntelFinal/ConsoleApp/Output/HexDetectedMines.txt") as f:
for line in f: for line in f:
x, y = line.split() x, y = line.split()
xf.append(int(x)) xf.append(int(x))
@@ -32,8 +32,8 @@ if __name__ == "__main__":
plt.plot(xc, yc, 'o', label='vehicle', color='blue') plt.plot(xc, yc, 'o', label='vehicle', color='blue')
plt.plot(xm, ym, 'o', label='all mines', color='red') plt.plot(xm, ym, 'o', label='all mines', color='red')
plt.plot(xf, yf, 'o', label='detected mines', color='orange') plt.plot(xf, yf, 'o', label='detected mines', color='orange')
plt.title('test 9') plt.title('Hex Simulation')
plt.legend(loc='lower left', fontsize='xx-small') plt.legend(loc='lower left', fontsize='xx-small')
matplotlib.pyplot.savefig('/Users/brady.bodily/Documents/Repositories/CS5890_Robot_Intelligence/RobotIntelFinal/ConsoleApp/Output/test.png') matplotlib.pyplot.savefig('/Users/brady.bodily/Documents/Repositories/CS5890_Robot_Intelligence/RobotIntelFinal/ConsoleApp/Output/HexTest.png')
plt.close(fig) plt.close(fig)

View File

@@ -0,0 +1,19 @@
using System.Collections.Generic;
using ConsoleApp.Maps;
using HexCore;
namespace ConsoleApp
{
public interface ISimulationResults
{
void WriteResults();
int HexTotalMoves { get; set; }
int HexBombsFound { get; set; }
int TotalBombs { get; set; }
List<Coordinate2D> HexPath { get; set; }
List<Coordinate2D> HexMappedBombs { get; set; }
List<Cell> Mines { get; set; }
int HexClearedCells { get; set; }
int HexUnClearedCells { get; set; }
}
}

View File

@@ -1,3 +1,5 @@
using System.Collections.Generic;
namespace ConsoleApp.Maps namespace ConsoleApp.Maps
{ {
public interface IMineMap public interface IMineMap
@@ -6,5 +8,6 @@ namespace ConsoleApp.Maps
int TotalBombs { get; } int TotalBombs { get; }
bool GetCell(int x, int y); bool GetCell(int x, int y);
List<Cell> PlacedMines { get; }
} }
} }

View File

@@ -12,23 +12,19 @@ namespace ConsoleApp.Maps
private int _y; private int _y;
public bool[,] Map { get; } public bool[,] Map { get; }
public int TotalBombs { get; } public int TotalBombs { get; }
private List<Cell> _placedMines; public List<Cell> PlacedMines { get; }
public MineMap(int x, int y, double minePercentage) public MineMap(int x, int y, double minePercentage)
{ {
_x = x; _x = x;
_y = y; _y = y;
_placedMines = new List<Cell>(); PlacedMines = new List<Cell>();
_mineCount = (int)(x*y*(minePercentage/100)); _mineCount = (int)(x*y*(minePercentage/100));
TotalBombs = _mineCount; TotalBombs = _mineCount;
Map = new bool[x, y]; Map = new bool[x, y];
Map.Fill2DArray(false); Map.Fill2DArray(false);
PlaceMines(); PlaceMines();
using(TextWriter tw = new StreamWriter("/Users/brady.bodily/Documents/Repositories/CS5890_Robot_Intelligence/RobotIntelFinal/ConsoleApp/Output/Mines.txt"))
{
foreach (var s in _placedMines)
tw.WriteLine($"{s.X} {s.Y}");
}
} }
public bool GetCell(int x, int y) => Map[x,y]; public bool GetCell(int x, int y) => Map[x,y];
@@ -47,7 +43,7 @@ namespace ConsoleApp.Maps
else else
{ {
Map[x, y] = true; Map[x, y] = true;
_placedMines.Add(new Cell(x,y)); PlacedMines.Add(new Cell(x,y));
} }
} }
} }

View File

@@ -0,0 +1,7 @@
General:
Total Mines: 23
Hex:
Total Moves: 927
Bombs Found: 23
Cleared Cell Count: 2295
Uncleared Cell Count: 9

View File

@@ -1,7 +0,0 @@
8 5
8 6
5 11
9 10
13 9
13 14
10 13

View File

View File

@@ -0,0 +1,927 @@
0 0
1 0
2 0
3 0
4 0
5 0
6 0
7 0
8 0
9 0
10 0
11 0
12 0
13 0
14 0
15 0
16 0
17 0
18 0
19 0
20 0
21 0
22 0
23 0
24 0
25 0
26 0
27 0
28 0
29 0
30 0
31 0
32 0
33 0
34 0
35 0
36 0
37 0
38 0
39 0
40 0
41 0
42 0
43 0
44 0
45 0
46 0
47 0
47 1
47 2
47 3
46 3
45 3
44 3
43 3
42 3
41 3
40 3
39 3
38 3
37 3
36 3
35 3
34 3
33 3
32 3
31 3
30 3
29 3
28 3
27 3
26 3
25 3
24 3
23 3
22 3
21 3
20 3
19 3
18 3
17 3
16 3
15 3
14 3
13 3
12 3
11 3
10 3
9 3
8 3
7 3
6 3
5 3
4 3
3 3
2 3
1 3
0 3
1 4
0 5
0 6
1 6
2 6
3 6
4 6
5 6
6 6
7 6
6 5
7 4
8 4
9 4
10 4
10 5
11 6
12 6
13 6
14 6
15 6
16 6
17 6
18 6
19 6
20 6
21 6
20 5
21 4
22 4
23 4
24 4
24 5
25 6
26 6
27 6
28 6
29 6
30 6
31 6
32 6
33 6
34 6
35 6
36 6
37 6
38 6
39 6
40 6
41 6
42 6
43 6
44 6
45 6
46 6
47 6
47 7
47 8
47 9
46 9
45 9
44 9
43 9
42 9
41 9
40 9
39 9
38 9
37 9
36 9
35 9
34 9
33 9
32 9
31 9
30 9
29 9
28 9
27 9
27 8
26 8
25 8
24 9
24 9
24 10
23 10
23 11
23 12
22 12
21 12
20 12
19 11
19 10
18 9
17 9
16 9
15 9
14 9
13 9
12 9
12 9
13 10
12 11
12 12
13 12
13 13
13 14
12 15
12 16
11 16
10 16
9 16
8 15
8 14
7 13
7 12
6 11
6 10
5 9
4 9
3 9
2 9
1 9
0 9
1 10
0 11
0 12
1 12
2 12
3 12
4 12
5 12
6 12
7 12
8 12
8 12
7 13
8 14
8 15
9 16
10 16
11 16
12 16
12 15
13 14
13 13
13 12
14 12
15 12
16 12
17 12
18 12
19 12
20 12
21 12
22 12
22 12
21 13
21 14
20 13
19 13
19 14
18 15
18 16
18 17
19 18
19 19
20 19
21 19
22 19
23 18
23 17
23 18
23 19
24 19
25 19
26 19
27 18
27 17
28 16
28 15
29 14
29 13
30 12
31 12
32 12
33 12
34 12
35 12
36 12
37 12
38 12
39 12
40 12
41 12
42 12
43 12
44 12
45 12
46 12
47 12
47 13
47 14
47 15
46 15
45 15
44 15
43 15
42 15
41 15
41 14
40 14
39 14
38 15
37 15
36 15
35 15
34 15
33 15
32 15
31 15
30 15
29 15
28 15
27 15
27 15
28 16
27 17
27 18
26 19
25 19
24 19
23 19
22 19
21 19
20 19
19 19
19 18
18 17
18 16
18 15
17 15
16 15
15 15
14 15
13 15
12 15
12 15
12 16
11 16
10 16
9 16
8 15
7 15
6 15
5 15
4 15
3 15
2 15
1 15
0 15
1 16
0 17
0 18
1 18
2 18
3 18
4 18
5 18
6 18
5 17
6 16
7 16
8 16
9 16
9 17
10 16
11 16
12 16
12 17
13 18
14 18
15 18
16 18
17 18
18 18
19 18
19 18
19 19
20 19
21 19
22 19
23 18
23 18
23 19
24 19
25 19
26 19
27 18
28 18
29 18
30 18
31 18
32 18
33 18
34 18
35 18
36 18
37 18
38 18
38 18
38 19
39 20
40 20
41 20
42 20
42 19
43 18
44 18
45 18
46 18
47 18
47 19
47 20
47 21
46 21
45 21
44 21
43 21
42 21
41 21
40 21
39 21
38 21
37 21
36 21
36 20
35 20
34 20
33 21
32 21
31 21
30 21
29 21
28 21
27 21
26 21
25 21
24 21
23 21
22 21
21 21
20 21
19 21
18 21
17 21
16 21
15 21
14 21
13 21
12 21
12 21
12 22
11 22
10 22
9 22
8 22
7 22
6 22
5 21
4 21
3 21
2 21
1 21
0 21
1 22
0 23
0 24
1 24
2 24
3 24
4 24
5 24
6 24
7 24
6 23
7 22
8 22
9 22
10 22
10 23
11 24
12 24
13 24
14 24
15 24
16 24
17 24
18 24
19 24
20 24
21 24
22 24
23 24
24 24
25 24
26 24
27 24
28 24
29 24
30 24
31 24
32 24
31 24
30 25
30 26
30 27
31 28
31 29
32 29
33 29
34 29
35 28
35 27
36 26
37 26
37 25
38 24
39 24
40 24
41 24
42 24
43 24
44 24
45 24
46 24
47 24
47 25
47 26
47 27
46 27
45 27
44 27
43 27
42 27
41 27
40 27
39 27
38 27
37 27
36 27
35 27
35 27
35 28
34 29
33 29
32 29
31 29
31 28
30 27
29 27
28 27
27 27
26 27
25 27
24 27
23 27
22 27
21 27
20 27
19 27
18 27
17 27
16 27
15 27
14 27
13 27
12 27
11 27
12 27
13 28
12 29
12 30
11 31
10 31
9 31
8 31
8 30
7 29
7 28
6 27
5 27
4 27
3 27
2 27
1 27
0 27
1 28
0 29
0 30
1 30
2 30
3 30
4 30
5 30
5 29
6 29
7 29
8 30
8 30
8 31
9 31
10 31
11 31
12 30
13 30
14 30
15 30
16 30
17 30
18 30
18 30
17 31
18 32
18 33
19 33
20 33
21 33
22 32
22 31
23 30
24 30
25 30
26 30
27 30
28 30
29 30
30 30
31 30
32 30
33 30
34 30
35 30
36 30
37 30
38 30
39 30
40 30
41 30
42 30
43 30
44 30
45 30
46 30
47 30
47 31
47 32
47 33
46 33
45 33
44 33
43 33
42 33
41 33
40 33
39 33
40 32
39 31
38 31
37 31
36 31
36 32
35 33
34 33
33 33
32 33
31 33
30 33
29 33
28 33
27 33
26 33
25 33
24 33
23 33
22 33
21 33
20 33
19 33
18 33
17 33
16 33
15 33
14 33
13 33
12 33
11 33
10 33
9 33
8 33
8 33
8 34
7 35
6 35
5 35
4 35
4 34
3 33
2 33
1 33
0 33
1 34
0 35
0 36
1 36
2 36
3 36
4 36
5 36
6 36
7 36
8 36
9 36
10 36
11 36
12 36
13 36
14 36
15 36
16 36
17 36
18 36
18 35
19 35
19 34
19 33
20 33
21 33
22 33
23 34
23 35
24 36
25 36
26 36
27 36
28 36
29 36
29 35
30 35
31 35
32 36
33 36
34 36
35 36
36 36
36 36
36 37
37 37
38 37
39 37
40 36
41 36
42 36
43 36
44 36
45 36
46 36
47 36
47 37
47 38
47 39
46 39
45 39
44 39
43 39
42 39
41 39
40 39
39 39
38 39
38 39
38 39
38 40
37 41
37 42
36 42
35 42
34 42
33 41
33 40
32 39
32 39
32 40
31 41
30 41
29 41
28 41
28 40
27 39
26 39
25 39
24 39
23 39
22 39
21 39
21 39
21 40
20 41
19 41
18 41
17 41
17 40
16 39
15 39
14 39
13 39
12 39
11 39
10 39
9 39
8 39
7 39
6 39
5 39
4 39
3 39
2 39
1 39
0 39
1 40
0 41
0 42
1 42
2 42
3 42
4 42
5 42
6 42
7 42
8 42
9 42
10 42
11 42
12 42
13 42
14 42
15 42
16 42
17 42
18 42
19 42
20 42
21 42
22 42
23 42
24 42
25 42
26 42
27 42
28 42
29 42
30 42
31 42
32 42
33 42
34 42
35 42
36 42
37 42
38 42
39 42
40 42
41 42
42 42
43 42
44 42
45 42
46 42
47 42
47 43
47 44
47 45
46 45
45 45
44 45
43 45
42 45
41 45
40 45
39 45
38 45
37 45
36 45
35 45
34 45
33 45
32 45
31 45
30 45
29 45
28 45
27 45
26 45
25 45
24 45
23 45
22 45
21 45
20 45
19 45
18 45
17 45
16 45
15 45
14 45
13 45
12 45
11 45
10 45
9 45
8 45
7 45
6 45
5 45
4 45
3 45
2 45
1 45
0 45

Binary file not shown.

After

Width:  |  Height:  |  Size: 34 KiB

View File

@@ -1,8 +0,0 @@
5 11
8 6
13 14
9 10
13 9
10 13
10 6
8 5

View File

@@ -1,150 +0,0 @@
0 0
1 0
2 0
3 0
4 0
5 0
6 0
7 0
8 0
9 0
10 0
11 0
12 0
13 0
14 0
15 0
16 0
17 0
18 0
19 0
19 1
19 2
19 3
18 3
17 3
16 3
15 3
14 3
13 3
12 3
11 3
10 3
9 3
9 2
8 2
7 2
6 3
5 3
4 3
3 3
2 3
1 3
0 3
1 4
0 5
0 6
1 6
2 6
3 6
4 6
5 6
6 6
5 7
6 8
6 9
7 9
14 6
15 6
16 6
17 6
18 6
19 6
19 7
19 8
19 9
18 9
17 9
16 9
15 9
16 10
15 11
15 12
14 12
15 12
15 13
16 14
15 15
15 16
14 17
13 17
12 17
11 17
11 16
10 15
10 16
9 16
8 15
8 14
7 13
6 14
5 14
4 14
3 13
3 12
2 11
3 10
3 9
1 9
0 9
1 10
0 11
0 12
1 12
2 12
3 12
3 13
4 14
4 15
5 16
5 17
6 17
7 17
8 17
9 17
10 17
11 17
12 17
13 17
14 17
15 16
15 15
16 14
15 13
15 12
17 12
18 12
19 12
19 13
19 14
19 15
18 15
17 15
16 15
15 15
15 16
14 17
13 17
12 17
11 17
11 16
10 16
9 16
8 15
6 15
5 15
4 15
3 15
2 15
1 15
0 15

Binary file not shown.

Before

Width:  |  Height:  |  Size: 31 KiB

View File

@@ -15,34 +15,14 @@ namespace ConsoleApp
static void Main(string[] args) static void Main(string[] args)
{ {
_bootstrapper = BootStrapper.BootstrapSystem(new CoreModule()); _bootstrapper = BootStrapper.BootstrapSystem(new CoreModule());
var simResults = _bootstrapper.Resolve<ISimulationResults>();
_userConsole = new UserConsole(); _userConsole = new UserConsole();
Initialization(); Initialization();
GenerateImages(); simResults.WriteResults();
Console.WriteLine("Program Completed"); Console.WriteLine("Program Completed");
} }
private static void GenerateImages()
{
// var generateMap= "python3 ConsoleApp/plot.py";
// System.Diagnostics.Process.Start("CMD.exe",generateMap);
//
var file = Path.Combine("./",Path.GetDirectoryName(Assembly.GetExecutingAssembly().Location), @"plot.py");
ProcessStartInfo startInfo = new ProcessStartInfo()
{
FileName = "python3",
Arguments = file,
UseShellExecute = true
};
Process proc = new Process()
{
StartInfo = startInfo,
};
proc.Start();
while (!proc.HasExited)
{
Thread.Sleep(500);
}
}
private static void Initialization() private static void Initialization()
{ {

View File

@@ -24,19 +24,23 @@ namespace ConsoleApp
private IReactivePathPlanner _reactivePathPlanner; private IReactivePathPlanner _reactivePathPlanner;
private HashSet<Coordinate2D> hexBombsFound = new HashSet<Coordinate2D>(); private HashSet<Coordinate2D> hexBombsFound = new HashSet<Coordinate2D>();
private List<Coordinate2D> testingPath = new List<Coordinate2D>(); private List<Coordinate2D> testingPath = new List<Coordinate2D>();
private ISimulationResults _simulationResults;
public SimRunner(IMapFactory mapFactory, IVehicle vehicle, IPathPlanner pathPlanner, IReactivePathPlanner reactivePathPlanner) public SimRunner(IMapFactory mapFactory, IVehicle vehicle, IPathPlanner pathPlanner, IReactivePathPlanner reactivePathPlanner, ISimulationResults simulationResults)
{ {
_mapFactory = mapFactory; _mapFactory = mapFactory;
_vehicle = vehicle; _vehicle = vehicle;
_pathPlanner = pathPlanner; _pathPlanner = pathPlanner;
_reactivePathPlanner = reactivePathPlanner; _reactivePathPlanner = reactivePathPlanner;
_simulationResults = simulationResults;
} }
public void Run() public void Run()
{ {
_mineMap = _mapFactory.GetMineMap(); _mineMap = _mapFactory.GetMineMap();
_simulationResults.Mines = _mineMap.PlacedMines;
_simulationResults.TotalBombs = _mineMap.TotalBombs;
SquareSimulation(); SquareSimulation();
HexSimulation(); HexSimulation();
// while(!squareTask.IsCompleted && !hexTask.IsCompleted){Thread.Sleep(500);} // while(!squareTask.IsCompleted && !hexTask.IsCompleted){Thread.Sleep(500);}
@@ -48,13 +52,12 @@ namespace ConsoleApp
var hexMap = _mapFactory.GetHexMap(); var hexMap = _mapFactory.GetHexMap();
_vehicle.CurrentHexCell = new Coordinate2D(0, 0, OffsetTypes.OddRowsRight); _vehicle.CurrentHexCell = new Coordinate2D(0, 0, OffsetTypes.OddRowsRight);
var optimalPath = _pathPlanner.GenerateOptimalHexPath(hexMap, _vehicle); var optimalPath = _pathPlanner.GenerateOptimalHexPath(hexMap, _vehicle);
var minimumMoves = optimalPath.Count;
var finished = false; var finished = false;
var totalMoves = 0; var totalMoves = 0;
while (!finished) while (!finished)
{ {
totalMoves += 1; totalMoves += 1;
testingPath.Add(_vehicle.CurrentHexCell); _simulationResults.HexPath.Add(_vehicle.CurrentHexCell);
var detectionCells = DetectionHead.GetCoveredCells(hexMap.Graph, _vehicle.CurrentHexCell, _vehicle.DetectorRadius, _vehicle.TurnRadius); var detectionCells = DetectionHead.GetCoveredCells(hexMap.Graph, _vehicle.CurrentHexCell, _vehicle.DetectorRadius, _vehicle.TurnRadius);
//Check Cells for mine //Check Cells for mine
@@ -80,63 +83,38 @@ namespace ConsoleApp
break; break;
} }
var replan = false; if (hexMap.Graph.IsCellBlocked(nextOptimal))
//if the next optimal cell is blocked then we need to replan around it.
while (hexMap.Graph.IsCellBlocked(nextOptimal))
{ {
replan = true; _reactivePathPlanner.GenerateReactiveHexPath(hexMap, optimalPath, _vehicle.CurrentHexCell);
if (optimalPath.TryDequeue(out nextOptimal)) continue;
finished = true;
break;
} }
if(replan) else
{
var tmpPath =
hexMap.Graph.GetShortestPath(_vehicle.CurrentHexCell, nextOptimal, hexMap.DefaultMovement);
if (Math.Abs(_vehicle.CurrentHexCell.X - nextOptimal.X) > 1 || Math.Abs(_vehicle.CurrentHexCell.Y - nextOptimal.Y) > 1)
optimalPath.Dequeue();
tmpPath.AddRange(optimalPath);
optimalPath.Clear();
foreach (var cell in tmpPath)
{
optimalPath.Enqueue(cell);
}
optimalPath.TryDequeue(out nextOptimal);
}
var last = testingPath[testingPath.Count-1];
if (Math.Abs(last.X - nextOptimal.X) > 1 || Math.Abs(last.Y - nextOptimal.Y) > 1)
Console.WriteLine("To big of a gap");
_vehicle.CurrentHexCell = nextOptimal; _vehicle.CurrentHexCell = nextOptimal;
} }
} }
//Debugging information //Debugging information
using(TextWriter tw = new StreamWriter("/Users/brady.bodily/Documents/Repositories/CS5890_Robot_Intelligence/RobotIntelFinal/ConsoleApp/Output/SavedList.txt")) var (cleared, uncleared) = CoveredCells();
{ _simulationResults.HexClearedCells = cleared;
foreach (Coordinate2D s in testingPath) _simulationResults.HexUnClearedCells = uncleared;
tw.WriteLine($"{s.X} {s.Y}"); _simulationResults.HexTotalMoves = totalMoves;
} _simulationResults.HexBombsFound = hexBombsFound.Count;
using(TextWriter tw = new StreamWriter("/Users/brady.bodily/Documents/Repositories/CS5890_Robot_Intelligence/RobotIntelFinal/ConsoleApp/Output/DetectedMines.txt"))
{
foreach (Coordinate2D s in hexBombsFound)
tw.WriteLine($"{s.X} {s.Y}");
}
var covered = CoveredCells();
Console.WriteLine($"Total cells traversed: {totalMoves} \n" +
$"Minimum required: {minimumMoves}");
Console.WriteLine($"Total bombs found: {hexBombsFound.Count}/{_mineMap.TotalBombs}");
} }
private int CoveredCells() private (int, int) CoveredCells()
{ {
var cleared = 0;
var uncleared = 0;
var hexMap = _mapFactory.GetHexMap(); var hexMap = _mapFactory.GetHexMap();
//for() foreach (var cellState in hexMap.Graph.GetAllCells())
return 0; {
if (cellState.TerrainType.Id == hexMap.ClearedTerrain.Id)
cleared++;
if (cellState.TerrainType.Id == hexMap.UnclearedTerrain.Id)
uncleared++;
}
return (cleared, uncleared);
} }
@@ -158,11 +136,6 @@ namespace ConsoleApp
var cellsToBlock = hexMap.Graph.GetRange(cell, _vehicle.Width / 2); var cellsToBlock = hexMap.Graph.GetRange(cell, _vehicle.Width / 2);
hexMap.Graph.BlockCells(cellsToBlock); hexMap.Graph.BlockCells(cellsToBlock);
// //debugging
// foreach (var celllll in cellsToBlock)
// {
// Console.WriteLine($"({celllll.X}, {celllll.Y}) Blocked: {hexMap.Graph.GetCellState(celllll).IsBlocked}");
// }
} }

View File

@@ -0,0 +1,104 @@
using System.Collections.Generic;
using System.Diagnostics;
using System.IO;
using System.Reflection;
using System.Threading;
using ConsoleApp.Maps;
using HexCore;
namespace ConsoleApp
{
public class SimulationResults : ISimulationResults
{
public int HexTotalMoves { get; set; }
public int HexBombsFound { get; set; }
public int TotalBombs { get; set; }
public List<Coordinate2D> HexPath { get; set; }
public List<Coordinate2D> HexMappedBombs { get; set; }
public List<Cell> Mines { get; set; }
public int HexClearedCells { get; set; }
public int HexUnClearedCells { get; set; }
public SimulationResults()
{
HexTotalMoves = 0;
HexBombsFound = 0;
TotalBombs = 0;
HexPath = new List<Coordinate2D>();
HexMappedBombs = new List<Coordinate2D>();
Mines = new List<Cell>();
HexClearedCells = 0;
HexUnClearedCells = 0;
}
public void WriteResults()
{
WriteData();
WriteMines();
WritePaths();
WriteDetectedMines();
GenerateImages();
}
private static void GenerateImages()
{
var file = Path.Combine("./",Path.GetDirectoryName(Assembly.GetExecutingAssembly().Location), @"HexPlot.py");
ProcessStartInfo startInfo = new ProcessStartInfo()
{
FileName = "python3",
Arguments = file,
UseShellExecute = true
};
Process proc = new Process()
{
StartInfo = startInfo,
};
proc.Start();
while (!proc.HasExited)
{
Thread.Sleep(500);
}
}
private void WriteData()
{
using(TextWriter tw = new StreamWriter("/Users/brady.bodily/Documents/Repositories/CS5890_Robot_Intelligence/RobotIntelFinal/ConsoleApp/Output/Data.txt"))
{
tw.WriteLine($"General:");
tw.WriteLine($"\t Total Mines: {TotalBombs}");
tw.WriteLine($"Hex: ");
tw.WriteLine($"\t Total Moves: {HexTotalMoves}");
tw.WriteLine($"\t Bombs Found: {HexBombsFound}");
tw.WriteLine($"\t Cleared Cell Count: {HexClearedCells}");
tw.WriteLine($"\t Uncleared Cell Count: {HexUnClearedCells}");
}
}
private void WriteMines()
{
using(TextWriter tw = new StreamWriter("/Users/brady.bodily/Documents/Repositories/CS5890_Robot_Intelligence/RobotIntelFinal/ConsoleApp/Output/Mines.txt"))
{
foreach (var s in Mines)
tw.WriteLine($"{s.X} {s.Y}");
}
}
private void WriteDetectedMines()
{
using(TextWriter tw = new StreamWriter("/Users/brady.bodily/Documents/Repositories/CS5890_Robot_Intelligence/RobotIntelFinal/ConsoleApp/Output/HexDetectedMines.txt"))
{
foreach (Coordinate2D s in HexMappedBombs)
tw.WriteLine($"{s.X} {s.Y}");
}
}
private void WritePaths()
{
using(TextWriter tw = new StreamWriter("/Users/brady.bodily/Documents/Repositories/CS5890_Robot_Intelligence/RobotIntelFinal/ConsoleApp/Output/HexPath.txt"))
{
foreach (Coordinate2D s in HexPath)
tw.WriteLine($"{s.X} {s.Y}");
}
}
}
}