认知思考沉迷:如何调试黑箱?

我8个多月大的儿子,今天让我想到了一个黑箱问题,他究竟发生了什么事儿,待会儿揭晓。

0. 黑箱是什么?

黑箱,是一个形象的比喻。指一个事物,你从外面看不透里面有什么,正在发生什么,发生过什么,就像正看着一个黑箱一样。

黑箱并不是完全不可知,黑箱有两个孔:输入口和输出口。

你往输入口里,放入一些信息,那么输出口就可能出来一些别的东西,也有可能不出来。

你发现放入的信息不同,出来的东西可能不同,但偶尔也可能相同。

于是,在黑箱之外的你,一定对黑箱充满好奇。在好奇心驱使下,你想发现黑箱的内在规律,甚至破解黑箱的内部构成。

1. 中文屋子

中文屋子,是历史上一次经典实验,用来验证图灵测试的失效。

先看什么叫图灵测试?我们结合刚刚的黑箱定义来说明一下。

把一台机器放入一个黑箱,允许一个人在黑箱之外,往黑箱输入口里提问题,那么黑箱输出口里会回应问题。黑箱外的人可反复提出多个问题。

如果超过30%的黑箱外测试者,都不能分清黑箱里,到底是一个人还是一台机器回答的,那么原本黑箱里的机器,就算拥有人工智能,也就算说,通过图灵测试。

中文屋子,算是对黑箱的一次调试,并且反驳图灵测试的结论。

中文屋子是什么?

这个黑箱就叫中文屋子,里面有一个只会说英文的人,一本中英翻译书,一些草稿纸。无论黑箱(中文屋子)的输入口,放入中文纸条。
这个只会英文的人将中英文工具翻译成英文,然后用英文作答,最后用中英文工具翻译成中文,放入输出口。

就这样,黑箱外的人看到输入中文,输出中文,以为里面有一个懂中文的人或者机器。

实际没有,中文屋子骗了他们。

2. 黑盒测试

在计算机软件行业的作业流程中,有个职位叫测试工程师。

测试工程师的岗位要求,就是对研发出来的软件进行各种测试,以期待发现缺陷(Bug),然后交还给开发去修正。

测试的工作有很多方法论,其中一种便是「黑盒测试」。与黑箱概念一致:把软件看成是一个黑箱,当某个输入发生时,有符合期待的输出,否则就要算软件出现了bug。

之所以输出要「符合期待」,是因为程序按照产品设计的,黑箱只是封装了具体的实现内容,但输入、输出结果是固定的。

暂且,把这类黑箱称之为「固定黑箱」。

2. Hey Siri

苹果的Siri,智能语音助手。你说出的任何语言,都会通过Siri上传到某云服务器,云服务器分析后,综合给出相应的解答,输出返回到你的手机。

在这个过程中,Siri本身就是一个黑箱,因为我们不知道Siri是依据什么回应的。

不同的人,不同的手机,问出同样一个问题,回答还各不相同。就算是同一个人,同一部手机,不同的时间,问出同样的问题,依然回答不同。

暂且,把这类黑箱称之为「可变黑箱」。

3. 无反馈黑箱

好了,我家8个月大的小宝儿上场了,他演绎了黑箱的一种最高级模式,「无反馈黑箱」。

最近一段时间,小宝儿睡得很不好,我们换过奶瓶,喂过水,但晚上睡觉依然莫名哭闹。我们也不知道怎么办。

上周末,家里停水让我们把小宝儿转移到外婆家。周末两天,在外婆家的睡觉却非常安稳。

一分析,外婆家的床比较软,而且有床垫,睡起来比较舒服。赶上这两天气温骤降,温度低的时候,加盖的不如加垫的有用。

大人都知道的道理,可我们一直没为小宝儿想出办法,最大的原因是:

小宝儿无法跟我们交流,他只能用哭闹表示不开心,但不能告诉我们具体哪里不开心。

如果小宝儿是黑箱,暂且,把这类黑箱称之为「无反馈黑箱」。

4. 调试黑箱的技巧

固定黑箱,可变黑箱,无反馈黑箱,一个比一个难度级别大。然而,这些级别通常都是有一定的套路。

第. 正向功能调试。按照需求、习惯、自然反射行事,把所有应该有的功能都调试到,争取符合期望。

第二. 单一变量调试。遇到复杂的问题,先将问题分解,对应上我们的调试策略,重复试,直到发现真理。

第三. 逆向调试。即反向调试,与期待的方向相反,来看黑箱的反馈。记住,不要调试小宝儿,否则后果自负。

第四,边界值调试。如果黑箱只能满足从0到1的数值范围,那就应该试试大于1的数字,或者小于0的数字,然后看黑箱的反馈。

第五,组合调试。综合以上所有调试方法,反复、随机、组合的调试。

5. 终章

周末结束,从外婆家回自己家,换上软软的、厚实的床垫,且看今晚小宝儿的反应。哦,对了,这算单一变量测试。

: end )

你可能感兴趣的:(认知思考沉迷:如何调试黑箱?)