2016-11-25 00:05:29 -06:00
|
|
|
|
namespace SpriteCompiler.AI
|
|
|
|
|
{
|
|
|
|
|
using System;
|
|
|
|
|
using System.Collections.Generic;
|
|
|
|
|
|
|
|
|
|
public abstract class AbstractSearchNode<A, S, T, C> : ISearchNode<A, S, T, C>
|
|
|
|
|
where T : ISearchNode<A, S, T, C>
|
2016-11-29 00:20:29 -06:00
|
|
|
|
where C : IPathCost<C>, new()
|
2016-11-25 00:05:29 -06:00
|
|
|
|
{
|
|
|
|
|
protected readonly S state;
|
|
|
|
|
protected readonly T parent;
|
|
|
|
|
protected A action = default(A);
|
|
|
|
|
|
2016-11-29 00:20:29 -06:00
|
|
|
|
protected C pathCost = new C();
|
|
|
|
|
protected C stepCost = new C();
|
2016-11-25 00:05:29 -06:00
|
|
|
|
protected readonly int depth;
|
|
|
|
|
|
|
|
|
|
public AbstractSearchNode(T node, S state)
|
|
|
|
|
{
|
|
|
|
|
this.state = state;
|
|
|
|
|
this.parent = node;
|
|
|
|
|
this.depth = HasParent ? parent.Depth + 1 : 0;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private bool HasParent { get { return !EqualityComparer<T>.Default.Equals(parent, default(T)); } }
|
|
|
|
|
|
|
|
|
|
public A Action { get { return action; } set { action = value; } }
|
|
|
|
|
public T Parent { get { return parent; } }
|
|
|
|
|
public C PathCost { get { return pathCost; } }
|
|
|
|
|
public int Depth { get { return depth; } }
|
|
|
|
|
public S State { get { return state; } }
|
|
|
|
|
|
|
|
|
|
public C StepCost
|
|
|
|
|
{
|
|
|
|
|
get
|
|
|
|
|
{
|
|
|
|
|
return stepCost;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
set
|
|
|
|
|
{
|
|
|
|
|
stepCost = value;
|
|
|
|
|
pathCost = HasParent ? parent.PathCost.Add(value) : value;
|
|
|
|
|
}
|
|
|
|
|
}
|
2016-12-04 23:14:51 -06:00
|
|
|
|
|
|
|
|
|
virtual public C EstCost { get { return PathCost; } }
|
2016-11-25 00:05:29 -06:00
|
|
|
|
}
|
|
|
|
|
}
|