|
使用爬山算法优化简单的数学函数 假设我们需要找到函数 𝑓(𝑥)=−𝑥^2+4𝑥的最大值。这是一个具有单个局部最大值的简单抛物线函数。 1 D4 }/ s6 C. A
步骤 1: 定义目标函数 首先,定义我们需要优化的函数。在MATLAB中,我们可以创建一个函数来计算给定x值的 𝑓(𝑥)。  - function y = myFunction(x)% m, X$ A o8 w2 Q4 s; @( p
- y = -x^2 + 4*x;% _1 ]* n) [\\" ]/ k
- end
步骤 2: 实现爬山算法 接着,实现爬山算法。我们从一个随机点开始,然后在每一步尝试移动到一个“邻居”点,如果那里的值更高,就移动到那里。  - function [bestX, bestY] = hillClimbing(func, initialX, stepSize, numIterations)
- $ j( _$ h# m1 q6 P
- currentX = initialX;
- 4 ^+ u& @# T' g% J
- currentY = func(currentX);. F0 I9 _# O+ I% ~9 x
- for i = 1:numIterations0 F7 ]5 P& F4 W; D: v\\" ~* }
- % 尝试在两个方向上移动% h\\" ]+ ]5 r* q/ ~, _8 ?6 R
- newX = [currentX + stepSize, currentX - stepSize];% d4 J* P5 T; \\\" R4 C$ E
- newY = [func(newX(1)), func(newX(2))];! u# |\\" ]: e/ s: t8 Y1 t
-
- 6 T' |3 N% R8 r b
- % 找出最好的移动方向+ J7 R8 u S1 h% x' k. [& {9 X
- [maxY, idx] = max(newY);
- & m2 M! p! O\\" p* d* r$ p\\" T8 L% |
- , F6 f4 N0 ?( e1 ^
- % 如果找到了更好的解,则更新当前解
- ; @\\" @( Y# K7 B6 \+ I5 ~* k
- if maxY > currentY6 l4 S+ \ Q\\" }4 J, Y n' t
- currentX = newX(idx);
- & ?9 K/ ~. @* w2 o3 Y
- currentY = maxY;) Q' u; D3 `- Q9 L\\" p. G- r\\" C
- else) x\\" K3 ~# k' d6 ^1 a5 n
- % 如果没有更好的解,结束搜索# V) N& Q$ }1 t6 R' A0 L
- break;; m3 H) J- J; h2 C2 M! a( ?( M
- end0 ?/ ?5 f+ y6 [2 {\\" R8 {4 w
- end4 v\\" \; W: K+ z; p
- bestX = currentX;8 x- o. ]\\" I% o) h+ u# I+ N
- bestY = currentY;
- - j$ _7 G8 h* O# ?% K
- end
- - R4 E' X% X- s0 y; U- t g# g\\" F) v
- \\" X8 I$ T9 g9 f) f
- % 运行爬山算法
- & j l5 h5 o\\" Q' n2 z% M: Q
- initialX = 0; % 初始点
- \\" O0 n+ j/ Q% ]9 B
- stepSize = 0.1; % 步长# G0 G5 F# R2 {5 v9 N4 `. [+ A2 \- ]\\" l
- numIterations = 100; % 迭代次数
- * _8 e; m& U6 x: R0 p6 [
- [bestX, bestY] = hillClimbing(@myFunction, initialX, stepSize, numIterations);
步骤 3: 输出结果 展示算法找到的最优解。 - disp(['The maximum value of f(x) is found at x = ', num2str(bestX)]);
+ [3 q# }: }1 w4 z! ~; _9 Q' K - disp(['The maximum value of f(x) is ', num2str(bestY)]);
复制代码 步骤 4: 可视化 可视化函数和算法找到的最大值点,以更好地理解算法的行为。  - x = 0:0.01:5; p8 z0 B\\" V2 `\\" g8 l) v$ ]
- y = myFunction(x);
- 2 y3 T# K3 v; X9 ?) C2 P# f
- figure;
- + @ d. T7 X3 e. J9 H6 N
- plot(x, y, 'b-', bestX, bestY, 'ro');( ] R, E+ h6 C3 P! t
- title('Function Optimization using Hill Climbing');\\" V, }# n: N& _. n5 I
- xlabel('x');
- 4 j3 ]) a5 U% r& {! f X
- ylabel('f(x)');9 N1 o. V& _) t! s4 ]
- legend('Function', 'Maximum Point');
Y- {$ H$ i* T. \+ c
|