from app.network.Network import Network
import traci
import pandas as pd
import traci.constants as tc


# class DataCollection(object):
#     # 使用字典
#     @classmethod
#     def get_orig_data(cls, tick, edge_ids):
#         """
#         获取车道信息  车道数、路段上的车辆数（拥堵情况）、车辆平均行驶速度、路段最大车速、是否有人行道、是否有自行车道
#         """
#
#         data = {}
#         # print(edge_ids)
#         for edge_id in edge_ids:
#             # 获取路段的车道数
#             #####print(f"==============={edge_id}===============")
#             lane_number = traci.edge.getLaneNumber(edge_id)
#             # edge_data.append(lane_number)
#             # print("车道数", lane_number)
#             # 获取路段上的车辆数
#             vehicle_number = traci.edge.getLastStepVehicleNumber(edge_id)
#             # edge_data.append(vehicle_number)
#             # print("路段上的车辆数", vehicle_number)
#             # 获取路段车辆的平均行驶速度
#             mean_speed = traci.edge.getLastStepMeanSpeed(edge_id)
#             # print("车辆的平均行驶速度", mean_speed)
#             # edge_data.append(mean_speed)
#
#
#             vehicle_lane = []
#             has_vehicle_lane = False
#             has_pedestrian_lane = False
#             has_bicycle_lane = False
#
#             total_speed = 0
#             total_vehicle = 0
#
#             # 获取车道属性
#             for i in range(lane_number):
#                 lane_id = f"{edge_id}_{i}"
#                 allowed_vehicles = traci.lane.getAllowed(lane_id)
#                 if allowed_vehicles == ('pedestrian',):
#                     has_pedestrian_lane = True
#                 elif allowed_vehicles == ('bicycle',):
#                     has_bicycle_lane = True
#                 else:
#                     has_vehicle_lane = True
#                     # vehicle_ids = traci.lane.getLastStepVehicleIDs(lane_id)
#                     # vehicle_lane.append(lane_id)
#                     # if len(vehicle_ids) > 0:
#                     #     for vehicle_id in vehicle_ids:
#                     #         speed = traci.vehicle.getSpeed(vehicle_id)
#                     #         total_speed += speed
#                     #         total_vehicle += len(vehicle_ids)
#                     # else:
#                     #     total_speed += traci.lane.getMaxSpeed(lane_id)
#                     #     total_vehicle += 1
#
#             # print(f"total_speed:{total_speed}")
#             # print(f"total_vehicle:{total_vehicle}")
#             # if has_vehicle_lane == True:
#             #     # 单行道，该方向没有车道
#             #     Mean_speed = total_speed / total_vehicle
#             #     # print(f"平均速度为:{Mean_speed}")
#             #     edge_data.append(Mean_speed)
#             # else:
#             #     Mean_speed = 0
#             #     # print(f"平均速度为:0，单行道，该方向没有车")
#             #     edge_data.append(Mean_speed)
#
#             # # print(f"has_vehicle_lane:{has_vehicle_lane}")
#             # edge_data.append(has_vehicle_lane)
#             # # print(f"has_pedestrian:{has_pedestrian_lane}")
#             # edge_data.append(has_pedestrian_lane)
#             # # print(f"has_bicycle:{has_bicycle_lane}")
#             # edge_data.append(has_bicycle_lane)
#             # # print(f"汽车道有{vehicle_lane}")
#             # edge_data = [edge_id, tick - 1, ]
#             ##### print(edge_data)
#             data[(edge_id)] = [tick - 1, lane_number, vehicle_number, mean_speed, has_vehicle_lane, has_pedestrian_lane, has_bicycle_lane]
#             # data.append(edge_data)
#         print(data)
#         return data
#
#
#     @classmethod
#     def mod_data(cls,  tick, vehicle_data, edge_ids):
#
#         # vehicle_lane = []
#         # total_speed = 0
#         # total_vehicle = 0
#         # has_vehicle_lane = False
#
#         # print(edge_ids)
#         # print(vehicle_data)
#         # vehicle_data = [[row[0], tick - 1] + row[2:] for row in vehicle_data]
#         # print(vehicle_data)
#         # vehicle_dict = dict((item[0], item[1:]) for item in vehicle_data)
#         # print(vehicle_data)
#         for edge_id in edge_ids:
#
#             edge_value = vehicle_data[str(edge_id)]
#             edge_value[0] = tick - 1
#             vehicle_number = traci.edge.getLastStepVehicleNumber(edge_id)
#             edge_value[2] = vehicle_number
#
#             mean_speed = traci.edge.getLastStepMeanSpeed(edge_id)
#             edge_value[3] = mean_speed
#
#             # lane_number = edge_value[1]
#             # for i in range(lane_number):
#             #     lane_id = f"{edge_id}_{i}"
#             #     allowed_vehicles = traci.lane.getAllowed(lane_id)
#             #     if (allowed_vehicles != ('pedestrian',)) and (allowed_vehicles != ('bicycle',)):
#             #         has_vehicle_lane = True
#             #         vehicle_ids = traci.lane.getLastStepVehicleIDs(lane_id)
#             #         vehicle_lane.append(lane_id)
#             #         if len(vehicle_ids) > 0:
#             #             for vehicle_id in vehicle_ids:
#             #                 speed = traci.vehicle.getSpeed(vehicle_id)
#             #                 total_speed += speed
#             #                 total_vehicle += len(vehicle_ids)
#             #         else:
#             #             total_speed += traci.lane.getMaxSpeed(lane_id)
#             #             total_vehicle += 1
#
#             # print(f"total_speed:{total_speed}")
#             # print(f"total_vehicle:{total_vehicle}")
#             # if has_vehicle_lane == True:
#             #     # 单行道，该方向没有车道
#             #     Mean_speed = total_speed / total_vehicle
#             #     # print(f"平均速度为:{Mean_speed}")
#             # else:
#             #     Mean_speed = 0
#             #     # print(f"平均速度为:0，单行道，该方向没有车")
#             # edge_value[4] = Mean_speed
#             # vehicle_dict[str(edge_id)] = edge_value
#
#         # vehicle_data = []
#         # for key, value in vehicle_dict.items():
#         #     vehicle_data.append([key] + value)
#         # print(vehicle_data)
#         print(f"+++++++{vehicle_data}+++++++++")
#         return vehicle_data
#         #
#         #     lane_number = int(vehicle_data.loc[vehicle_data[0] == str(edge_id), 2])
#         #
#         #     for i in range(lane_number):
#         #         lane_id = f"{edge_id}_{i}"
#         #         allowed_vehicles = traci.lane.getAllowed(lane_id)
#         #         if (allowed_vehicles != ('pedestrian',)) and (allowed_vehicles != ('bicycle',)):
#         #             has_vehicle_lane = True
#         #             vehicle_ids = traci.lane.getLastStepVehicleIDs(lane_id)
#         #             vehicle_lane.append(lane_id)
#         #             if len(vehicle_ids) > 0:
#         #                 for vehicle_id in vehicle_ids:
#         #                     speed = traci.vehicle.getSpeed(vehicle_id)
#         #                     total_speed += speed
#         #                     total_vehicle += len(vehicle_ids)
#         #             else:
#         #                 total_speed += traci.lane.getMaxSpeed(lane_id)
#         #                 total_vehicle += 1
#         #
#         #     # print(f"total_speed:{total_speed}")
#         #     # print(f"total_vehicle:{total_vehicle}")
#         #     if has_vehicle_lane == True:
#         #         # 单行道，该方向没有车道
#         #         Mean_speed = total_speed / total_vehicle
#         #         # print(f"平均速度为:{Mean_speed}")
#         #         vehicle_data.loc[vehicle_data[1] == str(edge_id), 5] = Mean_speed
#         #     else:
#         #         Mean_speed = 0
#         #         # print(f"平均速度为:0，单行道，该方向没有车")
#         #         vehicle_data.loc[vehicle_data[1] == str(edge_id), 5] = Mean_speed
#         #
#         # return vehicle_data.values.tolist()

class DataCollection(object):
    # 使用字典
    @classmethod
    def get_orig_data(cls, tick, edge_ids):
        """
        获取车道信息
        0时间 1是否有人行道 2是否有自行车道 3是否有车道、
        4车道数 5路段上的车辆数（拥堵情况） 6车辆平均行驶速度 7静止的车辆数量 8路段长度 9当前旅行时间 10上一时间步的车道占用率
        """

        data = {}
        # print(edge_ids)
        for edge_id in edge_ids:

            # 获取路段的车道数
            traci.edge.subscribe(edge_id, [tc.VAR_LANE_INDEX, tc.LAST_STEP_VEHICLE_NUMBER, tc.LAST_STEP_MEAN_SPEED,
                                           tc.LAST_STEP_VEHICLE_HALTING_NUMBER, tc.LAST_STEP_LENGTH,
                                           tc.VAR_CURRENT_TRAVELTIME, tc.LAST_STEP_OCCUPANCY])

            data_new = traci.edge.getSubscriptionResults(edge_id)
            # traci_data = traci.edge.getSubscriptionResults(edge_id)
            # print(traci_data)
            # data_new = [traci_data[19],traci_data[148]]
            # print(data_new)
            #####print(f"==============={edge_id}===============")
            # print(edge_length)


            # print("*******1111", edge_id)
            # ** ** ** *1111 - E0
            # ** ** ** *1111 - E10
            # ** ** ** *1111 - E7
            # ** ** ** *1111 - E8
            # ** ** ** *1111 - E9
            # ** ** ** *1111 E2
            # ** ** ** *1111 E3
            # ** ** ** *1111 E4
            # ** ** ** *1111 E7
            # ** ** ** *1111 E9

            lane_number = traci.edge.getLaneNumber(edge_id) # tc.LAST_STEP_VEHICLE_NUMBER


            vehicle_lane = []
            has_vehicle_lane = 0
            has_pedestrian_lane = 0
            has_bicycle_lane = 0

            total_speed = 0
            total_vehicle = 0

            # 获取车道属性
            for i in range(lane_number):
                lane_id = f"{edge_id}_{i}"
                allowed_vehicles = traci.lane.getAllowed(lane_id)
                if allowed_vehicles == ('pedestrian',):
                    has_pedestrian_lane = 1
                elif allowed_vehicles == ('bicycle',):
                    has_bicycle_lane = 1
                else:
                    has_vehicle_lane = 1
                    # vehicle_ids = traci.lane.getLastStepVehicleIDs(lane_id)
                    # vehicle_lane.append(lane_id)
                    # if len(vehicle_ids) > 0:
                    #     for vehicle_id in vehicle_ids:
                    #         speed = traci.vehicle.getSpeed(vehicle_id)
                    #         total_speed += speed
                    #         total_vehicle += len(vehicle_ids)
                    # else:
                    #     total_speed += traci.lane.getMaxSpeed(lane_id)
                    #     total_vehicle += 1
            edge_data = [tick - 1] + [has_pedestrian_lane, has_bicycle_lane, has_vehicle_lane] + \
                        [data_new[i] for i in [82, 16, 17, 20, 21, 90, 19]]
            # print(edge_data)
            data[edge_id] = edge_data
            # print("333", data[edge_id])
        # print(data)
        return data


    @classmethod
    def mod_data(cls,  tick, vehicle_data, edge_ids):

        for edge_id in edge_ids:
            # traci.edge.subscribe(edge_id, [tc.LAST_STEP_VEHICLE_NUMBER, tc.LAST_STEP_MEAN_SPEED,
            #                                tc.LAST_STEP_OCCUPANCY, tc.LAST_STEP_VEHICLE_HALTING_NUMBER,
            #                                tc.LAST_STEP_LENGTH, ])
            data_new = traci.edge.getSubscriptionResults(edge_id)
            # print(data_new)
            edge_value = vehicle_data[str(edge_id)]
            edge_value[0] = tick - 1

            edge_value[-6:] = [data_new[16], data_new[17], data_new[20], data_new[21], data_new[90], data_new[19]]

        return vehicle_data


