from utils import *
from vd_env import *


if False:
    n_customers = 40
    print(f"=== {n_customers}个客户CVRP测试 ===")
    # 智能生成CVRP实例
    distance_matrix_v, customer_demands, coordinates = generate_cvrp_instance(n_customers)
    distance_matrix_d = distance_matrix_v * 0.9
    reward_matrix = np.random.rand(n_customers, n_customers)
    reward_matrix = (reward_matrix + reward_matrix.T) / 2
    print(f"节点配置: 1个depot + {n_customers}个客户")
    print(f"客户需求范围: {min(customer_demands.values())}-{max(customer_demands.values())}")
    print(f"总需求量: {sum(customer_demands.values())}")

    # 智能配置车队 (根据客户数量调整)
    n_vehicles = 1
    n_drones = 0
    if n_vehicles == 1:
        vehicle_capacity = 10000
    else:
        vehicle_capacity = max(50, sum(customer_demands.values()) // n_vehicles * 1.2)  # 容量稍大于平均需求
    drone_capacity = 20
    print(f"智能车队配置: {n_vehicles}辆车，每辆容量{vehicle_capacity:.0f}")
    print(f"总容量: {n_vehicles * vehicle_capacity:.0f}")
    print()

    # 创建环境
    env = VDEnvironment(
        distance_matrix_v=distance_matrix_v,
        distance_matrix_d=distance_matrix_d,
        customer_demands=customer_demands,
        n_vehicles=n_vehicles,
        n_drones=n_drones,
        vehicle_capacity=int(vehicle_capacity),
        drone_capacity=int(drone_capacity),
        vehicle_speed=1.0,
        drone_speed=1.5
    )