Skip to content
Closed
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
54 changes: 34 additions & 20 deletions test/runtest.py
Original file line number Diff line number Diff line change
Expand Up @@ -248,26 +248,6 @@ def test_batch_same_strength(self):
self.assertAlmostEqual(post["b"].sigma,5.419,3)
self.assertAlmostEqual(post["c"].mu,25.000,3)
self.assertAlmostEqual(post["c"].sigma,5.419,3)
def test_add_events_batch(self):
pass
#agents= dict()
#for k in ["a", "b", "c", "d", "e", "f"]:
#agents[k] = ttt.Agent(ttt.Player(ttt.Gaussian(25., 25.0/3), 25.0/6, 25.0/300 ) , ttt.Ninf, -ttt.inf)
#composition = [ [["a"],["b"]], [["a"],["c"]] , [["b"],["c"]] ]
#results = [[1,0],[0,1],[1,0]]
#b = ttt.Batch(composition = composition, results = results, time=0, agents = agents)
#b.convergence()
#b.add_events(composition,results)
#self.assertEqual(len(b),6)
#post = b.posteriors()
#b.iteration(trace=True)
#b.iteration(trace=True)
#self.assertAlmostEqual(post["a"].mu,25.000,3)
#self.assertAlmostEqual(post["a"].sigma,3.88,3)
#self.assertAlmostEqual(post["b"].mu,25.000,3)
#self.assertAlmostEqual(post["b"].sigma,3.88,3)
#self.assertAlmostEqual(post["c"].mu,25.000,3)
#self.assertAlmostEqual(post["c"].sigma,3.88,3)
def test_history_init(self):
composition = [ [["aa"],["b"]], [["aa"],["c"]] , [["b"],["c"]] ]
results = [[1,0],[0,1],[1,0]]
Expand Down Expand Up @@ -578,6 +558,40 @@ def gamma(self):
mu100, sigma100 = h.batches[0].posterior("a")
self.assertAlmostEqual(mu100, 6.555467)
self.assertAlmostEqual(sigma100, 9.6449906)

## add_history and add_events methods.

def test_add_history(self):
composition = [ [["a","b"],["c","d"]], [["e","f"] , ["b","c"]], [["a","d"], ["e","f"]] ]
results = [[1,0],[0,1],[1,0]]
times =[100,300,500]
h = ttt.History(composition=[composition[0]], results=[results[0]],times=[times[0]], mu=0.0,sigma=6.0, beta=1.0, gamma=0.0)
h.convergence()
h.add_history(composition=[composition[1]], results=[results[1]],times=[times[1]])
h.add_history(composition=[composition[2]], results=[results[2]],times=[times[2]])
h.learning_curves()

def test_add_events_batch(self):
pass
#agents= dict()
#for k in ["a", "b", "c", "d", "e", "f"]:
#agents[k] = ttt.Agent(ttt.Player(ttt.Gaussian(25., 25.0/3), 25.0/6, 25.0/300 ) , ttt.Ninf, -ttt.inf)
#composition = [ [["a"],["b"]], [["a"],["c"]] , [["b"],["c"]] ]
#results = [[1,0],[0,1],[1,0]]
#b = ttt.Batch(composition = composition, results = results, time=0, agents = agents)
#b.convergence()
#b.add_events(composition,results)
#self.assertEqual(len(b),6)
#post = b.posteriors()
#b.iteration(trace=True)
#b.iteration(trace=True)
#self.assertAlmostEqual(post["a"].mu,25.000,3)
#self.assertAlmostEqual(post["a"].sigma,3.88,3)
#self.assertAlmostEqual(post["b"].mu,25.000,3)
#self.assertAlmostEqual(post["b"].sigma,3.88,3)
#self.assertAlmostEqual(post["c"].mu,25.000,3)
#self.assertAlmostEqual(post["c"].sigma,3.88,3)

def ToDo(self):
print("Ningun toDo")

Expand Down
39 changes: 30 additions & 9 deletions trueskillthroughtime/__init__.py
Original file line number Diff line number Diff line change
Expand Up @@ -525,24 +525,45 @@ def new_forward_info(self):

class History(object):
def __init__(self,composition, results=[], times=[], priors=dict(), mu=MU, sigma=SIGMA, beta=BETA, gamma=GAMMA, p_draw=P_DRAW, weights=[]):
if (len(results) > 0) and (len(composition) != len(results)): raise ValueError("len(composition) != len(results)")
if (len(times) > 0) and (len(composition) != len(times)): raise ValueError(" len(times) error ")
if (len(weights) > 0) and (len(composition) != len(weights)): raise ValueError("(length(weights) > 0) & (length(composition) != length(weights))")

self.size = len(composition)
self.size = 0
self.batches = []
self.agents = dict([ (a, Agent(priors[a] if a in priors else Player(Gaussian(mu, sigma), beta, gamma), Ninf, -inf)) for a in set( [a for teams in composition for team in teams for a in team] ) ])
self.agents = dict()
self.mu = mu
self.sigma = sigma
self.beta = beta
self.gamma = gamma
self.p_draw = p_draw
self.time = len(times)>0
self.trueskill(composition,results,times, weights)

self.time = None
self.latest_time = 0
self.add_history(composition, results, times, priors, weights)
def __repr__(self):
return "History(Events={}, Batches={}, Agents={})".format(self.size,len(self.batches),len(self.agents))
def __len__(self):
return self.size
def add_history(self, composition, results=[], times=[], priors=dict(), weights=[]):
if (len(results) > 0) and (len(composition) != len(results)): raise ValueError("len(composition) != len(results)")
if (len(times) > 0) and (len(composition) != len(times)): raise ValueError(" len(times) error ")
if (len(weights) > 0) and (len(composition) != len(weights)): raise ValueError("(length(weights) > 0) & (length(composition) != length(weights))")
if self.time is None:
self.time = len(times) > 0
self.latest_time = max(times)
else:
if self.time is True:
if len(times) == 0: raise ValueError(" len(times) error ")
self.latest_time = max(times)
else:
if len(times) > 0: raise ValueError(" len(times) error ")
self.size += len(composition)
for a in set( [a for teams in composition for team in teams for a in team] ):
if a in self.agents:
continue
if a in priors:
p = priors[a]
else:
p = Player(Gaussian(self.mu, self.sigma), self.beta, self.gamma)
self.agents[a] = Agent(p, Ninf, -inf)
self.trueskill(composition,results,times, weights)

def trueskill(self, composition, results, times, weights):
o = sortperm(times) if len(times)>0 else [i for i in range(len(composition))]
i = 0
Expand Down