MATLAB学习-1 蚁群算法解决TSP问题

matlab安装可以在网上找一个安装教程,我安装的是R2020a版本的。
学习解决该问题
利用蚁群算法对给定的TSP问题进行求解,求出一条最短路径。
用的是194个城市的TSPLIB数据集,如果需要TSPLIB数据集可点击 tsp、添加了可视化,迭代400次,目前最短路径为10576.5454,实现效果如下:
在这里插入图片描述

首先下载一个TSPLIB数据集文件,这种文件包含描述部分和数据部分。描述部分包含文件格式信息和数据的信息。数据部分包含确切的数据。
格式大概是这种:
在这里插入图片描述
NAME:< string >
标识数据文件。
TYPE: < string >
表示数据的类型。有TSP:对称旅行商问题;ATSP:非对称旅行商问题。
COMMENT:< string >
附加的注释(通常包含这个问题实例的创建者或贡献者的名字)。
DIMENSION: < integer >
维数,表示节点的个数。
CAPACITY: < integer >
在车辆路径问题(CVRP)中表示卡车的容量。
EDGE_WEIGHT_TYPE: < string >
表示边如何计量。

EXPLICIT 会明确给出
EUC_2D 二维的欧几里德距离
EUC_3D 三维的欧几里德距离
MAX_2D 二维空间中最大距离
MAX_3D 三维空间中最大距离
MAN_2D 二维的曼哈顿距离
MAN_3D 三维的曼哈顿距离
CEIL_2D 对二维的欧几里德距离上取整
GEO 实际距离
ATT 对于att48和att532的距离描述函数

我的TSPLIB数据集EDGE_WEIGHT_TYPE部分是EUC_2D

EOF:
结束标志。这项是可选的。
我的TSPLIB文件的EDGE_WEIGHT_TYPE是EUC_2D
新建一个工作目录 mkdir Directory,并将其添加到搜索路径
然后改变工作目录到Directory目录下

cd 'F:\MATLABFile\bin\Directoryone'

在当前目录下新建一个单独的acoTSP.m函数文件,内容如下:
acoTSP.m:

function [bestRoute, bestCost] = acoTSP(tsplibFilename, numAnts, numIterations, alpha, beta, rho, Q)
    % 读取TSPLIB文件并解析
    [coords, numCities, distMatrix] = readTSPLIB(tsplibFilename);
    numCities = size(distMatrix, 1);
    % 检查numCities是否为正整数
    if ~isnumeric(numCities) || numCities <= 0 || isnan(numCities) || isinf(numCities)
        error('无效的城市数量。');
    end
    % 初始化参数
    
    if numCities <= 0
        error('Number of cities must be a positive integer.');
    end
    pheromoneMatrix = ones(numCities,numCities)* 0.1; % 信息素矩阵
    pheromoneMatrix(eye(size(pheromoneMatrix)) == 1) = 0;
    
    % 初始化保存每一代最短成本和平均成本的数组
    bestCosts = zeros(numIterations, 1);
    averageCosts = zeros(numIterations, 1);
    
    % 蚁群算法主循环
    bestCost = inf;
    bestRoute = [];
    for iter = 1:numIterations
        antRoutes = zeros(numAnts, numCities + 1); % +1 for the return to the starting city
        antCosts = zeros(numAnts, 1);
        %disp(['Number of cities: ', num2str(numCities)]);
        for ant = 1:numAnts
            currentCity = randi(numCities); % 确保numCities是正整数
            
            antRoutes(ant, 1

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

IP寻址映射与网络通信互联

IP寻址映射 IP寻址映射能够让数据准确传输的重要部分。在网络之中&#xff0c;所有联网的设备都具有一个IP地址&#xff0c;而IP寻址映射就是负责将IP地址与设备位置或其他相关标识相联系起来&#xff0c;确保数据找到正确的路径传输&#xff0c;保障网络能够畅通。 动态主机配…

IO Virtualization with Virtio.part 1 [十二]

久等了各位&#xff01; 本篇开始讲解 IO 虚拟化中的 virtio&#xff0c;我会以 Linux 的 IIC 驱动为例&#xff0c;从 IIC 驱动的非虚拟化实现&#xff0c;到 IIC 驱动的半虚拟化实现&#xff0c;再到最后 X-Hyper 中如何通过 virtio 来实现前后端联系&#xff0c;一步步把 v…

ITOM系统在IT运维中的作用

在企业IT运维中&#xff0c;ITOM系统&#xff08;IT运营管理&#xff09;通过整合、自动化和监控&#xff0c;能够帮助企业有效管理IT基础设施&#xff0c;提高运维效率和系统的可靠性。本文将从多个角度探讨ITOM系统在IT运维中的作用及其功能。 提升运维效率&#xff1a;统一平…

水上救命稻草,充气救生板的关键救援效能|深圳鼎跃

当今社会&#xff0c;突发事件如影随形&#xff0c;其诱因常隐匿于生活细微之处。就像我们在户外游玩时&#xff0c;水域周边看似风平浪静&#xff0c;实则暗藏危机&#xff0c;稍有疏忽便可能失足落水。此类意外的发生毫无征兆&#xff0c;往往令人在瞬间陷入危险境地&#xf…

Mac M2 Pro安装MySQL 8.4.3

絮絮叨叨 MacBook Pro&#xff0c;芯片&#xff1a;Apple M2 Pro, macOS: Sonoma 14.0一直知道很多软件对Mac M1或M2的支持不好&#xff0c;但没想到在安装MySQL 8.x上也让我吃尽了苦头本文除了介绍如何安装MySQL 8.4.3外&#xff0c;还会记录笔者遇到的一些问题以及解决方法 …

Leecode刷题C语言之切蛋糕的最小总开销②

执行结果:通过 执行用时和内存消耗如下&#xff1a; int compare(const void* a, const void* b) {return (*(int*)b - *(int*)a); }long long minimumCost(int m, int n, int* horizontalCut, int horizontalCutSize, int* verticalCut, int verticalCutSize) {qsort(horizon…

FreeRTOS的内存管理(选择heap4.c文件的理由)

目录 1. 了解FreeRTOS内存管理 2. 了解内存碎片 3.了解各个heap.c的内存分配方法 1.heap1.c 2.heap2.c 3.heap3.c 4.heap4.c 5.heap5.c 总结&#xff1a; 内存管理是一个系统基本组成部分&#xff0c;FreeRTOS 中大量使用到了内存管理&#xff0c;比如创建任务、信号量…

[服务器][教程]Ubuntu24.04 Server开机自动挂载硬盘教程

1. 查看硬盘ID ls -l /dev/disk/by-uuid可以看到对应的UUID所对应的分区 2. 创建挂载文件夹 创建好文件夹即可 3. 修改配置文件 sudo vim /etc/fstab把对应的UUID和创建的挂载目录对应即可 其中# Personal mount points下面的是自己新添加的 &#xff1a;分区定位&#xff…

Python用K-Means均值聚类、LRFMC模型对航空公司客户数据价值可视化分析指标应用|数据分享...

全文链接&#xff1a;https://tecdat.cn/?p38708 分析师&#xff1a;Yuling Fang 信息时代的来临使得企业营销焦点从产品中心转向客户中心&#xff0c;客户关系管理成为企业的核心问题&#xff08;点击文末“阅读原文”获取完整代码数据&#xff09;。 客户关系管理的关键是客…

HTML——46.制作课程表

<!DOCTYPE html> <html><head><meta charset"UTF-8"><title>课程表</title></head><body><h3>课程表</h3><table border"1" cellspacing"0"><tr><th colspan"…

强化学习(1)

Reinforcement Learning Goal-directed learing from ineraction with the environment. 1. Basic Element 基本元素 1.1 Agent 玩家 1.2 Environment 1.3 Goal 2. Main Element 主要元素 2.1 State 2.2 Action 状态与行为往复 2.3 Reward 目标&#xff1a;最大化总…

《代码随想录》Day21打卡!

写在前面&#xff1a;祝大家新年快乐&#xff01;&#xff01;&#xff01;2025年快乐&#xff0c;2024年拜拜~~~ 《代码随想录》二叉树&#xff1a;修剪二叉搜索树 本题的完整题目如下&#xff1a; 本题的完整思路如下&#xff1a; 1.本题使用递归进行求解&#xff0c;所以分…

iOS 中的 nil、Nil、NULL、NSNull 僵尸对象和野指针

iOS 中的 nil、Nil、NULL、NSNull 僵尸对象和野指针-CSDN博客 类型含义使用场景示例nil表示一个指向 Objective - C 对象的空指针。在 Objective - C 和 Swift&#xff08;与 Objective - C 交互时&#xff09;中用于表示对象不存在。当一个对象变量没有指向任何有效的对象实例…

CPT203 Software Engineering 软件工程 Pt.6 软件管理(中英双语)

文章目录 10. Project Management&#xff08;项目管理&#xff09;10.1 Project Management Overview10.1.1 Project Management Importance&#xff08;项目管理的重要性&#xff09;10.1.2 Criteria for Project Management&#xff08;项目管理的准则&#xff09;10.1.3 Ch…

Java [后端] 开发日常记录(1)

目录 1、常用的注解 2、对字符串的处理 3、对JSON串的处理 -- The End -- 详细如下&#xff1a; 1、常用的注解 若返回的字段中有NUll&#xff0c;则不返回 JsonInclude(value JsonInclude.Include.NON_NULL) //在实体类中添加这个注解 JsonInclude(JsonInclude.Include.NON…

流计算需要框架吗?SPL 可能是更好的选择

流数据源通常是动态、无界的&#xff0c;看起来与静态、有限的批数据源区别较大&#xff0c;传统的数据库技术在架构上难以直接处理流数据源&#xff0c;只能让位于后来者。heron\samza\storm\spark\flink等计算框架最先完成突破&#xff0c;在流计算技术中占得先发优势。这些框…

设计模式の状态策略责任链模式

文章目录 前言一、状态模式二、策略模式三、责任链模式 前言 本篇是关于设计模式中的状态模式、策略模式、以及责任链模式的学习笔记。 一、状态模式 状态模式是一种行为设计模式&#xff0c;核心思想在于&#xff0c;使某个对象在其内部状态改变时&#xff0c;改变该对象的行为…

鸿蒙UI开发——使用WidthTheme实现局部深浅色

1、场景描述 在实际的应用开发中&#xff0c;我们可能需要在界面中局部应用深色或者浅色的界面样式&#xff0c;与全局的深色、亮色同时生效。场景例如&#xff1a;深/亮色预览。此时&#xff0c;我们可以使用WithTheme能力来达到我们的效果。 2、WithTheme WithTheme组件可…

20241231取消掉夸克浏览器为默认浏览器

20241231取消掉夸克浏览器为默认浏览器 2024/12/31 17:59 因为有些资源必须用夸克网盘下载&#xff01;^_ 地区特色问题。对于百度网盘&#xff0c;如果你分享BBC的纪录片合集&#xff0c;马上给你无效掉&#xff01;^_ 但是夸克有一点夜郎自大了&#xff0c;把客户的默认浏览器…

详细教程:SQL2008数据库备份与还原全流程!

数据的安全性至关重要&#xff0c;无论是操作系统、重要文件、磁盘存储&#xff0c;还是企业数据库&#xff0c;备份都是保障其安全和完整性的关键手段。拥有备份意味着即使发生误删、系统崩溃或病毒攻击等问题&#xff0c;也能迅速通过恢复功能解决&#xff0c;避免数据丢失带…