遗传算法的探究与应用

遗传算法的探究与应用摘要:随着全国各大高校的扩招,如何正规、科学、合理地安排好课程、教师、教室等诸多资源进行排课已经成为学校教务管理的重点与难点。随着人T智能领域的不断完善与发展,遗传算法山于其超群的并行搜索能力,以及在解决优化问题中体现出來的高度健壮性,迅速被应用于求解组合优化的排课问题。关键词:遗传算法;排课系统;优化中图分类号:TP301近些年來,伴随着“数字化校园计划”快速并逐步的向深入发展,传统高校中的教学管理模式也面临着重大的转变。有效运用计算机作为日常教学和教务的辅助管理已经成为各个高校实现数字化校园的工作垂点。遗传算法(GeneticAlgorithm-----------GA)是一类借鉴生物界的进化规律演化而来的高度并行、随机、自适应的搜索算法。S.even等人在1975年的研究证明了排课问题是NP-Complete问题[1],非“枚举法”之外不能找出最优可行解。国内外,已有众多学者将遗传算法的原理应用于排课系统之屮,如,乔树青将遗传算法的运行区分为多种不同的机制应用于排课系统之中[2];石慧运用基因对交叉遗传算法求解多校区排课问题[3]。但是山于约束条件过于宽泛,计算结果常常无法收敛于全局最优解。本文尝试利用遗传算法的原理对排课系统进行优化求解。1遗传算法描述遗传算法不同于传统的搜索算法[4]o遗传算法依据编码方式以及初始条件随机生成一组解,这组解被称为种群(Population)。构成种群的每个解都被称为染色体(Chromosonie)。染色体通常是一组数据,这组数据被用来作为表示问题的解的代码,其木身不一定是一组可行解[5]。这些染色体在后续的迭代过程中部分会不断的进入到下一代的染色体Z中这被称为遗传。在每一代种群中用适应度值(Fitness)來表示染色体的优劣程度,并利用适应度函数来対一组染色体进行适应度的测量。测量后根据选择算法进行选择是否遗传到子代之中。由此生成的下一代染色体称为后代(Offspring)o后代是还有可能是通过父代交叉和变异产生的个体。新一代形成中,根据适配值的大小选择部分后代,淘汰部分后代,从而保持种群大小是常数,适配值高的染色体被选中的概率较高。据此,经过若干代之后,算法可能收敛于最好的染色体,它很可能就是问题的最优解或较优解。2排课问题分析及算法设计从数学角度来讲排课问题,实质上是在时间、班级、教师以及教室和课程的5维空间上,以教学计划中的各种要求所产生一些约束条件的组合规划问题[6]。所需要采取的就是对排课问题中的各个维度上的对象按照各个约束条件解决对象间的冲突。在解决冲突之前,首先由理清一下四种关系:(1)课程与教师Z间的映射,即每门课程的任教的教师有哪些。(2)课程与的互斥关系,即在拓扑关系图中以时间描述的先后顺序。(3)课程与班级之间的映射,即需要学习木门课程的班级有哪些。(4)课程与时间的映射,即课程不能被安排在相同的时间段(更复杂的逻辑关系)。经过对高校排课系统的需求分析知道,若将教室维度加上很难在冇限的时间和空间存储条件下进行求解,并且在需求方对于教室安排并不是必须的,因此我们假设教室资源充足的前提下进行排课算法的设计。2.1个体表示在系统中笔者使用BYTE类型的三维数组来表示染色体个体(记为P)o其中第一维度(记为I维度)为班级编号classListSize,第二维度(记为J维度)为教师编号teacherListSize,第三维(记为K维度)度为时间片编号timeSliceTotal。个体中存的值则为教师授课程编号。个体表示I班级在K时间上J教师所教授的第P门课程。如图1:byte[][][]chromosome二newbyte[classListSize][teacherListSize][timeSliceTotal];图1染色体个体数据结构定义2.2评价函数评价根据班级所有相同课程的时间间隔度量值ti>班级教师教授课程的时间间隔度量值tj、班级主干课程重要度度量值之和Sumi.班级上课教师的要求与课程安排符合程度度量值Sumj,在此足义排课系统状态的评价特征特征向量X={ti,tj,Sumi,Sumj}0在域X上存在一个集合P,设存在一个数x与aPi(x)e[0,1](xeX)——对应。定义个体差异度为nki=max{aPi,-aPk}/min{aPi,-aPk}o定义适应度函数为,n为特征值个数(n二4)。2.3选释算法选择算法选用轮盘赌算法,...

1、当您付费下载文档后,您只拥有了使用权限,并不意味着购买了版权,文档只能用于自身使用,不得用于其他商业用途(如 [转卖]进行直接盈利或[编辑后售卖]进行间接盈利)。
2、本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供参考,付费前请自行鉴别。
3、如文档内容存在侵犯商业秘密、侵犯著作权等,请点击“举报”。

常见问题具体如下:

1、问:已经付过费的文档可以多次下载吗?

      答:可以。登陆您已经付过费的账号,付过费的文档可以免费进行多次下载。

2、问:已经付过费的文档不知下载到什么地方去了?

     答:电脑端-浏览器下载列表里可以找到;手机端-文件管理或下载里可以找到。

            如以上两种方式都没有找到,请提供您的交易单号或截图及接收文档的邮箱等有效信息,发送到客服邮箱,客服经核实后,会将您已经付过费的文档即时发到您邮箱。

注:微信交易号是以“420000”开头的28位数字;

       支付宝交易号是以“2024XXXX”交易日期开头的28位数字。

客服邮箱:

biganzikefu@outlook.com

所有的文档都被视为“模板”,用于写作参考,下载前须认真查看,确认无误后再购买;

文档大部份都是可以预览的,笔杆子文库无法对文档的真实性、完整性、准确性以及专业性等问题提供审核和保证,请慎重购买;

文档的总页数、文档格式和文档大小以系统显示为准(内容中显示的页数不一定正确),网站客服只以系统显示的页数、文件格式、文档大小作为依据;

如果您还有什么不清楚的或需要我们协助,可以联系客服邮箱:

biganzikefu@outlook.com

常见问题具体如下:

1、问:已经付过费的文档可以多次下载吗?

      答:可以。登陆您已经付过费的账号,付过费的文档可以免费进行多次下载。

2、问:已经付过费的文档不知下载到什么地方去了?

     答:电脑端-浏览器下载列表里可以找到;手机端-文件管理或下载里可以找到。

            如以上两种方式都没有找到,请提供您的交易单号或截图及接收文档的邮箱等有效信息,发送到客服邮箱,客服经核实后,会将您已经付过费的文档即时发到您邮箱。

注:微信交易号是以“420000”开头的28位数字;

       支付宝交易号是以“2024XXXX”交易日期开头的28位数字。

确认删除?