2024美国大学生数学建模C题网球运动中的势头详解思路+具体代码

2024美国大学生数学建模C题网球运动中的势头详解思路+具体代码

在这里插入图片描述

E题数据已更新,做E题的小伙伴推荐看看博主的E题解析文章。那么废话不多说我们继续来做C题。

赛题分析

我们先阅题:

在2023年温布尔登男单决赛中,20岁的西班牙新星卡洛斯·阿尔卡拉兹击败了36岁的 诺瓦克·德约科维奇。这是德约科维奇自2013年以来在温布尔登的首次失利,也终结 了这位历史上最伟大的大满贯选手之一的辉煌战绩。

这场比赛本身就是一场非凡的战斗。[1]德约科维奇似乎注定要轻松获胜,因为他以6比1 控制了第一局(7局中赢了6局)。然而,第二盘比赛气氛紧张,最终阿尔卡雷斯在抢七局 中以7 - 6获胜。第三局与第一局相反,阿尔卡拉斯以6 - 1轻松获胜。这位年轻的西班 牙人在第四盘开始时似乎完全控制了比赛,但不知怎么的,比赛再次改变了方向,德约 科维奇完全控制了比赛,以6比3赢得了比赛。第五盘也是最后一盘,德约科维奇从第四 盘开始保持优势,但再次改变方向,阿尔卡拉兹获得控制并以6比4获胜。本次比赛的数 据在提供的数据集中,“match_id”为“2023-wimbledon1701”。你可以用“set_no” 列= 1看到德约科维奇在第一盘领先时的所有得分。令人难以置信的挥杆,有时是在许多 分甚至是比赛中,发生在似乎有优势的球员身上,通常被归因于“势头”。

读到这里感觉这个题有点意思,比较抽象。这美赛难道是想让我们建模找出势头?说实话这玩意多半是和时间序列预测有关,而且这东西预测出来有点虚无缥缈,也就是言之有理即可,重要的是有过程的数据分析,题目不会算很难,给了很多答主自由选择模型的空间。我们继续往下读题:

字典上对动量的一个定义是“通过运动或一系列事件获得的强度或力”。[2]在体育运 动中,一个团队或球员在比赛中可能会感到他们有动力,或“力量/力量”,但很难衡 量这种现象。此外,我们也不清楚比赛中的各种事件是如何创造或改变动量的。 2023年温布尔登男单前两轮之后的每一分数据。你可以选择包含额外的玩家信息或其他 数据,但你必须完整地记录这些来源。使用这些数据:

(1).开发一个模型,在游戏流程捕捉势头,并将其应用于一场或多场比赛。你的模型应该识别出哪名球员在比赛的特定时间表现更好,以及他们的表现有多好。 提供基于您的模型的可视化来描述匹配流。注:在网球比赛中,发球的选手赢得得 分/比赛的可能性要大得多。您可能希望以某种方式将此因素纳入您的模型中。

(2).一位网球教练怀疑“势头”在比赛中是否起作用。相反,他假设一个玩家在游戏中 的波动和成功的运行是随机的。使用你的模型/指标来评估这种说法。

(3).教练们很想知道,是否有一些指标可以帮助确定比赛流程何时会从有利于一名球员转变为有利于另一名球员。

  • 使用至少一场比赛提供的数据,开发一个预测比赛中这些摆动的模型。哪些因素看起来最相关(如果有)?
  • 考虑到过去比赛中动量波动的差异,你如何建议一个球员在新的比赛中面对不同的球员?

(4).在一个或多个其他比赛中测试你开发的模型。你对比赛结果的预测有多准确?如果模 型有时表现不佳,您能否确定可能需要包括在未来模型中的任何因素?您的模型对 其他比赛(如女子比赛)、锦标赛、球场表面和其他运动(如乒乓球)的通用性如何?

(5).提交一份不超过25页的调查报告,并包括一到两页的备忘录,总结你的结果,并就“ 势头”的作用向教练提出建议,以及如何让球员准备好应对影响网球比赛过程的事件。

题一、抓捕势头模型

不看数据集不知道,一看数据集单场比赛居然可以有这么多特征,那么该题的最大问题就是如何用好这些数据集了。首先我们要明白一点,就是这些数据是建立在时间之上的,也就是时序数据。时序数据不能用传统的数据分析方法,而是要尽可能将时间视为一个特征链去分析,也就是视为一个x轴,在时间轴上去衡量计算各个维度的特征关联。模型应该能够在比赛的任何给定时间点评估哪位选手表现更好,以及他们的表现优势有多大。此外,模型应该考虑到发球方赢得得分/局的概率通常更高这一因素。

单次比赛数据包含了详细的比赛信息,包括比赛ID、选手姓名、比赛经过的时间、盘数、局数、分数等多达46个字段。这些数据提供了每一分的详细记录,包括选手的得分情况、发球速度、发球方向、球的落点深度、选手跑动距离、连续击球数(rally count)等。

数据处理和分析

首先,需要整理和分析提供的数据。这可能包括每个得分的详细信息,比如哪位选手得分、得分是如何获得的(例如,发球得分、主动得分或对手失误)以及得分时的比赛状态(例如,比分、局数、盘数)。

附加数据:可能还需要考虑选手的一些基本信息,如世界排名、赛前状态、历史对决记录等,这些都可能影响比赛动力的评估。

我们需要详细分析每个得分事件,并根据比赛情况(如谁赢得了分数)来更新得分,所以进行积分规则编程尤为重要。

建模思路

  1. 解析规则:根据提供的计分规则,我们需要一个函数来解释每个得分事件,并更新每位选手的得分。
  2. 计算得分:我们将使用比赛的得分事件来模拟每个游戏内的得分变化。每位选手的得分将根据比赛规则更新。
  3. 确定动力:我们可以通过考虑比赛中的关键事件(如破发点、保发、发球优势)来确定每位选手的动力。动力可以用得分差异来表示,也可以通过其他衡量方式来衡量,比如连续得分或突然得分变化。
  4. 可视化:使用得分差异和比赛关键时刻,我们可以创建一个时间序列图来显示比赛动力的变化。

规则题目已经给出:

在这里插入图片描述

那么我们开始进行仿真模拟单场发球规则,而且这么多维度的数据,必须要进行降维或者是优化得分更新逻辑,或者将数据分批处理,在更新得分之前先预处理数据以减少需要处理的数据量。

由于网球比赛的计分规则相对复杂,我们需要确保模型能够处理以下情况:

  • 普通得分,从0(Love)开始,到15、30、40,然后赢得游戏。
  • 当双方得分都达到40(Deuce)时,需要赢得连续两分才能赢得游戏。
  • 盘的胜利需要赢得至少6个游戏,并且至少领先对手2个游戏。如果双方都赢得6个游戏,那么进行决胜局。
  • 比赛的胜利需要赢得3个盘。

在网球得分系统中,当比分到达40-40(Deuce)时,需要连续赢得两分才能赢得该游戏。此外,在6-6平局时,通常会进行决胜局(Tie-break),其计分规则与普通游戏不同。在决胜局中,首先赢得7分(必须领先2分)的选手将赢得该盘。如果是比赛的最后一盘(通常是第五盘),则可能需要10分来赢得胜利。所以我们还需要加入Deuce规则:

考虑以上40-40(Deuce)的情况:

Rowcolumn(s)Value(s)Description
Row 8p1_score, p2_score40, 40The score is 40 – 40 meaning each player has won 3 previous points (this is also called “deuce”)
point_victor1Alcaraz wins point 7 (in row 8)
Row 9p1_score, p2_scoreAD,40Since Alcaraz won the previous point (point 7) the score on point 8 is now “AD” for Alcaraz and “40” for Jarry meaning Alcaraz has won one more point and could win the game on the next point.
point_victor2Jarry (player 2) wins point 8 (in row 9).
Row 10p1_score, p2_score40, 40The score returns to 40 – 40 (“deuce”) meaning each player has won the same number of previous points although now it is 4 points each.
point_victor1Alcaraz wins point 9 (in row 10).
Row 11p1_score, p2_scoreAD,40Alcaraz again has the advantage having won point 9
point_victor1Alcaraz wins point 10 (in row 11) which means he has won the game (has score 2 more points now).
Row 12game_no2This is now the first point of game 2.
p1_games1Alcaraz won game 1.
# 定义更新得分的函数,考虑到deuce和advantage的情况
def update_match_scores(df):p1_points, p2_points = 0, 0  # Points in a gamep1_games, p2_games = 0, 0  # Games in a setp1_sets, p2_sets = 0, 0  # Sets in the matchfor index, row in df.iterrows():if row['point_victor'] == 1:p1_points += 1else:p2_points += 1if p1_points >= 4 and p1_points - p2_points >= 2:p1_games += 1p1_points, p2_points = 0, 0  # Reset pointselif p2_points >= 4 and p2_points - p1_points >= 2:p2_games += 1p1_points, p2_points = 0, 0  # Reset pointsif p1_games >= 6 and p1_games - p2_games >= 2:p1_sets += 1p1_games, p2_games = 0, 0  # Reset gameselif p2_games >= 6 and p2_games - p1_games >= 2:p2_sets += 1p1_games, p2_games = 0, 0  # Reset gamesdf.loc[index, 'p1_points'] = p1_pointsdf.loc[index, 'p2_points'] = p2_pointsdf.loc[index, 'p1_games'] = p1_gamesdf.loc[index, 'p2_games'] = p2_gamesdf.loc[index, 'p1_sets'] = p1_setsdf.loc[index, 'p2_sets'] = p2_setsreturn df

在这里插入图片描述

这样一来我们就先完成了捕捉赛点发生时的比赛流程模拟,现在捕捉势头也就是预测峰值走向,其实就是梯度的概念,下一步我们开始进行时序预测模型的建模处理:

在这里插入图片描述

这样一来我们就先完成了捕捉赛点发生时的比赛流程模拟,现在捕捉势头也就是预测峰值走向,其实就是梯度的概念,下一步我们开始进行时序预测模型的建模处理。

对时序预测算法不是很有把握的推荐去看看博主之前写的专栏,很有帮助。先记录到这里后面整理一下,期待大家的关注和支持!就是我一直以来写作的动力!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/663373.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

/home/zzcg/BJCAROOT/ 把/换成File.separator

在Java中,File.separator 是系统相关的默认名称分隔符。对于UNIX系统,它是 /,对于Windows,它是 \。 所以,如果你想将字符串 "/home/zzcg/BJCAROOT/" 中的 / 替换为 File.separator,你可以这样做…

数据结构—动态查找

动态查找介绍 1. 动态查找的引入:当查找表以线性表的形式组织时,若对查找表进行插入、删除或排序操作,就必须移动大量的记录,当记录数很多时,这种移动的代价很大。 2. 动态查找表的设计思想:表结构本身是…

Midjourney新功能介绍:风格参考(Style References)详解

引言 对于追求创意和一致性的艺术家和设计师们来说,Midjourney的最新功能——风格参考(Style References),无疑是一个激动人心的消息。这项测试算法的发布,让我们得以通过简单的URL引用,将特定的风格应用于…

专项审计或鉴证报告

经具有资质并符合《工作指引》相关条件的中介机构出具的企业近三个会计年度(实际年限不足三年的按实际经营年限)研究开发费用专项审计或鉴证报告(附研究开发活动说明材料)、近一个会计年度高新技术产品(服务&#xff0…

【论文速览_01】Awesome Few Shot Segmentation论文

Awesome Few Shot Segmentation Awesome Few Shot Segmentation论文CVPR 2023Hierarchical Dense Correlation Distillation for Few-Shot Segmentation文章内容 MIANet: Aggregating Unbiased Instance and General Information for Few-Shot Semantic Segmentation文章内容 I…

探讨深浅拷贝在js加密中的运用

深浅拷贝是JavaScript中常用的概念,用于复制对象或数组。它们在处理数据时有不同的用途,适用于不同的场景。在本文中,我们将详细介绍深浅拷贝的概念,提供案例代码,并探讨它们在JavaScript中的应用场景,以及…

linux如何知道运行的进程的运行目录,就可以了解自己的程序是否在运行。

目 录 一、背景 二、找到运行的进程的运行目录的方法 1、使用ps命令结合grep命令 2. 使用pgrep命令结合readlink命令 一、背景 在实际应用中,发现Linux中运行了多个nginx,不知道自己的应用程序的Nginx是否在正常运行? 如果知道这…

学习python第五天

一.判断语句 yourAge 20 myAge 18if yourAge > myAge:print("你的年龄比我大")""" 输出 你的年龄比我大 """ 1.冒号 判断语句的固定格式,用来表示这行判断条件的结束。 2.四个空格(缩进) …

MySQL原理(一)架构组成之逻辑模块(1)组成

总的来说,MySQL可以看成是二层架构,第一层我们通常叫做SQL Layer,在MySQL数据库系统处理底层数据之前的所有工作都是在这一层完成的,包括权限判断,sql解析,执行计划优化,query cache的处理等等&…

中二少年工具箱(PC端)简介

同学们可以私信我加入学习群! 正文开始 简介一、功能模块1.node版本管理工具 总结 简介 中二少年开发的中二少年工具箱,相信博主,功能不孬。 辅助自己开发工作,帮助新人快速入门,提供交互式文档辅助学习……如果还不…

CSS3:最新特性和实例教程

今天简单复习一下css3的相关特性吧。 一:响应式设计 CSS3引入了媒体查询(Media Queries)和弹性盒子布局(Flexbox)等特性,使得响应式设计变得更加容易。媒体查询可以根据设备的屏幕大小、分辨率等属性来应…

拓展欧几里得法求逆元

板子: x即为最终答案,x可能为负数,加模数即可 乘法逆元 - OI Wiki (oi-wiki.org) void exgcd(int a, int b, int& x, int& y) {if (b 0) {x 1, y 0;return;}exgcd(b, a % b, y, x);y - a / b * x; } 使用: exgcd(a, n 1, x,…

什么是ISO21434网络安全中的汽车网络?-亚远景

在ISO 21434标准中,汽车网络指的是车辆内部和车辆与外部之间的所有电子控制单元(ECU)之间的连接和通信。这些电子控制单元包括车辆内部的各种系统和功能,例如引擎控制、刹车系统、驾驶辅助系统、娱乐系统等。 具体来说&#xff0c…

空间计算时代加速到来,需要的不只是苹果

近年来,科技行业一直在期待“寒武纪”时刻。伴随技术革命的深入推进,所有厂商都预感新的时代即将到来,并期待自己成为那个引爆点,轻轻一触,推开一扇新的未来之门。 今年开年,苹果就为科技圈锚定了一个可能…

学习C语言的第31天

全局函数和静态函数 全局函数 1、全局函数在作用域中唯一的&#xff1b; 2、作用域&#xff1a;在整个项目中使用文件中使用&#xff1b; 3、函数可以调用自己成为递归函数&#xff1b; #include<stdio.h> void bubblesort(int arr[],int len) {for(int i0;i<len…

Spring WebSocket实现实时通信

简介 WebSocket 是基于TCP/IP协议,独立于HTTP协议的通信协议。WebSocket 连接允许客户端和服务器之间的全双工通信,以便任何一方都可以通过已建立的连接将数据推送到另一方。 我们常用的HTTP是客户端通过「请求-响应」的方式与服务器建立通信的,必须是客户端主动触发的行为…

Hutool导入导出用法

整理了下Hutool导入导出的简单使用。 导入maven或jar包&#xff08;注意这里导入的poi只是为了优化样式&#xff09; <!-- https://mvnrepository.com/artifact/cn.hutool/hutool-all --> <dependency><groupId>cn.hutool</groupId><artifactId&g…

【笔记】Helm-5 Chart模板指南-6 流控制

流控制 控制结构&#xff08;在模板语言中称为“actions”&#xff09;提供给您和模板作者控制模板迭代流的能力。Helm的模板语言提供了以下控制结构&#xff1a; if/else&#xff0c;用来创建条件语句 with&#xff0c;用来指定范围 range&#xff0c;提供“for each”类型…

2024技术发展洞察与趋势学习总结

2023技术发展洞察 2024技术发展趋势

QT假如有三个线程如何保证顺序执行

目录 1 QSemaphore 2 QMutex和QWaitCondition 3 QFuture 1 QSemaphore #include <QSemaphore> #include <QThread> #include <QDebug> QSemaphore sem1(1); QSemaphore sem2(0); QSemaphore sem3(0);class Thread1 : public QThread { public:void run()…