\begin{algorithm}[h]
\caption{Multi-Persona Preference Augmentation}
\label{alg:augmentation}
\begin{algorithmic}[1]

\REQUIRE Base Dataset $\mathcal{D}_{TP}$, Survey Data $\mathcal{D}_{Stravl}$, Group Size $K$, Max Iterations $T_{max}$
\ENSURE Augmented Dataset $\mathcal{D}_{MP}$

\FOR{\textbf{each} plan $P_i$ in $\mathcal{D}_{TP}$}

    \STATE \textbf{Step 1: Candidate Extraction via MMR}
    \STATE $C_i \leftarrow \text{SelectCandidates}(P_i, \mathcal{D}_{Stravl})$
    \COMMENT{Select 200-800 rows balancing similarity and diversity}

    \STATE \textbf{Step 2: Persona Injection \& Constraint Validation}
    \STATE $ValidGroup \leftarrow \textbf{false}$
    \STATE $t \leftarrow 0$
    
    \WHILE{$t < T_{max} \land \neg ValidGroup$}
        \STATE Sample $K$ personas from $C_i$
        \STATE Apply MoSCoW method to define priorities $\{Must, Should, Could, Won't\}$
        
        \STATE \textit{// Check Hard Constraints (Must satisfy basic requirements)}
        \IF{($\exists$ Conflicts in $Must$) $\lor$ ($\nexists$ Common $Must$)}
            \STATE $t \leftarrow t + 1$
            \STATE \textbf{continue}
        \ENDIF
        
        \STATE \textit{// Check Soft Constraints (Ensure negotiation complexity)}
        \IF{CountConflicts($Should, Could$) \ge 2}
            \STATE $ValidGroup \leftarrow \textbf{true}$
            \STATE Add \{Personas, Assertiveness($\alpha$), Preferences\} to $\mathcal{D}_{MP}$
        \ENDIF
        \STATE $t \leftarrow t + 1$
    \ENDWHILE

\ENDFOR

\RETURN $\mathcal{D}_{MP}$

\end{algorithmic}
\end{algorithm}