\section{\ourmethod\: Algorithm}
\label{appendix:pikachu_algorithm}
In this section, we present a detailed, stepwise description of the \ourmethod\ in-context learning framework. The algorithm formalizes the complete workflow of our method, beginning with support-query preparation, followed by prototype construction in the frozen foundation-model feature space, and concluding with temperature-scaled similarity inference.

\begin{algorithm}[h]
\caption{\textbf{PIKACHU: Perceptual In-Context Knowledge Adaptation for Medical Image Classification}}
\label{alg:pikachu}
\DontPrintSemicolon

\KwIn{
Frozen Foundation Model such as PubMedCLIP encoder $\mathcal{E}$; \\
Support set $\mathcal{S}=\{(x_i, y_i)\}$ with $C$ classes and $K$ shots per class; \\
Query image $x_q$; \\
Learnable temperature parameter $\log T$.
}

\KwOut{
Predicted label $\hat{y}_q$ for the query image.
}
\vspace{0.2cm}
\textbf{Step 1: Support-Query Preprocessing and Feature Extraction} \\
Convert all support and query images to PIL format and preprocess/transforms.\;

\ForEach{support image $x_i$}{
    $\mathbf{f}_i \leftarrow \mathcal{E}(x_i)$ \tcp*{Frozen encoder}
    $\mathbf{f}_i \leftarrow \mathbf{f}_i / \|\mathbf{f}_i\|_2$ \tcp*{L2-normalize}
}

$\mathbf{f}_q \leftarrow \mathcal{E}(x_q)$; 
$\mathbf{f}_q \leftarrow \mathbf{f}_q / \|\mathbf{f}_q\|_2$ \tcp*{Query embedding}
\vspace{0.2cm}
\textbf{Step 2: Prototype Computation}\\
Initialize prototype vectors $\mathbf{p}_1, \dots, \mathbf{p}_C$.\;

\For{$c = 1$ \KwTo $C$}{
    $\mathcal{S}_c \leftarrow \{ \mathbf{f}_i \mid y_i = c \}$ \tcp*{Support features of class $c$}
    \eIf{$\mathcal{S}_c$ not empty}{
        $\mathbf{p}_c \leftarrow \frac{1}{|\mathcal{S}_c|} \sum_{\mathbf{f}_i \in \mathcal{S}_c} \mathbf{f}_i$ \tcp*{Mean prototype}
        $\mathbf{p}_c \leftarrow \mathbf{p}_c / \|\mathbf{p}_c\|_2$ \tcp*{Normalize}
    }{
        $\mathbf{p}_c \leftarrow \mathbf{0}$ \tcp*{Fallback for missing class}
    }
}
\vspace{0.2cm}
\textbf{Step 3: Temperature-Scaled Cosine Similarity Inference} \\

Compute logits for each class:
\[
\text{logits}_c = \exp(\log T) \cdot (\mathbf{f}_q^\top \mathbf{p}_c)
\]

Apply softmax:
\[
p(y=c \mid x_q, \mathcal{S}) = \frac{\exp(\text{logits}_c)}{\sum_{j=1}^C \exp(\text{logits}_j)}
\]

Predict class:
\[
\hat{y}_q = \arg\max_{c} \; p(y=c \mid x_q, \mathcal{S})
\]

\textbf{Training Procedure (Episodic Few-Shot)} \\
During training, only \emph{one parameter} is optimized: $\log T$.\;

\ForEach{episode}{
    Construct support set $\mathcal{S}$ and query batch.\;
    Compute prototypes and logits as above.\;
    Update $\log T$ using cross-entropy loss and Adam optimizer.\;
}
\Return $\hat{y}_q$
\end{algorithm}
\vspace{-5cm}
\clearpage