哪个网站可以做设计赚钱汽车门户网站开发

news/2025/9/27 8:44:36/文章来源:
哪个网站可以做设计赚钱,汽车门户网站开发,应用商店官方免费下载,国内免费域名注册前言 最近发现有挺多人喜欢径向基函数(Radial Basis Function,RBF)神经网络#xff0c;其实它就是将RBF作为神经网络层间的一种连接方式而已。这里做一个简单的描述和找了个代码解读。 之前也写过一篇#xff0c;不过排版不好看#xff0c;可以戳这里跳转 国际惯例#x…前言 最近发现有挺多人喜欢径向基函数(Radial Basis Function,RBF)神经网络其实它就是将RBF作为神经网络层间的一种连接方式而已。这里做一个简单的描述和找了个代码解读。 之前也写过一篇不过排版不好看可以戳这里跳转 国际惯例参考博客 维基百科径向基函数 《模式识别与智能计算——matlab技术实现第三版》第6.3章节 《matlab神经网络43个案例分析》第7章节 tensorflow2.0实现RBF numpy的实现 理论 基本思想 用RBF作为隐单元的“基”构成隐藏层空间隐藏层对输入矢量进行变换将低维的模式输入数据变换到高维空间内使得在低维空间内的线性不可分问题在高维空间内线性可分。 详细一点就是用RBF的隐单元的“基”构成隐藏层空间这样就可以将输入矢量直接(不通过权连接)映射到隐空间。当RBF的中心点确定以后这种映射关系也就确定 了。而隐含层空间到输出空间的映射是线性的(注意这个地方区分一下线性映射和非线性映射的关系)即网络输出是隐单元输出的线性加权和此处的权即为网络可调参数。 径向基神经网络的节点激活函数采用径向基函数定义了空间中任一点到某一中心点的欧式距离的单调函数。 我们通常使用的函数是高斯函数 ϕ(r)e−(ϵr)2\phi(r) e^{-(\epsilon r)^2} ϕ(r)e−(ϵr)2 在《Phase-Functioned Neural Networks for Character Control》论文代码中有提到很多径向基函数 kernels {multiquadric: lambda x: np.sqrt(x**2 1),inverse: lambda x: 1.0 / np.sqrt(x**2 1),gaussian: lambda x: np.exp(-x**2),linear: lambda x: x,quadric: lambda x: x**2,cubic: lambda x: x**3,quartic: lambda x: x**4,quintic: lambda x: x**5,thin_plate: lambda x: x**2 * np.log(x 1e-10),logistic: lambda x: 1.0 / (1.0 np.exp(-np.clip(x, -5, 5))),smoothstep: lambda x: ((np.clip(1.0 - x, 0.0, 1.0))**2.0) * (3 - 2*(np.clip(1.0 - x, 0.0, 1.0))) }下图是径向基神经元模型 径向基函数的激活函数是以输入向量和权值向量注意此处的权值向量并非隐藏层到输出层的权值具体看下面的径向基神经元模型结构之间的距离||dist||作为自变量的图中的b为阈值用于调整神经元的灵敏度。径向基网络的激活函数的一般表达式为 R(∥dist∥)e−∥dist∥R(\parallel dist \parallel) e^{-\parallel dist \parallel} R(∥dist∥)e−∥dist∥ 下图是以高斯核为径向基函数的神经元模型 对应到激活函数表达式 R(xp−ci)exp⁡(−12σ2∥xp−ci∥2)R(x_p-c_i)\exp{\left(-\frac{1}{2\sigma^2}\parallel x_p - c_i \parallel^2 \right)} R(xp​−ci​)exp(−2σ21​∥xp​−ci​∥2) 其中X代表输入向量C代表权值为高斯函数的中心σ\sigmaσ是高斯函数的方差可以用来调整影响半径(仔细想想高斯函数中ccc和σ\sigmaσ调整后对函数图的影响)当权值和输入向量的距离越小网络的输出不断递增输入向量越靠近径向基函数的中心隐层节点产生的输出越大。也就是说径向基函数对输入信号在局部产生响应输入向量与权值距离越远隐层输出越接近0再经过一层线性变换映射到最终输出层导致输出层也接近0。 结构 RBF是具有单隐层的三层前向网络。 第一层为输入层由信号源节点组成。 第二层为隐藏层隐藏层节点数视所描述问题的需要而定隐藏层中神经元的变换函数即径向基函数是对中心点径向对称且衰减的非负线性函数该函数是局部响应函数具体的局部响应体现在其可见层到隐藏层的变换是通过径向基函数计算跟其它的网络不同。以前的前向网络变换函数都是全局响应的函数。 第三层为输出层是对输入模式做出的响应。 输入层仅仅起到传输信号作用输入层和隐含层之间可以看做连接权值为1的连接输出层与隐含层所完成的任务是不同的因而他们的学习策略也不同。输出层是对线性权进行调整采用的是线性优化策略因而学习速度较快而隐含层是对激活函数格林函数高斯函数一般取后者的参数进行调整采用的是非线性优化策略因而学习速度较慢。 参数 径向基函数需要两组参数 基函数中心方差(宽度) 隐层到输出层只需要一组参数 权值 优点 逼近能力分类能力和学习速度等方面都优于BP神经网络结构简单、训练简洁、学习收敛速度快、能够逼近任意非线性函数克服局部极小值问题。原因在于其参数初始化具有一定的方法并非随机初始化。 缺点 如果中心点是样本中的数据就并不能反映出真实样本的状况那么输入到隐层的映射就是不准确的如果使用有监督学习函数中心是学习到的但是如果中心点选取不当就会导致不收敛。 各层的计算 首先初始化参数中心、宽度、权值 不同隐含层神经元的中心应有不同的取值并且与中心的对应宽度能够调节使得不同的输入信息特征能被不同的隐含层神经元最大的反映出来在实际应用时一个输入信息总是包含在一定的取值范围内。 中心 方法1 《模式识别与智能计算》中介绍了一种方法将隐含层各神经元的中心分量的初值按从小到大等间距变化使较弱的输入信息在较小的中心附近产生较强的响应。间距的大小可由隐藏层神经元的个数来调节。好处是能够通过试凑的方法找到较为合理的隐含层神经元数并使中心的初始化尽量合理不同的输入特征更为明显地在不同的中心处反映出来体现高斯核的特点 cjimin⁡imax⁡i−min⁡i2p(j−1)max⁡i−min⁡ipc_{ji} \min i \frac{\max i-\min i}{2p}(j-1)\frac{\max i-\min i}{p} cji​mini2pmaxi−mini​(j−1)pmaxi−mini​ 其中p为隐层神经元总个数j为隐层神经元索引i为输入神经元索引max⁡i\max imaxi是训练集中第i个特征所有输入信息的最小值$\max i $为训练集中第i个特征所有输入信息的最大值。 方法2 《43案例分析》中介绍的是Kmean使用方法就是传统的算法先随机选k个样本作为中心然后按照欧氏距离对每个样本分组再重新确定聚类中心再不断重复上面的步骤直到最终聚类中心变化在一定范围内。 宽度 宽度向量影响着神经元对输入信息的作用范围宽度越小相应隐含层神经元作用函数的形状越窄那么处于其他神经元中心附近的信息在该神经元出的响应就越小就跟高斯函数图像两边的上升下降区域的宽度一样。按照《模式识别与智能计算》计算有点像标准差的计算(但是此处原文没有带平方不过我觉得应该带上详细可以查阅这个YouTube视频不带平方万一出现负数是无法求根的) djidf1N∑k1N(xik−cji)2d_{ji} d_f\sqrt{\frac{1}{N}\sum_{k1}^N(x_i^k-c_{ji})^2} dji​df​N1​k1∑N​(xik​−cji​)2​ 当然也可以用《43案例分析》里面说的利用中心之间的最大距离cmaxc_{max}cmax​去计算其中h是聚类中心个数 dcmax2hd \frac{c_{max}}{\sqrt{2h}} d2h​cmax​​ 输入层到隐层的计算 直接套入到选择的径向基函数中 zjexp⁡(−∣∣X−CjDj∣∣2)z_j \exp\left(- \left|\left|\frac{X-C_j}{D_j} \right|\right|^2\right) zj​exp(−∣∣∣∣​∣∣∣∣​Dj​X−Cj​​∣∣∣∣​∣∣∣∣​2) 其中CjC_jCj​就是第j个隐层神经元对应的中心向量由隐层第j个神经元所连接的输入层所有神经元的中心分量构成即Cj[Cj1,Cj2,⋯,Cjn]C_j [C_{j1},C_{j2},\cdots,C_{jn}]Cj​[Cj1​,Cj2​,⋯,Cjn​]DjD_jDj​为隐层第j个神经元的宽度向量与CjC_jCj​对应DjD_jDj​越大隐层对输入向量的影响范围就越大而且神经元间的平滑程度就更好。 隐层到输出层的计算 就是传统的神经网络里面把核函数去掉变成了线性映射关系 yk∑j1pwkjzjy_k \sum_{j1}^p w_{kj}z_j yk​j1∑p​wkj​zj​ 其中k是输出层神经元个数。 权重迭代 直接使用梯度下降法训练中心、宽度、权重都通过学习来自适应调节更新。 其中η\etaη为学习率EEE为损失函数一般就是均方差。 训练步骤 先初始化中心、宽度、最后一层权重计算损失如果在接受范围内停止训练利用梯度更新的方法更新中心、宽度、权重返回第二步 代码实现 有大佬利用keras实现过基于Kmeans的高斯RBF神经网络层代码戳这里 首先利用sklearn里面的库构建一个K-means层 from keras.initializers import Initializer from sklearn.cluster import KMeansclass InitCentersKMeans(Initializer): Initializer for initialization of centers of RBF networkby clustering the given data set.# ArgumentsX: matrix, datasetdef __init__(self, X, max_iter100):self.X Xself.max_iter max_iterdef __call__(self, shape, dtypeNone):assert shape[1] self.X.shape[1]n_centers shape[0]km KMeans(n_clustersn_centers, max_iterself.max_iter, verbose0)km.fit(self.X)return km.cluster_centers_构建RBF层的时候第一层初始化使用上面的Kmeans初始化 self.centers self.add_weight(namecenters,shape(self.output_dim, input_shape[1]),initializerself.initializer,trainableTrue)第二层用一个线性加权的层 self.betas self.add_weight(namebetas,shape(self.output_dim,),initializerConstant(valueself.init_betas),# initializerones,trainableTrue) 计算时候 def call(self, x):C K.expand_dims(self.centers)H K.transpose(C-K.transpose(x))return K.exp(-self.betas * K.sum(H**2, axis1))但是此处我觉得有问题这里的宽度向量好像没有体现出来所以我重写了一个 def call(self, x):C K.expand_dims(self.centers)XC K.transpose(K.transpose(x)-C) D K.expand_dims(K.sqrt(K.mean(XC**2,axis0)),0) H XC/Dreturn K.exp(-self.betas * K.sum(H**2, axis1))可以看原作者的代码作者是用于二维数据的拟合 也可以看我的代码基于原作者代码做的二维数据分类 小点为训练集大圆点为测试集 后记 RBF可以用于插值、分类在论文《Phase-Functioned Neural Networks for Character Control》还用来更改地形也就是说图形、图像通用说明还是蛮重要的。这里主要介绍了一下理论后续再去做扩展性研究。 完整的python脚本实现放在微信公众号的简介中描述的github中有兴趣可以去找找同时文章也同步到微信公众号中有疑问或者兴趣欢迎公众号私信。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/919260.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

在Java 12环境中配置和部署Apache Tomcat

在Linux系统中,远程服务器的文件夹可以通过多种协议进行挂载,如NFS、SSHFS、CIFS等。要使这个过程像一场有趣的旅行一样,我们会“打包”(准备必要的工具),“规划路线”(确定连接的细节),然后“出发”(执行挂…

android pdf框架-14,mupdf重排 - 详解

android pdf框架-14,mupdf重排 - 详解pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-family: "Consolas", "Mona…

深入解析:UE5GAS GameAbility源码解析 CommitAbility

深入解析:UE5GAS GameAbility源码解析 CommitAbility2025-09-27 08:43 tlnshuju 阅读(0) 评论(0) 收藏 举报pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; di…

详细介绍:基于物联网的智能衣柜系统的设计(论文+源码)

详细介绍:基于物联网的智能衣柜系统的设计(论文+源码)pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-family: "Consolas…

电子商务平台 网站 建设方式博达网站建设怎么建立下载

成员函数和成员变量是分开存储的 1. 非静态成员变量,属于类的一部分,sizeof(类名)的时候会包括进去 2. 静态成员变量,不属于类的一部分,不会影响类的大小 3. 成员函数,都不属于类的一部分 4. 空类大小为1B

上海做网站好的公司有哪些安卓优化大师旧版本

Acrobat Pro DC 2023是一款功能强大的PDF编辑和管理软件,它可以帮助用户在创建、编辑、转换和共享PDF文档方面达到前所未有的高度。这款软件提供了丰富的编辑功能,使用户能够轻松添加注释、高亮、下划线、插入文本等,自由地编辑PDF文档。除了…

确定Ceph集群中OSD组件与具体物理磁盘的关联

在Ceph分布式存储系统中,Object Storage Daemons(OSDs)是主要的存储守护进程,负责存储数据、数据复制、恢复、再平衡以及提供信息给集群的监控模块以便于其他组件的决策。为了维护数据的完整性和高可用性,Ceph自动…

深入解析:Jenkins+Tomcat持续集成教程

pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-family: "Consolas", "Monaco", "Courier New", …

JavaScript加解密实践

加密算法设计 首先,我们选用对称加密,其中加密和解密使用同一把密钥。考虑到执行效率和实现复杂度,本例使用修改版的凯撒密码作为基础。凯撒密码是最简单的替换密码类型之一,通过将字母表中的每个字母移动固定数目…

维护一个网站难吗制作视频的网站软件

即时编译(Just-In-Time Compilation,JIT)是一种将程序在运行时动态地编译成机器代码的编译技术。相对于传统的静态编译,即时编译将编译过程延迟到程序执行的时候进行,而不是在程序执行之前。这种方法允许编译器根据程序…

手表网站建设策划新乡网站建设求职简历

直方图 何为直方图?没那么高大上,其实就是二维统计图。每个照片都是有像素点所组成,当然也是[0,255],直方图就是统计每个值所对应的像素点有几个。 直方图横坐标表示0-255这些像素点值;纵坐标表示对应像素点值的个数有…

重庆定制网站建设地址深圳松岗最新消息今天

https://vijos.org/p/1629 描述 八是个很有趣的数字啊。八发,八八爸爸,88拜拜。当然最有趣的还是8用二进制表示是1000。怎么样,有趣吧。当然题目和这些都没有关系。 某个人很无聊,他想找出[a,b]中能被8整除却不能被其他一些数整除…

Linux系统中使用df命令详解磁盘使用情况

df(disk free)是一款Linux系统中用于检查文件系统磁盘空间占用情况的命令行工具。通过这个命令,用户能够查看已挂载的磁盘分区的总空间、已使用空间、可用空间以及挂载点。以下是对 df命令功能的详细阐述。 基本用法…

读人形机器人24岗位替代

读人形机器人24岗位替代1. 评估失业风险 1.1. 人形机器人的兴起给全球社会带来了兴奋感和担忧 1.2. 机器具有无与伦比的机动性、灵活性和适应性,它们能够执行各行各业的复杂任务 1.3. 最容易受自动化影响的行业1.3.1.…

Palantir解密:从企业数字化能力构成说起,“本体”如何破解现代企业数据应用难题? - 指南

Palantir解密:从企业数字化能力构成说起,“本体”如何破解现代企业数据应用难题? - 指南pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !import…

在Ubuntu 18.04/20.04 LTS设置静态DNS服务器

要在Ubuntu 18.04/20.04 LTS上设置静态DNS服务器,需遵循特定的配置过程,这个过程因为Ubuntu系统中网络管理组件的不同而有所区别。 Ubuntu 18.04 (使用netplan) Ubuntu 18.04 默认使用netplan来代替之前的 /etc/netw…

做旅行网站好网络建设与运维初级

队列概念队列(Queue)是限定只能在一端插入、另一端删除的线性表。允许删除的一端叫做队头(front),允许插入的一端叫做队尾(rear),没有元素的队列称为“空队列”。队列具有先进先出(FIFO)的特性。普通顺序队列存在的问题在普通顺序队列中,入队的操作就是先将尾指针re…

杭州市城乡建设网站做字典网站开发

一、误差思维(只要有估计,就会有误差)1.误差永远存在,并且不可避免。2.多次测量用平均值的统计方式取得结果,尽量避免偶然因素的影响。二、置信区间(误差范围)1.统计学最核心思想:用…

wordpress下划线 代码东莞网站关键词优化怎么做

乘车人表结构 分库分表策略 乘车人的数据严重依赖于用户数据。每个用户至少需要有一个对应的乘车人,即自己本人。当然,也有可能是其他人,因为允许用户注册账号后为他人购票的情况。这种关联确保了用户和乘车人之间的正确映射,使系…

杭州手机网站黄埭网站建设

一、RAID的介绍 1.什么是raid "RAID"一词是由David Patterson, Garth A. Gibson, Randy Katz 于1987年在加州大学伯克利分校发明的。在1988年6月SIGMOD会议上提交的论文"A Case for Redundant Arrays of Inexpensive Disks”"中提出,当时性能最…