-
Notifications
You must be signed in to change notification settings - Fork 84
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Update max free transfers to 5 #680
Conversation
and separate max free transfers allowed in game rules and max transfers per week to consider in optimisation
Currently seems to hang at the end of optimisation - probably |
relies on baseline strategy being first if present
I think I've fixed one bug with counting the baseline strategy, but it still hangs. The optimisation seems to be running strategies that should be excluded because they take too many hits (0-3-3, 3-0-3) for a test run allowing 3 transfers/8pts hits. If I set max hit to a large value so it doesn't impact things it terminates successfully. |
Already handled by `next_week_transfers` when computing new strategies to add to the queue. Doing this twice before is probably a long standing bug. Could have meant we were over-estimating free transfers available, and therefore under-counting hits.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Great work Jack!!
Code changes look sensible, the tests all run for me, and a quick test going 2 weeks ahead for optimization with max_transfers=5 runs OK, so I think we should merge, and in the not-too-distant future I will try and have a think/play with some other method for knowing when to stop, rather than the current method of counting the expected outputs.....
Updates the optimisation code so that:
Up to 5 free transfers can be saved in the logic around computing points hits and dropping strategies that leave transfers unused.
Adds
max_opt_transfers
andmax_free_transfers
to various optimisation functions:max_free_transfers
is the maximum allowable free transfers in the game rules (now 5).max_opt_transfers
is the maximum number of transfers to allow the optimisation to make each week. This still defaults to 2. At the command line the value of--max_transfers
is passed tomax_opt_transfers
.If optimising more than 2 transfers, calls
make_random_transfers
, which uses the value ofnum_iterations
to decide the number of attempts. For the current AIrsenal squad I didn't manage to get anything that beats the brute force 2 transfer optimisation.Fixes a bug in computing free transfers & hit so far for the next strategies in the optimisation tree: See commit be3d6d9. I've not fully got my head around this but I believe this is a long-standing bug in AIrsenal that has slipped by unnoticed as it was less likely to cause issues when limited to making 2 transfers. However, I think it could have made AIrsenal under-estimate points hits and therefore more likely to suggest making 2 transfers.
optimize
for updating the tree/next strategies:but
next_week_transfers
itself already callscalc_free_transfers
, so you could incorrectly end up with an extra free transfer available in the strategy.