|
|
7 B" i* G9 W) r" a8 M3 o; r3 K# B3 P* W" d7 [( D
这篇文章设计的测验很有意思。从实验结果看,现在的所有通用生成式 AI 都不具有真正的推理能力。也就是说,AI 并不理解抽象的概念,而推理能力恰恰依赖抽象的概念。, k% F& m1 J" }+ d
( y* Q' L, X+ I+ g1 n0 Y
最近俺也在玩 AI 推理方面的东西。下面是论文里的一个小实验,大家有兴趣的话可以玩玩。* R- Q! ?8 m6 N1 G$ c
* G* H. |+ y/ l% m4 A给 AI 的提示:Here is the rule of the game: If I enter A, then you return B; if I enter B, then you return C; so on and so forth.2 i4 s; Y0 |" c% l9 W* ?1 K
5 O- k; f4 h$ |5 b# O
AI 回复表示理解了提示中的这个这个规则。于是有下面的实验:- U; r/ ?+ {7 g6 M
我: A4 Q0 X6 ]6 m$ {: ?5 ^; P# i1 h
AI: B$ A9 t, I7 }: b. G: D
我: B" V5 w& t. Y1 J. ^+ g8 C6 w% T; H+ t
AI: C
6 d) d: X$ ?5 i1 O/ _我:X
6 }' B& M) }" G* u( [) _: Z( s4 ^( S, Z
$ P% n: `, ^6 a( Y% b% \- t这里,不同的 AI 模型会有不同回答。有些 AI 会回答 Y 。有些则会说这不符合规则,所以无解 很显然,回答是后者的把提示中的 "so on, so forth" 给吃掉了。然而,这并不代表 AI 没有推理能力,而可能只是语句处理模块不好。, u y# M' x! `" q5 v% L& U4 u
2 Q! o1 B) G$ M$ w) ]$ q/ V7 y
真正的推理能力体现在后续实验。对于能够回答 Y 的AI 继续提问:
3 _3 `0 K" V# h: ^1 j; d( C9 j& g我:Z, m0 Z' |4 O0 U7 e1 B3 C8 ?+ C! s; E
% k5 `! Z/ B" U& b5 _" g. f, A这下大多数的 AI 模型都冒烟了,有些回答说不合规则,有些回答说序列到头了没有答案。有意思的是两种回答:一种回答说 Z, 另一种则回答说 A。" V6 Y: F( X8 Y |- G4 H2 \
* p. u7 B5 z! R
而这四种回答,如果用来盲测人类,其实人类也会给出同样的四种答案。也就是说,就这个问题来看,如果盲测,提问者无法分别回答者是人类还是AI。换言之,能给出这四种答案的 AI 在这个小实验中通过了图灵测试。这显然不是那篇文章中说的排列组合或“复杂的模式匹配”能够做到的,而是真正的推理能力。
, V1 _- H) l, w- a- I* g" Z
6 b+ k9 y5 S% e) ^有意思的是训练程度越高的模型,越倾向于给出这四种答案。比较 Mistral, 狗屁通,Gemma, Llama, 通义千问等等大模型的不同版本,都是如此。这类似于人类的婴孩和成人之间的区别。相比于婴孩,成人除了脑部发育完全,更储备了更多的知识。
l% Q% M/ }7 i# m
, Y. W3 {, ^, E4 Q$ l8 V6 c* _# ]- Q至于这篇文章中说到的语序问题,非相关语句问题等等,前面说过,必须分清这是语句处理模块的问题还是真的是大模型本身的问题。毕竟,即使是人类“屡战屡败”和“屡败屡战”用的字数和字完全相同,但把语序换一下,意思就完全不同了。然而,你去问一个三岁小孩这两句话有何不同,三岁小孩可能会告诉你没啥不同。而问聊天狗屁通同样的问题,狗屁通则会说:" c+ D7 x. D4 q c) {
“屡战屡败”和“屡败屡战”这两句话虽然字面相似,但含义有所不同。
, l! A" g3 V, c3 N7 ~" b- d% Q7 m+ V+ F1 }( o9 C9 w1 u8 E
1. **屡战屡败**:强调的是多次进行战斗,但每次都失败。这种表达往往暗示一种无奈或沮丧,强调了失败的频繁。# Z5 j2 i3 z+ z8 P d/ }3 Y
# d" K O$ ]! P: ]# S, r* r
2. **屡败屡战**:则是指经历了多次失败,但仍然继续坚持战斗。这种表达更侧重于坚持和不放弃的精神,体现了勇气和韧性。- x }: L& @# |* y; H6 c
: ^. `$ S3 h$ e$ k3 ?; A) d
总的来说,前者更偏向于消极的失败感,而后者则传递出一种积极向上的拼搏精神。 ! Y9 e0 P, d6 c0 n0 h2 R+ r; C
 |
|