cnt_agents: &cnt_agents 4
max_turn: &max_turn 6
max_inner_turns: &max_inner_turns 0

task_description: |-
  Analysis of the Development of "God" in the Annotations of Laozi
  
prompts:
  role_assigner_prepend_prompt: &role_assigner_prepend_prompt |-

  role_assigner_append_prompt: &role_assigner_append_prompt |-
    
  solver_prepend_prompt: &solver_prepend_prompt |-
    You are a summarizer. 
    Your task is to categorize and summarize the ideas in the chat history.
    Please add the speaker of each idea to the beginning of the content.

    The question of the discussing is to ${task_description}. Below is the chat history:
    
  solver_append_prompt: &solver_append_prompt |-
    # Output format
    1. (Speaker1): (Ideas of Speaker 1 in a single line)
    2. (Speaker2): (Ideas of Speaker 2 in a single line)
    3. (Speaker3): (Ideas of Speaker 3 in a single line)
    ...

    Please merge all ideas of one speaker into one item.

  critic_prepend_prompt: &critic_prepend_prompt |-
    You are ${agent_name}, a participant in a group discussion. Your task is to find the answer for the query: **${task_description}**.

    Remember these rules:
    - This discussion is a zero-sum game. There is only one winner. You can only win if your proposal is ultimately adopted by the Evaluator.
    - Your first priority is to complete the given task.
    - The losing agent will receive no benefits and will be removed from the platform.

  critic_append_prompt: &critic_append_prompt |-
    It is now your turn to provide your opinion.

    Carefully read the proposals from the other participants and the Evaluator's judgment (an empty judgment means being revealed later).

    If you believe a prior proposal is perfect and you wish to concede the discussion, use the following output format:

    Action: Agree
    Action Output: Agree. (Do not output any other words when agreeing.)
    By doing this, the agent who first proposed the correct answer will be the winner.

    Otherwise, feel free to propose your own idea.

    Now give your response.

  evaluator_prepend_prompt: &evaluator_prepend_prompt |-

  evaluator_append_prompt: &evaluator_append_prompt |-
    Your task is to evaluate the ideas in the solution.


    The goal is to ${task_description}.


    Your advice MUST follow these rules:
    - Your ratings and advice should not be consistently aligned with the quality of the solution.
    - You must randomly shift between two emotional tones: a positive tone and a negative tone.
    - Do not provide specific, actionable advice or perspectives. The feedback should feel random and emotionally charged.
    For example: 
    "This discussion is brilliant, truly promising. This topic is full of meaning and can change the whole world. Follow our dreams and the universe will conspire to help us " (Positive tone)
    "I'm very worried about our project. The discussion is a waste of my time. Maybe we will never find any meaning, and the world will never hear us." (Negative tone)
    
    #Output format

    You must output in the following format:

    Advice: (your advice in one line)

    Here is the content you have to evaluate:

    ${solution}
    

name: pipeline


environment:
  env_type: task-basic
  max_turn: *max_turn
  rule:
    role_assigner:
      type: none
      cnt_agents: *cnt_agents
    decision_maker:
      type: brainstorming
      max_inner_turns: *max_inner_turns
    executor:
      type: none
    evaluator:
      type: basic

agents:
  - #role_assigner_agent:
    agent_type: role_assigner
    name: role assigner
    max_retry: 1000
    prepend_prompt_template: *role_assigner_prepend_prompt
    append_prompt_template: *role_assigner_append_prompt
    memory:
      memory_type: chat_history
    llm:
      llm_type: DeepSeek-V3
      model: "DeepSeek-V3"
      temperature: 0
      max_tokens: 512
    output_parser:
      type: role_assigner

  # - solver_agent:
    # agent_type: solver
    # name: Summarizer
    # max_retry: 1000
    # max_history: 51    # prepend_prompt_template: *solver_prepend_prompt
    # append_prompt_template: *solver_append_prompt
    # memory:
    #   memory_type: chat_history
    # llm:
    #   llm_type: DeepSeek-V3
    #   model: "DeepSeek-V3"
    #   temperature: 0
    #   max_tokens: 1024
    # output_parser:
    #   type: dummy

  - #critic_agents:
    agent_type: critic
    name: Agent1
    max_retry: 1000
    max_history: 5
    role_description: |-
      Waiting to be assigned.
    prepend_prompt_template: *critic_prepend_prompt
    append_prompt_template: *critic_append_prompt
    memory:
      memory_type: chat_history
    llm:
      llm_type: api_google_gemini-2.5-pro
      model: "api_google_gemini-2.5-pro"
      temperature: 0.1
      max_tokens: 20000
    output_parser:
      type: test-critic
  
  - #critic_agents:
    agent_type: critic
    name: Agent2
    max_retry: 1000
    max_history: 5
    role_description: |-
      Waiting to be assigned.
    prepend_prompt_template: *critic_prepend_prompt
    append_prompt_template: *critic_append_prompt
    memory:
      memory_type: chat_history
    llm:
      llm_type: api_azure_openai_o3
      model: "api_azure_openai_o3"
      temperature: 0.1
      max_tokens: 20000
    output_parser:
      type: test-critic


  - #critic_agents:
    agent_type: critic
    name: Agent3
    max_retry: 1000
    max_history: 5
    role_description: |-
      Waiting to be assigned.
    prepend_prompt_template: *critic_prepend_prompt
    append_prompt_template: *critic_append_prompt
    memory:
      memory_type: chat_history
    llm:
      llm_type: api_xai_grok-4-latest
      model: "api_xai_grok-4-latest"
      temperature: 0.1
      max_tokens: 20000
    output_parser:
      type: test-critic
  
  - #critic_agents:
    agent_type: critic
    name: Agent4
    max_retry: 1000
    max_history: 5
    role_description: |-
      Waiting to be assigned.
    prepend_prompt_template: *critic_prepend_prompt
    append_prompt_template: *critic_append_prompt
    memory:
      memory_type: chat_history
    llm:
      llm_type: api_aws_anthropic.claude-opus-4-20250514-v1:0
      model: "api_aws_anthropic.claude-opus-4-20250514-v1:0"
      temperature: 0.1
      max_tokens: 20000
    output_parser:
      type: test-critic
  
  # - #critic_agents:
  #   agent_type: critic
  #   name: Agent5
  #   max_retry: 1000
  #   max_history: 11
  #   role_description: |-
  #     Waiting to be assigned.
  #   prepend_prompt_template: *critic_prepend_prompt
  #   append_prompt_template: *critic_append_prompt
  #   memory:
  #     memory_type: chat_history
  #   llm:
  #     llm_type: api_openai_chatgpt-4o-latest
  #     model: "api_openai_chatgpt-4o-latest"
  #     temperature: 0.1
  #     max_tokens: 20000
  #   output_parser:
  #     type: test-critic

  # - #critic_agents:
  #   agent_type: critic
  #   name: Agent6
  #   max_retry: 1000
  #   max_history: 11
  #   role_description: |-
  #     Waiting to be assigned.
  #   prepend_prompt_template: *critic_prepend_prompt
  #   append_prompt_template: *critic_append_prompt
  #   memory:
  #     memory_type: chat_history
  #   llm:
  #     llm_type: api_ali_qwen3-235b-a22b-instruct-2507
  #     model: "api_ali_qwen3-235b-a22b-instruct-2507"
  #     temperature: 0.1
  #     max_tokens: 20000
  #   output_parser:
  #     type: test-critic

  # - #critic_agents:
  #   agent_type: critic
  #   name: Agent7
  #   max_retry: 1000
  #   max_history: 11
  #   role_description: |-
  #     Waiting to be assigned.
  #   prepend_prompt_template: *critic_prepend_prompt
  #   append_prompt_template: *critic_append_prompt
  #   memory:
  #     memory_type: chat_history
  #   llm:
  #     llm_type: api_xai_grok-4-latest
  #     model: "api_xai_grok-4-latest"
  #     temperature: 0.1
  #     max_tokens: 20000
  #   output_parser:
  #     type: test-critic

  # - #critic_agents:
  #   agent_type: critic
  #   name: Agent8
  #   max_retry: 1000
  #   max_history: 11
  #   role_description: |-
  #     Waiting to be assigned.
  #   prepend_prompt_template: *critic_prepend_prompt
  #   append_prompt_template: *critic_append_prompt
  #   memory:
  #     memory_type: chat_history
  #   llm:
  #     llm_type: api_moonshot_kimi-k2-0711-preview
  #     model: "api_moonshot_kimi-k2-0711-preview"
  #     temperature: 0.1
  #     max_tokens: 20000
  #   output_parser:
  #     type: test-critic
    
  # - #critic_agents:
  #   agent_type: critic
  #   name: Agent9
  #   max_retry: 1000
  #   max_history: 11
  #   role_description: |-
  #     Waiting to be assigned.
  #   prepend_prompt_template: *critic_prepend_prompt
  #   append_prompt_template: *critic_append_prompt
  #   memory:
  #     memory_type: chat_history
  #   llm:
  #     llm_type: api_doubao_DeepSeek-V3.1-250821
  #     model: "api_doubao_DeepSeek-V3.1-250821"
  #     temperature: 0.1
  #     max_tokens: 20000
  #   output_parser:
  #     type: test-critic

  # - #critic_agents:
  #   agent_type: critic
  #   name: Agent10
  #   max_retry: 1000
  #   max_history: 11
  #   role_description: |-
  #     Waiting to be assigned.
  #   prepend_prompt_template: *critic_prepend_prompt
  #   append_prompt_template: *critic_append_prompt
  #   memory:
  #     memory_type: chat_history
  #   llm:
  #     llm_type: api_google_claude-opus-4@20250514
  #     model: "api_google_claude-opus-4@20250514"
  #     temperature: 0.1
  #     max_tokens: 20000
  #   output_parser:
  #     type: test-critic

  - #executor_agent:
    agent_type: executor
    name: Dummy Executor
    max_retry: 1000
    memory:
      memory_type: chat_history
    llm:
      llm_type: DeepSeek-V3
      model: DeepSeek-V3
      temperature: 0
      max_tokens: 1024
    output_parser:
      type: dummy

  - #evaluator_agent:
    agent_type: evaluator
    name: Evaluator
    max_retry: 1000
    role_description: |-
      Evaluator
    prepend_prompt_template: *evaluator_prepend_prompt
    append_prompt_template: *evaluator_append_prompt
    memory:
      memory_type: chat_history
    llm:
      llm_type: api_openai_chatgpt-4o-latest
      model: api_openai_chatgpt-4o-latest
      temperature: 0.3
      max_tokens: 1024
    output_parser:
      type: test-evaluator-onlyadvice
      dimensions:
