数学建模学习(90):Jaya优化算法对多元函数寻优

2024-01-07 15:20

本文主要是介绍数学建模学习(90):Jaya优化算法对多元函数寻优,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、算法介绍

算法步骤:

  1. 首先初始化种群个体数量,确定每个个体长度以及终止判据
  2. 找到当前种群下的最优个体 best 和最差个体 worst
  3. 遍历所有个体,根据公式(1)更新个体参数
    在这里插入图片描述

其中,i,j,k分别代表迭代代数,个体的某变量,种群中某个体。该公式是Jaya算法的核心

  1. 判断更新后的个体是否优于更新前的个体,若是,则更新个体,否则保留原个体到下一代
  2. 判断当前最优个体是否满足终止判据,若是则结束程序,否则遍历步骤2-4

二、 案例实现(一)

2.1 目标函数

第一步:导入模块

import numpy as np# Jaya
from pyMetaheuristic.algorithm import victory
from pyMetaheuristic.utils import graphs

第二步:目标函数设置

def easom(variables_values = [0, 0]):x1, x2     = variables_valuesfunc_value = -np.cos(x1) * np.cos(x2) * np.exp(-(x1 - np.pi) ** 2 - (x2 - np.pi) ** 2)return func_valueplot_parameters = {'min_values': (-5, -5),'max_values': (5, 5),'step': (0.1, 0.1),'solution': [],'proj_view': '3D','view': 'notebook'
}
graphs.plot_single_function(target_function = easom, **plot_parameters)

如下:
在这里插入图片描述

2.2 算法实现

第三步:设置算法参数

# jaya - Parameters
parameters = {# 该参数50左右'size': 50,'min_values': (-5, -5),'max_values': (5, 5),# 迭代次数'iterations': 500,'verbose': True
}

第四步:执行算法

jy = victory(target_function = easom, **parameters)

第五步:获取算法最优解

variables = jy[:-1]
minimum   = jy[ -1]
print('变量值为: ', np.around(variables, 4) , ' 最小值为: ', round(minimum, 4) )

如下:

变量值为:  [3.1258 3.1804]  最小值为:  -0.9974

第六步:可视化最优值
在这里插入图片描述

三、案例(二)

我们换一个目标函数,以五维球形函数的最优化计算为例子.

def easom(variables_values):x    = variables_valuesfunc_value = y=sum(x**2 for x in variables_values)return func_value

后续参数类似。。不再重复演示。

四、额外补充

4.1 封装代码

如果你希望改进该算法模块,可以研究修改以下代码:


# Required Libraries
import numpy  as np
import random
import os############################################################################# Function
def target_function():return############################################################################# Function: Initialize Variables
def initial_position(size = 5, min_values = [-5,-5], max_values = [5,5], target_function = target_function):position = np.zeros((size, len(min_values)+1))for i in range(0, size):for j in range(0, len(min_values)):position[i,j] = random.uniform(min_values[j], max_values[j])position[i,-1] = target_function(position[i,0:position.shape[1]-1])return position# Function: Updtade Position by Fitness
def update_bw_positions(position, best_position, worst_position):for i in range(0, position.shape[0]):if (position[i,-1] < best_position[-1]):best_position = np.copy(position[i, :])if (position[i,-1] > worst_position[-1]):worst_position = np.copy(position[i, :])return best_position, worst_position# Function: Search
def update_position(position, best_position, worst_position, min_values = [-5,-5], max_values = [5,5], target_function = target_function):candidate = np.copy(position[0, :])for i in range(0, position.shape[0]):for j in range(0, len(min_values)):a  = int.from_bytes(os.urandom(8), byteorder = "big") / ((1 << 64) - 1)b  = int.from_bytes(os.urandom(8), byteorder = "big") / ((1 << 64) - 1)candidate[j] = np.clip(position[i, j] + a * (best_position[j] - abs(position[i, j])) - b * ( worst_position[j] - abs(position[i, j])), min_values[j], max_values[j] )candidate[-1] = target_function(candidate[:-1])if (candidate[-1] < position[i,-1]):position[i,:] = np.copy(candidate)return position############################################################################# Jaya Function
def victory(size = 5, min_values = [-5,-5], max_values = [5,5], iterations = 50, target_function = target_function, verbose = True):    count              = 0position           = initial_position(size, min_values, max_values, target_function)best_position      = np.copy(position[0, :])best_position[-1]  = float('+inf')worst_position     = np.copy(position[0, :])worst_position[-1] = 0while (count <= iterations): if (verbose == True):print('Iteration = ', count,  ' f(x) = ', best_position[-1])position                      = update_position(position, best_position, worst_position, min_values, max_values, target_function)best_position, worst_position = update_bw_positions(position, best_position, worst_position)count                         = count + 1     return best_position 

4.2 算法论文

http://www.growingscience.com/ijiec/Vol7/IJIEC_2015_32.pdf

这篇关于数学建模学习(90):Jaya优化算法对多元函数寻优的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Vue3 的 shallowRef 和 shallowReactive:优化性能

大家对 Vue3 的 ref 和 reactive 都很熟悉,那么对 shallowRef 和 shallowReactive 是否了解呢? 在编程和数据结构中,“shallow”(浅层)通常指对数据结构的最外层进行操作,而不递归地处理其内部或嵌套的数据。这种处理方式关注的是数据结构的第一层属性或元素,而忽略更深层次的嵌套内容。 1. 浅层与深层的对比 1.1 浅层(Shallow) 定义

HarmonyOS学习(七)——UI(五)常用布局总结

自适应布局 1.1、线性布局(LinearLayout) 通过线性容器Row和Column实现线性布局。Column容器内的子组件按照垂直方向排列,Row组件中的子组件按照水平方向排列。 属性说明space通过space参数设置主轴上子组件的间距,达到各子组件在排列上的等间距效果alignItems设置子组件在交叉轴上的对齐方式,且在各类尺寸屏幕上表现一致,其中交叉轴为垂直时,取值为Vert

Ilya-AI分享的他在OpenAI学习到的15个提示工程技巧

Ilya(不是本人,claude AI)在社交媒体上分享了他在OpenAI学习到的15个Prompt撰写技巧。 以下是详细的内容: 提示精确化:在编写提示时,力求表达清晰准确。清楚地阐述任务需求和概念定义至关重要。例:不用"分析文本",而用"判断这段话的情感倾向:积极、消极还是中性"。 快速迭代:善于快速连续调整提示。熟练的提示工程师能够灵活地进行多轮优化。例:从"总结文章"到"用

不懂推荐算法也能设计推荐系统

本文以商业化应用推荐为例,告诉我们不懂推荐算法的产品,也能从产品侧出发, 设计出一款不错的推荐系统。 相信很多新手产品,看到算法二字,多是懵圈的。 什么排序算法、最短路径等都是相对传统的算法(注:传统是指科班出身的产品都会接触过)。但对于推荐算法,多数产品对着网上搜到的资源,都会无从下手。特别当某些推荐算法 和 “AI”扯上关系后,更是加大了理解的难度。 但,不了解推荐算法,就无法做推荐系

HDFS—存储优化(纠删码)

纠删码原理 HDFS 默认情况下,一个文件有3个副本,这样提高了数据的可靠性,但也带来了2倍的冗余开销。 Hadoop3.x 引入了纠删码,采用计算的方式,可以节省约50%左右的存储空间。 此种方式节约了空间,但是会增加 cpu 的计算。 纠删码策略是给具体一个路径设置。所有往此路径下存储的文件,都会执行此策略。 默认只开启对 RS-6-3-1024k

【前端学习】AntV G6-08 深入图形与图形分组、自定义节点、节点动画(下)

【课程链接】 AntV G6:深入图形与图形分组、自定义节点、节点动画(下)_哔哩哔哩_bilibili 本章十吾老师讲解了一个复杂的自定义节点中,应该怎样去计算和绘制图形,如何给一个图形制作不间断的动画,以及在鼠标事件之后产生动画。(有点难,需要好好理解) <!DOCTYPE html><html><head><meta charset="UTF-8"><title>06

学习hash总结

2014/1/29/   最近刚开始学hash,名字很陌生,但是hash的思想却很熟悉,以前早就做过此类的题,但是不知道这就是hash思想而已,说白了hash就是一个映射,往往灵活利用数组的下标来实现算法,hash的作用:1、判重;2、统计次数;

康拓展开(hash算法中会用到)

康拓展开是一个全排列到一个自然数的双射(也就是某个全排列与某个自然数一一对应) 公式: X=a[n]*(n-1)!+a[n-1]*(n-2)!+...+a[i]*(i-1)!+...+a[1]*0! 其中,a[i]为整数,并且0<=a[i]<i,1<=i<=n。(a[i]在不同应用中的含义不同); 典型应用: 计算当前排列在所有由小到大全排列中的顺序,也就是说求当前排列是第

使用opencv优化图片(画面变清晰)

文章目录 需求影响照片清晰度的因素 实现降噪测试代码 锐化空间锐化Unsharp Masking频率域锐化对比测试 对比度增强常用算法对比测试 需求 对图像进行优化,使其看起来更清晰,同时保持尺寸不变,通常涉及到图像处理技术如锐化、降噪、对比度增强等 影响照片清晰度的因素 影响照片清晰度的因素有很多,主要可以从以下几个方面来分析 1. 拍摄设备 相机传感器:相机传

csu 1446 Problem J Modified LCS (扩展欧几里得算法的简单应用)

这是一道扩展欧几里得算法的简单应用题,这题是在湖南多校训练赛中队友ac的一道题,在比赛之后请教了队友,然后自己把它a掉 这也是自己独自做扩展欧几里得算法的题目 题意:把题意转变下就变成了:求d1*x - d2*y = f2 - f1的解,很明显用exgcd来解 下面介绍一下exgcd的一些知识点:求ax + by = c的解 一、首先求ax + by = gcd(a,b)的解 这个