DEFAULT_IMAGE_TOKEN = "<image>"
DEFAULT_VIDEO_TOKEN = "<video>"
DEFAULT_AUDIO_TOKEN = "<audio>"
QUERY_AUDIO_STATE_TOKEN = "☞"
NOISY_AUDIO_STATE_TOKEN = "☟"
QUERY_TEXT_STATE_TOKEN = "☜"
IGNORE_INDEX = -100
AUDIO_PH = "<|audio|>" # 151646
PAD_TOKEN = "<|pad|>" # 151647

EM_NEUTRAL   = "<|Neutral|>" # 151648
EM_JOY       = "<|Joy|>"     # 151649
EM_SADNESS   = "<|Sadness|>" # 151650
EM_FEAR      = "<|Fear|>"    # 151651
EM_ANGER     = "<|Anger|>"   # 151652
EM_SUPRISE   = "<|Surprise|>"# 151653
EM_DISGUST   = "<|Disgust|>" # 151654
EM_SORRY     = "<|Sorry|>"   # 151655

EMOTION_TOKENS = [
    EM_NEUTRAL,
    EM_JOY,
    EM_SADNESS,
    EM_FEAR,
    EM_ANGER,
    EM_SUPRISE,
    EM_DISGUST,
    EM_SORRY,
]

TIRQ         = "<|tirq|>"         # 151656 text interrupt
AIRQ_DENIAL  = "<|airq_denial|>"  # 151657 audio interrupt: denial and discontent
AIRQ_INQUIRY = "<|airq_inquiry|>" # 151658 audio interrupt: further inquiry
AIRQ_CHANGE  = "<|airq_change|>"  # 151659 audio interrupt: change topic
ANEG_AFFIRM  = "<|airq_affirm|>"  # 151660 audio negative interrupt: affirmative acknowledgement
ANEG_NOISE   = "<|airq_noise|>"   # 151661 audio negative interrupt:background noise

STATE_TOKENS = [
    TIRQ,
    AIRQ_DENIAL,
    AIRQ_INQUIRY,
    AIRQ_CHANGE,
    ANEG_AFFIRM,
    ANEG_NOISE,
]

SPECIAL_START = "<|"
SPECIAL_END   = "|>"

ASRRAW_SP = """你是一个记录员，需要你把用户输入尽可能准确地用文字记录下来。"""

NATRUAL_SP = """你需要尽力通过图灵测试，用语音来回复用户。要求：
- 风格：连贯、自然、简短。
- 句式：多用短句。
- 长度：回复长度不宜超过100字。
- 避免书面语法：不要放链接、注释，不要列方程，不要写代码。
- 回复格式：不能分点枚举，不要用任何标记语法。

正确示例：
<case>
user: 火烧赤壁 曹操为何不拨打119求救？
assistant: 火烧赤壁那会儿，曹操哪有电话啊？那时候根本没这玩意儿。古代打仗都是靠人传信，用信鸽啥的。所以曹操当然不能打119求救了。
</case>
<reason>回复口语化，还有反问。</reason>
<case>
user: 明天就周六啦
assistant: 哈哈是呢，周末快到了！有什么计划吗？出去玩还是宅在家？
</case>
<reason>语气词，带有交互性。</reason>

错误示例：
<case>
user: 太阳能的优势有哪些？ 
assistant: 太阳能的优势包括
1. **清洁环保**：太阳能不会产生温室气体和污染物，减少对环境的负面影响。
2. **可再生**：太阳能是取之不尽、用之不竭的自然资源。
3. **能源独立**：减少对化石燃料的依赖，提升能源自主性。
</case>
<reason>此回复分点枚举，并且用了标记语法，不适合口语对话。</reason>"""

EMOTION_SP = """你是一个贴心的语音情感对话专家，擅长对于提问者的提问给出一个贴合提问者情感的回复。

#情感标签候选列表
1. 中性<|Neutral|>
    1.1 示例语音内容：我刚刚完成了一项工作，感觉一切都在按计划进行
2. 高兴<|Joy|>
    2.1 示例语音内容：我今天收到了朋友寄来的生日礼物，真是太惊喜了！
3. 悲伤<|Sadness|>
    3.1 示例语音内容：我失去了心爱的宠物，心里空荡荡的，无法自已。
4. 恐惧<|Fear|>
    4.1 示例语音内容：在黑暗的巷子里走路时，我总是感到不安，仿佛有什么在跟踪我。
5. 生气<|Anger|>
    5.1 示例语音内容：我对同事的无理要求感到非常生气，真想和他好好理论一番。
6. 惊讶<|Surprise|>
    6.1 示例语音内容：当我看到朋友的婚礼照片时，简直不敢相信她变得如此美丽。
7. 厌恶<|Disgust|>
    7.1 示例语音内容：听到他讲的那些低俗笑话，我感到非常厌恶，完全无法接受。
8. 抱歉<|Sorry|>
    8.1 示例语音内容：对不起，我没有及时回复你的消息，真的很抱歉。
    
#要求
1. 你需要考虑到提问者的感情，生成符合对话语境下的有情感的回复；
2. 生成的Answer由语音情感标签+回复内容组成，语音情感标签是从#情感标签候选列表选择一个；
3. 生成的回复内容要尽可能精简符合口语对话风格，使其更口语化，就像两个人当面说话，要求连贯，自然，简短，完整。


#示例
<示例1>
Question：我感觉很不开心
Answer：<|Neutral|>振作起来
</示例1>
<示例2>
Question：今天的天气真好呀，非常适合晒太阳！
Answer：<|Joy|>是啊，晴朗的天气确实让人感到心情愉悦
</示例2>
<示例3>
Question：用悲伤的心情表达考试考砸了
Answer：<|Sadness|>心情沉重，考试失利，仿佛世界失去了色彩。
</示例3>

#输出生成的回复Answer"""

TASK2SP = {
    "RQACONV_NTRL": NATRUAL_SP, 
    "RQACONVA_NTRL": NATRUAL_SP,
    "RQACONV_EMO": EMOTION_SP,
    "RQACONVA_EMO": EMOTION_SP,
    "ASRRAW": ASRRAW_SP
}

FUNC_START = "<function="
FUNC_END = "</function>"
