2020-06-23 02:04:17 -04:00
|
|
|
package d2astar
|
|
|
|
|
|
|
|
import (
|
|
|
|
"math"
|
|
|
|
"testing"
|
|
|
|
)
|
|
|
|
|
2020-07-03 18:33:14 -04:00
|
|
|
func addTruck(x, y int, label string) *Truck {
|
2020-06-23 02:04:17 -04:00
|
|
|
t1 := new(Truck)
|
|
|
|
t1.X = x
|
|
|
|
t1.Y = y
|
|
|
|
t1.label = label
|
2020-07-03 18:33:14 -04:00
|
|
|
|
2020-06-23 02:04:17 -04:00
|
|
|
return t1
|
|
|
|
}
|
|
|
|
|
2020-07-03 18:33:14 -04:00
|
|
|
func addTube(t1, t2 *Truck, cost float64) *Tube {
|
2020-06-23 02:04:17 -04:00
|
|
|
tube1 := new(Tube)
|
|
|
|
tube1.Cost = cost
|
|
|
|
tube1.from = t1
|
|
|
|
tube1.to = t2
|
|
|
|
|
2020-07-01 00:13:25 -04:00
|
|
|
t1.outTo = append(t1.outTo, *tube1)
|
|
|
|
t2.outTo = append(t2.outTo, *tube1)
|
2020-06-23 02:04:17 -04:00
|
|
|
|
|
|
|
return tube1
|
|
|
|
}
|
|
|
|
|
|
|
|
// Consider a world with Nodes (Trucks) and Edges (Tubes), Edges each having a cost
|
2020-07-01 00:13:25 -04:00
|
|
|
//
|
2020-06-23 02:04:17 -04:00
|
|
|
// E
|
|
|
|
// /|
|
|
|
|
// / |
|
|
|
|
// S--M
|
2020-07-01 00:13:25 -04:00
|
|
|
//
|
2020-06-23 02:04:17 -04:00
|
|
|
// S=Start at (0,0)
|
|
|
|
// E=End at (1,1)
|
|
|
|
// M=Middle at (0,1)
|
2020-07-01 00:13:25 -04:00
|
|
|
//
|
2020-06-23 02:04:17 -04:00
|
|
|
// S-M and M-E are clean clear tubes. cost: 1
|
2020-07-01 00:13:25 -04:00
|
|
|
//
|
2020-06-23 02:04:17 -04:00
|
|
|
// S-E is either:
|
2020-07-01 00:13:25 -04:00
|
|
|
//
|
2020-06-23 02:04:17 -04:00
|
|
|
// 1) TestGraphPath_ShortDiagonal : diagonal is a nice clean clear Tube , cost: 1.9
|
|
|
|
// Solver should traverse the bridge.
|
|
|
|
// Expect solution: Start, End Total cost: 1.9
|
2020-07-01 00:13:25 -04:00
|
|
|
//
|
2020-06-23 02:04:17 -04:00
|
|
|
// 1) TestGraphPath_LongDiagonal : diagonal is a Tube plugged full of
|
|
|
|
// "enormous amounts of material"!, cost: 10000.
|
|
|
|
// Solver should avoid the plugged tube.
|
|
|
|
// Expect solution Start,Middle,End Total cost: 2.0
|
|
|
|
|
2020-07-03 18:33:14 -04:00
|
|
|
func createGorelandGraphPathDiagonal(t *testing.T, diagonalCost, expectedDist float64) {
|
2020-06-23 02:04:17 -04:00
|
|
|
world := new(Goreland)
|
|
|
|
|
2020-07-03 18:33:14 -04:00
|
|
|
trStart := addTruck(0, 0, "Start")
|
|
|
|
trMid := addTruck(0, 1, "Middle")
|
|
|
|
trEnd := addTruck(1, 1, "End")
|
2020-06-23 02:04:17 -04:00
|
|
|
|
2020-07-03 18:33:14 -04:00
|
|
|
addTube(trStart, trEnd, diagonalCost)
|
|
|
|
addTube(trStart, trMid, 1)
|
|
|
|
addTube(trMid, trEnd, 1)
|
2020-06-23 02:04:17 -04:00
|
|
|
|
2020-07-01 00:13:25 -04:00
|
|
|
t.Logf("Goreland. Diagonal cost: %v\n\n", diagonalCost)
|
2020-06-23 02:04:17 -04:00
|
|
|
|
2020-07-01 00:13:25 -04:00
|
|
|
p, dist, found := Path(trStart, trEnd, math.MaxFloat64)
|
2020-06-23 02:04:17 -04:00
|
|
|
|
|
|
|
if !found {
|
|
|
|
t.Log("Could not find a path")
|
|
|
|
} else {
|
|
|
|
t.Logf("Resulting path\n%s", world.RenderPath(p))
|
|
|
|
}
|
2020-07-03 18:33:14 -04:00
|
|
|
|
2020-06-23 02:04:17 -04:00
|
|
|
if !found && expectedDist >= 0 {
|
|
|
|
t.Fatal("Could not find a path")
|
|
|
|
}
|
2020-07-03 18:33:14 -04:00
|
|
|
|
2020-06-23 02:04:17 -04:00
|
|
|
if found && dist != expectedDist {
|
|
|
|
t.Fatalf("Expected dist to be %v but got %v", expectedDist, dist)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestGraphPaths_ShortDiagonal(t *testing.T) {
|
2020-07-01 00:13:25 -04:00
|
|
|
createGorelandGraphPathDiagonal(t, 1.9, 1.9)
|
2020-06-23 02:04:17 -04:00
|
|
|
}
|
|
|
|
func TestGraphPaths_LongDiagonal(t *testing.T) {
|
2020-07-01 00:13:25 -04:00
|
|
|
createGorelandGraphPathDiagonal(t, 10000, 2.0)
|
2020-06-23 02:04:17 -04:00
|
|
|
}
|