import os

import httpcore
import httpx
from google import genai

# Netlist constants
MAX_NUM_NODES = 256

# CT format benchmarks (pb.txt format, use get_dreamplace_params not bookshelf)
# These are ungrouped but need CT DREAMPlace flow
CT_FORMAT_BENCHMARKS = {"ariane133", "ariane136"}
BENCHMARK_EPISODE_LENGTHS = {
        "adaptec1": 63,
        "adaptec2": 127,
        'adaptec3': 58,
        'adaptec4': 69,
        'bigblue1': 32,
        'bigblue2': 256,
        'bigblue3': 256,
        'bigblue4': 199,
        'ibm01': 246,
        'ibm02': 256,
        'ibm03': 256,
        'ibm04': 256,

}

# Total number of nodes (including standard cells, hard macros, and ports)
# Used for calculating num_groups from cells_per_cluster
BENCHMARK_NODE_COUNTS = {
        "adaptec1": 227710,
        "adaptec2": 269189,
        "adaptec3": 464707,
        "adaptec4": 511793,
        "bigblue1": 286082,
        "bigblue2": 563586,
        "bigblue3": 1158835,
        "bigblue4": 2232813,
        "ibm01": 15484,
        "ibm02": 21749,
        "ibm03": 25780,
        "ibm04": 30670,
}

# Canvas dimensions (width, height) for each benchmark
# Extracted from .plc files using veoplace/analysis/get_canvas_sizes.py
BENCHMARK_CANVAS_DIMENSIONS = {
        "adaptec1": (10692, 10680),
        "adaptec2": (14054, 14040),
        "adaptec3": (23190, 23328),
        "adaptec4": (23190, 23328),
        "bigblue1": (10692, 10680),
        "bigblue2": (18690, 18792),
        "bigblue3": (27690, 27792),
        "bigblue4": (32190, 32328),
        "ibm01": (2295, 2304),
        "ibm02": (3256, 3248),
        "ibm03": (3512, 3504),
        "ibm04": (3409, 3408),
}

# Grid sizes for different environments
CHIPFORMER_GRID_SIZE = 84  # Original ChipFormer data was saved with 84x84 grid
VEOPLACE_GRID_SIZE = 512  # Alias for backwards compatibility

MASK_PLACE_GRID_SIZE = 224
# History strategy constants

MAX_HISTORY_CLUSTERS = 1000
EPS_GREEDY = 0.2
RANK_SOFTMAX_TEMP = 0.43  # Keeps max cluster probability at ~90%
KMEANS_NUM_ITERATIONS = 10
# https://scikit-learn.org/stable/modules/generated/sklearn.cluster.MiniBatchKMeans.html
KMEANS_BATCH_SIZE = os.cpu_count() * 1024  # From scikit-learn documentation

# Grid rendering
GRID_IMG_WIDTH = 3000
GRID_IMG_HEIGHT = 3000
MARGIN_LEFT = 80  # Increased for 3-digit numbers (e.g., 480, 512)
MARGIN_RIGHT = 40  # For labels at rightmost grid line
MARGIN_TOP = 20  # Small margin to prevent top clipping
MARGIN_BOTTOM = 50
FONT_SIZE = 30
MIN_FONT_SIZE = 6  # Lowered from 25 to fit labels on smaller macros (readable when zoomed)
MAX_FONT_SIZE = FONT_SIZE
STROKE_WIDTH = 1.05

# Gemini settings
GEMINI_THINKING_BUDGET = -1  # Model decides when and how much to think
GEMINI_THINKING_MODELS = ('gemini-2.5-pro', 'gemini-2.5-flash',
                          'gemini-3.0-pro-preview')
GEMINI_RETRYABLE_ERRORS = (
        genai.errors.ServerError,
        genai.errors.ClientError,
        httpcore.NetworkError,
        httpcore.TimeoutException,
        httpcore.ProtocolError,
        httpx.HTTPError,
)
# Used for labeling axes if needed
CANVAS_LABEL_PERCENTAGE = 0.01
