Algorithm: ParaShield
Input:
    - Client updates: {update_1, update_2, ..., update_n}, each a parameter vector
    - Global model parameters: flat_global_model
    - Global model: global_model (unused)
    - Current round: rnd
    - Hyperparameters: sparsity_cpsc, sparsity_cpcs, lambda_s, lambda_c, beta_weight
    - Client data sizes: {data_size_1, data_size_2, ..., data_size_n}
    - Number of malicious clients: num_corrupt

Output:
    - Aggregated update vector: aggregated_update

1. Initialize:
   - Collect client updates into local_updates and IDs into chosen_clients
   - Classify clients as malicious (ID < num_corrupt) or benign (ID >= num_corrupt)
   - Organize updates into a matrix inter_model_updates

2. Compute Parameter Importance (NPI):
   - For each client update:
     - Compute parameter significance
     - Normalize significance scores
     - Store scores in npi_scores

3. Compute CPSC and CPCS Scores:
   - Compute global sign trend from inter_model_updates
   - For each client:
     - Combine update with significance scores
     - Select key parameters (proportion sparsity_cpsc) for CPSC
     - Compute CPSC: proportion of selected parameters matching global sign trend
     - Select key parameters (proportion sparsity_cpcs) for CPCS
     - Create masked update with selected parameters
     - Compute CPCS: similarity between masked update and flat_global_model
     - Store CPSC and CPCS scores

4. Compute DMAS Scores:
   - For CPSC scores:
     - Compute median and standard deviation
     - Compute standardized scores DMAS_cpsc
   - For CPCS scores:
     - Compute median and standard deviation
     - Compute standardized scores DMAS_cpcs

5. Filter Benign Clients:
   - Select clients with DMAS_cpsc < lambda_s
   - Select clients with DMAS_cpcs < lambda_c
   - Identify clients passing both thresholds (vote count >= 2)
   - If no clients are selected, return zero update

6. Clip Updates:
   - Compute clipping threshold from selected updates' magnitudes
   - Clip all updates to limit their scale

7. Compute Statistical Weights:
   - Build feature matrix from DMAS_cpsc and DMAS_cpcs
   - Compute client differences and covariance-based distances
   - Derive quality weights using exponential decay
   - Normalize quality weights

8. Compute Final Weights:
   - Compute data weights from client data sizes
   - Combine quality and data weights using beta_weight
   - Apply scaling to weights of selected clients

9. Aggregate Updates:
   - Initialize aggregated update as zero
   - For each selected client:
     - Add weighted clipped update
   - If total weight is positive, normalize by total weight
   - Otherwise, return zero update