上个月,我拒绝了来自 B 公司的一个年薪 7 位数的 Offer,从而,也可能拒绝了人生最后一次在互联网公司的机会。
可能,一方面是为自己的头发着想,我希望头发留在头顶上风中凌乱,而不是留在凌晨下班时报销的出租车的座椅上;另一方面,也感受到巨厂 HR 对候选人的店大欺客般的不尊重,作为一个中年男人,我拥有死要面子的经典特质。
这家公司之所以找到我,希望我参与到他们的一个 AI 相关的项目,是因为,作为一个中年失业产品经理的我,居然莫名其妙地登上了 GitHub 的全球热榜:
图为拍照留念。
这是我人生一个高光时刻,在过去,我是那个晚上请程序员喝酒搞关系,白天指着他们鼻子干活的产品经理,我无论如何也想不到,有一天我会在全球最大的程序员社区闪耀一次。
这个高光时刻,少不了 ChatGPT 的支持。
每月只需要支付不到 1/4 价格的男士专属 SPA 的费用,就可以拥有一个几乎全能的助理,这显然是非常划算的。
屈指一算,我从 BOSS 直聘离开已经正好 12 个月了,在这 12 个月里,我做了这些事:
- 沿着黄河骑摩托车 2000 公里
- 减少了 4% 的体脂率
- 写了一个名为 Macify 的 Chrome 扩展,目前日活 1000+
- 写了一个 MyIP 项目,GitHub 星星 2000+
- 写了一个躺平计算器项目,用户量 10000+
- 为一家德国投资公司提供咨询服务,搭建了内部的 AI 辅助系统
- 为一家中国心理咨询公司提供咨询服务,设计了 AI 融合到产品的方案
- 为我自己的家庭网络,设计了一整套优化和监控方案
- 拒绝了 2 个联合创业,1 个打工的机会
- 写了一篇公众号文章
这些事里,除了 1,2,10,都和 ChatGPT 相关。
看到这里,你应该看出来了,这篇文章和中年男人的头发没关系,不是一篇关于非那雄胺或米诺地尔的广告,而是一篇分享 ChatGPT 使用心得小经验的文章。
ChatGPT 是一个实习生
毫无疑问,ChatGPT 是目前全球最好的大模型。然而,它并不是万能的。
它的数学很差。
它有时候会胡扯。
它大多数时候不和你聊黄段子。
在和许多朋友分享 ChatGPT 使用经验的时候,我会打这样一个比喻:
ChatGPT 就像一个非常正经的、学习能力很强的、刚刚 985 大学毕业的实习生。
一方面,作为实习生,它的可塑性很强,只要你愿意花时间引导它,它能学会你希望它学会的东西,从而帮你完成你指定的工作。另一方面,你不能对一个实习生期望过高,因为对某件你需要做的事,最熟悉的人是你,而不是它。
在当前的语境下,容易高估它的能力,但低估它的未来潜力。它从推出市场到现在,仅仅才 1 年的时间,它还不是一个让所有人都能轻易上手的产品,因此,把它看作是一个还未成熟的实习生,可能是当下合适的做法。
首先,我们自己得会
我在 BOSS 直聘工作的时候,我的老板鹏哥曾经说过一句话:
作为 Leader,你让手下做的事,你得自己会做。
这句话的潜台词是:只有你会做你手下做的事,你才不会被懵;只有你会做,你才能合理地发号施令。
把这句话放在 ChatGPT 上是非常合适的。
因为大模型容易跑偏,因为大模型并不是无所不能,这要求我们在使用大模型的大多数时候,是让它替代我们完成重复性高的工作 — 就像我们安排自己的手下去做事那样。如果某件我们希望它完成的事,我们自己一点头绪都没有,当然它能给出一些启发,但没有你给的完整指引,它无法给你带来你想要的结果。
就像前面举的例子,它是一个实习生,虽然学习能力很强,但对于刚来贵司报到的它,对业务是不熟悉的。你需要教导它,一步一步告知它工作应该如何做。它很聪明,只要你教导的步骤是正确的,它几乎总能做出正确的答案。
接着,缜密的表达能力
经常有朋友问我,为什么我能够玩 ChatGPT 玩得那么溜,而他只能和 ChatGPT 闲聊,让 ChatGPT 帮他做事总是做不出他想要的效果。
这可能是表达的问题。
如果我们已经确信,我们要让它做的事是我们自己会做的,那接下来第二步是,将做这件事的需求和步骤告知 ChatGPT。许多人卡在这个地方。
举个例子,我们正在做一个网页,希望这个网页的右下角放置一个小球,鼠标点击小球后,它会在屏幕四周反复跳动,同时,为每次跳动设置衰减值,最后小球会停下来。
你把这个需求告诉了这位新来的实习生,它很聪明,它很快就用 JavaScript 给你把代码写出来了。
然而,当你去运行这段代码时你发现:
- 这个小球应该是红色的,不是蓝色的
- 这个小球应该是 20pt 直径,不是 45px
- 小球起跳的速度不正确,显得不够自然
- 小球衰减时只考虑了摩擦力,没有考虑重力
然而,实习生反驳道:老板,这些需求你也没跟我说啊。
相信这个例子,对于在中大型公司工作过的人,完全不陌生。当一个团队大了之后,沟通是最大的障碍。这个障碍是来自双方的:
- 我是否说明白了
- 你是否听懂了
当我们让实习生也好、员工也好、ChatGPT 也好,去做某件事的时候,实际上这件事的完整描述是非常大篇幅的,但我们容易高估我们与同事的默契度,从而只说最关键的部分,而忽略了,这个员工可能仅仅是一个从未有工作经验的实习生。
所以,当我们对 ChatGPT 提需求的时候,应当依旧把它当作一个实习生来看待:
- 把你脑子里所有想到的东西,全部用文字表达出来
- 正着说一遍,如有必要,反着说一遍
- 参考费曼理论,让它把你的需求通过它的话术表达出来,确保需求理解正确
这个时候,你可能会有疑问,如果我像素级描述我的需求,那和我自己做一遍有什么区别?
没有区别。在上一部分我加粗的「重复性高」这几个字,如果你要做的不是一件未来需要重复的事,不如自己一次性做了,因为这会让你节省大量的沟通时间。
并不是所有事,都适合安排别人或 ChatGPT 去做。
然后,解构问题的能力
「小李,我是你老板老王,我晚上要和邻居小姐姐吃饭,你帮我把躺平计算器程序写出来,需求我已经像素级写好了,你参考着写代码,明天早上 5 点我要看到代码」
嗯,看起来老王已经知道,给实习生小李提需求,要通过像素级的方式来提了。
然而,当老王第二天看到小李提交的代码时,发现实现的结果完全跑偏。
为什么?
在这里,我想引入两个很不科学的概念:
- 对话长度
- 实现偏移
我们还是以实习生作为例子。作为一个可能有 10 年工作经验的你,你认为:
- 你和小李一口气聊了 2 小时,让他按照你这 2 小时的指导去做事,你认为他能完全记住吗?
- 你让小李一口气做 80 件事,每件事之间是上下游衔接,你认为他能确保每一件事都做对,从而第 80 件事输出你想要的完美结果吗?
放到物理现实里,这些答案大概率是否定的。
因为,当对话长度越长,实习生的理解能力就会下降,事实上,你的表达缜密程度也会下降。在这种负负得更负的情况下,最终实现的偏移量就会增加。而如果你要实习生做的事是多个小事的串联,每件小事都产生小实现偏移的情况下,最终必定是大大的实现偏移。
所以,不要高估大模型对长文本的理解能力,也不要高估自己在长文本中逻辑缜密的表达能力。同时,也不要高估大模型实现需求的准确度。
当我在使用 ChatGPT 帮我写 MyIP 和躺平计算器的时候,我的流程是这样的:
- 定义需求
- 研究需求实现的原理
- 选定要使用的程序语言
- 规划主程序的结构
- 开发子程序
- 测试 Demo,调整子程序
- 微调子程序
- 调整 UI
- 测试与修复
- 上线
看起来非常像互联网公司里产品的整个定义和开发阶段,是的,就是这样的流程。每个阶段我会继续拆分,减少对话长度,务求让 ChatGPT 每次只帮我完成其中一件小事,从而控制最终的实现偏移 = 0 。
当且仅当,我已经确保多件小事都不会出现实现偏移之后,我才会将这些小事们串联在一起,让它一次性给我「来个大的」输出。
最后,持续的学习能力
如果我们使用 ChatGPT 只是用来做一些简单的事,比如:
- 告诉我,鸡蛋白的热量多少?
- 帮我汇总下面这些我手下们的周报
- 我希望对 Excel 的这一列根据条件求和,你告诉我公式
这确实并不需要我们有多少学习能力。然而,这种用法也限制了我们对大模型的想象力。
在我给德国一家企业做咨询的时候,他们提出的课题是:将 AI 融入到我们的工作流程。于是,我开始对他们的工作流程进行调研,发现他们的工作流程涉及到的环节非常多,涉及到的工具也非常多,有外部的,也有内部的。
这意味着,我需要帮助他们的,并不是告诉他们如何正确地给 ChatGPT 提问,而是如何构建基于大模型核心的 Agents 架构。
但是,我从未真正设计过这样的架构。怎么办?学呗。
好消息是,ChatGPT 不仅能帮助我做事,还能教我如何设计我想要的产品技术架构,当然,在让它教我的时候,我同时也会在 Google 搜索相关的资料进行查证,同时也会自己动手去实现,验证效果。
这个时候,我会打开 3 个浏览器窗口:
- 让 ChatGPT 告诉我某件事如何做
- Google 搜索结果返回的这件事如何做的教程
- 一个新的 ChatGPT 对话,将我在前面学到的,投入对话中让它帮我实现
一个是引导式学习,一个是书本式学习,一个是立即实践。这,难道不就是最佳的学习方式?
大模型至于个人与企业
我想,在当下,每个人都应该尝试使用大模型,如果有条件使用 ChatGPT 就最好了。它不仅仅是一个可以帮我们实现重复工作的工具,在许多时候,还是提供启发式学习的好帮手。
在你需要它帮你做事的时候,你需要把它当作初来乍到的实习生。
在你需要它引导你学习的时候,你需要把自己当作初来乍到的实习生。
当熟练使用之后,你会发现,原来你每天可以节省那么多时间;当你熟练使用之后,你也会发现,原来我能实现许多之前只是想一下但无法动手的工作。
对于企业来说,我自然没有太多的发言权,因为我这一年我服务过的公司并不多,然而,有 2 个思考点是必然绕不过的:
- 如何叠加 AI 的能力,直接或间接提高产品收入
- 如何整合 AI 的能力,直接或间接提高团队的人效
我在为企业进行咨询的时候,发现这往往都是最原始的出发点。
在未来,我相信每个企业以及每个企业里的员工,甚至他们的用户,都会用上 AI 的能力,与人工智能共存的世界,我认为是一个人类会释放更多创造力的世界。
中年男人创意多
最近有一些感慨。
从我第一次在互联网上写字,到现在,已经 23 年了。第一次写字的时候,我 14 岁,现在,头发已经开始稀薄。
35 岁那一年,我和朋友调侃说,通常互联网人士 35 岁就会失业。结果,小丑居然是我自己。
在没有上班这一年里,我颓废了 3 个月,每天除了睡觉、打游戏、吃饭,就是睡觉、打游戏、吃饭。
后来,我恢复每天健身,并深入研究大模型,用产品经理的视角去研究它的边界以及它至于个人和企业应该是什么。所幸的是,还算有一些收获。
在这个过程中,我发现,虽然我的头发变少了,但创意没有变少,甚至,反而更多了。更重要的是,这些创意以前仅仅是想一下,现在居然可以通过「自然语言编程」来实现。
我在视频号刷到不少和我年龄相当的互联网人士失业的视频,作为一个劳动密集型产业,这个行业自然是不缺年轻人的,尽管我们还有年轻的、炙热的好奇心,但无法改变 35 岁有可能失业的现状。
怎么办?我和自己说,靠自己。
上帝关上了一扇窗户,我们可以自己凿墙再开一扇。
文章中提到的链接
你可能会需要文章中提到的这些链接:
- Macify Chrome 扩展:https://knb.im/8wg
- MyIP: https://ipcheck.ing
- 躺平计算器: https://retire.money
- Bochana 咨询: https://bochana.com
隔年更
简单重复的工作我倒是更多地直接做成程序功能了。
编程方面的工作帮助一方面是语法翻译,比如我不熟悉js语法,以往每次写东西都需要一边查询语法一边写。现在直接伪代码或者写清需求,然后review加局部调整,就能得到不错的输出。
另一方面是一些一次性的代码,比如昨天为了定义页面布局,需要统计一堆图片的宽高比,然后输出统计图形,GPT就很快能给出可以直接运行的python。放在以前,这种场景就随便估一个了,毕竟这个代码也很少有复用的机会,写起来又有点麻烦。
代码以外的需求层的使用,最多是作为brain storm助手。很多偏文科的输出还是需要仔细确认,很容易出错。
不过翻译方面倒是很好,英文日文不在话下,连港澳台用词区别也能照顾到,场景语气也都不错。
[…] Ng 那么,我是如何使用 ChatGPT 的 https://kenengba.com/post/3800.html 他把 ChatGPT […]
博主的分享很有启发性。