import torch
from typing import List, Dict

def FedAvg(self, params: List[Dict[str, torch.Tensor]]) -> List[Dict[str, torch.Tensor]]:
    """
    朴素聚合（无聚类、无路由）：对所有客户端的参数取平均，并为每个客户端返回同样的副本。

    Args:
        self: Server instance (expects self.device).
        params: list of per-client param dicts (name -> tensor).

    Returns:
        aggregated_results: list (len == num_clients) of dicts mapping param_name -> averaged tensor.
    """
    if not params:
        raise ValueError("params list is empty")

    # 将所有参数移到 server 的 device 上
    gpu_params = [
        {k: v.to(self.device) for k, v in client_params.items()}
        for client_params in params
    ]
    num_clients = len(gpu_params)
    param_names = list(gpu_params[0].keys())

    # 对每个参数求平均
    averaged_params = {}
    for name in param_names:
        tensors = [client_params[name] for client_params in gpu_params if name in client_params]
        stacked = torch.stack(tensors)
        averaged_params[name] = stacked.mean(dim=0)

    # 为每个客户端返回一个相同的副本
    aggregated_results = [
        {k: v.clone() for k, v in averaged_params.items()}  # clone() 避免共享引用
        for _ in range(num_clients)
    ]

    return aggregated_results
