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

【控制】基于使用Koopman算子识别的多面体不确定性LPV系统的鲁棒非线性模型预测控制 附matlab代码

✅作者简介热爱科研的Matlab仿真开发者擅长毕业设计辅导、数学建模、数据处理、程序设计科研仿真。完整代码获取 定制创新 论文复现点击Matlab科研工作室 关注我领取海量matlab电子书和数学建模资料个人信条做科研博学之、审问之、慎思之、明辨之、笃行之是为博学慎思明辨笃行。 内容介绍一、引言基于 Koopman 算子的模型预测控制是一种针对动力学未知的非线性系统的数据驱动控制方法。然而在运用 Koopman 算子时建模误差几乎难以避免。为解决这一问题本文提出一种通过 Koopman 算子在非线性系统识别中处理建模误差的方法。该方法将非线性系统表示为具有多面体不确定性的线性参数变化LPV系统多面体的顶点通过数据驱动方式获取。基于所识别的 Koopman 算子 - 多面体 LPV 系统在最坏情况下为原始非线性系统设计了一种鲁棒模型预测控制器。控制设计被表述为一个受特定线性矩阵不等式LMI约束的优化问题以确保递归可行性和闭环稳定性。数值模拟验证了所提建模与控制方法的有效性。二、基于 Koopman 算子的非线性系统建模挑战一Koopman 算子概述Koopman 算子是一种将非线性系统提升到高维线性空间的数学工具它能够对非线性动力学进行线性表示为非线性系统的分析和控制提供了新的视角。通过对系统状态进行适当的函数变换Koopman 算子可以将非线性系统转化为线性系统使得传统的线性控制理论有可能应用于非线性系统。二建模误差问题尽管 Koopman 算子为非线性系统建模带来了便利但由于实际系统的复杂性和数据的有限性建模误差几乎不可避免。这些误差可能源于系统中未建模的动态、噪声干扰以及数据采集的不完整性等因素。建模误差会导致基于 Koopman 算子的模型不能准确反映实际非线性系统的行为从而影响控制性能甚至可能导致系统不稳定。三、基于多面体不确定性 LPV 系统的非线性系统表示一LPV 系统基本概念线性参数变化LPV系统是一种系统参数随时间或其他参数变化的线性系统。这种系统结构能够捕捉系统在不同工作条件下的动态变化为处理具有参数不确定性的系统提供了有效的框架。二多面体不确定性的引入为了处理 Koopman 算子建模误差本文将非线性系统表示为具有多面体不确定性的 LPV 系统。多面体不确定性是指系统参数在一个多面体区域内变化。通过数据驱动的方法确定多面体的顶点。具体而言利用系统的输入 - 输出数据通过特定的算法如系统辨识技术找到一组能够描述系统在不同可能情况下的参数组合这些参数组合构成了多面体的顶点。这样将非线性系统的不确定性通过多面体的形式进行量化使得可以在一个相对确定的框架内分析和设计控制器。四、基于 Koopman 算子 - 多面体 LPV 系统的鲁棒模型预测控制器设计一最坏情况场景考虑在设计控制器时考虑最坏情况场景即假设系统参数在多面体不确定性范围内取最不利于控制性能的组合。这种保守的设计方法能够保证在各种可能的系统参数变化下控制器都能保持一定的性能和稳定性。二基于 LMI 的优化问题控制设计被表述为一个受特定线性矩阵不等式LMI约束的优化问题。LMI 是一种在控制理论中广泛应用的数学工具它能够简洁地描述系统的稳定性和性能条件。通过求解这个优化问题可以得到使系统满足递归可行性和闭环稳定性的控制器参数。递归可行性确保在每个采样时刻优化问题都有可行解从而保证控制器能够持续运行。闭环稳定性则保证了在控制器作用下系统能够稳定运行即系统状态能够收敛到期望的平衡点。五、数值模拟一模拟系统选择选择具有代表性的非线性系统进行数值模拟例如具有复杂动力学行为的化学反应过程模型或机械振动系统模型。这些系统具有典型的非线性特性能够很好地验证所提方法在实际非线性系统中的有效性。二模拟结果分析通过数值模拟对比基于传统 Koopman 算子模型预测控制和基于所提方法考虑多面体不确定性 LPV 系统的鲁棒模型预测控制的控制性能。结果表明所提方法在存在建模误差的情况下能够更有效地跟踪期望的系统输出并且在面对系统参数的不确定性时具有更好的稳定性和鲁棒性。具体表现为系统的输出响应更加平滑超调量更小并且在参数变化时能够更快地恢复到稳定状态。六、总结本文提出的基于使用 Koopman 算子识别的多面体不确定性 LPV 系统的鲁棒非线性模型预测控制方法为处理 Koopman 算子建模误差提供了一种有效的途径。通过将非线性系统表示为具有多面体不确定性的 LPV 系统并在最坏情况下设计鲁棒模型预测控制器成功地提高了系统在面对建模误差和参数不确定性时的控制性能。数值模拟结果验证了该方法的有效性。未来的研究可以进一步探索如何更精确地确定多面体的顶点以减少保守性提高控制器的性能。同时可以考虑将该方法应用于更复杂的实际系统如航空航天系统、电力系统等以推动其在实际工程中的应用。⛳️ 运行结果 部分代码clcclearclose allr randi(5000);rng(3506)f_u (t,x,u)(-[ -2*x(2,:) ; 1*x(1,:) 3*x(1,:).^2.*x(2,:) - 0.8*x(2,:) - u]);n 2;m 1; % number of control inputsA {};B {};C {};Ylift {};Xlift {};U_sub {};X_sub {};W {};V {};VVt {};WVt {};M {};%% ************************** Discretization ******************************deltaT 0.05;%Runge-Kutta 4k1 (t,x,u) ( f_u(t,x,u) );k2 (t,x,u) ( f_u(t,x k1(t,x,u)*deltaT/2,u) );k3 (t,x,u) ( f_u(t,x k2(t,x,u)*deltaT/2,u) );k4 (t,x,u) ( f_u(t,x k1(t,x,u)*deltaT,u) );f_ud (t,x,u) ( x (deltaT/6) * ( k1(t,x,u) 2*k2(t,x,u) 2*k3(t,x,u) k4(t,x,u) ) );%% ************************** Basis functions *****************************basisFunction rbf;Nrbf 2;cent rand(2,Nrbf)*4 - 2;% cent [[0.7423; 0.9025] [-0.8372; .2427]]rbf_type gauss;% Lifting mapping - RBFs the state itself% liftFun (xx)( [xx;rbf(xx,cent,rbf_type)] - [zeros(2, 1);rbf(zeros(2, 1),cent,rbf_type)]);liftFun (xx)( [xx]);Nsim 100;Ntraj 100;Nd 2;Nlift size( liftFun(zeros(2, 1)), 1);Ubig 2*rand([Nsim Ntraj]) - 1;Xcurrent (rand(n,Ntraj)*4 - 2);N Nsim * Ntraj / Nd;[AA, BB, CC, YYlift, XXlift, XX, UU] VDP_System_Generate(liftFun, Ubig, Xcurrent, Nsim, Ntraj);for i 1 : NdYlift{i} YYlift(:, N * (i - 1) (1 : N));Xlift{i} XXlift(:, N * (i - 1) (1 : N));X_sub{i} XX(:, N * (i - 1) (1 : N));U_sub{i} UU(:, N * (i - 1) (1 : N));W{i} [Ylift{i} ; X_sub{i}];V{i} [Xlift{i} ; U_sub{i}];VVt{i} V{i}*V{i};WVt{i} W{i}*V{i};M{i} WVt{i} * pinv(VVt{i});A{i} M{i}(1:Nlift,1:Nlift);B{i} M{i}(1:Nlift,Nlift1:end);C{i} M{i}(Nlift1:end,1:Nlift);endNd_temp 2 * Nd;for i Nd 1 : Nd_tempA{i} -A{i - Nd};B{i} -B{i - Nd};C{i} C{i - Nd};endA{Nd_temp 1} diag(0.001 * ones(Nlift, 1));B{Nd_temp 1} 0.001 * ones(Nlift, m);C{Nd_temp 1} C{Nd_temp};Nd Nd_temp 1;%% Not polytopic, just one modelnotpolytopic 0;if notpolytopic 1for i 1 : NdA{i} AA;B{i} BB;endepsilon [0.0; 0.0; 0.0; 0.0; 0.0; zeros(Nd - 5, 1)];end%% LQRQ1 diag([10 * ones(n, 1); 0.1 * ones(Nlift - n, 1)]);% Q1 100 * eye(Nlift);R 0.001;F_Receding -dlqr(AA, BB, Q1, R);%% VerificationN 1200;% x0_init [-0.06; 0.83];% x0_init [-1.3; 1.8];% x0_init [0.3; 0.83];% epsilon [0.00; 0.0; zeros(Nd - 2, 1)];if notpolytopic 0epsilon [0.1 ; 0.0; 0.1; 0.0; 0.0; 0.0 * ones(Nd - 5, 1)];% epsilon [0.0 ; 0.0; 0.0; 0.0; 0.0; 0.0 * ones(Nd - 5, 1)];endflag 1;if flag 1for j 1 : NdA{j} (1 epsilon(j)) * A{j};B{j} (1 epsilon(j)) * B{j};endendu 2 * rand(1, N) - 1;for k 1 : 1% x0_init 2 * rand(2, 1) - 1;x0_init [-1.3; 1.8];% epsilon [0.01; 0.0; 0.01; -1.01; -1.02; -1.02; 0.02; -1.02; 0.01; 0.01; 0.02; -1.02; 0.02; -1.02; 0.02; 0.02];% epsilon 0.5 * epsilon;Cy [1 0];NSpan 1 : N;x0 x0_init;% u 2 * rand(1, N) - 1;% u prbs(15, N);X {};x {};x_temp {};for i 1 : NdX{i} [];x{i} liftFun(x0);endx_rec liftFun(x0);Coefficient_Set [];X_Real [x0];X_Recon [x_rec];P_i [];for i 1 : Nfor j 1 : Ndx_candidate{j} C{j} * ( A{j} * x_rec B{j} * u(i) );endM cell2mat(x_candidate);x0 f_ud(0, x0, u(i));p_i lsqlin(M, x0,[ [-eye(Nd, Nd) ; ];], [zeros(Nd, 1);], ones(1, Nd), 1)% p_i lsqlin(M, x0, [-eye(Nd, Nd) ; ones(1, Nd)], [zeros(Nd, 1); 1]);Coefficient_Set [Coefficient_Set p_i];A_Nd cell2mat(A);B_Nd cell2mat(B);A_Rec A_Nd * kron(p_i, eye(Nlift));B_Rec B_Nd * p_i;x_rec A_Rec * x_rec B_Rec * u(i);X_Real [X_Real x0];X_Recon [X_Recon x_rec];endfigureplot(X_Real(1, :), LineWidth, 3, LineStyle, --,Color,r)hold onplot(X_Recon(1, :), LineWidth, 2, LineStyle, -,Color,b)legend(Original, LPV)figureplot(X_Real(2, :), LineWidth, 3, LineStyle, --,Color,r)hold onplot(X_Recon(2, :), LineWidth, 2, LineStyle, -,Color,b)legend(Original, LPV)pause(0.1)end%% Plot polytopic coefficientfigurefor i 1 : Ndplot(Coefficient_Set(i, :), LineStyle,--)hold onend%%Control_Bound 4;Loops 1;X_Loop [];U_Loop [];for L 1 : Loops% A1 A(0.1);% A2 A(10);nx size(A{1}, 1);nu size(B{1}, 2);init [1 ; -0.5];x0 liftFun(init);% Q1 1 * C1*C1;%% F_Receding F_Receding_Static;X_Receding [init];F_Set [];x_next init;U_Receding [];time 200;J_Set [0];J 0;for i 1 : timegamma sdpvar(1, 1);X sdpvar(nu, nu);Q sdpvar(nx, nx);Y sdpvar(nu, nx);LMI1 [1 liftFun(x_next);liftFun(x_next) Q];for j 1 : NdLMI2{j} [Q (A{j} * Q B{j} * Y) (sqrt(Q1)*Q) (sqrt(R)*Y)A{j} * Q B{j} * Y Q zeros(nx, nx) zeros(nx, nu);sqrt(Q1)*Q zeros(nx, nx) (gamma) * eye(nx, nx) zeros(nx, nu);sqrt(R)*Y zeros(nu, nx) zeros(nu, nx) (gamma) * eye(nu, nu)];endLMI0 [X Y;Y Q];ZEROS 0;Constraints [LMI0 0, LMI1 ZEROS, Q ZEROS];for j 1 : NdConstraints [Constraints LMI2{j} ZEROS];end% Input constraints |uk| 2for j 1 : nuConstraints [Constraints X(j, j) Control_Bound^2 ] ;endObjective gamma;sol solvesdp(Constraints, Objective)if sol.problem ~ 0error(Infeasible!)endY double(Y)Q double(Q)F_Receding Y / QJ J x_next * x_next [F_Receding * liftFun(x_next)]*[F_Receding * liftFun(x_next)]J_Set [J_Set J];x_next f_ud(0,x_next,F_Receding * liftFun(x_next))% x_next f_ud(0,x_next,0)X_Receding [X_Receding x_next];U_Receding [U_Receding F_Receding * liftFun(x_next)];F_Set [F_Set; F_Receding];endU_Loop [U_Loop U_Receding];X_Loop [X_Loop X_Receding];endTspan 0:0.05: time * 0.05;NTime size(Tspan, 2);figuresubplot 211for L 0 : Loops - 1plot(Tspan,X_Loop(1, L * (time 1) 1 : (L 1)* (time 1)), LineWidth, 3, Color, b)hold onplot(Tspan,X_Loop(2, L * (time 1) 1 : (L 1)* (time 1)), LineWidth, 3, Color, r)end% axis([0 10,-0.2 1]);xlabel($Time(sec)$,interpreter,latex);ylabel($State$,interpreter,latex);title($State\,\,trajectory$,interpreter,latex);legend($x_1$, $x_2$, Interpreter, latex)subplot 212for L 0 : Loops - 1plot(Tspan(1: end - 1),U_Loop(1, L * (time 1) 1 : (L 1)* (time)), LineWidth, 3)hold onend% plot(Tspan,Control_Bound * ones(1, NTime),LineWidth, 3, LineStyle,--);% plot(Tspan,-Control_Bound* ones(1, NTime),LineWidth, 3, LineStyle,--);% axis([0 10,-2 0.5]);xlabel(time(sec));ylabel($u$ ,interpreter,latex);title(Control signal $u$,interpreter,latex);figureplot(Tspan(1 : end), J_Set,LineWidth, 3, LineStyle,-)xlabel(time(sec));ylabel($J$ ,interpreter,latex); 参考文献Robust Nonlinear Model Predictive Control Based on the LPV System with Polytopic Uncertainty Identified Using Koopman Operator (CDC 2024)更多免费数学建模和仿真教程关注领取

相关文章:

【控制】基于使用Koopman算子识别的多面体不确定性LPV系统的鲁棒非线性模型预测控制 附matlab代码

✅作者简介:热爱科研的Matlab仿真开发者,擅长毕业设计辅导、数学建模、数据处理、程序设计科研仿真。 🍎完整代码获取 定制创新 论文复现点击:Matlab科研工作室 👇 关注我领取海量matlab电子书和数学建模资料 &…...

【无人机】基于无人机UAV和物联网IoT的奶牛健康监测系统算法实现附matlab代码

✅作者简介:热爱科研的Matlab仿真开发者,擅长数据处理、建模仿真、程序设计、完整代码获取、论文复现及科研仿真。 🍎完整代码获取 定制创新 论文复现点击:Matlab科研工作室 🍊个人信条:格物致知,完整Matla…...

【雷达】基于Matlab GUI的中重频PD雷达仿真系统,根据输入参数仿真,图形界面简单

✅作者简介:热爱科研的Matlab仿真开发者,擅长数据处理、建模仿真、程序设计、完整代码获取、论文复现及科研仿真。 🍎完整代码获取 定制创新 论文复现点击:Matlab科研工作室 🍊个人信条:格物致知,完整Matla…...

5步掌握TIDAL高品质音乐下载:tidal-dl-ng高效使用指南

5步掌握TIDAL高品质音乐下载:tidal-dl-ng高效使用指南 【免费下载链接】tidal-dl-ng TIDAL Media Downloader Next Generation! Up to HiRes / TIDAL MAX 24-bit, 192 kHz. 项目地址: https://gitcode.com/gh_mirrors/ti/tidal-dl-ng 想要永久保存TIDAL平台上…...

golang如何实现表单验证_golang表单验证实现方法

用 validator 包校验结构体最省心,需导出字段、正确打标签、调用 Validate() 并处理 error;HTTP 请求解析后立即校验,避免空格等边界问题,配合 Translations 实现多语言错误提示。用 validator 包做结构体字段校验最省心Go 没有内…...

HTML怎么标注回收估价规则_HTML估价逻辑说明折叠区【指南】

用detailssummary实现可折叠估价规则,语义清晰且原生支持键盘与屏幕阅读器;summary仅放标题,正文置于其后;禁用aria-expanded手动控制,避免破坏可访问性;主流浏览器兼容良好,但Safari旧版不支持…...

利用Taotoken多模型聚合能力为AIGC应用动态选择最佳性价比模型

利用Taotoken多模型聚合能力为AIGC应用动态选择最佳性价比模型 在开发一个内容生成应用时,我们常常面临一个现实问题:不同的生成任务对模型的要求差异很大。一段需要文采斐然的创意写作,与一段需要精准、快速的代码补全,对底层大…...

如何通过3步解锁QQ群聊天记录的隐藏价值:ChatLog完整指南

如何通过3步解锁QQ群聊天记录的隐藏价值:ChatLog完整指南 【免费下载链接】chatLog QQ群聊天记录分析 项目地址: https://gitcode.com/gh_mirrors/ch/chatLog 你是否曾经好奇,每天在QQ群里海量的聊天记录背后,究竟隐藏着怎样的社群秘密…...

Python数据分析如何填充缺失日期_Pandas的asfreq技巧

asfreq填充缺失日期前必须将索引设为DatetimeIndex,否则静默失效;需确保索引为datetime64[ns],用freqD等正确频率对齐,再链式调用ffill()等填充NaN。asfreq 填充缺失日期前必须重设索引为 DatetimeIndex直接对普通 df 调用 asfreq…...

基于改进粒子群算法的时间-冲击最优轨迹规划五次B样条【附代码】

✨ 本团队擅长数据搜集与处理、建模仿真、程序设计、仿真代码、EI、SCI写作与指导,毕业论文、期刊论文经验交流。 ✅ 专业定制毕设、代码 ✅ 如需沟通交流,查看文章底部二维码(1)五次B样条曲线构造与关节运动特性约束:…...

CLAWSPACE:专为静态前端应用打造的轻量级发布与分享平台

1. 项目概述:一个为创意而生的轻量级应用宇宙如果你是一个独立开发者、创意工作者,或者只是一个喜欢捣鼓点小玩意、做个网页小游戏自娱自乐的人,你可能经常面临一个困境:做出来的东西,除了自己电脑上的localhost&#…...

从零构建轻量级实时监控系统:WebSocket与数据可视化实践

1. 项目概述:一个名为“Aura”的代码仓库能做什么?在GitHub上,当你看到一个以开发者用户名命名的仓库,比如bryanchen3777/Project-Aura,第一反应会是什么?这很可能是一个个人项目,一个实验性的想…...

Taotoken的按token计费模式如何让实验性项目的成本更可控

Taotoken的按token计费模式如何让实验性项目的成本更可控 1. 实验性项目的成本挑战 在AI原型验证或小规模实验阶段,开发者通常面临模型选型与成本控制的双重压力。传统包月套餐要求预先支付固定费用,而实验过程中频繁切换模型、调整参数会导致实际用量…...

YOLO 系列:半监督学习落地:结合 FixMatch 范式,用少量标注数据训练 YOLOv11,降低标注成本

引言:当目标检测遇上“标注瓶颈” 计算机视觉社区有一句流传已久的调侃:“深度学习工程师的80%时间花在数据上,其中80%花在标注上。” 这句话虽然夸张,却道出了工业界和学术界共同的痛点。以目标检测为例,一张包含50个…...

实战指南:MeteoInfo开源项目中GRIB转ARL格式转换问题的完整解决方案

实战指南:MeteoInfo开源项目中GRIB转ARL格式转换问题的完整解决方案 【免费下载链接】MeteoInfo MeteoInfo: GIS, scientific computation and visualization environment. 项目地址: https://gitcode.com/gh_mirrors/me/MeteoInfo MeteoInfo作为一款强大的气…...

SPSSAU文本分析新手入门:从数据上传到生成第一个词云图的全流程指南

SPSSAU文本分析实战:零基础生成专业词云图的完整指南 第一次面对海量用户评论或问卷开放题时,很多研究者都会感到无从下手。上周帮一位市场营销专业的研究生分析电商平台2000条用户评价,她盯着Excel里密密麻麻的文字直摇头:"…...

JavaScript中Object-getOwnPropertySymbols获取方法

Object.getOwnPropertySymbols() 返回对象自身所有Symbol属性键的数组,不包括字符串键和继承属性;例如返回[Symbol(a), Symbol(b)];区别于Object.keys()和Object.getOwnPropertyNames(),它只获取Symbol键且无论是否可枚举。Object…...

Windows热键冲突终极指南:三步快速定位被占用的快捷键

Windows热键冲突终极指南:三步快速定位被占用的快捷键 【免费下载链接】hotkey-detective A small program for investigating stolen key combinations under Windows 7 and later. 项目地址: https://gitcode.com/gh_mirrors/ho/hotkey-detective 你是否曾…...

PySide6实战:手把手教你用SQLite+QTableView打造个人数据管理工具(附源码)

PySide6实战:手把手教你用SQLiteQTableView打造个人数据管理工具(附源码) 在桌面应用开发领域,数据管理功能几乎是每个工具类软件的标配。想象一下,当你需要管理个人藏书、影碟收藏,或是记录客户联系方式时…...

3步实现视频PPT智能提取:extract-video-ppt让课件整理自动化

3步实现视频PPT智能提取:extract-video-ppt让课件整理自动化 【免费下载链接】extract-video-ppt extract the ppt in the video 项目地址: https://gitcode.com/gh_mirrors/ex/extract-video-ppt 还在为从在线课程、会议录屏中手动截取PPT而烦恼吗&#xff…...

AISMM×ISO 27001×NIST RMF三模融合实践:一位CISO亲授的72小时风险响应加速方案

更多请点击: https://intelliparadigm.com 第一章:AISMM模型与风险管理整合的理论根基 核心范式演进 AISMM(Artificial Intelligence Security Maturity Model)并非孤立的安全评估框架,而是将AI系统生命周期与传统风…...

AI 热点资讯日报-2026-05-07

文章目录AI 热点资讯日报今日核心热点总结新华网科技 (tech.news.cn)36氪 (36kr.com)虎嗅网 (huxiu.com)网易科技 (tech.163.com)雷锋网 (leiphone.com)今日关键词云编辑点评📖 延伸阅读AI 热点资讯日报 日期:2026年5月7日(星期四&#xff0…...

AISMM模型落地预算规划全流程(2024财年头部企业已验证的7大关键控制点)

更多请点击: https://intelliparadigm.com 第一章:AISMM模型与预算规划融合的底层逻辑 AISMM(Adaptive Intelligent Strategic Management Model)并非传统静态框架,而是一个以实时反馈、多源数据协同与动态权重调整为…...

D21: 周复盘 —— 流程是骨架,AI 是肌肉

文章目录 D21: 周复盘 —— 流程是骨架,AI 是肌肉 📊 Week3 效能数据对比 需求评审效率 代码审查效率 项目估算准确度 会议效率 跨部门协作响应速度 📊 Week3 流程重构全景图 🕳️ Week3 踩坑清单:5 个真实教训 踩坑 1:需求评审 AI 化后,过度依赖 AI 生成的需求分析 …...

AI Agent团队数字档案库:用工程化方法管理角色人格与长期记忆

1. 项目概述:一个为AI工程师团队设计的“数字身份档案库”最近在整理团队知识库时,我一直在思考一个问题:在一个由AI Agent组成的虚拟工程团队里,如何让每个“成员”保持稳定、一致且富有深度的“人格”与“记忆”?这不…...

2025届毕业生推荐的降重复率平台解析与推荐

Ai论文网站排名(开题报告、文献综述、降aigc率、降重综合对比) TOP1. 千笔AI TOP2. aipasspaper TOP3. 清北论文 TOP4. 豆包 TOP5. kimi TOP6. deepseek 时下,人工智能生成内容检测技术正日趋成熟,然而用户同样能够借助专业…...

深度解密PCL2启动器:3大核心技术优势与实战开发指南

深度解密PCL2启动器:3大核心技术优势与实战开发指南 【免费下载链接】PCL Minecraft 启动器 Plain Craft Launcher(PCL)。 项目地址: https://gitcode.com/gh_mirrors/pc/PCL Plain Craft Launcher 2(PCL2)是一…...

Universal Split Screen:单机多人游戏解决方案的技术实现与应用

Universal Split Screen:单机多人游戏解决方案的技术实现与应用 【免费下载链接】UniversalSplitScreen Split screen multiplayer for any game with multiple keyboards, mice and controllers. 项目地址: https://gitcode.com/gh_mirrors/un/UniversalSplitScr…...

血清替代物(人血小板裂解液)从工艺到细胞扩增性能替代FBS的可行性分析

在技术领域,我们常常被那些闪耀的、可见的成果所吸引。今天,这个焦点无疑是大语言模型技术。它们的流畅对话、惊人的创造力,让我们得以一窥未来的轮廓。然而,作为在企业一线构建、部署和维护复杂系统的实践者,我们深知…...

使用 taotoken cli 工具快速为团队统一配置开发环境

使用 taotoken cli 工具快速为团队统一配置开发环境 当团队开始使用多个大模型进行开发时,每个成员都需要在各自的开发工具中配置 API 密钥、模型和接入端点。手动配置不仅繁琐,还容易出错,导致团队成员环境不一致,影响协作效率。…...