我的编程空间,编程开发者的网络收藏夹
学习永远不晚

怎么用Python遗传算法处理TSP问题

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

怎么用Python遗传算法处理TSP问题

本文小编为大家详细介绍“怎么用Python遗传算法处理TSP问题”,内容详细,步骤清晰,细节处理妥当,希望这篇“怎么用Python遗传算法处理TSP问题”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。

TSP问题

那么在开始之前的话,咱们来仔细描述一下这个TSP问题。这个打过数模,或者接触过智能优化或者机器学习方面的朋友应该都知道,当然为了本文的受众普适性,咱们在这里尽可能去完善一点,说清楚,这样便于咱们去实际解决问题。

那么这个问题的其实简单,是这样子的:

怎么用Python遗传算法处理TSP问题

在我们的N维平面是,咱们今天的话是拿这个二维平面来的,在这个平面上有很多个城市,城市之间是彼此联通的,我们现在要找出一条最短的路径可以将全部城市都走完。例如我们有城市A,B,C,D,E。现在知道了城市间的坐标,也就是相当于知道了城市之间的距离,那么现在找到一个顺序,能够使得走完A,B,C,D,E所有城市的路径和最短。比如计算完之后可能是B-->A-->C-->E-->D。换一句话说找到这个顺序。

枚举

首先要解决这个问题的话,其实方案有很多,说变白了,咱们就是要找到一个顺序,能够让路径之和最小,那么最容易想到的自然就是枚举,例如让A先走然后看距离A最近的假设是B,那么就走B,然后从B走。当然这个是局部贪心策略,很容易走到局部最优,那么这个时候我们可以考虑DP,也就是说依然假设从A开始,然后确保2个城市最短,3个城市最短,4个5个。最后在假设从B开始同理。或者直接 枚举全部情况,计算距离。但是无论如何,随着城市数量的上升,他们的复杂度都会增加,所以这个时候我们就要想办法让计算能不能发挥一下咱们人类的专长了。我称之为“瞎蒙”。

智能算法

现在我们来聊聊这个智能算法,以及为什么要用着玩意,刚刚咱们说了前面的方案对于大量的数据计算量会很大,也不见得编写简单。那么这个时候,首先单单对于TSP问题来说,我们要的就是一个序列,一个不会重复的序列。那么这个时候,有什么一个更加简便的方案,而且在数据足够大的情况下,我们也不见得需要一个完全精准,完全最小的解,只要接近就好。那么这个时候,采用传统的那些算法的话,一就是一,他只会按照我们的规则去计算,而且我们也确实不知道标准答案是什么,对传统算法也比较难去设定一个阈值去停止运算。但是对我们人来说,有一种东西叫做“运气”,有的人运气贼好,可能一发入魂,一下子就懵出了答案。那么我们的智能算法其实就是有点类似于“蒙”。但是人家蒙是讲究技巧的,例如经验告诉我们,三长一短选最短,通过这个技巧可以去蒙一下答案,或者找男盆友的时候像博主一样帅气的男孩纸,只要一张40系(30也可以)显卡就可以轻松带走一样。蒙是要技巧的,我们管这个叫做策略。

策略

那么我们刚刚说的这个技巧,这个蒙的技巧。在智能算法里面,这个蒙,就是我们的一种策略。我们要怎么去蒙才能够让我们的解更加合理。那么这个时候,就开始百花齐放了,这里我就不念经了,我们拿最金典的两个算法为例子,一个是遗传算法,一个是粒子群算法(PSO)。为例子,他们就是采用了一种策略去蒙,例如遗传算法,通过模拟物竞天择,一开始先随机蒙出一堆解,一堆序列,然后按照咱们的这个物竞天择的策略出筛选这些解,然后通过这些解再去蒙出新的更好的解。如此往复,之后蒙出不错的解。粒子群也是类似的,这些部分咱们用的时候再详细说明。

算法

现在咱们已经知道了这个策略,那么算法是啥,其实就是实现这些策略的步骤啊,就是咱们的代码,咱们的循环,数据结构。我们要去实现刚刚说的例如物竞天择,例如咱们TSP,如何随机生成一堆解。

数据样例

ok,到这里咱们已经说完了,基本的一些概念,那么这个时候的话,咱们来看看咱们如何表示这个TSP的问题,这个其实很简单,咱们这边的话就简单的准备一个测试数据,我们这里假设有14个城市,那么我们的这些城市的数据如下:

    data = np.array([16.47, 96.10, 16.47, 94.44, 20.09, 92.54,                     22.39, 93.37, 25.23, 97.24, 22.00, 96.05, 20.47, 97.02,                     17.20, 96.29, 16.30, 97.38, 14.05, 98.12, 16.53, 97.38,                     21.52, 95.59, 19.41, 97.13, 20.09, 92.55]).reshape((14, 2))

我们后面都用这组数据进行测试,现在在上面已经有了14个城市。

那么接下来我们开始我们的解决方案

遗传算法

ok,那么我们来说一说咱们的这个遗传算法是怎么一回事,之后的话,咱们用这个来解决这个TSP问题。

那么现在的话,我们来看看我们的遗传算法是怎么蒙的。

算法流程

遗传算法其实是在用计算机模拟我们的物种进化。其实更加通俗的说法是筛选,这个就和我们袁老爷爷种植水稻一样。有些个体发育良好,有些个体发育不好,那么我就先筛选出发育好的,然后让他们去繁衍后代,然后再筛选,最后得到高产水稻。其实也和我们社会一样,不努力就木有女朋友就不能保留自己的基因,然后剩下的人就是那些优秀的人和富二代的基因,这就是现实呀。所以得好好学习,天天向上!

那么回到主题,我们的遗传算法就是在模拟这一个过程,模拟一个物竞天择的过程。

所以在我们的算法里面也是分为几大块

繁殖

首先我们的种群需要先繁殖。这样才能不断产生优良基于,那么对应我们的算法,假设我们需要求取

Y = np.sin(10 * x) * x + np.cos(2 * x) * x

的最大值(在一个范围内)那么我们的个体就是一组(X1)的解。好的个体就会被保留,不好的就会被pass,选择标准就是我们的函数 Y 。那么问题来了如何模拟这个过程?我们都知道在繁殖后代的时候我们是通过DNA来保留我们的基因信息,在这个过程当中,父母的DNA交互,并且在这个过程当中会产生变异,这样一来,父母双方的优秀基于会被保存,并且产生的变异有可能诞生更加优秀的后代。

所以接下来我们需要模拟我们的DNA,进行交叉和变异。

交叉

这个交叉过程和我们的生物其实很像,当然我们在我们的计算机里面对于数字我们可以将其转化为二进制,当做我们的DNA

怎么用Python遗传算法处理TSP问题

交叉的方式有很多,我们这边选择这一个,进行交叉。

变异

那这个在我们这里就更加简单了

我们只需要在交叉之后,再随机选择几个位置进行改变值就可以了。当然变异的概率是很小的,并且是随机的,这一点要注意。并且由于变异是随机的,所以不排除生成比原来还更加糟糕的个体。

选择

最后我们按照一定的规则去筛选这个些个体就可以了,然后淘汰原来的个体。那么在我们的计算机里面是使用了两个东西,首先我们要把原来二进制的玩意,给转化为我们原来的十进制然后带入我们的函数运算,然后保存起来,之后再每一轮统一筛选一下就好了。

逆转

这个咋说呢,说好听点叫逆转,难听点就算,对于一些新的生成的不好的解,我们是要舍弃的。

代码

那么这部分用代码描述的话就是这样的:

import numpy as npimport matplotlib.pyplot as pltPopulation_Size = 100Iteration_Number = 200Cross_Rate = 0.8Mutation_Rate = 0.003Dna_Size = 10X_Range=[0,5]def F(x):    '''    目标函数,需要被优化的函数    :param x:    :return:    '''    return np.sin(10 * x) * x + np.cos(2 * x) * xdef CrossOver(Parent,PopSpace):    '''    交叉DNA,我们直接在种群里面选择一个交配    然后就生出孩子了    :param parent:    :param PopSpace:    :return:    '''    if(np.random.rand()) < Cross_Rate:        cross_place = np.random.randint(0, 2, size=Dna_Size).astype(np.bool)        cross_one = np.random.randint(0, Population_Size, size=1) #选择一位男/女士交配        Parent[cross_place] = PopSpace[cross_one,cross_place]    return Parentdef Mutate(Child):    '''    变异    :param Child:    :return:    '''    for point in range(Dna_Size):        if np.random.rand() < Mutation_Rate:            Child[point] = 1 if Child[point] == 0 else 0    return Childdef TranslateDNA(PopSpace):    '''    把二进制转化为十进制方便计算    :param PopSpace:    :return:    '''    return PopSpace.dot(2 ** np.arange(Dna_Size)[::-1]) / float(2 ** Dna_Size - 1) * X_Range[1]def Fitness(pred):    '''    这个其实是对我们得到的F(x)进行换算,其实就是选择的时候    的概率,我们需要处理负数,因为概率不能为负数呀    pred 这是一个二维矩阵    :param pred:    :return:    '''    return pred + 1e-3 - np.min(pred)def Select(PopSpace,Fitness):    '''    选择    :param PopSpace:    :param Fitness:    :return:    '''    '''    这里注意的是,我们先按照权重去选择我们的优良个体,所以我们这里选择的时候允许重复的元素出现    之后我们就可以去掉这些重复的元素,这样才能实现保留良种去除劣种。100--》70(假设有30个重复)    如果不允许重复的话,那你相当于没有筛选    '''    Better_Ones = np.random.choice(np.arange(Population_Size), size=Population_Size, replace=True,                           p=Fitness / Fitness.sum())    # np.unique(Better_Ones) #这个是我后面加的    return PopSpace[Better_Ones]if __name__ == '__main__':    PopSpace = np.random.randint(2, size=(Population_Size, Dna_Size))  # initialize the PopSpace DNA    plt.ion()     x = np.linspace(X_Range, 200)    # plt.plot(x, F(x))    plt.xticks([0,10])    plt.yticks([0,10])    for _ in range(Iteration_Number):        F_values = F(TranslateDNA(PopSpace))          # something about plotting        if 'sca' in globals():            sca.remove()        sca = plt.scatter(TranslateDNA(PopSpace), F_values, s=200, lw=0, c='red', alpha=0.5)        plt.pause(0.05)        # GA part (evolution)        fitness = Fitness(F_values)        print("Most fitted DNA: ", PopSpace[np.argmax(fitness)])        PopSpace = Select(PopSpace, fitness)        PopSpace_copy = PopSpace.copy()        for parent in PopSpace:            child = CrossOver(parent, PopSpace_copy)            child = Mutate(child)            parent[:] = child    plt.ioff()    plt.show()

这个代码是以前写的,逆转没有写上(下面的有)

TSP遗传算法

ok,刚刚的例子是拿的解方程,也就是说是一个连续问题吧,当然那个连续处理的话并不是很好,只是一个演示。那么我们这个的话其实类似的。首先我们的DNA,是城市的路径,也就是A-B-C-D等等,当然我们用下标表示城市。

种群表示

首先我们确定了使用城市的序号作为我们的个体DNA,例如咱们种群大小为100,有ABCD四个城市,那么他就是这样的,我们先随机生成种群,长这个样:

1 2 3 4
2 3 4 5
3 2 1 4
...

那个1,2,3,4是ABCD的序号。

交叉与变异

这里面的话,值得一提的就是,由于暂定城市需要是不能重复的,且必须是完整的,所以如果像刚刚那样进行交叉或者变异的话,那么实际上会出点问题,我们不允许出现重复,且必须完整,对于我们的DNA,也就是咱们瞎蒙的个体。

代码

由于咱们每一步在代码里面都有注释,所以的话咱们在这里就不再进行复述了。

from math import floorimport numpy as npimport matplotlib.pyplot as pltclass Gena_TSP(object):    """    使用遗传算法解决TSP问题    """    def __init__(self, data, maxgen=200,                 size_pop=200, cross_prob=0.9,                 pmuta_prob=0.01, select_prob=0.8                 ):        self.maxgen = maxgen            # 最大迭代次数        self.size_pop = size_pop        # 群体个数,(一次性瞎蒙多少个解)        self.cross_prob = cross_prob    # 交叉概率        self.pmuta_prob = pmuta_prob    # 变异概率        self.select_prob = select_prob  # 选择概率        self.data = data        # 城市的坐标数据        self.num = len(data)    # 有多少个城市,对应多少个坐标,对应染色体的长度(我们的解叫做染色体)        """        计算城市的距离,我们用矩阵表示城市间的距离        """        self.__matrix_distance = self.__matrix_dis()        self.select_num = int(self.size_pop * self.select_prob)        # 通过选择概率确定子代的选择个数        """        初始化子代和父代种群,两者相互交替        """        self.parent = np.array([0] * self.size_pop * self.num).reshape(self.size_pop, self.num)        self.child = np.array([0] * self.select_num * self.num).reshape(self.select_num, self.num)        """        负责计算每一个个体的(瞎蒙的解)最后需要多少距离        """        self.fitness = np.zeros(self.size_pop)        self.best_fit = []        self.best_path = []        # 保存每一步的群体的最优路径和距离    def __matrix_dis(self):        """        计算14个城市的距离,将这些距离用矩阵存起来        :return:         """        res = np.zeros((self.num, self.num))        for i in range(self.num):            for j in range(i + 1, self.num):                res[i, j] = np.linalg.norm(self.data[i, :] - self.data[j, :])                res[j, i] = res[i, j]        return res    def rand_parent(self):        """        初始化种群        :return:        """        rand_ch = np.array(range(self.num))        for i in range(self.size_pop):            np.random.shuffle(rand_ch)            self.parent[i, :] = rand_ch            self.fitness[i] = self.comp_fit(rand_ch)    def comp_fit(self, one_path):        """        计算,咱们这个路径的长度,例如A-B-C-D        :param one_path:        :return:        """        res = 0        for i in range(self.num - 1):            res += self.__matrix_distance[one_path[i], one_path[i + 1]]        res += self.__matrix_distance[one_path[-1], one_path[0]]        return res    def out_path(self, one_path):        """        输出我们的路径顺序        :param one_path:        :return:        """        res = str(one_path[0] + 1) + '-->'        for i in range(1, self.num):            res += str(one_path[i] + 1) + '-->'        res += str(one_path[0] + 1) + '\n'        print(res)    def Select(self):        """        通过我们的这个计算的距离来计算出概率,也就是当前这些个体DNA也就瞎蒙的解        之后我们在通过概率去选择个体,放到child里面        :return:        """        fit = 1. / (self.fitness)  # 适应度函数        cumsum_fit = np.cumsum(fit)        pick = cumsum_fit[-1] / self.select_num * (np.random.rand() + np.array(range(self.select_num)))        i, j = 0, 0        index = []        while i < self.size_pop and j < self.select_num:            if cumsum_fit[i] >= pick[j]:                index.append(i)                j += 1            else:                i += 1        self.child = self.parent[index, :]    def Cross(self):        """        模仿DNA交叉嘛,就是交换两个瞎蒙的解的部分的解例如        A-B-C-D        C-D-A-B        我们选几个交叉例如这样        A-D-C-B        1,3号交换了位置,当然这里注意可不能重复啊        :return:        """        if self.select_num % 2 == 0:            num = range(0, self.select_num, 2)        else:            num = range(0, self.select_num - 1, 2)        for i in num:            if self.cross_prob >= np.random.rand():                self.child[i, :], self.child[i + 1, :] = self.intercross(self.child[i, :],                                                                             self.child[i + 1, :])    def intercross(self, ind_a, ind_b):        """        这个是我们两两交叉的具体实现        :param ind_a:        :param ind_b:        :return:        """        r1 = np.random.randint(self.num)        r2 = np.random.randint(self.num)        while r2 == r1:            r2 = np.random.randint(self.num)        left, right = min(r1, r2), max(r1, r2)        ind_a1 = ind_a.copy()        ind_b1 = ind_b.copy()        for i in range(left, right + 1):            ind_a2 = ind_a.copy()            ind_b2 = ind_b.copy()            ind_a[i] = ind_b1[i]            ind_b[i] = ind_a1[i]            x = np.argwhere(ind_a == ind_a[i])            y = np.argwhere(ind_b == ind_b[i])            if len(x) == 2:                ind_a[x[x != i]] = ind_a2[i]            if len(y) == 2:                ind_b[y[y != i]] = ind_b2[i]        return ind_a, ind_b    def Mutation(self):        """        之后是变异模块,这个就是按照某个概率,去替换瞎蒙的解里面的其中几个元素。        :return:        """        for i in range(self.select_num):            if np.random.rand() <= self.cross_prob:                r1 = np.random.randint(self.num)                r2 = np.random.randint(self.num)                while r2 == r1:                    r2 = np.random.randint(self.num)                self.child[i, [r1, r2]] = self.child[i, [r2, r1]]    def Reverse(self):        """        近化逆转,就是说下一次瞎蒙的解如果没有更好的话就不进入下一代,同时也是随机选择一个部分的        我们不是一次性全部替换        :return:         """        for i in range(self.select_num):            r1 = np.random.randint(self.num)            r2 = np.random.randint(self.num)            while r2 == r1:                r2 = np.random.randint(self.num)            left, right = min(r1, r2), max(r1, r2)            sel = self.child[i, :].copy()            sel[left:right + 1] = self.child[i, left:right + 1][::-1]            if self.comp_fit(sel) < self.comp_fit(self.child[i, :]):                self.child[i, :] = sel    def Born(self):        """        替换,子代变成新的父代        :return:        """        index = np.argsort(self.fitness)[::-1]        self.parent[index[:self.select_num], :] = self.childdef main(data):    Path_short = Gena_TSP(data)     # 根据位置坐标,生成一个遗传算法类    Path_short.rand_parent()        # 初始化父类    ## 绘制初始化的路径图    fig, ax = plt.subplots()    x = data[:, 0]    y = data[:, 1]    ax.scatter(x, y, linewidths=0.1)    for i, txt in enumerate(range(1, len(data) + 1)):        ax.annotate(txt, (x[i], y[i]))    res0 = Path_short.parent[0]    x0 = x[res0]    y0 = y[res0]    for i in range(len(data) - 1):        plt.quiver(x0[i], y0[i], x0[i + 1] - x0[i], y0[i + 1] - y0[i], color='r', width=0.005, angles='xy', scale=1,                   scale_units='xy')    plt.quiver(x0[-1], y0[-1], x0[0] - x0[-1], y0[0] - y0[-1], color='r', width=0.005, angles='xy', scale=1,               scale_units='xy')    plt.show()    print('初始染色体的路程: ' + str(Path_short.fitness[0]))    # 循环迭代遗传过程    for i in range(Path_short.maxgen):        Path_short.Select()     # 选择子代        Path_short.Cross()      # 交叉        Path_short.Mutation()   # 变异        Path_short.Reverse()    # 进化逆转        Path_short.Born()      # 子代插入        # 重新计算新群体的距离值        for j in range(Path_short.size_pop):            Path_short.fitness[j] = Path_short.comp_fit(Path_short.parent[j, :])        index = Path_short.fitness.argmin()        if (i + 1) % 50 == 0:            print('第' + str(i + 1) + '步后的最短的路程: ' + str(Path_short.fitness[index]))            print('第' + str(i + 1) + '步后的最优路径:')            Path_short.out_path(Path_short.parent[index, :])  # 显示每一步的最优路径        # 存储每一步的最优路径及距离        Path_short.best_fit.append(Path_short.fitness[index])        Path_short.best_path.append(Path_short.parent[index, :])    return Path_short  # 返回遗传算法结果类if __name__ == '__main__':    data = np.array([16.47, 96.10, 16.47, 94.44, 20.09, 92.54,                     22.39, 93.37, 25.23, 97.24, 22.00, 96.05, 20.47, 97.02,                     17.20, 96.29, 16.30, 97.38, 14.05, 98.12, 16.53, 97.38,                     21.52, 95.59, 19.41, 97.13, 20.09, 92.55]).reshape((14, 2))    main(data)

运行结果

ok,我们来看看运行的结果:

怎么用Python遗传算法处理TSP问题

读到这里,这篇“怎么用Python遗传算法处理TSP问题”文章已经介绍完毕,想要掌握这篇文章的知识点还需要大家自己动手实践使用过才能领会,如果想了解更多相关内容的文章,欢迎关注编程网行业资讯频道。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

怎么用Python遗传算法处理TSP问题

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

怎么用Python遗传算法处理TSP问题

本文小编为大家详细介绍“怎么用Python遗传算法处理TSP问题”,内容详细,步骤清晰,细节处理妥当,希望这篇“怎么用Python遗传算法处理TSP问题”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。TSP问题那么
2023-07-04

Python 遗传算法处理TSP问题详解

遗传算法(Genetic Algorithm, GA)是模拟达尔文生物进化论的自然选择和遗传学机理的生物进化过程的计算模型,是一种通过模拟自然进化过程搜索最优解的方法
2022-11-13

怎么使用Python PSO算法处理TSP问题

这篇文章主要介绍了怎么使用Python PSO算法处理TSP问题的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇怎么使用Python PSO算法处理TSP问题文章都会有所收获,下面我们一起来看看吧。PSO算法那么
2023-07-04

PythonPSO算法处理TSP问题详解

这篇文章主要介绍了PythonPSO算法处理TSP问题,PSO粒子群算法是一种基于鸟类觅食开发出来的优化算法,它是从随机解出发,通过迭代寻找最优解,通过适应度来评价解的品质
2022-11-13

Python怎么实现遗传算法

这篇文章给大家分享的是有关Python怎么实现遗传算法的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。(一)问题遗传算法求解正方形拼图游戏(二)代码#!/usr/bin/env python# -*- coding
2023-06-21

python遗传算法之单/多目标规划问题怎么解决

这篇“python遗传算法之单/多目标规划问题怎么解决”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“python遗传算法之单
2023-06-30

怎么用python代码实现遗传算法

要使用Python代码实现遗传算法,可以按照以下步骤进行操作:1. 定义问题:首先,需要明确要解决的问题是什么,例如优化问题、寻找最佳解等。2. 初始化种群:创建一个初始的种群,其中每个个体都是问题的一个解决方案。可以使用随机数生成器或其他
2023-10-10

python遗传算法之geatpy的怎么安装使用

这篇“python遗传算法之geatpy的怎么安装使用”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“python遗传算法之g
2023-06-30

如何使用matlab遗传算法求解车间调度问题

这篇文章主要介绍了如何使用matlab遗传算法求解车间调度问题,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。一、车间调度简介1 车间调度定义车间调度是指根据产品制造的合理需求
2023-06-29

Python中怎么实现一个简单遗传算法

今天就跟大家聊聊有关Python中怎么实现一个简单遗传算法,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。遗传算法遗传算法是模仿自然选择过程的优化算法。 他们没有使用"数学技巧",而是
2023-06-16

Python中怎么实现一个遗传算法框架

本篇文章给大家分享的是有关Python中怎么实现一个遗传算法框架,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。算法特点以决策变量的编码作为运算对象,使得优化过程借鉴生物学中的概
2023-06-17

如何使用Python地图四色原理的遗传算法着色

小编给大家分享一下如何使用Python地图四色原理的遗传算法着色,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!1 任务需求  首先,我们来明确
2023-06-29

Django怎么处理文件上传问题

在Django中处理文件上传问题通常涉及以下几个步骤:在forms.py中定义一个表单类,用于接收文件上传的表单数据。from django import formsclass UploadFileForm(forms.Form):file
Django怎么处理文件上传问题
2024-03-05

怎么使用vue处理seo问题

这篇文章主要介绍了怎么使用vue处理seo问题的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇怎么使用vue处理seo问题文章都会有所收获,下面我们一起来看看吧。服务器端渲染(SSR)最好的解决方案是使用服务器端
2023-07-05

Python中怎么处理常见报错问题

这篇文章主要介绍Python中怎么处理常见报错问题,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!1.首先是常见的语法错误。2.然后是基础语法中的常见异常。3.最后是操作文件过程中的常见异常,这部分也是重难点知识。这是
2023-06-26

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录