- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
当我们比较遗传算法(GA)和粒子群优化(PSO)的结构时,可以说:
遗传算法中的种群=粒子群算法中的种群。
遗传算法中的染色体(势解)等于粒子群优化算法中的粒子(势解)。
遗传算法中染色体的基因=粒子群算法中粒子的坐标。
最佳答案
因为你必须知道遗传算法和粒子群算法都属于进化计算。这两种进化启发式算法都是基于种群的搜索方法。
好像,我们考虑了原始遗传算法的情况(这里我甚至没有讨论稍微修改的遗传算法)它受到遗传和进化原理的启发,模仿在生物种群或环境中观察到的繁殖行为它遵循“适者生存”的原则,选择和产生适应环境或约束的后代。但是,如果我们谈论pso。它的灵感来源于在鱼群和鸟群中观察到的行为。他们如何利用外部的刺激反应或行为(以健身功能达到最大值或最小值),利用他们的认知和集体力量?
粒子群算法被认为是对遗传算法的改进,因为它计算期望结果的时间更短。然而,由于易于实现和理解,ga仍然被许多人和公司使用。
现在,让我们讨论一下你的问题:
遗传算法中的种群=粒子群算法中的种群?
我想答案是肯定的,但并不总是。因为有些情况下,我们不能直接用粒子群算法来表示种群,但我们可以用遗传算法来表示种群。例如,如果我们考虑离散向量表示,那么我们可以很容易地使用遗传算法,但在将向量输入粒子群算法之前,我们需要做一些修改。
遗传算法中的染色体(势解)和粒子群优化算法中的粒子(势解)?
也许,你是对的。但让我提醒你为什么我们使用电子商务技术因为,问题的可能解决方案的数量(使用EC技术解决)通常具有大量的状态空间而且,我们只考虑它的一小部分作为我们的产出或结果。因此,即使我们达到了所需的基准,我们也不能确定结果是否匹配。
遗传算法中染色体的基因=粒子群算法中粒子的坐标?
As,我们都知道遗传算法本质上是用来评估离散向量表示的,其中As,PSO在具有连续变量的无约束问题上表现最好由于原始粒子群算法对局部极大值或极小值不太免疫。因此,在约束条件下有时会出现早熟收敛这在遗传病中很少见到(由于突变)所以,我会说不。遗传算法中染色体的基因并不总是粒子群中粒子的坐标。
编辑:
你能给我举个简单的例子吗?“…在将矢量输入PSO算法之前,我们需要做一些修改。”
因为我已经告诉过你们,遗传算法天生就是为离散计算而设计的,而粒子群优化算法在连续变量的情况下效果更好让我们考虑一个案子。在这里,我们得到了一系列0
和1
字符串我们要满足给定的适应度函数来终止循环。众所周知,f(x)
和0
是两个离散的数字。因此,在应用交叉或变异(在遗传算法的情况下)我们将得到离散输出之后,我们将把这个输出输入fitness函数来检查它的强度如果它能在f(x)中存活下来,那么我们将把这个输出推到下一代。
但对于粒子群优化算法,我们通常考虑位置向量或0和1的字符串,以及速度向量或将数改变为相反数的概率(意味着将1
改变为0
的概率,反之亦然)现在,假设将值1
更改为0
的概率为1
,0.6
更改为1
的概率为0
。然后应用概率分布,我们将得到一个过渡状态,该状态在某种程度上保持0.3
或0
。换句话说,即将到来的状态将包含1
和0
之间的值,这本身是不正确的。而且,因为我们只期待离散的数字因此,我们必须设置一些基准,比如-below1
将是0.5
(零),below0
将是0.5
(一),现在这个基准或修改后的输出将用作下一代的输入。
关于algorithm - 比较遗传算法(GA)的结构和粒子群优化(PSO)的结构,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35354111/
我正在创建一个使用 tsParticles 的 Preact 组件库,但什么也没有出现。 我正在移植 React project但可能有些地方不兼容。 您可以在此处 checkout 组件:https
我试图为具有三的粒子提供速度和原点,但我无法添加原点 function getOrigin() { return new THREE.Vector3(Weapon.vehicle.posit
当用户单击任何粒子时,我希望它扩展和淡出,并且在与任何其他粒子碰撞时,该粒子也会扩展和淡出。现在我的问题是我想知道是否有一种方法可以让这些粒子(在本例中由构造函数制成)在碰撞时相互影响。链接至Code
http://www.mrspeaker.net/ 这个人制作了他的整个背景粒子,但我一直在 Inspect Element 中漫游以弄清楚他是怎么做到的,又不能。我不太确定它是如何完成的,有人知道他
这是我个人网站的存储库:https://github.com/flakpanzer40/flakpanzer40.github.io 您可能会注意到,我使用的粒子只是显示在我的名字、图片和描述下方。我
我在实现粒子 JS 时遇到了问题。我添加了两个 JS 文件,但在浏览器中没有得到任何输出。这是我的代码。 particles.js 最佳答案 您的 b
我正在尝试将粒子 js 设置为我网站的背景。我正在尝试应用这个: https://codepen.io/nikspatel/pen/aJGqpv 我尝试将其 css 设置为:position: fix
我正在尝试修改这个 Digiben 样本,以便获得从一个点(撞击点)产生并向上漂浮的粒子效果,有点像火的 Spark 。样本中的粒子在一个圆圈内旋转......我已经尝试删除余弦/正弦函数并将它们替换
我正在开发我的第一个游戏引擎,并尝试实现 GPU 粒子系统。我以前在 CPU 上实现过一个,但现在我正在努力提高它的效率。具体来说,我的问题是在一生中产生粒子。 由于我正在为粒子引擎处理帧缓冲区纹理,
我正在创建一个网络应用程序,该应用程序具有交互式背景,粒子会四处弹跳。在任何时候,屏幕上都有大约 200 个圆形粒子,最多大约 800 个粒子。为粒子运行的一些碰撞和效果是以下原型(prototype
我正在尝试让一些轨道物体留下痕迹。为此,我创建了一个粒子系统,其中包含三个几何体、三个点云和三个点云 Material : particleMaterial = new THREE.PointClou
如上所述,我正在使用 particles.js库,用于向我正在设计的网站上的 div 添加背景。 当页面加载时,正确的 div 将动画作为背景,但它总是开始得太“放大”。它似乎使用太大的默认屏幕尺寸,
我找不到是否可以限制粒子总数。 有什么办法吗? Particles.js Github 最佳答案 您可以修改 particles.js(第 750 行),在推送函数中添加额外的检查: /* -----
我正在尝试从主机ubuntu计算机上的远程Ubuntu计算机上运行CUDA粒子示例。 我遵循了本教程: http://devblogs.nvidia.com/parallelforall/remote
编辑嗨,我正在尝试实现粒子(或遗传)群优化。然而,我已经卡在第一步了…… 我对如何初始化粒子以及这些粒子(就代码而言)是什么感到困惑。 我已经找到了有关算法(单独)和实现的各种信息,但没有找到我想要的
我正在开发一个 2d android 策略游戏,它在 SurfaceView 上运行,所以我不能(或者我可以吗?)使用 LibGdx 的粒子系统。我想做一个下雨的效果,我的目标是这样的(http://
我正在使用粒子效果,它会到达您单击的位置并且不会停止。当我点击某个地方时,粒子就会相应地移动。然而,当我再次单击时,粒子开始越来越快地发挥其效果,我完全不明白为什么。我假设它在 SpellParent
好吧,我在 HTML 和 CSS 方面拥有丰富的经验,并且在 Javascript 方面也有一些经验(我可以编写基本功能并使用类似的语言进行编码)。 我正在寻找一些视觉项目,并且对进入粒子系统特别感兴
所以我有一些粒子(椭圆)在屏幕上跳来跳去。我试图让他们碰撞而不是互相超越。为了做到这一点,我必须循环遍历每个粒子,并将它与每个其他粒子的距离与嵌套在另一个 for 循环中的 for 循环进行比较,然后
我有使用 pygame 绘制的粒子和爆炸类。 爆炸代表一堆飞行的粒子。一个粒子最终会消失;当它的 ttl 属性变为 0 时,它不应该是可见的并且应该从 Explosion.particles 中移除。
我是一名优秀的程序员,十分优秀!