# ACD task generation settings
# acd:
# Task directory configuration
seed_tasks_dir: "ACD/seed_tasks"
tasks_output_dir: "${output_dir}/generated_tasks" # General output for ACD related files if needed elsewhere
template_dir: "ACD/templates"
initial_pool_size: 300 # Number of tasks to generate initially, 500

# Task adaptation parameters
max_pool_size: 250
task_generation_interval: 5  # Generate new tasks every N generations
validation_interval: 10      # Validate on held-out tasks every N generations
new_tasks_per_generation: 150  # Number of new tasks to generate each time
num_initialization_workers: 128 # Number of parallel workers for initial pool generation (null = cpu_count)
num_adaptation_workers: 128   # Number of parallel workers for task adaptation (null = cpu_count)
num_sandbox_workers: 16
# num_sandbox_workers: 4

# Task difficulty settings
initial_difficulty: 0.5
initial_complexity: 0.3
difficulty_threshold_easy: 0.5  # Tasks with pass rate > this are considered easy
difficulty_threshold_hard: 0.  # Tasks with pass rate < this are considered hard
validation_split: 0.2

# Stopping criteria for model generation
stop_token_ids: ${model_stop_token_ids} # EOS tokens for the merged models

# Docker sandbox configuration
docker_enabled: true         # Use Docker for secure task execution
docker_image: "python:3.11-slim"
docker_cpu_limit: 1.0        # CPU cores allocation limit
docker_memory_limit: "512m"  # Memory limit
docker_timeout: 30           # Maximum execution time in seconds
docker_network_enabled: false # Whether to allow network access
docker_writable_fs: false    # Whether to allow write access to the filesystem
docker_max_retries: 3        # Maximum number of retries for Docker operations
docker_initial_backoff: 1.0  # Initial backoff time for retries (seconds)

# Docker security and resource limits
docker_security_level: "high"  # Security level (low, medium, high)
docker_additional_mounts: []   # Additional volume mounts [(src, dst), ...]
docker_pid_limit: 50           # Maximum number of processes
docker_ulimit_nproc: 20        # Process limit for user
docker_ulimit_nofile: 64       # File descriptors limit
docker_ulimit_cpu: 10          # CPU time limit in seconds
docker_memory_reservation: "256m"  # Memory reservation

# LLM configuration for task generation and evaluation
# For scientist model, we use a locally running vLLM server
# For subject model, we use a model from the population
scientist_model: "vllm/Qwen/Qwen2.5-72B-Instruct"  # Model identifier (can be ACD standard or vllm/...)
# scientist_model: "vllm/Qwen/Qwen3-235B-A22B-Instruct-2507"  # Model identifier (can be ACD standard or vllm/...)
task_creation_prompt_name: "task_creation_system_msg" # Name of the prompt variable in dns.
# task_creation_prompt_name: "task_creation_system_msg_no_judge" # Name of the prompt variable in dns.
use_subject_model_from_population: true  # Use a model from the population as subject model

# vLLM server configuration for scientist model
vllm_enabled: true                # Whether to use vLLM for the scientist model
vllm_model_path: "meta-llama/Meta-Llama-3-8B-Instruct"  # Model name/path for reference
vllm_server_host: "your IP address"     # Host where vLLM server is running
vllm_server_port: 8001            # Port where vLLM server is running
scientist_vllm_url: "http://${acd.vllm_server_host}:${acd.vllm_server_port}/v1" # Base URL for vLLM OpenAI API
vllm_max_retries: 5               # Maximum number of retries for vLLM operations
vllm_retry_delay: 1.0             # Delay between retries in seconds
vllm_timeout: 60                  # Timeout for vLLM requests in seconds
vllm_max_tokens: 2000             # Maximum tokens for task generation
vllm_temperature: 0.7             # Temperature for task generation
vllm_top_p: 0.95                  # Top-p sampling parameter

# Dummy BC parameters for ACDTask adapter
acd_bc_num_dims: 1
acd_bc_min_vals: [0.0]
acd_bc_max_vals: [1.0]
acd_bc_grid_sizes: [10]