一、TSP简介

旅行商问题,即TSP问题(Traveling Salesman Problem)又译为旅行推销员问题、货郎担问题,是数学领域中著名问题之一。假设有一个旅行商人要拜访n个城市,他必须选择所要走的路径,路径的限制是每个城市只能拜访一次,而且最后要回到原来出发的城市。路径的选择目标是要求得的路径路程为所有路径之中的最小值。
TSP的数学模型

二、遗传算法简介

1 引言


2 遗传算法理论
2.1 遗传算法的生物学基础


2.2 遗传算法的理论基础




2.3 遗传算法的基本概念






2.4 标准的遗传算法


2.5 遗传算法的特点


2.6 遗传算法的改进方向

3 遗传算法流程



4 关键参数说明

三、模拟退火算法简介

1 引言
模拟退火算法(Simulated Annealing,SA)的思想最早由Metropolis等人于1953年提出:Kirkpatrick于1983年第一次使用模拟退火算法求解组合最优化问题[1] 。模拟退火算法是一种基于MonteCarlo迭代求解策略的随机寻优算法, 其出发点是基于物理中固体物质的退火过程与一般组合优化问题之间的相似性。其目的在于为具有NP(Non-deterministic Polynomial) 复杂性的问题提供有效的近似求解算法,它克服了其他优化过程容易陷入局部极小的缺陷和对初值的依赖性。
模拟退火算法是一种通用的优化算法,是局部搜索算法的扩展。它不同于局部搜索算法之处是以一定的概率选择邻域中目标值大的劣质解。从理论上说,它是一种全局最优算法。模拟退火算法以优化问
题的求解与物理系统退火过程的相似性为基础, 它利用Metropolis算法并适当地控制温度的下降过程来实现模拟退火,从而达到求解全局优化问题的目的[2].
模拟退火算法是一种能应用到求最小值问题的优化过程。在此过程中,每一步更新过程的长度都与相应的参数成正比,这些参数扮演着温度的角色。与金属退火原理相类似,在开始阶段为了更快地最小
化,温度被升得很高,然后才慢慢降温以求稳定。
目前,模拟退火算法迎来了兴盛时期,无论是理论研究还是应用研究都成了十分热门的课题[3-7]。尤其是它的应用研究显得格外活跃,已在工程中得到了广泛应用,诸如生产调度、控制工程、机器学习、神经网络、模式识别、图像处理、离散/连续变量的结构优化问题等领域。它能有效地求解常规优化方法难以解决的组合优化问题和复杂函数优化问题,适用范围极广。
模拟退火算法具有十分强大的全局搜索性能,这是因为比起普通的优化搜方法,它采用了许多独特的方法和技术:在模拟退火算法中,基本不用搜索空间的知识或者其他的辅助信息,而只是定义邻域
结构,在其邻域结构内选取相邻解,再利用目标函数进行评估:模拟退火算法不是采用确定性规则,而是采用概率的变迁来指导它的搜索方向,它所采用的概率仅仅是作为一种工具来引导其搜索过程朝着更优化解的区域移动。因此,虽然看起来它是一种盲目的搜索方法,但实际上有着明确的搜索方向。

2 模拟退火算法理论
模拟退火算法以优化问题求解过程与物理退火过程之间的相似性为基础,优化的目标函数相当于金属的内能,优化问题的自变量组合状态空间相当于金属的内能状态空间,问题的求解过程就是找一个组
合状态, 使目标函数值最小。利用Me to polis算法并适当地控制温度的下降过程实现模拟退火,从而达到求解全局优化问题的目的[8].
2.1物理退火过程
模拟退火算法的核心思想与热力学的原理极为类似。在高温下,液体的大量分子彼此之间进行着相对自由移动。如果该液体慢慢地冷却,热能原子可动性就会消失。大量原子常常能够自行排列成行,形成一个纯净的晶体,该晶体在各个方向上都被完全有序地排列在几百万倍于单个原子的距离之内。对于这个系统来说,晶体状态是能量最低状态,而所有缓慢冷却的系统都可以自然达到这个最低能量状态。实际上,如果液态金属被迅速冷却,则它不会达到这一状态,而只能达到一种只有较高能量的多晶体状态或非结晶状态。因此,这一过程的本质在于缓慢地冷却,以争取足够的时间,让大量原子在丧失可动性之前进行重新分布,这是确保能量达到低能量状态所必需的条件。简单而言,物理退火过程由以下几部分组成:加温过程、等温过程和冷却过程。

加温过程
其目的是增强粒子的热运动,使其偏离平衡位置。当温度足够高时,固体将熔解为液体,从而消除系统原先可能存在的非均匀态,使随后进行的冷却过程以某一平衡态为起点。熔解过程与系统的能量增
大过程相联系,系统能量也随温度的升高而增大。

等温过程
通过物理学的知识得知,对于与周围环境交换热量而温度不变的封闭系统,系统状态的自发变化总是朝着自由能减小的方向进行:当自由能达到最小时,系统达到平衡态。

冷却过程
其目的是使粒子的热运动减弱并逐渐趋于有序,系统能量逐渐下降,从而得到低能量的晶体结构。

2.2 模拟退火原理
模拟退火算法来源于固体退火原理,将固体加温至充分高,再让其徐徐冷却。加温时,固体内部粒子随温升变为无序状,内能增大:而徐徐冷却时粒子渐趋有序,在每个温度上都达到平衡态,最后在常
温时达到基态,内能减为最小。模拟退火算法与金属退火过程的相似关系如表7.1所示。根Metropolis准则, 粒子在温度7时趋于平衡的概率为exp(-▲E/T) , 其中E为温度7时的内能, ▲E为其改变量。用
固体退火模拟组合优化问题,将内能E模拟为目标函数值,温度7演化成控制参数,即得到解组合优化问题的模拟退火算法:由初始解%和控制参数初值7开始,对当前解重复“产生新解→计算目标函数差一接受或舍弃”的迭代,并逐步减小T值,算法终止时的当前解即为所得近似最优解, 这是基MonteCarlo迭代求解法的一种启发式随机搜索过程。退火过程由冷却进度表控制,包括控制参数的初值7及其衰
减因子K、每个7值时的迭代次数I和停止条件。

2.3 模拟退火算法思想
模拟退火的主要思想是:在搜索区间随机游走(即随机选择点),再利用Metropolis抽样准则, 使随机游走逐渐收敛于局部最优解。而温度是Metropolis算法中的一个重要控制参数,可以认为这个参数的大小控制了随机过程向局部或全局最优解移动的快慢。Metropolis是一种有效的重点抽样法, 其算法为:系统从一个能量状态变化到另一个状态时,相应的能量从E变化到E,其概率为

这样经过一定次数的迭代,系统会逐渐趋于一个稳定的分布状态。
重点抽样时,新状态下如果向下,则接受(局部最优);若向上(全局搜索),则以一定概率接受。模拟退火算法从某个初始解出发,经过大量解的变换后,可以求得给定控制参数值时组合优化问题的相对最优解。然后减小控制参数7的值, 重复执行Metropolis算法,就可以在控制参数T趋于零时,最终求得组合优化问题的整体最优解。控制参数的值必须缓慢衰减。温度是Metropolis算法的一个重要控制参数, 模拟退火可视为递减控制参数7时Metro pl is算法的迭代。开始时7值大, 可以接受较差的恶化解;随着7的减小,只能接受较好的恶化解;最后在7趋于0时,就不再接受任何恶化解了。
在无限高温时,系统立即均匀分布,接受所有提出的变换。T的衰减越小, 7到达终点的时间越长; 但可使马尔可夫(Markov) 链减小,以使到达准平衡分布的时间变短。

2.4 模拟退火算法的特点
模拟退火算法适用范围广,求得全局最优解的可靠性高,算法简单,便于实现;该算法的搜索策略有利于避免搜索过程因陷入局部最优解的缺陷,有利于提高求得全局最优解的可靠性。模拟退火算法具
有十分强的鲁棒性,这是因为比起普通的优化搜索方法,它采用许多独特的方法和技术。主要有以下几个方面:
(1)以一定的概率接受恶化解。
模拟退火算法在搜索策略上不仅引入了适当的随机因素,而且还引入了物理系统退火过程的自然机理。这种自然机理的引入,使模拟退火算法在迭代过程中不仅接受使目标函数值变“好”的点,而且还能够以一定的概率接受使目标函数值变“差”的点。迭代过程中出现的状态是随机产生的,并且不强求后一状态一定优于前一状态,接受概率随着温度的下降而逐渐减小。很多传统的优化算法往往是确定性
的,从一个搜索点到另一个搜索点的转移有确定的转移方法和转移关系,这种确定性往往可能使得搜索点远达不到最优点,因而限制了算法的应用范围。而模拟退火算法以一种概率的方式来进行搜索,增加了搜索过程的灵活性。
(2)引进算法控制参数。
引进类似于退火温度的算法控制参数,它将优化过程分成若干阶段, 并决定各个阶段下随机状态的取舍标准, 接受函数由Metropolis算法给出一个简单的数学模型。模拟退火算法有两个重要的步骤:一
是在每个控制参数下,由前迭代点出发,产生邻近的随机状态,由控制参数确定的接受准则决定此新状态的取舍,并由此形成一定长度的随机Markov链; 二是缓慢降低控制参数, 提高接受准则, 直至控制参数趋于零,状态链稳定于优化问题的最优状态,从而提高模拟退火算法全局最优解的可靠性。
(3)对目标函数要求少。
传统搜索算法不仅需要利用目标函数值,而且往往需要目标函数的导数值等其他一些辅助信息才能确定搜索方向:当这些信息不存在时,算法就失效了。而模拟退火算法不需要其他的辅助信息,而只是
定义邻域结构,在其邻域结构内选取相邻解,再用目标函数进行评估。

2.5模拟退火算法的改进方向
在确保一定要求的优化质量基础上,提高模拟退火算法的搜索效率,是对模拟退火算法改进的主要内容[9-10]。有如下可行的方案:选择合适的初始状态;设计合适的状态产生函数,使其根据搜索进程的
需要表现出状态的全空间分散性或局部区域性:设计高效的退火过程;改进对温度的控制方式:采用并行搜索结构;设计合适的算法终止准则:等等。
此外,对模拟退火算法的改进,也可通过增加某些环节来实现。
主要的改进方式有:
(1)增加记忆功能。为避免搜索过程中由于执行概率接受环节而遗失当前遇到的最优解,可通过增加存储环节,将到目前为止的最好状态存储下来。
(2)增加升温或重升温过程。在算法进程的适当时机,将温度适当提高,从而可激活各状态的接受概率,以调整搜索进程中的当前状态,避兔算法在局部极小解处停滞不前。
(3)对每一当前状态,采用多次搜索策略,以概率接受区域内的最优状态,而不是标准模拟退火算法的单次比较方式。
(4)与其他搜索机制的算法(如遗传算法、免疫算法等)相结合。可以综合其他算法的优点,提高运行效率和求解质量。

3 模拟退火算法流程
模拟退火算法新解的产生和接受可分为如下三个步骤:
(1)由一个产生函数从当前解产生一个位于解空间的新解;为便于后续的计算和接受,减少算法耗时,通常选择由当前解经过简单变换即可产生新解的方法。注意,产生新解的变换方法决定了当前新解
的邻域结构,因而对冷却进度表的选取有一定的影响。
(2)判断新解是否被接受,判断的依据是一个接受准则,最常用的接受准则是Metropolis准则:若AK 0, 则接受X作为新的当前解否则, 以概率exp(-▲E/7) 接受X”作为新的当前解X.
(3)当新解被确定接受时,用新解代替当前解,这只需将当前解中对应于产生新解时的变换部分予以实现,同时修正目标函数值即可。此时,当前解实现了一次迭代,可在此基础上开始下一轮试验。若当新解被判定为舍弃,则在原当前解的基础上继续下一轮试验。模拟退火算法求得的解与初始解状态(算法迭代的起点)无关,具有渐近收敛性,已在理论上被证明是一种以概率1收敛于全局最优解的优化算法。模拟退火算法可以分解为解空间、目标函数和初始解三部分。该算法具体流程如下[8]:
(1)初始化:设置初始温度7(充分大)、初始解状态%(是算
法迭代的起点)、每个7值的迭代次数L:
(2)对k=1,…,L做第(3)至第(6)步;
(3)产生新解X;
(4) 计算增量A BE(X) -E(X) , 其中E() ) 为评价函数:
(5)若AK0,则接受X作为新的当前解,否则以概率
exp(-▲E/7) 接受X作为新的当前解;
(6)如果满足终止条件,则输出当前解作为最优解,结束程序:
(7)7逐渐减小,且T→0,然后转第(2)步。
模拟退火算法流程如图7.1所示。

4 关键参数说明
模拟退火算法的性能质量高,它比较通用,而且容易实现。不过,为了得到最优解,该算法通常要求较高的初温以及足够多次的抽样,这使算法的优化时间往往过长。从算法结构知,新的状态产生函
数、初温、退温函数、Markov链长度和算法停止准则, 是直接影响算法优化结果的主要环节。
状态产生函数
设计状态产生函数应该考虑到尽可能地保证所产生的候选解遍布全部解空间。一般情况下状态产生函数由两部分组成,即产生候选解的方式和产生候选解的概率分布。候选解的产生方式由问题的性质决
定,通常在当前状态的邻域结构内以一定概率产生。
初温
温度7在算法中具有决定性的作用,它直接控制着退火的走向。由随机移动的接受准则可知:初温越大,获得高质量解的几率就越大,且Metropolis的接收率约为1。然而, 初温过高会使计算时间增加。
为此,可以均匀抽样一组状态,以各状态目标值的方差为初温。
退温函数
退温函数即温度更新函数,用于在外循环中修改温度值。目前,最常用的温度更新函数为指数退温函数, 即T(n+1) =KXT(n) , 其中0<K1是一个非常接近于1的常数。
Markov链长度L的选取
Markov链长度是在等温条件下进行迭代优化的次数, 其选取原则是在衰减参数7的衰减函数己选定的前提下,L应选得在控制参数的每一取值上都能恢复准平衡,一般L取100~1000.
算法停止准则
算法停止准则用于决定算法何时结束。可以简单地设置温度终值T,当F=T,时算法终止。然而,模拟火算法的收敛性理论中要求T趋向于零,这其实是不实际的。常用的停止准则包:设置终止温度的阈
值,设置迭代次数阈值,或者当搜索到的最优值连续保持不变时停止搜索。

四、部分源代码

function f = genetic_algorithm(D, mute, Pm)
% 遗传算法解决中国省会城市TSP问题的简单实现
% 包含台北,香港,澳门%% 默认参数设置clear;if ~exist('mute', 'var')mute = 0; % 是否显示各种提示信息endif ~exist('Pm', 'var')Pm = 0.2; % 变异概率,越大收敛越慢但是解一般越好endif ~exist('D', 'var')data=xlsread('省会经纬坐标.xlsx');C=data;D=zeros(35,35);% D为城市间的距离矩阵% 形成两两之间对应的矩阵(对称阵,可以只看上三角或下三角)[LA1,LA2]=meshgrid(C(:,2));[LO1,LO2]=meshgrid(C(:,1));% 计算两两之间的距离,单位为公里R = distance(LA1,LO1,LA2,LO2,almanac('earth','wgs84'));D = num2str(R,'%10.2f');%disp(D);end%% 遗传算法参数设置rng(1); % 控制随机数生成(种子)n = size(D, 1);N = 100; % 群体规模(必须设为偶数)TOL = 20; % 最大容忍次数(连续TOL次rate不上升,或找不到更优解,则停止迭代)%% 初始可行解solutions = zeros(N, n); % 由于最后一个城市默认是返回解的第一个城市,故可行解里没有必要包含最后访问的城市fs = zeros(N, 1);   % 适应度for i = 1:Nsolutions(i, :) = [1, randperm(n-1) + 1]; % 生成N个解,假定从1开始fs(i) = TSP_distance(D, solutions(i, :));endPu = max(fs) - fs + 1; % 加1为了防止max(fs)对应的那一位为0P = Pu/sum(Pu); % 由此,适应度越大的那一项可能选取的概率越小cumP = cumsum(P); % 计算累积概率best = min(fs); % 计算最短路径avg = mean(fs);rate = best/avg;if ~mutedisp('初始解的群体中最短的路径长度为:');disp(best);disp('初始解的群体中平均路径长度为:');disp(avg);end%% 进化tol = 0;count = 0;while 1count = count + 1;if ~mutefprintf('当前第%d次迭代\n', count);end% 使用轮盘赌的方式选出父代的染色体parents = zeros(size(solutions));for i = 1:Nindex = sum(cumP <= rand) + 1; % 随机数rand落在的区间编号parents(i, :) = solutions(index, :);endassert(mod(N, 2) == 0); % N必须为偶数,否则出错% 交配操作;这里默认N为偶数,每两个父代一起产生两个子代for i = 1:N/2 % 产生的子代1取父代1的前一半染色体,后一半则由父代2提供;同理于子代2p1 = parents(2*i-1, :);p2 = parents(2*i, :);middle = ceil(n/2);s1 = p1(1:middle);res1 = setdiff(p2, s1, 'stable'); % 找到p2中含有的而s1不中含有的基因,相当于p2\s1s1 = [s1, res1];s2 = p2(1:middle);res2 = setdiff(p1, s2, 'stable');s2 = [s2, res2];new_solutions(2*i-1, :) = s1;new_solutions(2*i, :) = s2;end% 变异操作;变异的方式为随机取个城市与第一个城市交换for i = 1:N if rand < Pmtemp = randperm(n-1) + 1;k = temp(1);new_solutions(i, [1, k]) = new_solutions(i, [k, 1]);endend% 至此,新的种群已经生成完毕,代替旧种群后开始新一轮的计算solutions = new_solutions;for i = 1:Nfs(i) = TSP_distance(D, solutions(i, :));endavg = mean(fs);rate_new = best_new/avg;if ~mutedisp('最短的路径长度为:');disp(best_new);disp('平均的路径长度为:');disp(avg);endtol = tol + 1;% 如果本轮更新,最优解有变好,则tol归0if best_new < best || rate_new > rate  best = best_new;rate = rate_new;tol = 0;endif tol >= TOLbreakendif count > 5000breakendend %% 输出最优解[f, index] = min(fs);solution = solutions(index, :);if ~mutefprintf('最后搜索得到的最优路径为:\n');disp(solution); % 最后还要回到起点1disp('路径长度为:');disp(f);end
function f = simulated_annealing(D, mute, MAX_ITER)
% 模拟退火解决中国省会城市TSP问题的简单实现
% 包含台北,香港,澳门%% 默认参数设置clear;if ~exist('mute', 'var')mute = 0; % 是否显示各种提示信息endif ~exist('MAX_ITER', 'var')MAX_ITER = 50; % 每个温度内的最大状态交换尝试次数% 这个参数很玄乎没什么固定规律的样子endif ~exist('D', 'var')data=xlsread('省会经纬坐标.xlsx');C=data;D=zeros(35,35);% D为城市间的距离矩阵% 形成两两之间对应的矩阵(对称阵,可以只看上三角或下三角)[LA1,LA2]=meshgrid(C(:,2));[LO1,LO2]=meshgrid(C(:,1));% 计算两两之间的距离,单位为公里R = distance(LA1,LO1,LA2,LO2,almanac('earth','wgs84'));D = num2str(R,'%10.2f');%disp(D);end%% 模拟退火算法参数设置rng(0);n = size(D, 1);T_range_factor = exp(0:-0.1:-5); % 温度的范围系数solution = [1, randperm(n-1) + 1]; % 生成一个解,假定从1开始if ~mutefprintf('邻域内总共有%d个解。\n', numel(P));endf = TSP_distance(D, solution); % 求出当前解的总距离if ~mutedisp('初始的路径为:');   disp(solution);disp('路径长度为:');disp(f);endP = generate_neighbors(solution); % 生成初始解的邻域PTMAX = f;% 温度范围动态地随初始解的好坏而变化(初始解越差,要求探索的需求就越大)T_range = T_range_factor * TMAX; % 尽量保证开始的温度足够高 结束的足够低for i = 1:MAX_ITER  % 内循环index = randi(numel(P), 1); % 产生一个1~|P|之间的随机整数neighbor = P{index}; % 在P中随机取一个解f_neighbor = TSP_distance(D, neighbor); % 计算这个解的距离Pt = exp(-(f_neighbor - f)/t); % 转移概率if Pt > 1, Pt = 1; end % 说明f_neighbor<fif Pt > randf = f_neighbor;solution = neighbor;P = generate_neighbors(solution);end% 记录外循环第一轮的转移概率if ~mute && t == T_range(1)first(i) = Pt;end% 记录外循环最后一轮的转移概率if ~mute && t == T_range(end)final(i) = Pt;endendif ~mute && t == T_range(1)fprintf('初始温度下的转移概率中位数为%f\n', median(first));endif ~mute && t == T_range(end)fprintf('最后温度下的转移概率中位数为%f\n', median(final));endendif ~mutefprintf('最后搜索得到的最优路径为:\n');disp(solution);disp('路径长度为:');disp(f);end

五、运行结果

六、matlab版本及参考文献

1 matlab版本
2014a

2 参考文献
[1] 包子阳,余继周,杨杉.智能优化算法及其MATLAB实例(第2版)[M].电子工业出版社,2016.
[2]张岩,吴水根.MATLAB优化算法源代码[M].清华大学出版社,2017.

【TSP】基于matlab遗传和模拟退火算法求解中国省会城市旅行商问题【含Matlab源码 1254期】相关推荐

  1. 【路径规划】基于matlab遗传优化模拟退火算法避障路径规划【含Matlab源码 889期】

    ⛄一.简介 路径规划主要是让目标对象在规定范围内的区域内找到一条从起点到终点的无碰撞安全路径.路径规划中有静态路径规划以及动态路径规划,本文所讨论的问题仅针对静态路径规划.具体问题描述如下: 给定起点 ...

  2. 【Matlab人脸识别】人脸实时检测与跟踪【含GUI源码 673期】

    一.代码运行视频(哔哩哔哩) [Matlab人脸识别]人脸实时检测与跟踪[含GUI源码 673期] 二.matlab版本及参考文献 1 matlab版本 2014a 2 参考文献 [1]孟逸凡,柳益君 ...

  3. 【Matlab指纹识别】指纹识别门禁系统【含GUI源码 1692期】

    一.代码运行视频(哔哩哔哩) [Matlab指纹识别]指纹识别门禁系统[含GUI源码 1692期] 二.matlab版本及参考文献 1 matlab版本 2014a 2 参考文献 [1] 包子阳,余继 ...

  4. 【Matlab树叶分类】BP神经网络植物叶片分类【含GUI源码 916期】

    一.代码运行视频(哔哩哔哩) [Matlab树叶分类]BP神经网络植物叶片分类[含GUI源码 916期] 二.matlab版本及参考文献 1 matlab版本 2014a 2 参考文献 [1] 蔡利梅 ...

  5. 【Matlab水果蔬菜识别】形态学水果蔬菜识别【含GUI源码 919期】

    一.代码运行视频(哔哩哔哩) [Matlab水果蔬菜识别]形态学水果蔬菜识别[含GUI源码 919期] 二.matlab版本及参考文献 1 matlab版本 2014a 2 参考文献 [1] 蔡利梅. ...

  6. 【Matlab青草识别】形态学马唐草+牛筋草识别【含GUI源码 908期】

    一.代码运行视频(哔哩哔哩) [Matlab青草识别]形态学马唐草+牛筋草识别[含GUI源码 908期] 二.matlab版本及参考文献 1 matlab版本 2014a 2 参考文献 [1] 蔡利梅 ...

  7. 【Matlab限速标志识别】形态学限速标志识别【含GUI源码 1142期】

    一.代码运行视频(哔哩哔哩) [Matlab限速标志识别]形态学限速标志识别[含GUI源码 1142期] 二.matlab版本及参考文献 1 matlab版本 2014a 2 参考文献 [1] 蔡利梅 ...

  8. 【乌鸦算法】基于正弦余弦指引乌鸦算法求解单目标优化问题含Matlab代码

    ✅作者简介:热爱科研的Matlab仿真开发者,修心和技术同步精进,matlab项目合作可私信.

  9. 【智能优化算法】基于闪电连接过程优化算法求解单目标优化问题含Matlab源码

    1 简介 闪电连接过程算法( Lightning Attachment Procedure Optimization,LAPO)是受自然界中闪电上迎先导与下行先导连接过程的启发,于2017年提出的一种 ...

  10. 【单目标优化求解】基于matlab黑猩猩算法求解单目标问题【含Matlab源码 1413期】

    一.获取代码方式 获取代码方式1: 完整代码已上传我的资源:[单目标优化求解]基于matlab黑猩猩算法求解单目标问题[含Matlab源码 1413期] 点击上面蓝色字体,直接付费下载,即可. 获取代 ...

最新文章

  1. 彻底透析SpringBoot jar可执行原理
  2. 人工智能可以自己编码?2022年这8个人工智能趋势值得关注!
  3. SpringCloud学习之运行第一个Eureka程序
  4. C#异步编程(一):异步基础
  5. bootstrap table 搜索列formatter之后,单字节搜索异常
  6. everything便携版和安装版区别_什么是超极本?超极本和笔记本的区别科普知识...
  7. 论述计算机模拟的优势与重要性,计算机模拟技术在高中地理教学的应用
  8. 游戏筑基开发之C语言编程技巧
  9. 计算机学不学工程制图,如何学好工程制图
  10. 基于Python和MySQL的学生信息管理系统
  11. c语言节点的作用,C语言试题
  12. 中值定理5-泰勒中值定理
  13. 多功能聊天室 第一次迭代总结与第二次迭代计划
  14. 基于Hi3516DV300的嵌入式入门演练(下)
  15. U盘什么格式最好?U盘格式介绍
  16. Dark GDK 初体验
  17. 计算机专业的职业探索,职业教育计算机教学的探索
  18. 深入理解Python函数的9个黄金法则
  19. 图形学笔记 For GAMES201
  20. Google在东京搬出了所有的AI产品和技术,你知道哪个? | 精选

热门文章

  1. OO第四单元UML作业总结暨OO课程总结
  2. python学习笔记4-切片
  3. 顺序输出一个整数的各位数字
  4. 学习笔记day1-计算机介绍
  5. [POI2012]STU-Well(二分答案+神仙操作)
  6. 设计模式-结构型模式,适配器模式(4)
  7. 创建.ignore文件
  8. 30+简约和平铺的WordPress复古主题
  9. 20191004每日一句
  10. 181029每日一句