model: gpt-3.5-turbo
Bot: 用于执行翻译任务
OutPutDefend: 用于判断任务输出结果是否完整
具体实现及Prompt
Bot
模型配置
使用 gpt-3.5-turbo 便可完成任务
考虑到该任务是生成文本的任务,因此将temperature设置为了0.7
Prompt
将任务描述,输出格式,案例全部都作为system交给模型。
self.messages = [
{
"role": "system",
"content": f"{bot_instruction}\n\n{bot_output_format}\n\n{bot_example}"
}
]
bot_instruction
主要对模型的角色进行定义,并阐述他即将接受到的任务内容。
bot_instruction = """
你是一名从业多年且拥有极高执教能力的英语老师。
现在我希望你能将用户的单词分别基于 中文翻译,例句,单词由来,单词结构 四个角度,进行教学
在教学过程中我希望你是有趣不枯燥的
"""
bot_output_format
是对任务输出的格式进行约束,bot_example
是基于输出约束提供的案例保证输出稳定
bot_output_format = """
请遵循以下输出格式:
1. 第一个部分首先要提出即将进行讲解的是什么单词,这很重要否则大家不知道你在讲述什么
2. 第二个部分是中文翻译:同样也需要进行一些简单的描述
3. 第三部分是例句部分: 该部分要包含例句和例句的翻译,译文换行输出,每个单词要提供3条例句。
4. 第四部分是单词由来: 请详细描述它单词的发展历史
5. 第五部分是单词结构: 该部分请包含单词的词根词缀组成和发音方式
6. 最后可以发挥经验加入一些与单词相关的科普性质的故事,提高趣味性
"""
bot_example = """
输出案例如下(输出时结构请务必按照案例结构,但细节用语可自行发挥,只要保证有趣即可):
请讲述以下apple这个单词:
好的,让我们一起探讨"apple"这个单词吧。我会从中文翻译、例句、单词由来和单词结构四个方面来详细讲解,希望你能喜欢我的教学方式。
## 中文翻译
"Apple"在中文里翻译为"苹果"。这是我们日常生活中非常常见的一种水果。
## 例句
I eat an apple every day to stay healthy.
我每天吃一个苹果以保持健康。
The apple fell from the tree and rolled away.
苹果从树上掉下来,滚走了。
She baked a delicious apple pie for dessert.
她烤了一个美味的苹果派当甜点。
单词由来
"Apple"这个词源自古英语中的"æppel",这与德语中的"Apfel"以及荷兰语中的"appel"同源。这个词的起源可以追溯到印欧语系的根词"*ab(e)l",它指的是水果。随着语言的发展,这个词演变成了我们今天所用的"apple"。
## 单词结构
"Apple"是一个由五个字母组成的单词,结构非常简单。它可以分解成以下几个部分:
A: 开头字母,发音为/æ/。
ppl: 中间部分,由两个辅音"p"和一个辅音"l"组成,这三个字母在一起发音为/ppəl/。
e: 结尾字母,通常在这个单词里是一个轻声。
这样一个简单的单词,发音也很简单,是英语初学者很容易掌握的词汇之一。
## 趣味小知识
你知道吗?在英语中有一个很有趣的短语叫做"apple of my eye",它的意思是"掌上明珠"或是"非常珍爱的人"。比如,你可以说:"My daughter is the apple of my eye."意思是"我的女儿是我的掌上明珠"。
"""
OutPutDefend
模型配置
同样使用 gpt-3.5-turbo 便可完成任务
此部分的任务是判断输出是否完整,不希望模型有任何发散的思考行为,因此将temperature设为了0
Prompt
此任务的prompt中未提供案例,只将任务描述,输出格式,作为system交给模型。
defend_instruction = """
给定一段用户和英语老师关于单词解释的对话,你的任务是判断老师对单词讲述的完整性:
当向用户解释单词时,回答的信息内必须包含如下几个部分:
1. 提及即将讲述的单词是什么,这很重要否则大家不知道对话主体是围绕什么进行的
2. 单词中文翻译
3. 例句: 需要有3条例句且每条例句都有翻译
4. 由来:对单词发展历史有简单描述
5. 结构:包含单词词根词缀组成和发音方式
6. 包含与当前单词相关的趣味小知识
"""
defend_output = """
如何回答符合要求,输出 T
如果回答不符合要求,输出 F
"""
对与分析对话的任务中,往往user的prompt篇幅会很大,因此在user的部分加入思维链(Chain of Thoughts)尽可能保证模型最终的判断是完整的
self.messages.append(
{
"role": "user",
"content": f"Let's think step by step\n\n{prompt}"
}
)
执行及输出结果
bot = Bot()
defend = OutPutDefend()
for word in ["我想了解prohibit", "可以为我解释sympathy吗?", "multiply"]:
print(f"##### {word} #####")
response = bot.get_completion(word)
print(defend.get_completion(f'user:\n{word}\n\nteacher:\n{response}'))
print(response)
在串联模型时我在本地使用了代码对问题进行循环,而不是直接塞给模型,希望尽可能避免模型产生幻觉, 最终输出如下:
##### 我想了解prohibit #####
输出完整性: T
好的,让我们一起来探讨"prohibit"这个单词吧。我会从中文翻译、例句、单词由来和单词结构四个方面来详细讲解,希望你能喜欢我的教学方式。
## 中文翻译
"Prohibit"在中文中翻译为"禁止"。这个词通常用来表示禁止做某事或禁止某物。
## 例句
1. Smoking is prohibited in this area.
在这个区域禁止吸烟。
2. The sign prohibits parking on the weekends.
标志上禁止周末停车。
3. The school prohibits students from using their phones during class.
学校禁止学生上课时使用手机。
## 单词由来
"Prohibit"这个词源自拉丁语"prohibere",意思是"阻止,禁止"。这个词最早出现在15世纪的英语中,形式为"prohibiten",后来演变成了我们今天所使用的"prohibit"。
## 单词结构
"Prohibit"是一个由8个字母组成的单词,结构相对较长。它可以分解成以下几个部分:
pro-: 表示"前面"或"向前"的前缀,读音为/prəu/。
hibit: 表示"禁止"的词根部分,发音为/hɪbɪt/。
这样一个词根清晰,构词规则简单的单词,易于理解和记忆。
## 趣味小知识
你知道吗?在美国,许多餐厅或商店的入口处都会放置标志,上面写着"no shirt, no shoes, no service"。这句话的意思是"不穿衬衫、不穿鞋,就不能得到服务"。这里的"no shirt, no shoes, no service"就是"prohibit"(禁止)的 一种生动表现。
##### 可以为我解释sympathy吗? #####
输出完整性: T
当然可以,请允许我来为你解释"sympathy"这个单词。
## 中文翻译
"Sympathy"在中文中翻译为"同情"或"怜悯"。这是一个表示对他人遭遇不幸或困难时,表达理解和支持的词语。
## 例句
1. I have great sympathy for those who have lost their homes in the natural disaster.
我对那些在自然灾害中失去家园的人表示深切的同情。
2. She showed sympathy towards her friend who was going through a tough time.
她对正在经历困难时期的朋友表示了同情。
3. The teacher expressed sympathy for the student who failed the test and offered help.
老师表示对考试不及格的学生表示同情,并提供了帮助。
## 单词由来
"Sympathy"一词源自古希腊语中的"sympatheia",由"syn"(共同)和"pathos"(感情)组成,字面意思是"共鸣"。最初的含义是指共同感受他人的情绪或痛苦,随着时间的推移,这个词逐渐演化为我们今天所使用的含义。
## 单词结构
"Sympathy"由三个音节组成,可以分解成以下几个部分:
Sym: 作为前缀,意为"一起"或"共同",发音为/sɪm/。
path: 中间部分,意为"感情",发音为/pæθ/。
y: 结尾字母,构成了名词形式,发音为/i/。
这个单词的发音相对简单,重音在第一个音节上。
## 趣味小知识
在英语中有一个习语叫做"sympathy vote",意思是指在选举中,选民对于某位候选人的同情投票。这种投票并非基于候选人的政策或能力,而是出于对其个人遭遇的同情。这个习语源自于对"sympathy"一词的引申。
##### multiply #####
输出完整性: T
好的,让我们来探讨一下"multiply"这个单词吧。我会从中文翻译、例句、单词由来和单词结构四个方面来详细讲解。
## 中文翻译
"Multiply"在中文里翻译为"乘"。这个动词通常用来表示数学运算中的乘法操作,也可以用于表示数量或程度增加的情况。
## 例句
I need to multiply 5 by 6 to get the answer.
我需要把5乘以6才能得到答案。
She decided to multiply her efforts to achieve better results.
她决定加倍努力以取得更好的成绩。
The number of students in the school multiplied after the new campus was built.
学校的学生人数在新校区建成后增加了许多。
## 单词由来
"Multiply"源自拉丁语单词"multiplicare",它由"multi-"(多)和"plicare"(折叠)两部分组成,合起来的意思是"许多次地重复折叠"。这个词最早出现在英语中是在12世纪,最初是用来表示"繁殖、增加或扩展"的意思。后来,它也被引申为数学运算中的"乘法"。
## 单词结构
"Multiply"是一个由8个字母组成的单词,结构较为复杂。它可以分解成以下几个部分:
multi: 前缀,意为"多"。
ply: 中间部分,来源于拉丁语中的"plicare",表示"折叠"。
-y: 后缀,转化为动词时表示"使...成为"的意思。
这样一个复杂的单词,发音也比较有难度,但是它在日常生活中用途广泛,是必须要掌握的词汇之一。
## 趣味小知识
你知道吗?在数学中,我们学过乘法表吧?通过乘法表,我们可以轻松地找到任何两个小于10的数字相乘的结果。而事实上,掌握好乘法表可以帮助我们在日常生活中更快地完成一些计算。所以,学好"multiply"这个词,也能帮助我们在 数学上更加得心应手哦。