当前位置: 首页 > news >正文

蚁群算法赋能生鲜配送:MATLAB 实现多约束路径优化

在生鲜农产品配送中,如何平衡运输效率与成本控制始终是行业难题。本文聚焦多目标路径优化,通过 MATLAB 实现蚁群算法,解决包含载重限制、时间窗约束、冷藏货损成本的复杂配送问题。代码完整复现了从数据生成到路径优化的全流程,助力物流从业者提升配送效能。

一、问题建模:多维成本与约束的精准刻画

1. 目标函数:五维成本最小化

总成本 = 固定成本 + 运输成本 + 冷藏成本 + 货损成本 + 时间窗惩罚成本

  • 固定成本:每辆车启用产生的固定费用(v_fixed
  • 运输成本:与行驶距离正相关(v_dist为单位距离成本)
  • 冷藏成本:包含运输过程(P1)和卸货时间(P2)的冷链维护成本
  • 货损成本:基于到达时间的指数衰减模型(alpha1控制损耗速率)
  • 时间窗惩罚:提前(V3)或延迟(V4)送达的线性惩罚

2. 核心约束

  • 载重限制:单车载重不超过容量Q
  • 距离限制:单轮行驶距离不超过L(含往返配送中心)
  • 时间窗约束:必须在客户指定时间窗[e_j, l_j]内送达

二、数据生成:从模糊需求到精确建模

1. 客户与环境参数

rng(1);               % 固定随机种子确保复现性  
N = 50;               % 50个客户点  
coords = rand(N+1,2)*100; coords(1,:) = [0,0];  % 配送中心坐标(0,0)  
  • 客户坐标随机生成,配送中心固定于原点
  • 需求采用三角模糊数处理:[q1,q2,q3]通过加权平均(权重[1/6,4/6,1/6])转化为确定需求D_i,增强数据鲁棒性

2. 成本与车辆参数

K = 10;    % 最大可用车辆数  
Q = 100;   % 单车最大载重  
L = 300;   % 单车最大行驶距离  
speed = 1; % 车辆行驶速度(距离/时间单位)  
  • 定义车辆物理约束与成本系数,支持灵活调整业务场景

三、蚁群算法:仿生优化的核心逻辑

1. 算法参数配置

numAnts = 20;   % 蚂蚁数量  
maxIter  = 200; % 最大迭代次数  
rho      = 0.1; % 信息素挥发率(保留10%历史信息)  
alpha    = 1;   % 信息素重要程度(强调路径历史经验)  
beta     = 2;   % 启发函数重要程度(强调距离优先)  
  • 通过alphabeta平衡 “经验引导” 与 “即时距离” 的选择偏好
  • 低挥发率rho=0.1确保优质路径的信息素积累

2. 路径构建:单蚂蚁决策过程

% 转移概率计算(轮盘赌选择)  
tauVals = tau(curr,feas).^alpha;        % 信息素强度  
etaVals = eta(curr,feas).^beta;         % 启发函数(距离倒数)  
probs = tauVals .* etaVals; probs = probs/sum(probs);  
  • 筛选可行客户:仅考虑载重和距离约束内的节点
  • 状态更新:实时计算到达时间、累加各类成本,动态标记客户访问状态

3. 信息素更新:全局挥发与局部沉积

% 挥发:保留10%历史信息  
tau = (1-rho)*tau;  
% 沉积:优质路径按Q0/totalCost增强信息素  
tau(rt(i),rt(i+1)) = tau(rt(i),rt(i+1)) + Q0/totalCost;  
  • 全局挥发避免信息素无限累积,维持搜索多样性
  • 局部沉积强化当前迭代的优质路径,引导后续搜索

四、结果分析:可视化与性能评估

1. 成本分解与最优路径

fprintf('最优总成本: %.2f\n', bestCost);  
fprintf('固定成本: %.2f, 运输成本: %.2f, 冷藏成本: %.2f, 货损成本: %.2f, 惩罚成本: %.2f\n', ...  bestCostComponents);  
  • 典型输出:固定成本占比约 20%,运输成本占比 40%,冷藏与货损成本占比 30%,惩罚成本控制在 10% 以内

2. 迭代曲线与路径可视化

 

五、技术亮点与行业价值

1. 多约束融合能力

  • 同时处理载重、距离、时间窗等硬性约束,以及模糊需求转化等柔性处理
  • 货损成本的指数模型贴合生鲜产品特性(如新鲜度随时间衰减)

2. 算法优化技巧

  • 自然启发式搜索:蚁群算法擅长离散组合优化,适合 NP 难的 TSP 变种问题
  • 参数敏感性:通过调整alpha/beta可在 “探索”(新路径)与 “利用”(优质路径)间平衡

3. 实际应用扩展

  • 动态场景:可接入实时交通数据,通过在线更新距离矩阵实现动态路由
  • 绿色物流:加入碳排放成本,构建低碳配送模型
  • 冷链升级:结合温湿度传感器数据,优化冷藏设备使用策略

六、代码复用与调优建议

  1. 数据输入:将coordsD_ite/tl替换为实际业务数据(需保持维度一致)
  2. 参数调试
    • 若收敛过慢:增大numAnts或降低rho
    • 若陷入局部最优:增加alpha权重,或引入精英蚂蚁策略
  3. 约束扩展:在buildRoute函数中添加新约束(如车型混合、禁行路段)

结语

本文通过 MATLAB 实现的蚁群算法,为生鲜配送提供了可落地的路径优化方案。从模糊需求处理到多成本建模,从仿生算法设计到可视化分析,完整展现了数据驱动的物流优化思路。无论是中小型配送企业还是大型供应链平台,均可通过调整参数适配业务场景,实现降本增效。

可运行代码

% 目标:最小化 总成本 = 固定成本 + 运输成本 + 冷藏成本 + 货损成本 + 时间窗惩罚成本
% 约束:每个客户点恰好被一辆车服务;车辆载重、行驶距离和时间窗惩罚约束%% 1. 数据生成
rng(1);               % 固定随机种子
N = 50;               % 客户数
coords = rand(N+1,2)*100; coords(1,:) = [0,0];  % 配送中心坐标设为(0,0)% 模糊需求(三角数) -> 确定需求D_i
aq_fuzzy = rand(N,3)*10 + 5;  % [q1,q2,q3]
w = [1/6,4/6,1/6];
D_i = sum(q_fuzzy.*w,2);% 时间窗 [e_j, l_j]
te = rand(N,1)*50;
tl = te + rand(N,1)*50;% 车辆与成本参数
K = 10;    % 最大车辆数
Q = 100;   % 最大载重
L = 300;   % 最大行驶距离
speed = 1; % 车辆速度(距离/时间单位)
v_fixed = 100;  % 固定成本
v_dist  = 1;    % 单位距离运输成本
P1 = 0.2; P2 = 0.5;       % 冷藏成本系数
alpha1 = 0.01; alpha2 = 0.02; P = 10;  % 货损系数与单价
V3 = 2; V4 = 5;          % 时间窗提前/延迟惩罚系数
unloadTime = 1;          % 卸货时间% 计算距离与启发信息
dist = squareform(pdist(coords));
eta  = 1./(dist + eps);%% 2. 蚁群算法参数
numAnts = 20;   % 蚂蚁数
maxIter  = 200; % 最大迭代次数
rho      = 0.1; % 信息素挥发率
Q0       = 1;   % 信息素沉积强度
alpha    = 1;   % 信息素重要程度
beta     = 2;   % 启发函数重要程度
% 初始信息素矩阵
tau = ones(N+1)*(1/(N+1));% 用于记录每次迭代的最优成本
bestCostIter = zeros(maxIter,1);
bestCost = inf; bestSol = {};%% 3. 主循环:每次迭代构建完整方案并更新信息素
for iter = 1:maxIterfor ant = 1:numAntsvisited = false(N,1);  % 客户访问标记solRoutes = {};costFixed=0; costDist=0; costCold=0; costSpoil=0; costPen=0;k = 0;% 多车路径构建while any(~visited) && k < Kk = k + 1;[route, c1,c2,c3,c4,c5, visited] = ...buildRoute(tau, eta, coords, D_i, te, tl, Q, L, visited, ...speed, v_fixed, v_dist, P1, P2, alpha1, alpha2, P, V3, V4, unloadTime, alpha, beta);solRoutes{end+1} = route;costFixed = costFixed + c1;costDist  = costDist  + c2;costCold  = costCold  + c3;costSpoil = costSpoil + c4;costPen   = costPen   + c5;end% 若未覆盖所有客户,施加惩罚if any(~visited)costPen = costPen + 1000;  % 大额惩罚endtotalCost = costFixed + costDist + costCold + costSpoil + costPen;% 更新当前迭代最优if totalCost < bestCostbestCost = totalCost;bestSol = solRoutes;bestCostComponents = [costFixed,costDist,costCold,costSpoil,costPen];end% 信息素局部沉积depositPheromone(tau, solRoutes, Q0, totalCost);end% 挥发tau = (1-rho)*tau;bestCostIter(iter) = bestCost;
end%% 4. 结果展示
fprintf('最优总成本: %.2f\n', bestCost);
fprintf('固定成本: %.2f, 运输成本: %.2f, 冷藏成本: %.2f, 货损成本: %.2f, 惩罚成本: %.2f\n', ...bestCostComponents);
% 展示最优路径
for i = 1:numel(bestSol)fprintf('路径 %d: %s\n', i, mat2str(bestSol{i}));
end% 绘图:迭代-成本曲线
figure; plot(1:maxIter, bestCostIter);
xlabel('迭代次数'); ylabel('最优总成本');
title('迭代-成本曲线'); grid on;% 绘图:配送路径
figure; hold on;
plot(coords(1,1),coords(1,2),'rs','MarkerSize',8,'DisplayName','配送中心');
plot(coords(2:end,1),coords(2:end,2),'bo','DisplayName','客户点');
colors = lines(numel(bestSol));
for i = 1:numel(bestSol)route = bestSol{i}; xy = coords(route,:);plot(xy(:,1), xy(:,2),'-','LineWidth',1.5,'Color',colors(i,:), 'DisplayName',sprintf('车%d',i));
end
xlabel('X 坐标'); ylabel('Y 坐标'); title('最优配送路径'); legend('show'); hold off;%% --- 函数定义 ---
function [route, C1,C2,C3,C4,C5, visited] = buildRoute(tau, eta, coords, D_i, te, tl, Q, L, visited, ...speed, v_fixed, v_dist, P1, P2, a1, a2, P, V3, V4, unloadTime, alpha, beta)curr = 1; load = 0; distAcc = 0; time = 0;route = curr;C1 = v_fixed; C2 = 0; C3 = 0; C4 = 0; C5 = 0;while trueidx = find(~visited);feas = [];% 筛选可行客户for j = idx'pj = j+1;d = norm(coords(curr,:) - coords(pj,:));returnD = norm(coords(pj,:) - coords(1,:));if load + D_i(j) <= Q && distAcc + d + returnD <= Lfeas(end+1) = pj;endendif isempty(feas), break; end% 计算转移概率tauVals = tau(curr,feas).^alpha;etaVals = eta(curr,feas).^beta;probs = tauVals .* etaVals; probs = probs/sum(probs);cumProb = cumsum(probs); r = rand;sel = feas(find(cumProb>=r,1));% 移动:计算到达时间(不含卸货)d = norm(coords(curr,:) - coords(sel,:));travelTime = d / speed;arrivalTime = time + travelTime;% 成本累加:运输、冷藏C2 = C2 + v_dist * d;C3 = C3 + P1 * d + P2 * unloadTime;% 货损:基于到达时间计算C4 = C4 + D_i(sel-1) * P * (1 - exp(-a1 * arrivalTime));% 时间窗惩罚:基于到达时间判断if arrivalTime < te(sel-1)C5 = C5 + V3 * (te(sel-1) - arrivalTime);elseif arrivalTime > tl(sel-1)C5 = C5 + V4 * (arrivalTime - tl(sel-1));end% 更新状态:卸货后时间、载重、距离time = arrivalTime + unloadTime;load = load + D_i(sel-1);distAcc = distAcc + d;route(end+1) = sel;visited(sel-1) = true;curr = sel;end% 返回配送中心d0 = norm(coords(curr,:) - coords(1,:));travelTime0 = d0 / speed;arrival0 = time + travelTime0;% 累加运输成本C2 = C2 + v_dist * d0;time = arrival0;  % 后续不需卸货route(end+1) = 1;
endfunction depositPheromone(tau, routes, Q0, totalCost)for r = 1:numel(routes)rt = routes{r};for i = 1:length(rt)-1tau(rt(i),rt(i+1)) = tau(rt(i),rt(i+1)) + Q0/totalCost;tau(rt(i+1),rt(i)) = tau(rt(i),rt(i+1));endend
end

相关文章:

蚁群算法赋能生鲜配送:MATLAB 实现多约束路径优化

在生鲜农产品配送中&#xff0c;如何平衡运输效率与成本控制始终是行业难题。本文聚焦多目标路径优化&#xff0c;通过 MATLAB 实现蚁群算法&#xff0c;解决包含载重限制、时间窗约束、冷藏货损成本的复杂配送问题。代码完整复现了从数据生成到路径优化的全流程&#xff0c;助…...

前苹果首席设计官回顾了其在苹果的设计生涯、公司文化、标志性产品的背后故事

每周跟踪AI热点新闻动向和震撼发展 想要探索生成式人工智能的前沿进展吗&#xff1f;订阅我们的简报&#xff0c;深入解析最新的技术突破、实际应用案例和未来的趋势。与全球数同行一同&#xff0c;从行业内部的深度分析和实用指南中受益。不要错过这个机会&#xff0c;成为AI领…...

《基于 Kubernetes 的 WordPress 高可用部署实践:从 MariaDB 到 Nginx 反向代理》

手把手教你用 Kubernetes 部署高可用 WordPress 博客 本实验通过 Kubernetes 容器编排平台&#xff0c;完整部署了一个高可用的 WordPress 网站架构&#xff0c;包含 MariaDB 数据库、WordPress 应用和 Nginx 反向代理三大核心组件。实验涵盖了从基础环境准备到最终服务暴露的…...

文件上传总结

攻击与绕过方式 一、条件竞争 攻击原理&#xff1a;在上传文件的同时利用代码逻辑中的时序问题&#xff08;如 unlink() 删除操作&#xff09;触发条件竞争&#xff0c;从而实现上传恶意文件并绕过限制。 示例测试源码&#xff1a; 以下为测试文件上传功能的 PHP 源码&#xff…...

在文档里如何引用在线SVG甘特图

在文档里如何引用在线SVG甘特图 介绍 本文将详细介绍如何快速创建一个功能强大的在线甘特图&#xff0c;并将其嵌入到其他文档&#xff08;如 Notion、Wiki、Qiita、GitHub、Obsidian、Email 等&#xff09;中。只要目标工具支持引用网络图片&#xff0c;你就可以轻松实现这一…...

Spring AI 与 Groq 的深度集成:解锁高效 AI 推理新体验

Spring AI 与 Groq 的深度集成&#xff1a;解锁高效 AI 推理新体验 前言 在人工智能飞速发展的当下&#xff0c;AI 推理的效率和性能成为开发者关注的焦点。Groq 作为一款基于 LPU™ 的超快速 AI 推理引擎&#xff0c;凭借其强大的性能&#xff0c;能够支持各类 AI 模型&…...

101alpha---第10

rank(((0 < ts_arg_min(ts_delta(close, 1), 4)) ? ts_delta(close, 1) : ((ts_arg_max(ts_delta(close, 1), 4) < 0) ? ts_delta(close, 1) : (-1 * ts_delta(close, 1))))) alpha 那么我们来看具体含义 吧 rank(((0 < ts_arg_min(ts_delta(close, 1), 4)) ? …...

vim中的查找

在 Vim 中&#xff0c;使用 n 键可以按正向&#xff08;向下&#xff09;继续查找下一个匹配项。若要反向&#xff08;向上&#xff09;查找&#xff0c;可以使用以下方法&#xff1a; 1. 使用 N 键反向查找 在查找命令&#xff08;如 /keyword&#xff09;后&#xff0c;按下…...

什么是IP专线?企业数字化转型的关键网络基础设施

为什么企业需要IP专线&#xff1f; 在当今数字化浪潮席卷全球的背景下&#xff0c;企业网络需求正经历着前所未有的变革。传统网络架构已难以满足现代企业对高效、安全、灵活网络服务的需求&#xff0c;IP专线正是在这一背景下应运而生的关键网络解决方案。 专线服务本质上是…...

Linux环境基础开发工具的使用(yum、vim、gcc、g++、gdb、make/Makefile)

目录 Linux软件包管理器 - yum Linux下载软件的方式 认识yum 查找软件包 安装软件包 如何实现本地机器和云服务器之间的文件互传 卸载软件 Linux编辑器 - vim vim的基本概念 vim下各模式的切换 vim命令模式各命令汇总 vim底行模式各命令汇总 Linux编译器 - gcc/g …...

5.11 - 5.12 JDBC+Mybatis+StringBoot项目配置文件

JDBC&#xff1a; 预编译SQL优点&#xff1a;安全&#xff0c;性能更高。 在cmd里面输入java-jar就可以运行jar包。 Mybatis&#xff1a; 持久层框架。用于简化JDBC的开发。 数据库连接池里面放置的是一个一个Connection连接对象。&#xff08;连接池中的连接可以复用&#…...

判断一个数组有没有重复值

要判断一个数组是否包含重复值&#xff0c;你可以使用多种方法。以下是一些常用的方法&#xff1a; 方法 1&#xff1a;使用 Set Set 是一种集合数据结构&#xff0c;它只存储唯一的值。因此&#xff0c;你可以将数组转换为 Set&#xff0c;然后比较 Set 的大小与数组的长度。…...

51c大模型~合集127

我自己的原文哦~ https://blog.51cto.com/whaosoft/13905076 #Executor-Workers架构 图解Vllm V1系列2 本文详细介绍了vllm v1的Executor-Workers架构&#xff0c;包括Executor的四种类型&#xff08;mp、ray、uni、external_launcher&#xff09;及其适用场景&#xff…...

Spring急速入门

Spring 是 企业级开发的一站式框架&#xff0c;核心是 IOC&#xff08;控制反转&#xff09; 和 AOP&#xff08;面向切面编程&#xff09; 一、Spring 核心&#xff1a;IOC 理论 1. 什么是 IOC&#xff1f; IOC&#xff08;Inversion of Control&#xff0c;控制反转&…...

#在 CentOS 7 中手动编译安装软件操作及原理

在 CentOS 7 中&#xff0c;手动编译安装软件&#xff08;即从源代码编译安装&#xff09;是一种高度灵活的方式&#xff0c;适用于需要定制化软件功能、优化性能或安装官方仓库未提供的软件版本的场景。以下是针对手动编译安装的详细说明&#xff0c;包括原理、步骤、注意事项…...

【Kubernetes】初识基础理论(第一篇)

前言 单机容器编排&#xff1a; docker-compose 容器集群编排&#xff1a; docker swarm、mesosmarathon、kubernetes 应用编排&#xff1a; ansible 一、Kubernetes概述 Kubernetes 是一个可移植的、可扩展的开源平台&#xff0c;用于管理容器化的…...

配置集群(yarn)

在配置 YARN 集群前&#xff0c;要先完成以下准备工作&#xff1a; 集群环境规划&#xff1a;明确各节点的角色&#xff0c;如 ResourceManager、NodeManager 等。网络环境搭建&#xff1a;保证各个节点之间能够通过网络互通。时间同步设置&#xff1a;安装 NTP 服务&#xff0…...

按钮导航组件 | 纯血鸿蒙组件库AUI

摘要&#xff1a; 按钮导航组件(A_ButtonNav)&#xff1a;可设置导航数据(含文本及路由)&#xff0c;可设置按钮颜色、导航标题及导航子标题。 一、组件调用方式 1.1.极简调用&#xff1a; 用 A_ButtonNav 调用“按钮导航组件”&#xff0c;只需要给属性 data &#xff08;导…...

自适应主从复制模拟器的构建与研究

自适应主从复制模拟器的构建与研究 摘要: 本文旨在构建一个自适应主从复制模拟器,深入研究主从复制原理及优化方法。从研究者视角出发,详细阐述模拟器的设计、实现与实验过程,通过表格、图表及代码等辅助手段,逐步探讨如何在不同网络条件和负载下,自动调整主从复制参数和…...

015枚举之滑动窗口——算法备赛

滑动窗口 最大子数组和 题目描述 给你一个整数数组 nums &#xff0c;请你找出一个具有最大和的连续子数组&#xff08;子数组最少包含一个元素&#xff09;&#xff0c;返回其最大和。 原题链接 思路分析 见代码注解 代码 int maxSubArray(vector<int>& num…...

【Dv3Admin】工具视图配置文件解析

在开发后台管理系统时,处理复杂的 CRUD 操作是常见的需求。Django Rest Framework(DRF)通过 ModelViewSet 提供了基础的增删改查功能,但在实际应用中,往往需要扩展更多的功能,如批量操作、权限控制、查询优化等。dvadmin/utils/viewset.py 模块通过继承并扩展 ModelViewS…...

在MyBatis Plus里处理LocalDateTime类型

在MyBatis Plus里处理LocalDateTime类型 在MyBatis Plus里处理LocalDateTime类型时&#xff0c;你要确保数据库字段和Java实体类属性之间的类型映射是正确的。下面为你介绍处理这种情况的方法&#xff1a; 1. 数据库字段类型对应设置 要保证数据库字段类型和LocalDateTime相…...

编程技能:字符串函数03,strncpy

专栏导航 本节文章分别属于《Win32 学习笔记》和《MFC 学习笔记》两个专栏&#xff0c;故划分为两个专栏导航。读者可以自行选择前往哪个专栏。 &#xff08;一&#xff09;WIn32 专栏导航 上一篇&#xff1a;编程技能&#xff1a;字符串函数02&#xff0c;strcpy 回到目录…...

edge设置位IE模式打开网页

打开Edge浏览器->在浏览器工具栏右键->自定义工具栏->外观->选择要在工具栏上显示的按钮->找到“Internet Explorer 模式”按钮->开启,将其添加到工具栏中...

代码随想录训练营第二十二天| 101.对称二叉树 100.相同的树

101.对称二叉树&#xff1a; 文档讲解&#xff1a;代码随想录|101.对称二叉树 视频讲解&#xff1a;新学期要从学习二叉树开始&#xff01; | LeetCode&#xff1a;101. 对称二叉树_哔哩哔哩_bilibili 状态&#xff1a;已做出 思路&#xff1a; 这道题目我初始做的时候想着使用…...

nvm管理node版本

To manage Node.js versions on Windows, I recommend using nvm-windows (Node Version Manager for Windows). Here’s how we can handle this: First, let’s install nvm-windows. I’ll propose a command to check if it’s already installed: nvm versionGreat! I s…...

智能手表测试计划文档(软/硬件)

&#x1f4c4; 智能手表测试计划文档&#xff08;软/硬件&#xff09; 项目名称&#xff1a;Aurora Watch S1 文档编号&#xff1a;AW-S1-QA-TP-001 编制日期&#xff1a;2025-xx-xx 版本&#xff1a;V1.0 编写人&#xff1a;xxx&#xff08;测试主管&#xff09; 一、测试目标…...

基于大模型的原发性醛固酮增多症全流程预测与诊疗方案研究

目录 一、引言 1.1 研究背景与意义 1.2 国内外研究现状 1.3 研究目的与方法 二、原发性醛固酮增多症概述 2.1 疾病定义与发病机制 2.2 临床表现与诊断标准 2.3 流行病学特征 三、大模型预测原理与技术 3.1 大模型简介 3.2 预测原理与算法 3.3 数据收集与预处理 四…...

spring中的@Lazy注解详解

一、核心功能与作用 Lazy 注解是 Spring 框架中用于延迟 Bean 初始化的核心工具&#xff0c;通过将 Bean 的创建推迟到首次使用时&#xff0c;优化资源利用和启动性能。其核心功能包括&#xff1a; 延迟初始化 默认情况下&#xff0c;Spring 在容器启动时立即初始化所有单例 …...

Docker快速入门与应用

1. 什么是 Docker&#xff1f; Docker 就像一个“魔法箱子”&#xff0c;可以把你开发的应用&#xff08;代码、环境、配置&#xff09;‌打包成一个标准化的容器‌&#xff0c;这个容器可以在任何支持 Docker 的系统上运行&#xff0c;无需担心环境差异导致的问题。 ‌类比‌…...

判断一个数是不是素数的最高效的算法

判断一个数是否是素数&#xff0c;有从简单到复杂多种方法。最高效的算法取决于输入规模&#xff08;是几个亿以内的数&#xff0c;还是上百位的大整数&#xff09;&#xff0c;我会按实用场景分类讲解&#xff1a; ✅ 常规范围内&#xff08;比如 ≤ 1e12&#xff09;判断素数…...

《Head First 设计模式》第一章 - 笔记

本书是本人写的设计模式的笔记&#xff0c;写下核心要点&#xff0c;如果你掌握过设计模式&#xff0c;想快速阅读本书内容&#xff0c;这个笔记适合你阅读。如果你是新手&#xff0c;有 java 基础和 oo 设计原则基础&#xff0c;你适合跟我一样从零阅读本书。 第一章 策略模式…...

GPT系列:自然语言处理的演进与多模态的探索

GPT系列&#xff1a;自然语言处理的演进与多模态的探索 GPT系列的发展一、GPT-1 &#xff1a;通过生成式的预训练改进自然语言GPT-1的动机做一个预训练模型的难点GPT-1的微调模式GPT-1的训练数据Bert 二、GPT-2语言模型是非监督的GPT-2的动机引入promptGPT-2模型架构的改变GPT-…...

Linux驱动:驱动编译流程了解

要求 1、开发板中的linux的zImage必须是自己编译的 2、内核源码树,其实就是一个经过了配置编译之后的内核源码。 3、nfs挂载的rootfs,主机ubuntu中必须搭建一个nfs服务器。 内核源码树 解压 tar -jxvf x210kernel.tar.bz2 编译 make x210ii_qt_defconfigmakeCan’t use ‘…...

【MySQL】数据库基础

目录 1.什么是数据库2.见一见数据库3.服务器、表、库之间的关系4.MySQL架构5.sql语句分类6.查看MySQL存储引擎6.1 查看存储引擎6.2 常见存储引擎对比 1.什么是数据库 概念&#xff1a;数据库一般是指&#xff0c;在磁盘或者内存中存储的特定结构组织的数据 – 将来在磁盘上存储…...

1.1 文章简介

前因后果链 行业需求 → 技能断层 → 课程设计响应 (高薪岗位要求数学基础) → (符号/公式理解困难) → (聚焦原理与应用) 行业驱动因素 • 前因&#xff1a;机器学习/AI等领域的高薪岗位激增&#xff0c;但数学能力成为主要门槛 • 关键矛盾&#xff1a;算法论文中的数学…...

laravel 中使用的pdf 扩展包 laravel-snappy(已解决中文乱码)

Centos7 安装 wkhtmltopdf 1、先查看系统是 32 位的还是 64 位的 uname -a2、通过 composer 安装 wkhtmltopdf 32位: $ composer require h4cc / wkhtmltopdf-i386 0.12.x $ composer require h4cc / wkhtmltoimage-i386 0.12.x 64位: $ composer require h4cc/wkhtmltopdf-…...

java反序列化commons-collections链6

cc链6&#xff0c;最好用的cc链&#xff0c;因为它不受jdk版本的限制和cc版本的限制&#xff0c;前半段很像urldns链&#xff0c;后半段是cc1链 先来看一下它的利用链 Gadget chain:java.io.ObjectInputStream.readObject()java.util.HashSet.readObject()java.util.HashMap.p…...

WebSocket的原理及QT示例

一.WebSocket 介绍 1.概述 WebSocket 是一种在单个 TCP 连接上进行全双工通讯的协议&#xff0c;它在 2011 年被 IETF 定为标准 RFC 6455&#xff0c;并由 RFC7936 补充规范。与传统的 HTTP 协议不同&#xff0c;WebSocket 允许服务器和客户端之间进行实时、双向的数据传输&a…...

css 点击后改变样式

背景&#xff1a; 期望实现效果&#xff1a;鼠标点击之后&#xff0c;保持选中样式。 实现思路&#xff1a;在css样式中&#xff0c;:active 是一种伪类&#xff0c;用于表示用户当前正在与被选定的元素进行交互。当用户点击或按住鼠标时&#xff0c;元素将被激活&#xff0c;此…...

AI 在模仿历史语言方面面临挑战:大型语言模型在生成历史风格文本时的困境与研究进展

概述 在当今数字化时代&#xff0c;人工智能&#xff08;AI&#xff09;技术在诸多领域展现出了强大的能力&#xff0c;但在处理历史语言这一特定任务时&#xff0c;却遭遇了不小的挑战。美国和加拿大的研究人员通过合作发现&#xff0c;像 ChatGPT 这样的大型语言模型&#x…...

C++.Windows图形

Windows图形 1. 基础知识1.1 Windows图形编程基础1.2 GDI与GDI1.3 窗口消息处理2.1 注册窗口类2.2 创建窗口2.3 显示窗口3.1 创建按钮3.2 按钮消息处理4.1 设置窗口透明度4.2 透明窗口示例5.1 使用区域创建异形窗口5.2 异形窗口示例6.1 GDI抗锯齿设置6.2 抗锯齿绘图示例7.1 Dir…...

【Vue3】使用vite创建Vue3工程、Vue3基本语法讲解

一、什么是Vite Vite是新一代前端构建工具&#xff0c;官网地址&#xff1a;Vite中文网&#xff0c;vite的优势如下&#xff1a; 轻量快速的热重载&#xff08;HMR&#xff09;&#xff0c;能实现极速的服务启动对TypeScript、JSX、CSS等支持开箱即用真正的按需编译&#xff…...

专题二:二叉树的深度优先搜索

以leetcode2331题为例 题目分析&#xff1a; 以第一个示例为例 算法原理分析&#xff1a; 从宏观角度&#xff0c;也就是我的算法之回溯的第一篇 我们发现我们在研究示例的时候&#xff0c;必须从下往上推 也就是我在研究一个结点是true还是false的时候&#xff0c;必须…...

Termius ssh连接服务器 vim打开的文件无法复制问题

你的问题是&#xff1a; • 在 Termius (macOS) SSH 连接到 VMware Ubuntu&#xff0c;使用 vim 打开 .cpp 文件时&#xff0c;可以复制文本&#xff1b; • 但在 Windows 10 上 SSH 到 VMware 的 Red Hat 6.4 时&#xff0c;复制操作无效。 ⸻ &#x1f3af; 初步分析 复制…...

搭建大数据学习的平台

一、基础环境准备 1. 硬件配置 物理机&#xff1a;建议 16GB 内存以上&#xff0c;500GB 硬盘&#xff0c;多核 CPU虚拟机&#xff1a;至少 3 台&#xff08;1 主 2 从&#xff09;&#xff0c;每台 4GB 内存&#xff0c;50GB 硬盘 2. 操作系统 Ubuntu 20.04 LTS 或 CentOS…...

Matlab 模糊控制节水洗衣机模型

1、内容简介 Matlab 232-模糊控制节水洗衣机模型 可以交流、咨询、答疑 2、内容说明 略 3、仿真分析 略 4、参考论文 略...

如何找正常运行虚拟机

1.新建虚拟机。Linux centos7&#xff0c;给虚拟机改个名字不要放在c盘 2.安装操作系统。cd/dvd->2009.iso 启动虚拟机...

python二手书交易管理系统

目录 技术栈介绍具体实现截图系统设计研究方法&#xff1a;设计步骤设计流程核心代码部分展示研究方法详细视频演示试验方案论文大纲源码获取/详细视频演示 技术栈介绍 Django-SpringBoot-php-Node.js-flask 本课题的研究方法和研究步骤基本合理&#xff0c;难度适中&#xf…...

使用本地部署的 LLaMA 3 模型进行中文对话生成

以下程序调用本地部署的 LLaMA3 模型进行多轮对话生成&#xff0c;通过 Hugging Face Transformers API 加载、预处理、生成并输出最终回答。 程序用的是 Chat 模型格式&#xff08;如 LLaMA3 Instruct 模型&#xff09;&#xff0c;遵循 ChatML 模板&#xff0c;并使用 apply…...