IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 人工智能 -> 粒子群算法求解多元函数最值问题 -> 正文阅读

[人工智能]粒子群算法求解多元函数最值问题

粒子群算法求解多元函数最值问题

一、简介

多元函数极值&最值问题通常使用导数/偏导数进行推导,这里尝试使用启发式算法进行求解近似最优解。选用粒子群算法进行求解,粒子群算法模仿鸟群觅食行为,核心思想是通过向距离食物最近的鸟集聚,不断更新速度和位置以达到最优解,即表现不好的个体通过向表现好的个体学习使得自身往好的方向转变,这里存在一个前提:所有鸟知道距离食物的远近,距离食物最近包含两部分:当前最近和历史最近。标准粒子群算法适合求解函数极值问题,在TSP、背包问题上多用混合型粒子群算法。算法详细介绍可参考【粒子群算法研究】。

二、粒子群算法求解

多元函数:y = ( x 1 x_1 x1?+ x 2 x_2 x2?)/( x 1 2 x_1^2 x12?+ x 2 2 x_2^2 x22?+1)

粒子群编程求解

import pylab as mpl 
import random import
matplotlib.pyplot as plt 
mpl.rcParams['font.sans-serif'] = ['SimHei'] # 添加这条可以让图形显示中文

def fitness(x):
    """
    计算适应值:y = (x1+x2)/(x1**2+x2**2+1)
    """
    x1 = x[0]
    x2 = x[1]
    y = (x1+x2)/(x1**2+x2**2+1)
    return y

def update(x, p, g, w, c1, c2, v_low, v_high, vi, d, x_low, x_up):
    '''
    更新速度和位置
    '''
    # 更新速度
    vi = w * vi + c1 * random.uniform(0, 1) * (p-x) + c2 * random.uniform(0, 1) * (g-x)
    for j in range(d):
        if vi[j] >v_high:
            vi[j] = v_high
        elif vi[j] < v_low:
            vi[j] = v_low

    # 更新位置
    x = x +vi
    for j in range(d):
        if x[j] > x_up[j]:
            x[j] = x_up[j]
        elif x[j] < x_low[j]:
            x[j] = x_low[j]
    return x


if __name__ == '__main__':
    # 参数
    birdNum = 20  # 粒子数量
    w = 0.2  # 惯性因子
    c1 = 0.4  # 自我认知因子
    c2 = 0.4  # 社会认知因子
    # pBest, pLine = 0, []  # 当前最优值、当前最优解,(自我认知部分)
    # gBest, gLine = 0, []  # 全局最优值、全局最优解,(社会认知部分)
    v_low = -2 #速度约束
    v_high =2
    iterMax = 100  # 迭代次数
    iterI = 1  # 当前迭代次数
    bestfit = -100000  # 记录每代最优值
    #y = (x1+x2)/(x1**2+x2**2+1)
    d = 2 #函数变量个数
    x_low = [-10, -10]#变量范围
    x_up = [10, 10]

    #随机生成初始解
    xs = np.array([np.array([random.uniform(x_low[0],x_up[0]),random.uniform(x_low[1],x_up[1])])
	for i in range(birdNum)])
    v = np.array([random.uniform(v_low,v_high) for i in range(birdNum)])
    fits = np.array([fitness(x) for x in xs])

    fit = max(fits)
    x = xs[np.argmax(fits)]

    gBest = pBest = fit # 全局最优值、当前最优值
    gSolve = pSolve = x  # 全局最优解、当前最优解
    bestfit = []
    bestfit.append(gBest)

    while iterI <= iterMax:  # 迭代开始
        for i in range(birdNum):
            xs[i] = update(xs[i], pSolve, gSolve, w, c1, c2, v_low, v_high, v[i], d, x_low, x_up)
            fits[i] = fitness(xs[i])

        pBest, pSolve = max(fits), xs[np.argmax(fits)]

        if max(fits) >= gBest:
            gBest, gSolve = max(fits), xs[np.argmax(fits)]

        bestfit.append(gBest)
        print(iterI, gBest)  # 打印当前代数和最佳适应度值
        print(gSolve, pSolve)
        iterI += 1  # 迭代计数加一

    #迭代图
    plt.plot(range(1,len(bestfit)+1), bestfit)
    plt.xlabel("迭代次数")
    plt.ylabel("最优值")
    plt.show()

结果
y y y=0.7068, x 1 = 0.8701 , x 2 = 0.8287 x_1=0.8701,x_2=0.8287 x1?=0.8701,x2?=0.8287
在这里插入图片描述

  人工智能 最新文章
2022吴恩达机器学习课程——第二课(神经网
第十五章 规则学习
FixMatch: Simplifying Semi-Supervised Le
数据挖掘Java——Kmeans算法的实现
大脑皮层的分割方法
【翻译】GPT-3是如何工作的
论文笔记:TEACHTEXT: CrossModal Generaliz
python从零学(六)
详解Python 3.x 导入(import)
【答读者问27】backtrader不支持最新版本的
上一篇文章      下一篇文章      查看所有文章
加:2021-10-11 17:31:30  更:2021-10-11 17:33:44 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/11 12:32:54-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码