【布局优化】基于遗传算法的车间布局优化 车间设施布局优化【Matlab代码#50】

文章目录

    • 【`获取资源`请见文章第5节:资源获取】
    • 1. 车间布局优化
    • 2. 基于GA的布局优化模型
    • 3. 部分代码展示
    • 4. 仿真结果展示
    • 5. 资源获取


获取资源请见文章第5节:资源获取】


1. 车间布局优化

车间设施布置的规划一直是工业工程领域不断研究和探索的内容,其中最具代表性之一的是系统布置设计(system layout planning,SLP) 方法。作为一种经典且有效的方法,其为设施布置提供了很好的改善思路,但在长期的发展中也存在一些不可避免的缺点,如计算结果不够精确,很难确保计算结果较优且受人员主观因素的影响较大等。

随着计算机技术的快速发展,基于计算机技术的启发式算法在数据处理、数学建模、运算速度等方面相比传统方法具备更大的优势,因此在用 SLP 方法布置时完全可以将大量计算求解的工作交由计算机处理,从而可大幅度提高布置效率和布置结果的精确性。

目前设施布置设计的模型与算法已经比较成熟,常见的有遗传算法、蚁群算法、模拟退火算法等启发式算法。

2. 基于GA的布局优化模型

车间布局优化模型如下图所示:
在这里插入图片描述
模型目标函数为搬运费用最小化非物流关系最大化

假设布置方案为X,i 和 j 为该方案的作业单位,两者距离用 d i j d_{ij} dij表示,搬运量用 f i j f_{ij} fij表示,可得距离矩阵及物流量矩阵,进而求得物料搬运成本表达式如下:
C 1 = ∑ i = 1 m ∑ j = 1 m c i j f i j d i j C_{1}=\sum_{i=1}^{m} \sum_{j=1}^{m} c_{ij}f_{ij}d_{ij} C1=i=1mj=1mcijfijdij
式中, C 1 C_{1} C1为总搬运成本; c i j c_{ij} cij为各单位之间的搬运成本。非物流关系表达式为:
C 2 = ∑ i = 1 m ∑ j = 1 m T i j b i j C_{2}=\sum_{i=1}^{m} \sum_{j=1}^{m} T_{ij}b_{ij} C2=i=1mj=1mTijbij
式中, C 2 C_{2} C2为非物流关系总和; T i j T_{ij} Tij为作业单位之间非物流关系的紧密程度。

由此可得两个基本目标,即 C 1 C_{1} C1的最小化和 C 2 C_{2} C2的最大化,从而构建双目标函数如下:
m i n C 1 = ∑ i = 1 m ∑ j = 1 m c i j f i j d i j minC_{1}=\sum_{i=1}^{m} \sum_{j=1}^{m} c_{ij}f_{ij}d_{ij} minC1=i=1mj=1mcijfijdij
m a x C 2 = ∑ i = 1 m ∑ j = 1 m T i j b i j maxC_{2}=\sum_{i=1}^{m} \sum_{j=1}^{m} T_{ij}b_{ij} maxC2=i=1mj=1mTijbij
为方便求解,将双目标函数 C 1 C_{1} C1 C 2 C_{2} C2进行合并,得到单目标函数 C C C表达式如下:
m i n C = ∑ i = 1 m ∑ j = 1 m c i j f i j d i j − ∑ i = 1 m ∑ j = 1 m T i j b i j minC=\sum_{i=1}^{m} \sum_{j=1}^{m} c_{ij}f_{ij}d_{ij}-\sum_{i=1}^{m} \sum_{j=1}^{m} T_{ij}b_{ij} minC=i=1mj=1mcijfijdiji=1mj=1mTijbij

此单目标函数仍需进行标准化处理,并且还需以惩罚函数加以限制,

3. 部分代码展示

%% 物料搬运成本最小化和非物流关系最大化的合并目标函数
function [fit,Z1,Z2] = Fitness(P,LW,D,A,C,T,L,W,big)
dmax = max([L W]);
gap = 3;
%% SECTION TITLE
% DESCRIPTIVE TEXT
K = size(P,1);   % 设施数量
%% 计算关联因子
dB = zeros(K);
for i = 1 : K
    for j = i + 1 : K
        if D(i,j) <= dmax / 6
            dB(i,j) = 1;
        elseif D(i,j) <= dmax / 3
            dB(i,j) = 0.8;
        elseif D(i,j) <= dmax / 2
            dB(i,j) = 0.6;
        elseif D(i,j) <= dmax * 2 / 3
            dB(i,j) = 0.4;
        elseif D(i,j) <= dmax * 5 / 6
            dB(i,j) = 0.2;
        else
            dB(i,j) = 0;
        end
        dB(j,i) = dB(i,j);
    end
end
%% 目标函数1
Z1 = 0;
for i = 1 : K - 1
    for j = i + 1 : K
        Z1 = Z1 + C(i,j) * A(i,j) * D(i,j);
    end
end
%% 目标函数2
Z2 = 0;
for i = 1 : K - 1
    for j = i + 1 : K
        Z2 = Z2 + T(i,j) * dB(i,j);
    end
end
%% 归化因子计算
u1 = 0;
 for i = 1 : K - 1
    for j = i + 1 : K
        u1 = u1 + C(i,j) * A(i,j) * dmax;
    end
 end
u1 = 1 / u1;
u2 = 0;
for i = 1 : K - 1
    for j = i + 1 : K
        u2 = u2 + T(i,j);
    end
end
u2 = 1 / u2;
%% 边界约束1
t = 0;
for i = 1 : K
    if P(i,1) - LW(i,1) / 2 < gap ||  P(i,1) + LW(i,1) / 2 > L - gap
        t = t + 1;     % x方向不满足边界要求
    end
    if P(i,2) - LW(i,2) / 2 < gap ||  P(i,2) + LW(i,2) / 2 > W - gap
        t = t + 1;     % y方向不满足边界要求
    end
end
%%
dtag = (D == big);
dtn = sum(sum(dtag));
t = t + dtn;
%% 适应度
w1 = 3 / 4;
w2 = 1 / 4;
fit = w1 * u1 * Z1 - w2 * u2 * Z2 + 10000000000 * t;

4. 仿真结果展示

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

5. 资源获取

可以获取完整代码资源。

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

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

相关文章

【人工智能】xAI——“X宇宙”又增添了一位新成员

个人主页&#xff1a;【&#x1f60a;个人主页】 &#x1f31e;热爱编程&#xff0c;热爱生活&#x1f31e; 文章目录 前言xAI团队成员做解开宇宙本质的AI 前言 有人问他&#xff0c;xAI公司是干啥的&#xff1f;马斯克的回答引用了其偶像、科幻作家道格拉斯・亚当斯的话&…

[javascript核心-08] V8 内存管理机制及性能优化

V8 内存管理 V8 本身也是程序&#xff0c;它本身也会申请内存&#xff0c;它申请的内存称为常驻内存&#xff0c;而它又将内存分为堆和栈 栈内存 栈内存介绍 栈用于存放JS 中的基本类型和引用类型指针栈空间是连续的&#xff0c;增加删除只需要移动指针&#xff0c;操作速度…

leetcode100.相同的树

⭐️ 题目描述 &#x1f31f; leetcode链接&#xff1a;相同的树 1️⃣ 代码&#xff1a; bool isSameTree(struct TreeNode* p, struct TreeNode* q){// 判断两棵树当前结点是否为空if (p NULL && q NULL) {// 说明是相同的return true;}// 来到这里有几种情况// …

单片机第一季:零基础6——按键

目录 1&#xff0c;独立按键 2&#xff0c;矩阵按键 &#xff08;注意&#xff1a;文章中的代码仅供参考学习&#xff0c;实际使用时要根据需要修改&#xff09; 1&#xff0c;独立按键 按键管脚两端距离长的表示默认是导通状态&#xff0c;距离短的默认是断开状态&#xf…

集群基础3——haproxy负载均衡apache

文章目录 一、环境说明二、安装配置httpd三、安装配置haproxy四、验证http负载均衡五、配置https负载均衡六、haproxy网页监控6.1 监控参数详解6.2 页面操作 一、环境说明 使用haproxy对apache进行负载均衡。 主机IP角色安装服务192.168.161.131后端服务器1httpd,80端口192.168…

前端 | (五)CSS三大特性及常用属性 | 尚硅谷前端html+css零基础教程2023最新

学习来源&#xff1a;尚硅谷前端htmlcss零基础教程&#xff0c;2023最新前端开发html5css3视频 文章目录 &#x1f4da;CSS三大属性&#x1f407;层叠性&#x1f407;继承性&#x1f407;优先级 &#x1f4da;CSS常用属性&#x1f407;像素的概念&#x1f407;颜色的表示⭐️表…

【数据挖掘】如何为可视化准备数据

一、说明 想要开始您的下一个数据可视化项目吗&#xff1f;首先与数据清理友好。数据清理是任何数据管道中的重要步骤&#xff0c;可将原始的“脏”数据输入转换为更可靠、相关和简洁的数据输入。诸如Tableau Prep或Alteryx之类的数据准备工具就是为此目的而创建的&#xff0c;…

Android 开发规范(基础版)

背景 项目的代码时间时间很长,经过太多人手,代码的规范性堪忧,目前存在较多的比较自由的「代码规范」,这非常不利于项目的维护,代码可读性也不够高。 分析现有项目的代码的情况,输出的『定制化规范』文档,用于提高代码的可读性和可维护性。 收益 对于个人:帮助团队写「…

IIS 日志分析

Microsoft互联网信息服务&#xff08;IIS&#xff09;服务器&#xff0c;包括Web和FTP&#xff0c;已成为企业必不可少的。但是&#xff0c;IT 安全管理员的工作并不仅仅局限于部署 IIS 服务器。部署后&#xff0c;管理员必须采取安全措施来保护这些服务器。监视 IIS 服务器安全…

Java版知识付费源码 Spring Cloud+Spring Boot+Mybatis+uniapp+前后端分离实现知识付费平台

知识付费平台主要指的是能够通过付费来满足用户知识需求的平台&#xff0c;用户可以通过该平台来消费知识或者开展知识买卖等行为。 此处的平台是一个广义的概念&#xff0c;可以是微信小程序或者论坛&#xff0c;也可以是网页或者手机APP&#xff0c;等&#xff0c;就我国的情…

基于IMX6ULL的AP3216C的QT动态数据曲线图显示

前言&#xff1a;本文为手把手教学 LinuxQT 的典型基础项目 AP3216C 的数据折线图显示&#xff0c;项目使用正点原子的 IMX6ULL 阿尔法( Cortex-A7 系列)开发板。项目需要实现 AP3216C 在 Linux 系统下的驱动&#xff0c;使用 QT 设计 AP3216C 的数据显示页面作为项目的应用层。…

聊聊ChatGPT是如何组织对话的

为什么要组织对话&#xff1f; 总所周知&#xff0c;ChatGPT的训练大致可分为下图中展示的几个阶段&#xff0c;其中&#xff0c;在Pretraining阶段&#xff0c;模型的训练数据是纯文本&#xff0c;目标是根据上文预测下一个token&#xff0c;而在后面的几个阶段中&#xff0c…

【软件测试】selenium中元素的定位

1.元素的定位 不管用那种方式&#xff0c;必须保证页面上该属性的唯一性 1.CSS 定位 CSS(Cascading Style Sheets)是一种语言&#xff0c;它被用来描述HTML 和XML 文档的表现。 CSS 使用选择器来为页面元素绑定属性。这些选择器可以被selenium 用作另外的定位策略CSS的获取可…

scrapy ---分布式爬虫

导模块 pip install scrapy-redis 原来scrapy的Scheduler维护的是本机的任务队列&#xff08;待爬取的地址&#xff09;本机的去重队列&#xff08;放在集合中&#xff09;---》在本机内存中 如果把scrapy项目&#xff0c;部署到多台机器上&#xff0c;多台机器爬取的内容是重…

静态数码管——FPGA

文章目录 前言一、数码管1、数码管简介2、共阴极数码管or共阳极数码管3、共阴极与共阳极的真值表 二、系统设计1、模块框图2、RTL视图 三、源码1、seg_led_static模块2、time_count模块3、top_seg_led_static(顶层文件) 四、效果五、总结六、参考资料 前言 环境&#xff1a; 1、…

我爱学QT--qt的网络编程

学习地址&#xff1a; QT网络编程之TCP通信_哔哩哔哩_bilibili QT网络编程有TCP和UDP。 TCP编程需要用到两个类&#xff1a;QTcpServer和QTcpSocket 本节课目标&#xff1a; 完成一个服务器和一个客户端 首先是经典的几步 先设计ui再设计逻辑实现 多看看写的文件理解吧

【淘宝API接口系列】,商品详情接口响应参数有哪些?响应示例是否满足

商品数据&#xff1a;淘宝提供了商品的基本信息&#xff0c;包括商品名称、描述、规格、价格、销量、库存等信息。此外&#xff0c;也可以通过淘宝提供的API接口来获取商品的图片、评价、物流信息等详细数据。 响应参数 Version: Date:2022-04-04 名称类型必须示例值描述 ite…

数据库小白看这里,这个Oracle数据库知识图谱你值得拥有

2022年前后&#xff0c;墨天轮社区曾陆续推出PostgreSQL知识图谱、MySQL知识图谱&#xff0c;并得到了大家的广泛好评。此后&#xff0c;便有众多朋友对Oracle知识图谱发起不断“催更“。经过近期的内容搜集整合、专家复审与打磨&#xff0c;墨天轮社区正式推出Oracle知识图谱&…

Mac搭建安卓模拟器(支持M1/M2)

引言 最近在研究Vue打包成app&#xff0c;给我的报价器搞一个移动端&#xff0c;奈何没有安卓手机用于测试。所以想到安装一个安卓模拟器。 看了下目前主流的安卓模拟器基本都不支持Mac版本。网易的mumu目前来看还是只支持Intel芯。 1. 简单版&#xff08;仅M系&#xff09;…

目标检测——R-CNN网络基础

目录 Overfeat模型RCNN模型算法流程候选区域生成CNN网络提取特征目标分类&#xff08;SVM&#xff09;目标定位预测过程 算法总结 Fast RCNN模型算法流程ROI Pooling目标分类和回归 模型训练模型总结 Overfeat模型 RCNN模型 算法流程 候选区域生成 CNN网络提取特征 目标分类&am…