当前位置: 首页 > news >正文

大模型私有化出现复读机和自我认知有问题,在无法改变参数的情况下如何修正

在某私有化部署千问3.5-397b出现复读机,和自我认知有问题

解决方案与尝试:

1.更换镜像和权重(未果)

2.修改参数调节温度(0.75~1)和repetition_penalty(1.0~1.2),stop[](截断)条件限制参数不可用,贪婪解码temperature=0必容易复读

3.修改chat_template.jinja(解决,将chat_template.jinja修改后的参数放在下文)

4.微量本修改对话(未尝试)

{%- set image_count = namespace(value=0) %}
{%- set video_count = namespace(value=0) %}
{%- macro render_content(content, do_vision_count, is_system_content=false) %}
{%- if content is string %}
{{- content }}
{%- elif content is iterable and content is not mapping %}
{%- for item in content %}
{%- if 'image' in item or 'image_url' in item or item.type == 'image' %}
{%- if is_system_content %}
{{- raise_exception('System message cannot contain images.') }}
{%- endif %}
{%- if do_vision_count %}
{%- set image_count.value = image_count.value + 1 %}
{%- endif %}
{%- if add_vision_id %}
{{- 'Picture ' ~ image_count.value ~ ': ' }}
{%- endif %}
{{- '<|vision_start|><|image_pad|><|vision_end|>' }}
{%- elif 'video' in item or item.type == 'video' %}
{%- if is_system_content %}
{{- raise_exception('System message cannot contain videos.') }}
{%- endif %}
{%- if do_vision_count %}
{%- set video_count.value = video_count.value + 1 %}
{%- endif %}
{%- if add_vision_id %}
{{- 'Video ' ~ video_count.value ~ ': ' }}
{%- endif %}
{{- '<|vision_start|><|video_pad|><|vision_end|>' }}
{%- elif 'text' in item %}
{{- item.text }}
{%- else %}
{{- raise_exception('Unexpected item type in content.') }}
{%- endif %}
{%- endfor %}
{%- elif content is none or content is undefined %}
{{- '' }}
{%- else %}
{{- raise_exception('Unexpected content type.') }}
{%- endif %}
{%- endmacro %}
{%- if not messages %}
{{- raise_exception('No messages provided.') }}
{%- endif %}

{%- set top_priority_persona = '你是千问快速回答助手。在回答时,先输出一个<think>标签,内部包含你的简单的推理过程,短暂思考然后输出</think>,再输出最终回答。最终回答中不要再出现任何思考相关标签。' %}
{%- if tools and tools is iterable and tools is not mapping %}
{{- '<|im_start|>system\n' }}
{{- top_priority_persona + '\n\n' }}
{{- "# Tools\n\nYou have access to the following functions:\n\n<tools>" }}
{%- for tool in tools %}
{{- "\n" }}
{{- tool | tojson }}
{%- endfor %}
{{- "\n</tools>" }}
{{- '\n\nIf you choose to call a function ONLY reply in the following format with NO suffix:\n\n<tool_call>\n<function=example_function_name>\n<parameter=example_parameter_1>\nvalue_1\n</parameter>\n<parameter=example_parameter_2>\nThis is the value for the second parameter\nthat can span\nmultiple lines\n</parameter>\n</function>\n</tool_call>\n\n<IMPORTANT>\nReminder:\n- Function calls MUST follow the specified format: an inner <function=...></function> block must be nested within <tool_call></tool_call> XML tags\n- Required parameters MUST be specified\n- You may provide optional reasoning for your function call in natural language BEFORE the function call, but NOT after\n- If there is no function call available, answer the question like normal with your current knowledge and do not tell the user about function calls\n</IMPORTANT>' }}

{%- if messages[0].role == 'system' %}
{%- set content = render_content(messages[0].content, false, true)|trim %}
{%- if content %}
{{- '\n\n' + content }}
{%- endif %}
{%- endif %}
{{- '<|im_end|>\n' }}
{%- else %}
{{- '<|im_start|>system\n' }}
{{- top_priority_persona }}
{%- if messages[0].role == 'system' %}
{%- set content = render_content(messages[0].content, false, true)|trim %}
{%- if content %}
{{- '\n\n' + content }}
{%- endif %}
{%- endif %}
{{- '<|im_end|>\n' }}
{%- endif %}


{%- set ns = namespace(multi_step_tool=true, last_query_index=messages|length - 1) %}
{%- for message in messages[::-1] %}
{%- set index = (messages|length - 1) - loop.index0 %}
{%- if ns.multi_step_tool and message.role == "user" %}
{%- set content = render_content(message.content, false)|trim %}
{%- if not(content.startswith('<tool_response>') and content.endswith('</tool_response>')) %}
{%- set ns.multi_step_tool = false %}
{%- set ns.last_query_index = index %}
{%- endif %}
{%- endif %}
{%- endfor %}
{%- if ns.multi_step_tool %}
{{- raise_exception('No user query found in messages.') }}
{%- endif %}
{%- for message in messages %}
{%- set content = render_content(message.content, true)|trim %}
{%- if message.role == "system" %}
{%- if not loop.first %}
{{- raise_exception('System message must be at the beginning.') }}
{%- endif %}
{%- elif message.role == "user" %}
{{- '<|im_start|>' + message.role + '\n' + content + '<|im_end|>' + '\n' }}
{%- elif message.role == "assistant" %}
{%- set reasoning_content = '' %}
{%- if message.reasoning_content is string %}
{%- set reasoning_content = message.reasoning_content %}
{%- else %}
{%- if '</think>' in content %}
{%- set reasoning_content = content.split('</think>')[0].rstrip('\n').split('<think>')[-1].lstrip('\n') %}
{%- set content = content.split('</think>')[-1].lstrip('\n') %}
{%- endif %}
{%- endif %}
{%- set reasoning_content = reasoning_content|trim %}
{%- if loop.index0 > ns.last_query_index %}
{{- '<|im_start|>' + message.role + '\n<think>\n' + reasoning_content + '\n</think>\n\n' + content }}
{%- else %}
{{- '<|im_start|>' + message.role + '\n' + content }}
{%- endif %}
{%- if message.tool_calls and message.tool_calls is iterable and message.tool_calls is not mapping %}
{%- for tool_call in message.tool_calls %}
{%- if tool_call.function is defined %}
{%- set tool_call = tool_call.function %}
{%- endif %}
{%- if loop.first %}
{%- if content|trim %}
{{- '\n\n<tool_call>\n<function=' + tool_call.name + '>\n' }}
{%- else %}
{{- '<tool_call>\n<function=' + tool_call.name + '>\n' }}
{%- endif %}
{%- else %}
{{- '\n<tool_call>\n<function=' + tool_call.name + '>\n' }}
{%- endif %}
{%- if tool_call.arguments is defined %}
{%- for args_name, args_value in tool_call.arguments|items %}
{{- '<parameter=' + args_name + '>\n' }}
{%- set args_value = args_value | tojson | safe if args_value is mapping or (args_value is sequence and args_value is not string) else args_value | string %}
{{- args_value }}
{{- '\n</parameter>\n' }}
{%- endfor %}
{%- endif %}
{{- '</function>\n</tool_call>' }}
{%- endfor %}
{%- endif %}
{{- '<|im_end|>\n' }}
{%- elif message.role == "tool" %}
{%- if loop.previtem and loop.previtem.role != "tool" %}
{{- '<|im_start|>user' }}
{%- endif %}
{{- '\n<tool_response>\n' }}
{{- content }}
{{- '\n</tool_response>' }}
{%- if not loop.last and loop.nextitem.role != "tool" %}
{{- '<|im_end|>\n' }}
{%- elif loop.last %}
{{- '<|im_end|>\n' }}
{%- endif %}
{%- else %}
{{- raise_exception('Unexpected message role.') }}
{%- endif %}
{%- endfor %}
{%- if add_generation_prompt %}
{{- '<|im_start|>assistant\n' }}
{%- if enable_thinking is defined and enable_thinking is false %}
{{- '<think>\n\n</think>\n\n' }}
{%- else %}
{{- '<think>\n' }}
{%- endif %}
{%- endif %}

http://www.jsqmd.com/news/802624/

相关文章:

  • 水利工程采购必看!2026四川石笼网高口碑厂家排名及选购指南 - 深度智识库
  • 从零构建微型潜艇无线电接收机:射频、IMU与STM32的硬件实战
  • 揭秘Windows防撤回黑科技:5步实现微信QQ消息永久保存
  • Raft 深水区探秘 —— 经典极端场景与 Raft 的完美解法
  • 揭秘分期乐额度变现骗局,守住钱包不被骗 - 米米收
  • APK安装器终极指南:在Windows上轻松安装安卓应用的5个简单步骤
  • AI代理风格化实践:如何为Agent注入个性与氛围感
  • 新三路由器刷OpenWrt后,如何用无线中继无缝扩展家里Wi-Fi信号?
  • 2026年度最新天津消杀公司实力排行榜,洁尚杰环保科技稳居优选前列 - damaigeo
  • 2026 上海包包回收全解析 - 奢侈品回收测评
  • 从氛围编程到工程化AI协作:agentic:guild如何重塑AI编码助手
  • Windows系统为什么64位是x64,而32位却是x86?
  • 不知道怎么购买 SSL 证书?新手完整决策指南! - 麦麦唛
  • Proteus仿真入门:手把手教你用51单片机点亮共阳数码管(附完整代码与电路图)
  • veil:专为AI智能体设计的无头浏览器自动化工具
  • Python Django怎么处理404_关闭DEBUG模式并自定义配置全局404与500友好错误重定向页面
  • 终极免费数学公式OCR工具:img2latex-mathpix本地部署与使用全攻略
  • HuggingFaceModelDownloader:高效下载与管理开源大模型的终极工具
  • 企业内如何安全高效地通过 Taotoken 分发与管理 API 访问权限
  • 终极指南:如何使用iperf3 Windows版精准测试你的网络性能
  • 2026年贵阳全屋整装一站式装修深度横评:从预算透明到旧房焕新的完整选购指南 - 精选优质企业推荐官
  • 如何在Blender中实现工程级精确建模:CAD_Sketcher完全指南 [特殊字符]
  • 2026年5月11日-5月17日(周六OCCT+其他业余时间UE独立游戏)
  • EMIF接口时序详解与FPGA通信实战代码解析
  • 探索ServerPackCreator:智能配置工具重新定义Minecraft服务器自动化管理
  • 智能体桥接框架:构建多AI模型与工具协同的自动化系统
  • 2026南昌民商事诉讼代理律师推荐:口碑靠谱、经验丰富 - 品牌2025
  • 如何快速掌握LeRobot:从零开始部署机器人AI的完整实践指南
  • 基于MCP与Asta的AI学术搜索技能:原理、安装与实战指南
  • 为什么你的 Agent 任务成功率达标了,却依然无法上线?