【人工智能大脑】仿生学与人工智能交汇:基于MP神经网络的精准农业实践

本文主要是介绍【人工智能大脑】仿生学与人工智能交汇:基于MP神经网络的精准农业实践,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

MP神经网络,即McCulloch-Pitts模型(MCP Model),是神经网络的早期形式之一,由Warren McCulloch和Walter Pitts在1943年提出。这个模型为现代人工神经网络的发展奠定了理论基础,并首次尝试模拟了生物神经元的工作原理。
在这里插入图片描述

MCP由来

深度学习的历史可以追溯到1943年,当时Walter Pitts(数学家)和Warren McCulloch(神经科学家)基于人类大脑的神经网络创建了一个计算机模型,模型名字是用两人名字命名,McCulloch&Pitts,称为MCP模型。

沃尔特·皮茨简介

在这里插入图片描述

1923年4月23日,美国逻辑学家小沃尔特·皮茨出生在底特律一个简陋的社区,年轻的皮茨他特别喜欢数理逻辑。12岁时,他在图书馆阅读了伯特兰·罗素(英国哲学家、数学家、逻辑学家、历史学家、文学家,分析哲学的主要创始人)和阿尔弗雷德·诺斯·怀特海的《数学原理》,并给罗素写了一封信,这封信给他留下了深刻的印象,罗素回复了他,还邀请皮茨来英国。 1938年,皮茨在芝加哥大学(University of Chicago)研究时,他被认为是一个古怪的天才。他参加了罗素在芝加哥的讲座,皮茨也给芝加哥的教授们留下了深刻的印象。
1940年,莱特文把皮茨介绍给了伊利诺伊大学新来的精神病学教授沃伦·麦卡洛克。42岁的麦卡洛克和匹兹第一次交谈时,他们马上发现他们有很多共同之处。而麦卡洛克则成为了皮茨生命中最重要的人。McCulloch和Pitts的研究是在计算机科学领域的早期阶段进行的,他们利用有限的计算资源和技术设备,最终提出了McCulloch-Pitts神经元模型。

跨学科合作创举MCP(MP)

McCulloch是一位神经科学家,而Pitts则是一位数学家和逻辑学家。他们的合作是跨学科的,结合了神经科学、数学和逻辑学的知识。这种跨学科的合作促进了他们对神经元行为的理解,并为神经网络的发展提供了坚实的基础。
原理: MP神经元模型相对简单,它是一个二值逻辑单元,可以看作是一种简化的阈值函数。其工作原理如下:

输入层:MP神经元接受多个布尔型输入信号,这些信号对应于生物神经元中的树突输入。
权重:每个输入信号都有一个对应的权重(w1, w2, w3…),表示该输入信号对神经元输出的影响程度,类似于突触强度。
加权求和与阈值比较:神经元将所有输入信号与其权重相乘后求和,并加上一个偏置(bias),然后将这个总和与一个预设的阈值进行比较。
非线性激活:当加权求和结果大于或等于阈值时,神经元输出一个固定的“兴奋”状态(通常为1);否则输出“抑制”状态(通常为0)。这种开关行为是对生物神经元激发/不激发状态的简化模拟。

数学原理

在这里插入图片描述

使用方法: MP神经元主要用于构建简单的逻辑门电路,例如与门、或门、非门等。通过适当设置权重和阈值,可以实现布尔逻辑运算。然而,由于其功能较为有限,无法直接处理连续值输入或实现复杂的非线性映射,因此在现代神经网络中并不常用作为基础计算单元。

原理电路

在这里插入图片描述

MP神经网络模型(McCulloch-Pitts 模型)的原理可以生动地比喻
一个自动灌溉系统精灵,它基于天气和土壤湿度来决定是否开启洒水装置。这个系统包含两个输入信号:一个是“天气传感器”,它提供晴天或雨天的信息(0表示晴天,1表示雨天);另一个是“土壤湿度传感器”,它提供土壤湿度的高低信息(0表示湿度低,1表示湿度高)。
在这里插入图片描述

权重:在这个系统中,你可以给每个输入信号分配一个权重值。比如,如果认为下雨时不需要浇水(因此雨天信号应该降低开启洒水器的可能性),你可以赋予“天气传感器”一个负权重,如-2;同时,如果认为土壤干燥时强烈需要浇水,你可以赋予“土壤湿度传感器”一个正权重,如+3。

加权求和与阈值比较:当系统接收到输入信号时,会将这两个信号分别乘以其对应的权重值,然后将它们相加。例如,如果是雨天且土壤湿度低(0 * -2 + 0 * 3 = 0),或者晴天且土壤湿度高(1 * -2 + 1 * 3 = 1),此时的结果就是系统的加权输入。

阈值判断(洒水装置自动调节开关):

def fire(self, weather_signal, humidity_signal):"""模拟神经元激活函数,计算加权求和并判断是否达到阈值。输入信号weather_signal和humidity_signal分别代表天气和土壤湿度状态,对应于自动灌溉系统中的晴雨信息和土壤干湿程度。返回值:True - 开启洒水装置(对应门开启)False - 不开启洒水装置(对应门关闭)"""weighted_sum = self.weather_weight * weather_signal + self.humidity_weight * humidity_signalif weighted_sum >= threshold:return 1else:return 0

系统有一个预设的阈值(假设为1)。只有当加权后的总和大于等于这个阈值时,洒水装置才会被激活开启。
所以,在上面的例子中有一行核心分析代码,帮助神经元做出精准判断,在晴天且土壤湿度高的情况下,洒水器才会开启。

洒水控制的高端大脑函数 def fire(self, weather_signal, humidity_signal)

# 计算加权求和,这个步骤是将天气信号(weather_signal)和土壤湿度信号(humidity_signal)分别乘以对应的权重值(self.weather_weight 和 self.humidity_weight)
# 然后将这两个加权后的结果相加。在洒水系统的比喻中:
# - 天气信号的权重(self.weather_weight)代表了天气条件对是否需要灌溉决策的影响程度;
#   如果天气权重为负数,则说明雨天时减少洒水需求(比如-2表示雨天时洒水装置开启的可能性降低)。
# - 土壤湿度信号的权重(self.humidity_weight)则反映了土壤湿度对于是否需要灌溉的重要性;
#   如果湿度权重为正数,则说明土壤干燥时增加洒水需求(如+3表示土壤越干燥,洒水装置开启的可能性越高)。weighted_sum = self.weather_weight * weather_signal + self.humidity_weight * humidity_signal# 通过上述计算,我们得到一个综合考虑了当前天气状况与土壤湿度情况的加权求和值,
# 这个数值将会用来决定是否开启洒水装置(例如,当加权求和值大于或等于阈值时,意味着应该开启洒水装置)。
# 定义类:MPNeuron(对应自动灌溉系统的决策中心“小精灵”)
class MPNeuron:def __init__(self, weather_weight=-2, humidity_weight=3, threshold=1):"""初始化MP神经元,权重参数对应于比喻中的“魔法棒”的魔力大小,阈值对应于决定是否开启门或洒水装置所需的神秘数值。"""self.weather_weight = weather_weight  # 天气传感器信号权重(雨天影响)self.humidity_weight = humidity_weight  # 土壤湿度传感器信号权重(土壤湿度影响)self.threshold = threshold  # 决策阈值def fire(self, weather_signal, humidity_signal):"""模拟神经元激活函数,计算加权求和并判断是否达到阈值。输入信号weather_signal和humidity_signal分别代表天气和土壤湿度状态,对应于自动灌溉系统中的晴雨信息和土壤干湿程度。返回值:True - 开启洒水装置(对应门开启)False - 不开启洒水装置(对应门关闭)"""weighted_sum = self.weather_weight * weather_signal + self.humidity_weight * humidity_signalif weighted_sum >= threshold:return 1else:return 0# 实例化MP神经元,并进行测试
neuron = MPNeuron()# 测试示例,假设获取到的实际天气和湿度信号
test_weather = 1  # 雨天(对应信号1)
test_humidity = 0  # 干燥(对应信号0)# 判断是否开启洒水装置
decision = neuron.fire(test_weather, test_humidity)
print(f"当前天气:{('晴天', '雨天')[test_weather]},土壤湿度:{'干燥' if test_humidity == 0 else '湿润'}")
print(f"是否开启洒水装置:{decision}")

还原神经网络本质

# 定义激活函数(这里使用阶跃函数作为简化)
def step_function(summed_signal):if summed_signal >= 0:return 1  # 激活状态,对应洒水装置开启else:return 0  # 非激活状态,对应洒水装置关闭# 初始化权重和阈值
weather_weight = -2
humidity_weight = 3
threshold = 1# 定义模拟MP神经元的函数
def mp_neuron(weather, humidity):# 计算加权求和weighted_sum = weather * weather_weight + humidity * humidity_weight# 应用激活函数output = step_function(weighted_sum - threshold)  # 减去阈值是因为通常在实际应用中,我们会从总和中减去阈值来进行判断return output# 测试数据
test_weather = 0  # 晴天(0代表晴天,1代表雨天)
test_humidity = 0  # 干燥(0代表干燥,1代表湿润)# 模拟决策过程mp_neuron()函数是一个激活开头,激活就是decision = mp_neuron(test_weather, test_humidity)print(f"当前天气:{'晴天' if test_weather == 0 else '雨天'},土壤湿度:{'干燥' if test_humidity == 0 else '湿润'}")
print(f"是否开启洒水装置:{decision}")

在这里插入图片描述

古老的MP虽然现在已经退居幕后,但是MP神经网络:从硬件智慧的基石到深度学习繁花——也曾经,如同人工智能世界中的初露晨曦,启迪了如何在电路板上编织逻辑之网;而今,在误差反向传播算法破晓的光辉中,MP模型原理为多层感知器(MLP)等更繁复精妙的架构提供了更强有力的支撑。这些后继者犹如科技树上的累累硕果,将智能渗透至图像识别、语音辨识与自然语言处理的广阔天地,续写着人类认知机器智慧的新篇章。"

这篇关于【人工智能大脑】仿生学与人工智能交汇:基于MP神经网络的精准农业实践的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/634788

相关文章

LangChain转换链:让数据处理更精准

1. 转换链的概念 在开发AI Agent(智能体)时,我们经常需要对输入数据进行预处理,这样可以更好地利用LLM。LangChain提供了一个强大的工具——转换链(TransformChain),它可以帮我们轻松实现这一任务。 转换链(TransformChain)主要是将 给定的数据 按照某个函数进行转换,再将 转换后的结果 输出给LLM。 所以转换链的核心是:根据业务逻辑编写合适的转换函

C++必修:模版的入门到实践

✨✨ 欢迎大家来到贝蒂大讲堂✨✨ 🎈🎈养成好习惯,先赞后看哦~🎈🎈 所属专栏:C++学习 贝蒂的主页:Betty’s blog 1. 泛型编程 首先让我们来思考一个问题,如何实现一个交换函数? void swap(int& x, int& y){int tmp = x;x = y;y = tmp;} 相信大家很快就能写出上面这段代码,但是如果要求这个交换函数支持字符型

亮相WOT全球技术创新大会,揭秘火山引擎边缘容器技术在泛CDN场景的应用与实践

2024年6月21日-22日,51CTO“WOT全球技术创新大会2024”在北京举办。火山引擎边缘计算架构师李志明受邀参与,以“边缘容器技术在泛CDN场景的应用和实践”为主题,与多位行业资深专家,共同探讨泛CDN行业技术架构以及云原生与边缘计算的发展和展望。 火山引擎边缘计算架构师李志明表示:为更好地解决传统泛CDN类业务运行中的问题,火山引擎边缘容器团队参考行业做法,结合实践经验,打造火山

人工智能机器学习算法总结神经网络算法(前向及反向传播)

1.定义,意义和优缺点 定义: 神经网络算法是一种模仿人类大脑神经元之间连接方式的机器学习算法。通过多层神经元的组合和激活函数的非线性转换,神经网络能够学习数据的特征和模式,实现对复杂数据的建模和预测。(我们可以借助人类的神经元模型来更好的帮助我们理解该算法的本质,不过这里需要说明的是,虽然名字是神经网络,并且结构等等也是借鉴了神经网络,但其原型以及算法本质上还和生物层面的神经网络运行原理存在

python实现最简单循环神经网络(RNNs)

Recurrent Neural Networks(RNNs) 的模型: 上图中红色部分是输入向量。文本、单词、数据都是输入,在网络里都以向量的形式进行表示。 绿色部分是隐藏向量。是加工处理过程。 蓝色部分是输出向量。 python代码表示如下: rnn = RNN()y = rnn.step(x) # x为输入向量,y为输出向量 RNNs神经网络由神经元组成, python

人工智能做音乐

0 别人做的音乐demo https://yun.baidu.com/share/link?shareid=1799925478&uk=840708891 1 为什么人工智能能做音乐? 最下面蓝色的部分是你输入的音乐。 从上图可以看出,input是一个个的点,然后通过input来相互结合生成灰色的点,经过几层的连接之后,最后的Output就是新生成的音乐,也就是黄色的点。 把黄色的点

9 个 GraphQL 安全最佳实践

GraphQL 已被最大的平台采用 - Facebook、Twitter、Github、Pinterest、Walmart - 这些大公司不能在安全性上妥协。但是,尽管 GraphQL 可以成为您的 API 的非常安全的选项,但它并不是开箱即用的。事实恰恰相反:即使是最新手的黑客,所有大门都是敞开的。此外,GraphQL 有自己的一套注意事项,因此如果您来自 REST,您可能会错过一些重要步骤!

神经网络第四篇:推理处理之手写数字识别

到目前为止,我们已经介绍完了神经网络的基本结构,现在用一个图像识别示例对前面的知识作整体的总结。本专题知识点如下: MNIST数据集图像数据转图像神经网络的推理处理批处理  MNIST数据集          mnist数据图像 MNIST数据集由0到9的数字图像构成。像素取值在0到255之间。每个图像数据都相应地标有“7”、“2”、“1”等数字标签。MNIST数据集中,

神经网络第三篇:输出层及softmax函数

在上一篇专题中,我们以三层神经网络的实现为例,介绍了如何利用Python和Numpy编程实现神经网络的计算。其中,中间(隐藏)层和输出层的激活函数分别选择了 sigmoid函数和恒等函数。此刻,我们心中不难发问:为什么要花一个专题来介绍输出层及其激活函数?它和中间层又有什么区别?softmax函数何来何去?下面我们带着这些疑问进入本专题的知识点: 1 输出层概述 2 回归问题及恒等函数 3

神经网络第一篇:激活函数是连接感知机和神经网络的桥梁

前面发布的文章介绍了感知机,了解了感知机可以通过叠加层表示复杂的函数。遗憾的是,设定合适的、能符合预期的输入与输出的权重,是由人工进行的。从本章开始,将进入神经网络的学习,首先介绍激活函数,因为它是连接感知机和神经网络的桥梁。如果读者认知阅读了本专题知识,相信你必有收获。 感知机数学表达式的简化 前面我们介绍了用感知机接收两个输入信号的数学表示如下: