使用 Python 和 NumPy 为神经网络创建简单高效的遗传算法

使用 python 和 numpy 为神经网络创建简单高效的遗传算法

这是有关 ml 进化算法课程的第一篇文章。

当你知道神经网络的参数,但不知道输出应该是什么时,就需要遗传算法,例如,这个算法可以用来玩 google dinosaur 或 flappy bird,因为你不知道输出应该是什么,但您有能力对最可行的选项进行排序,例如按时间,这称为适应度函数。

我一直没能找到这样一个有效、简单且可用的算法,所以我开始创建自己的轻量级、简单、完美运行的遗传算法。

我的目的不是拖拖拉拉地写这篇文章,也不是用它的篇幅来折磨读者,所以我们直接上代码吧。正如已经提到的,代码很简单,所以大部分内容不需要在整篇文章中描述。

立即学习“Python免费学习笔记(深入)”;

首先我们需要导入模块:

import numpy as npimport random

然后我们添加dataset及其答案,但不使用反向传播算法,而只是统计正确答案的数量。然后你可以在其他变体上进行测试,这些变体现在已被注释掉

x = np.array([[1, 1, 0], [0, 0, 1], [1, 0, 1], [0, 0, 0], [1, 0, 0], [0, 1, 0], [1, 1, 0], [0, 1, 1], [1, 1, 1]])y = np.array([[0],[1],[1], [0], [0], [0], [0], [1], [1]])#x = np.array([[0, 1, 1], [0, 0, 1], [1, 0, 1], [0, 1, 0], [1, 0, 0], [1, 1, 0], [0, 0, 0], [1, 1, 0], [1, 1, 1]])#y = np.array([[1],[0], [0], [1], [0], [1], [0], [1], [1]])#x = np.array([[1, 1, 0], [0, 0, 1], [1, 0, 1], [0, 1, 0], [1, 0, 0], [0, 0, 0], [1, 1, 0], [0, 1, 1], [1, 1, 1]])#y = np.array([[1],[0],[1], [0], [1], [0], [1], [0], [1]])

添加列表和激活函数。这些列表的含义稍后将会变得清晰。第一个激活函数是 sigmoid,第二个是阈值。

listnet = []newnet = []goodnet = []goodnet0 = []goodnet1 = []goodnet2 = []goodnet3 = []goodnet4 = []goodnet5 = []goodnet6 = []good = 0epoch = 0good = 0epoch = 0def sigmoid(x):    return 1/(1 + np.exp(-x)) def finfunc(x):    if x[0] >= 0.5:        x[0] = 1        return x[0]    else:        x[0] = 0        return x[0]

接下来,我们需要创建两个类,第一个类用于创建初始群体,第二个类用于所有后续群体,因为第一次我们需要随机创建权重,然后仅交叉和使它们变异。 init() 函数用于创建或添加权重,predict() 是算法本身和计算最佳选项所必需的,fredict() 函数的不同之处在于它返回答案和适应度函数来显示数字在屏幕上查看训练阶段。在输出层,首先使用 sigmoid 函数使答案更接近其中一个选项,然后才使用阈值函数。

class network():    def __init__(self):        self.h1 = np.random.randn(3, 6)        self.o1 = np.random.randn(6, 1)    def predict(self, x, y):        t1 = x @ self.h1        t1 = sigmoid(t1)        t2 = t1 @ self.o1        t2 = sigmoid(t2)        t2 = finfunc(t2)        if t2 == y[0]:            global good            good += 1    def fpredict(self, x, y):        t1 = x @ self.h1        t1 = sigmoid(t1)        t2 = t1 @ self.o1        t2 = sigmoid(t2)        t2 = finfunc(t2)        if t2 == y[0]:            global good            good += 1        return t2, goodclass network1():    def __init__(self, h1, o1):        self.h1 = h1        self.o1 = o1    def predict(self, x, y):        t1 = x @ self.h1        t1 = sigmoid(t1)        t2 = t1 @ self.o1        t2 = sigmoid(t2)        t2 = finfunc(t2)        if t2 == y[0]:            global good            good += 1    def fpredict(self, x, y):        t1 = x @ self.h1        t1 = sigmoid(t1)        t2 = t1 @ self.o1        t2 = sigmoid(t2)        t2 = finfunc(t2)        if t2 == y[0]:            global good            good += 1        return t2, good

我们输出第一个答案和变量good,这是这里的适应度函数,然后我们为下一个神经网络重置它,打印“wait0”(你可以在这里写任何你想要的东西)是必要的,以免对不同神经网络的答案从哪里开始感到困惑。

s = network()print(s.fpredict(x[0], y[0]))print(s.fpredict(x[1], y[1]))print(s.fpredict(x[2], y[2]))print(s.fpredict(x[3], y[3]))print("wait0")good = 0

第一个周期过去了,在这里以及随后的所有周期中,我们只给出了六个问题来检查它如何处理任务,而它还没有满足,也就是说,我们检查它是否临时抱佛脚,这种情况有时会发生。现在让我们更详细地讨论一下:根据它正确回答了多少个答案,我们将其分配给其中一个类,如果大量答案是正确的,那么我们必须支持这样的神经网络并增加其数量,以便随着随后的变异将会出现更多更聪明的人,要理解这一点,你可以想象100个人中有一个天才,但这对于每个人来说是不够的,这意味着他的天才将在下一代中消失,这意味着神经网络要么学习速度非常慢,要么根本不存在,为了避免这种情况,我们增加了循环中具有大量正确答案的神经网络的数量。最后,我们清空主 listnet 列表,按照从最好到最差的顺序为其分配 goodnet 列表的新值,筛选出 100 个最佳个体,用于后续突变。

for s in range (1000):    s = network()    good = 0    s.predict(x[0], y[0])    s.predict(x[1], y[1])    s.predict(x[2], y[2])    s.predict(x[3], y[3])    s.predict(x[4], y[4])    s.predict(x[5], y[5])    if good == 6:        goodnet6.append(s)        for r in range(15):            goodnet4.append(s)    elif good == 5:        goodnet5.append(s)        for r in range(10):            goodnet4.append(s)    elif good == 4:        goodnet4.append(s)        for r in range(5):            goodnet4.append(s)    elif good == 3:        goodnet3.append(s)    elif good == 2:        goodnet2.append(s)    elif good == 1:        goodnet1.append(s)    elif good == 0:        goodnet0.append(s)    good = 0listnet = []listnet.extend(goodnet6)listnet.extend(goodnet5)listnet.extend(goodnet4)listnet.extend(goodnet3)listnet.extend(goodnet2)listnet.extend(goodnet1)goodnet1 = []goodnet2 = []goodnet3 = []goodnet4 = []goodnet5 = []goodnet6 = []goodnet = listnet[:100]listnet = goodnetgoodnet = []

交叉和变异本身:我们从第一个亲本中取出一部分,从第二个中取出第二部分,进行变异,然后我们在 newnet 列表中得到一个孩子,所以 1000 次。

for g in range(1000):    parent1 = random.choice(listnet)    parent2 = random.choice(listnet)    ch1h = np.vstack((parent1.h1[:1], parent2.h1[1:])) * random.uniform(-0.2, 0.2)    ch1o = parent1.o1 * random.uniform(-0.2, 0.2)    g = network1(ch1h, ch1o)    newnet.append(g)listnet = newnetnewnet = []

从代码的前一部分开始,我们使用 network1(),因为我们现在是交叉和变异,而不是随机创建。所以我们需要重复 1000 次(这是一个超参数,所以你可以自己选择 epoch 的数量,15 对我来说就足够了),我们在第一个 epoch 上显示答案,第 1000 个是最终版本(如果你有,例如,20,然后指定 20)。这里代码是重复的,所以我就不描述了,一切都很清楚了。

for i in range(1000):    good = 0    epoch += 1    for s in listNet:      good = 0      s.predict(x[0], y[0])      s.predict(x[1], y[1])      s.predict(x[2], y[2])      s.predict(x[3], y[3])      s.predict(x[4], y[4])      s.predict(x[5], y[5])      if good == 6:          GoodNet6.append(s)          for r in range(15):              GoodNet4.append(s)      elif good == 5:          GoodNet5.append(s)          for r in range(10):              GoodNet4.append(s)      elif good == 4:          GoodNet4.append(s)          for r in range(5):              GoodNet4.append(s)      elif good == 3:          GoodNet3.append(s)      elif good == 2:          GoodNet2.append(s)      elif good == 1:          GoodNet1.append(s)      elif good == 0:          GoodNet0.append(s)      good = 0    listNet = []    listNet.extend(GoodNet6)    listNet.extend(GoodNet5)    listNet.extend(GoodNet4)    listNet.extend(GoodNet3)    listNet.extend(GoodNet2)    listNet.extend(GoodNet1)    GoodNet1 = []    GoodNet2 = []    GoodNet3 = []    GoodNet4 = []    GoodNet5 = []    GoodNet6 = []    goodNET = listNet[:100]    listNet = goodNET    goodNET = []    if epoch == 1000:        print(listNet[0].Fpredict(x[0], y[0]))        print(listNet[0].Fpredict(x[1], y[1]))        print(listNet[0].Fpredict(x[2], y[2]))        print(listNet[0].Fpredict(x[3], y[3]))        print(listNet[0].Fpredict(x[4], y[4]))        print(listNet[0].Fpredict(x[5], y[5]))        print(listNet[0].Fpredict(x[6], y[6]))        print(listNet[0].Fpredict(x[7], y[7]))        print(listNet[0].Fpredict(x[8], y[8]))        good = 0        print('wait')    elif epoch == 1:        good = 0        print(listNet[0].Fpredict(x[0], y[0]))        print(listNet[0].Fpredict(x[1], y[1]))        print(listNet[0].Fpredict(x[2], y[2]))        print(listNet[0].Fpredict(x[3], y[3]))        print('wait1')    for g in range(1000):        parent1 = random.choice(listNet)        parent2 = random.choice(listNet)        ch1H = np.vstack((parent1.H1[:1], parent2.H1[1:])) * random.uniform(-2, 2)        ch1O = parent1.O1 * random.uniform(2, 2)        g = Network1(ch1H, ch1O)        NewNet.append(g)    listNet = NewNet

这就是神经网络应该找到的模式,这就是最终版本所依赖的数字(第一,第二,第三)并忽略其余的。例如,您可以执行逻辑运算(xor、not、and …),仅在这种情况下,在网络类中将输入数据更改为 2,我还遵循隐藏层中的神经元等于输入的规则数据乘以二,它起作用了,但是你可以尝试你的选择,向神经网络提供相同数量的一些答案和其他答案也很重要,以便正确答案的数量,例如“a”,将等于“b”,否则神经网络将回答所有答案同样的方式,也就是说,如果有更多的 a,那么它会回答所有问题,但不会有任何结果,也在训练样本中给它完全不同的选项,以便它理解模式,例如,如果你一个xor块,那么你必须添加一个带有两个1的选项,但是在逻辑运算的情况下,你必须给出所有选项,因为它们太少了,它不会理解任何东西。
就是这样!!!下一篇文章(必读!):很快……
代码:https://github.com/lanskoykirill/gennumpy.git

我的网站(可能正在重新设计):selfrobotics.space

以上就是使用 Python 和 NumPy 为神经网络创建简单高效的遗传算法的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1354747.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月13日 18:46:27
下一篇 2025年12月13日 18:46:40

相关推荐

  • 代码的出现 &#- DayDisk Fragmenter (Python)

    代码出现第 9 天:磁盘碎片 今天的解决方案只是用 Python 完成的,老实说,我发现很难找到时间用 Python 和 C# 编写以及撰写文章,所以选择继续使用其中之一。 第 1 部分 这相当简单,要求是将输入转换为 id 和空格,其中奇数索引是 id,偶数索引是空格 (.) 并重复 x 次,与输…

    好文分享 2025年12月13日
    000
  • 易于复制的 Bash 脚本来可视化 Python 代码

    通过视觉理解代码比仅仅阅读代码容易 10 倍。 想知道如何快速创建一个吗? 这是我用来可视化 python 代码的 3 个最佳 bash 脚本: 可视化代码结构 你永远不知道什么时候会遇到下一个过于复杂的代码,如果没有工具,就很难发现代码的复杂性。随着项目规模的扩大,这可能会导致可读性差和出现错误的…

    2025年12月13日
    000
  • 使用 Python 请求模块使 HTTP 变得简单

    简介 http 是一种基于 tcp/ip 的应用层通信协议,它标准化了客户端和服务器之间的通信方式。它用于使用超文本链接加载网页。 “无论您是从 api 获取数据还是提交表单数据,python 中的 requests 库都是您的首选工具,可以让 http 请求无缝且直观。” 如何安装请求 在终端中输…

    2025年12月13日
    000
  • 掌握 Python 并发编程:利用先进技术提升性能

    python 的并发编程能力已经显着发展,为开发人员提供了编写高效、并行代码的强大工具。我花了相当多的时间探索这些先进技术,很高兴与您分享我的见解。 使用 asyncio 进行异步编程是 i/o 密集型任务的游戏规则改变者。它允许我们编写非阻塞代码,可以同时处理多个操作,而无需线程开销。下面是一个简…

    2025年12月13日
    000
  • ChatsAPI — 世界上最快的人工智能代理框架

    github: https://github.com/chatsapi/chatsapi图书馆: https://pypi.org/project/chatsapi/ 人工智能已经改变了各行各业,但有效部署人工智能仍然是一项艰巨的挑战。复杂的框架、缓慢的响应时间和陡峭的学习曲线给企业和开发人员带来了…

    2025年12月13日 好文分享
    000
  • 最大化间隔

    每周挑战 298 穆罕默德·s·安瓦尔 (mohammad s. anwar) 每周都会发出“每周挑战”,让我们所有人都有机会为每周两次的任务提出解决方案。这对我们所有人来说都是练习编码的好方法。 挑战,我的解决方案 任务 1:最大平方 任务 给你一个只有 0 和 1 的 m x n 二进制矩阵。 …

    2025年12月13日
    000
  • 如何在 Google Colab 上运行 stable-diffusion–large-turbo

    stable-diffusion-3.5-large-turbo 是一种高精度文本到图像模型。 本指南将解释如何在 google colab 上设置和运行模型。 先决条件 访问拥抱脸。 要使用 stable-diffusion-3.5-large-turbo,您需要一个 huggingface 帐户…

    2025年12月13日 好文分享
    000
  • 在 PyTorch 中移动 MNIST

    请我喝杯咖啡☕ *我的帖子解释了移动 mnist。 movingmnist() 可以使用 moving mnist 数据集,如下所示: *备忘录: 第一个参数是 root(必需类型:str 或 pathlib.path)。 *绝对或相对路径都是可能的。第二个参数是 split(optional-de…

    2025年12月13日 好文分享
    000
  • 用于安全密码哈希的 Bcrypt 算法

    哈希是一种无法逆转的加密函数。它需要随机大小的输入来生成固定大小的值。这些固定大小的值称为哈希值, 加密函数称为哈希函数。散列具有一致和可预测的性质,这意味着相同的输入将始终产生相同的散列值。它还表现出雪崩效应,这意味着即使输入的微小变化也会导致哈希值截然不同,从而确保高安全性和不确定性。 散列通常…

    2025年12月13日
    000
  • PyTorch 中的 FashionMNIST

    请我喝杯咖啡☕ *我的帖子解释了 fashion-mnist。 fashionmnist() 可以使用 fashion-mnist 数据集,如下所示: *备忘录: 第一个参数是 root(必需类型:str 或 pathlib.path)。 *绝对或相对路径都是可能的。第二个参数是 train(opt…

    2025年12月13日
    000
  • 任务-Python 包

    几个 python 包 进度条和 tqdm: 为循环、文件处理或下载等任务实现进度条。 from progress.bar import chargingbarbar = chargingbar(‘processing’, max=20)for i in range(20): # do some w…

    2025年12月13日
    000
  • 使用 Python、LangChain 和矢量搜索构建可扩展的 AI 聊天应用程序

    构建可投入生产的人工智能聊天应用程序需要强大的矢量存储和高效的工作流程管理。让我们探索如何使用 astra db 和 langflow 创建它。 环境设置 首先,让我们使用所需的依赖项设置 python 环境: from langchain.vectorstores import astradbfr…

    2025年12月13日
    000
  • 通过 Ready Mailing Team 的首席执行官电子邮件列表释放战略业务增长

    在商业领域,与合适的人建立联系可以定义成功。 ready mailing team 的首席执行官电子邮件列表是您到达决策顶峰的终极工具——首席执行官、总裁和各行业的顶级领导者。无论您是想提出突破性的想法、促进合作还是加强您的营销活动,此电子邮件列表都可以弥合您的愿景与能够将其变为现实的领导者之间的差…

    2025年12月13日
    000
  • Python 中处理错误的最佳实践

    错误处理是编写健壮且可维护的 python 代码的关键。这是使您的错误管理更智能、更有效的快速指南。 ☝️ 捕获特定异常。 始终捕获特定异常,而不是使用通用的 except 块。这可以帮助您更轻松地识别问题的根本原因,并防止掩盖其他潜在错误。☝️ 针对无效条件提出例外。如果不满足某些条件,请故意提出…

    2025年12月13日
    000
  • 用于动态代码的强大 Python 元编程技术

    作为一名 python 开发人员,我一直对该语言操纵自身的能力着迷。元编程是一种编写在运行时生成或修改其他代码的代码的艺术,它为创建灵活和动态的程序开辟了可能性的世界。在本文中,我将分享七种强大的元编程技术,这些技术彻底改变了我的 python 开发方法。 装饰器:修改函数行为 装饰器是 pytho…

    2025年12月13日
    000
  • Day – CSV 文件、ASCII、字符串方法

    csv(逗号分隔值): csv 文件代表一行,行内的每个值都用逗号分隔。csv 文件看起来像 excel,但 excel 文件只能在 excel 软件中打开。csv 文件用于所有操作系统。 我们可以打开以下两种格式的csv文件。 f =open(“sample.txt”, “r”)with open…

    2025年12月13日
    000
  • Python 缓存:如何通过有效的缓存来加速代码

    此博客最初发布到 crawlbase 博客 高效、快速的代码对于在软件应用程序中创建出色的用户体验非常重要。用户不喜欢等待缓慢的响应,无论是加载网页、训练机器学习模型还是运行脚本。加快代码速度的一种方法是缓存。 缓存的目的是临时缓存经常使用的数据,以便您的程序可以更快地访问它,而不必多次重新计算或检…

    2025年12月13日
    000
  • python中:代表什么

    在 Python 中,冒号 (:) 具有多重作用:作为分隔符:用于分隔字典中的键值对或切片中的索引。执行操作:索引切片:返回指定索引范围内的序列。条件语句:指示在条件为真时执行的语句块。列表推导:创建列表。字典解析:创建字典。 在 Python 中,”:” 表示冒号,用作分隔…

    2025年12月13日
    000
  • Python Day- 使用循环、任务形成模式

    图案形成:练习: 1) for row in range(5): for col in range(5-row): print(5-col,end=’ ‘) print() 输出: 5 4 3 2 1 5 4 3 2 5 4 3 5 4 5 2) no = 1for row in range(5):…

    2025年12月13日
    000
  • Solving Word Cookies Puzzles: A Python Adventure

    玩游戏是让大脑从一天的压力中放松下来的一种方式,或者只是从工作中休息一下。然而,有时,游戏本身就会带来压力,所以我认为“word cookies”就是这样,这是一款有趣的益智游戏,你会得到一组打乱的字母,并被要求解决其中包含的单词。 随着我在游戏中的进展,解决问题变得越来越困难,几乎没有资源可以帮助…

    2025年12月13日 好文分享
    000

发表回复

登录后才能评论
关注微信