如何解决选择足球队球员的组合优化
我正在考虑使用整数规划来生成组成一支球队的足球运动员的最佳组合。
尽管问题本身很简单,但我无法为职位资格制定有效的约束条件。
我在 stackoverflow 中搜索了经典整数规划问题的变体,并提出了一个临时解决方案,但想验证当前的解决方案是否有效。
问题
从一组有限的潜在球员中为一支足球队选择 11 名球员。
球队由11个位置组成:5个进攻,5个防守和1个守门员。
每个角色都有自己的合格玩家池。
(例如守门员只能从一组戴手套的球员中选择)
每个玩家都会被分配一个代表他们技能的“技能分数”
目标函数
最大化:所有 11 个玩家技能得分的总和
约束
- 所有 11 个插槽必须至少有 1 名玩家填满
- 1 个玩家只能占用 1 个位置
- 每个空位必须由有资格担任该角色的球员填补
我的临时解决方案
Let xij: player i in consideration for slot j (j=1,2,...,11,1 <= i <= n)
and w: n x 1 weight matrix representing skill score for player i
1. sum_j(xij) == 1 for each slot j
2. 0 <= sum_i(xij) <= 1 for each player i
3. 0 <= xij <= 1 if player i is eligible for slot j,== 0 otherwise
maximize sum(wTx)
我还想不出一种优雅的方法来操作 3,所以我现在的答案是将每个单元格硬编码为 0。
我打算在 Python(cvxpy 或 PuLP)中使用整数编程库。
当前的设计是否会导致收敛或计算时间方面的问题?
是否有更有效的方法来对问题建模?
注意事项
- 为简单起见,我们假设一个玩家可以成为多个角色的候选人,但他们的技能点不会因角色而变化
- 如果玩家的技能分数根据他们与其他玩家的协同作用而变化,问题的表述是否会改变?我认为通过 nC2 可能的交互简单地扩展 x 矩阵是可行的,但我很好奇是否有更好的解决方案。
解决方法
您的 IP 公式看起来不错。但是,这个问题也可以使用动态规划来解决:
让数组 dp[n][mask]
表示将 1 到 n 的玩家放入 mask
二进制表示中的 0 位对应的位置时可以获得的最大可能分数。例如,dp[5][0b11111110101]
等于将玩家 1 到 5 放在位置 2 和 4 中可以获得的最大分数。(掩码的第二和第四位为零。)
现在我们递归地定义dp[n][mask]
:
dp[n][mask] = max{
dp[n-1][mask],# the case when we don't use player n
max_j{ dp[n-1][mask|(1<<j)] + w[n] } (1 <= j <= 11 and mask's jth bit is 0)
}
基本情况是 n=0
。
dp[0][mask] = {
-infinity,if there are 0 bits in mask # there are empty positions left,we want to strictly discourage this case.
0,if all 11 bits of mask is 1
}
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。