import json
import os
import sys
from copy import deepcopy
import random
random.seed(42)
# 添加项目根目录到Python路径
sys.path.append(os.path.abspath(os.path.join(os.path.dirname(__file__), '..', '..','..')))
from Evaluation.Transportation.val_transports import TransportationEvaluator

# ================= 1. 严格复用交通版辅助函数 =================

def find_generate_func(rubric_detail_dict, target_id):
    for desc_key, desc_val in rubric_detail_dict.items():
        if desc_key == "_id" or not isinstance(desc_val, dict): continue
        res = desc_val.get("result")
        if not isinstance(res, dict): continue
        all_labels = res.get("all_labels_and_ranges", {})
        for label_dict in all_labels.values():
            if isinstance(label_dict, dict) and label_dict.get("_id") == target_id:
                return desc_val.get("generate_func")
    return None

def build_generate_params(rubric_result_dict, picked_ids):
    generate_params = {}
    for desc_key, desc_val in rubric_result_dict.items():
        if "result" not in desc_val: continue
        all_labels = desc_val["result"]["all_labels_and_ranges"]
        for label_key, label_obj in all_labels.items():
            if label_obj["_id"] in picked_ids:
                generate_params[label_key] = label_obj["value"]
    return generate_params

# ================= 2. 核心动态验证逻辑 (交通版) =================

def check_feasibility_transport(trip_data, evaluator):
    """
    完全基于 applied_modification_chains 动态调用交通评估器验证。
    """
    route = trip_data.get("route", [])
    if len(route) == 1:
      routes_info_depart = [{
        "departure_city": route[0]["from"],
        "arrival_city": route[0]["to"],
        "date_str": route[0]["depart_date"],
        "number_of_people": route[0]["number_of_people"]
      }]

      routes_info_return = [{
          "departure_city": route[0]["to"],
          "arrival_city": route[0]["from"],
          "date_str": route[0]["return_date"],
          "number_of_people": route[0]["number_of_people"]
        }]

    else:
      routes_info_depart = [
          {
              "departure_city": route[0]["from"],
              "arrival_city": route[0]["to"],
              "date_str": route[0]["depart_date"],
              "number_of_people": route[0]["number_of_people"]
          },
          {
              "departure_city": route[1]["from"],
              "arrival_city": route[1]["to"],
              "date_str": route[1]["depart_date"],
              "number_of_people": route[1]["number_of_people"]
          }
      ]

      routes_info_return = [{
          "departure_city": route[1]["to"],
          "arrival_city": route[0]["from"],
          "date_str": route[1]["return_date"],
          "number_of_people": route[0]["number_of_people"]
      }]

    applied_chains = trip_data.get("applied_modification_chains", {})
    original_rubrics = trip_data.get("rubric_results", {})
    
    candidate_sets = []

    # 2. 遍历链路动态执行生成
    for rubric_name, picked_ids in applied_chains.items():
        if not picked_ids:
            continue
            
        last_id = picked_ids[-1]
        rubric_detail = original_rubrics.get(rubric_name, {})
        
        # 确定 generate_func
        gen_func = find_generate_func(rubric_detail, last_id)
        if not gen_func:
            continue

        # 构造 generate_params
        gen_params = build_generate_params(rubric_detail, [last_id])

        # 交通版核心逻辑：根据 Rubric 类型选择不同的 routes_info 参数
        if rubric_name == "RUBRIC_TIME_RETURN":
            routes_info_param = routes_info_return
        else:
            routes_info_param = routes_info_depart + routes_info_return

        # 执行 evaluator.execute
        try:
            result = evaluator.execute(
                gen_func,
                routes_info_param,
                transport_type="all",
                generate_params=gen_params
            )
            candidate_ids = set(result.get("candidate_ids", []))
            candidate_sets.append(candidate_ids)
        except Exception as e:
            print(f"Dynamic eval error in {gen_func}: {e}")
            return False, 0

    # 3. 求交集并判定
    if candidate_sets:
        intersection = set.intersection(*candidate_sets)
        # 交通版阈值：1 (代表 至少有一套 去+回 的组合满足所有约束)
        feasible = len(intersection) >= 1
        return feasible
    else:
        # 如果没有任何约束，理论上是可行的
        return True

# ================= 3. 使用示例 =================

if __name__ == "__main__":
    # 初始化
    flight_path = "/data/hzs/triptailor_v2_wzy/ttv2_up/data_final/flights.json"
    evaluator = TransportationEvaluator(flight_path)
    
    # 假设 test_data 是你的 trip 对象
    test_data =   {
    "trip_id": "c3_35835",
    "route": [
      {
        "from": "Guilin",
        "to": "Beijing",
        "distance_km": 1727.42,
        "depart_date": "2025-10-26",
        "stay_days": 3,
        "return_date": "2025-10-28",
        "number_of_people": 5
      },
      {
        "from": "Beijing",
        "to": "Tianjin",
        "distance_km": 113.72,
        "depart_date": "2025-10-29",
        "stay_days": 2,
        "return_date": "2025-10-30",
        "number_of_people": 5
      }
    ],
    "rubric_results": {
      "RUBRIC_COST_TRANSPORT": {
        "Less than a certain transportation cost per person (one-way)": {
          "probability": 1,
          "description": "The one-way transportation cost per person is less than {slot}.",
          "violation_description": "The one-way transportation cost per person exceeds {slot}.",
          "generate_func": "generate_transport_cost_less_per_person_one_way",
          "validate_func": "validate_transport_cost_less_per_person_one_way",
          "result": {
            "selected_description": "1300",
            "validation_params": 1300,
            "all_labels_and_ranges": {
              "800": {
                "value": 800,
                "_id": "transport_3_1_1"
              }
            }
          },
          "_id": "transport_3_1"
        }
      },
      "RUBRIC_TIME_RETURN": {
        "Depart after a specific time": {
          "probability": 1,
          "description": "For the return trip, depart after {slot}.",
          "violation_description": "The return departure time is not after {slot}.",
          "generate_func": "generate_depart_after_time",
          "validate_func": "validate_depart_time_condition",
          "result": {
            "selected_description": "after 07:00",
            "validation_params": "07:00-23:59",
            "all_labels_and_ranges": {
              "after 07:00": {
                "value": "07:00-23:59",
                "_id": "transport_2_4_2"
              }
            }
          },
          "_id": "transport_2_4"
        }
      }
    },
    "applied_modification_chains": {
      "RUBRIC_COST_TRANSPORT": [
        "transport_3_1_1"
      ],
      "RUBRIC_TIME_RETURN": [
        "transport_2_4_2"
      ]
    },
    "intersection_count": 1,
    "feasible": True,
    "SAMPLE_RUBRIC_COUNT": 2,
    "TOTAL_CHAIN_LENGTH": 2
  }
    is_feasible = check_feasibility_transport(test_data, evaluator)
    print(f"Feasible: {is_feasible}")