Video Brain Decoding

Download as pdf or txt
Download as pdf or txt
You are on page 1of 15

Cinematic Mindscapes: High-quality Video

Reconstruction from Brain Activity

Zijiao Chen∗ Jiaxin Qing∗


National University of Singapore The Chinese University of Hong Kong
zijiao.chen@u.nus.edu jqing@ie.cuhk.edu.hk
arXiv:2305.11675v1 [cs.CV] 19 May 2023

Juan Helen Zhou†


National University of Singapore
helen.zhou@nus.edu.sg
https://mind-video.com

Abstract
Reconstructing human vision from brain activities has been an appealing task that
helps to understand our cognitive process. Even though recent research has seen great
success in reconstructing static images from non-invasive brain recordings, work on
recovering continuous visual experiences in the form of videos is limited. In this work,
we propose MinD-Video that learns spatiotemporal information from continuous fMRI
data of the cerebral cortex progressively through masked brain modeling, multimodal
contrastive learning with spatiotemporal attention, and co-training with an augmented
Stable Diffusion model that incorporates network temporal inflation. We show that
high-quality videos of arbitrary frame rates can be reconstructed with MinD-Video
using adversarial guidance. The recovered videos were evaluated with various semantic
and pixel-level metrics. We achieved an average accuracy of 85% in semantic
classification tasks and 0.19 in structural similarity index (SSIM), outperforming the
previous state-of-the-art by 45%. We also show that our model is biologically plausible
and interpretable, reflecting established physiological processes.

1 Introduction

Life unfolds like a film reel, each moment seamlessly transitioning into the next, forming a “perpetual
theater” of experiences. This dynamic narrative forms our perception, explored through the naturalistic
paradigm, painting the brain as a moviegoer engrossed in the relentless film of experience. Understanding
the information hidden within our complex brain activities is a big puzzle in cognitive neuroscience. The task
of recreating human vision from brain recordings, especially using non-invasive tools like functional Mag-
netic Resonance Imaging (fMRI), is an exciting but difficult task. Non-invasive methods, while less intrusive,
capture limited information, susceptible to various interferences like noise [1]. Furthermore, the acquisition
of neuroimaging data is a complex, costly process. Despite these complexities, progress has been made,
notably in learning valuable fMRI features with limited fMRI-annotation pairs. Deep learning and represen-
tation learning have achieved significant results in visual class detections [2, 3] and static image reconstruc-
tion [4, 5, 6, 7], advancing our understanding of the vibrant, ever-changing spectacle of human perception.
Unlike still images, our vision is a continuous, diverse flow of scenes, motions, and objects. To recover
dynamic visual experience, the challenge lies in the nature of fMRI, which measures blood oxygenation
level dependent (BOLD) signals and captures snapshots of brain activity every few seconds. Each fMRI scan

Equal contributions

Corresponding author

Preprint. Under review.


Visual Stimuli
Video watching during MRI scan

Brain
Encoding Our Reconstructed Video

Brain
Decoding

Figure 1. Brain decoding & video reconstruction. We propose a progressive learning approach to recover continuous
visual experience from fMRI. High-quality videos with accurate semantics and motions are reconstructed.

essentially represents an “average” of brain activity during the snapshot. In contrast, a typical video has about
30 frames per second (FPS). If an fMRI frame takes 2 seconds, during that time, 60 video frames - potentially
containing various objects, motions, and scene changes - are presented as visual stimuli. Thus, decoding
fMRI and recovering videos at an FPS much higher than the fMRI’s temporal resolution is a complex task.
Hemodynamic response (HR) [8] refers to the lags between neuronal events and activation in BOLD signals.
When a visual stimulus is presented, the recorded BOLD signal will have certain delays with respect to the
stimulus event. Moreover, the HR varies across subjects and brain regions [9]. Thus, the common practice
that shifts the fMRI by a fixed number in time to compensate for the HR would be sub-optimal.
In this work, we present MinD-Video, a two-module pipeline designed to bridge the gap between image and
video brain decoding. Our model progressively learns from brain signals, gaining a deeper understanding of
the semantic space through multiple stages in the first module. Initially, we leverage large-scale unsupervised
learning with masked brain modeling to learn general visual fMRI features. We then distill semantic-related
features using the multimodality of the annotated dataset, training the fMRI encoder in the Contrastive
Language-Image Pre-Training (CLIP) space with contrastive learning. In the second module, the learned
features are fine-tuned through co-training with an augmented stable diffusion model, which is specifically
tailored for video generation under fMRI guidance. Our contributions are summarized as follows:

• We introduced a flexible and adaptable brain decoding pipeline decoupled into two modules: an fMRI
encoder and an augmented stable diffusion model, trained separately and finetuned together.
• We designed a progressive learning scheme where the encoder learns brain features through multiple
stages, including multimodal contrastive learning with spatiotemporal attention for windowed fMRI.
• We augmented the stable diffusion model for scene-dynamic video generation with near-frame
attention. We also designed adversarial guidance for distinguishable fMRI conditioning.
• We recovered high-quality videos with accurate semantics, e.g., motions and scene dynamics. Results
are evaluated with semantic and pixel metrics at video and frame levels. An accuracy of 85% is achieved
in semantic metrics and 0.19 in SSIM, outperforming the previous state-of-the-art approaches by 45%.
• The attention analysis revealed mapping to the visual cortex and higher cognitive networks suggesting
our model is biologically plausible and interpretable.

2 Background

Image Reconstruction Image reconstruction from fMRI was first explored in [2], which showed that hier-
archical image features and semantic classes could be decoded from the fMRI data collected when the partic-
ipants were looking at a static visual stimulus. Authors in [5] designed a separable autoencoder that enables
self-supervised learning in fMRI and images to increase training data. Based on a similar philosophy, [6]
proposed to perform self-supervised learning on a large-scale fMRI dataset using masked data modeling as a
pretext task. Using a stable diffusion model as a generative prior and the pre-trained fMRI features as condi-
tions, [6] reconstructed high-fidelity images with high semantic correspondence to the groundtruth stimuli.
Video Reconstruction The conventional method formulated the video reconstruction as multiple image
reconstructions [10], leading to low frame rates and frame inconsistency. Nonetheless, [10] showed that
low-level image features and classes can also be decoded from fMRI collected with video stimulus. Using
fMRI representations encoded with a linear layer as conditions, [11] generated higher quality and frame
rate videos with a conditional video GAN. However, the results are limited by data scarcity, especially

2
ttn
-A
SC
fMRI Tokens

fMRI Tokens
Activated fMRI
Voxels

Adversarial Guidance
for fMRI

Figure 2. MinD-Video Overview. Our method has two modules that are trained separately, then finetuned together.
The fMRI encoder progressively learns fMRI features through multiple stages, including SC-MBM pre-training and
multimodal contrastive learning. A spatiotemporal attention is designed to process multiple fMRI in a sliding window.
The augmented Stable Diffusion is trained with videos and then tuned with the fMRI encoder using annotated data.

for GAN training, which generally requires a large amount of data. [12] took a similar approach as [5],
which relied on the same separable autoencoder that enables self-supervised learning. Even though better
results were achieved than [11], the generated videos were of low visual fidelity and semantic meanings.
MBM Masked brain modeling (MBM) is a pre-text task that enables self-supervised learning in a large
fMRI dataset [6], aiming to build a brain foundation model. It learns general features of fMRI by trying to
recover masked data from the remainings, similar to the GPT [13] and MAE [14], after which knowledge
can be distilled and transferred to a downstream task with limited data and a few-step tuning [15, 13, 14, 6].
CLIP Contrastive Language-Image Pre-Training (CLIP) is a pre-training technique that builds a shared
latent space for images and natural languages by large-scale contrastive learning [16]. The training aims to
minimize the cosine distance of paired image and text latent while maximizing permutations of pairs within
a batch. The shared latent space (CLIP space) contains rich semantic information on both images and texts.
Stable Diffusion Diffusion models are emerging probabilistic generative models defined by a reversible
Markov chain [17, 18]. As a variant, stable diffusion generates a compressed version of the data (data latent)
instead of generating the data directly. As it works in the data latent space, the computational requirement is
significantly reduced, and higher-quality images with more details can be generated in the latent space [19].

3 Methodology

3.1 Motivation and Overview

Aiming for a flexible design, MinD-Video is decoupled into two modules: an fMRI encoder and a video
generative model, as illustrated in Fig. 2. These two modules are trained separately and then finetuned
together, which allows for easy adaption of new models if better architectures of either one are available.
As a representation learning model, the encoder in the first module transfers the pre-processed fMRI into
embeddings, which are used as a condition for video generations. For this purpose, the embedding should
have the following traits: 1) It should contain rich and compact information about the visual stimulus
presented during the scan. 2) It should be close to the embedding domain that the generative model
is trained with. When designing the generative model, it is essential that the model produces not only
diverse, high-quality videos with high computational efficiency but also handles potential scene transitions,
mirroring the dynamic visual stimuli experienced during scans.

3.2 The fMRI Pre-processing

The fMRI captures whole-brain activity with BOLD signals (voxels). Each voxel is assigned to a region
of interest (ROI) for focused analysis. Here, we concentrate on voxels activated during visual stimuli.
There are two ways to define the ROIs: one uses a pre-defined parcellation such as [20] and [21] to
obtain the visual cortex; the other relies on statistical tests to identify activated voxels during stimuli. Our
large-scale pre-training is based on the parcellation in [20], while statistical tests are employed for the target
dataset, i.e., the Wen (2018) [10] dataset containing fMRI-video pairs. To determine activated regions, we
calculate intra-subject reproducibility of each voxel, correlating fMRI data across multiple viewings. The

3
correlation coefficients are then converted to z-scores and averaged. We compute statistical significance
using a one-sample t-test (P<0.01, DOF=17, Bonferroni correction). We selected the top 50% of the most
significant voxels after the statistical test. Notice that most of the identified voxels are from the visual cortex.

3.3 Progressive Learning and fMRI Encoder

Progressive learning is used as an efficient training scheme where general knowledge is learned first, and
then more task-specific knowledge is distilled through finetuning [22, 23, 24]. To generate meaningful em-
beddings specific for visual decoding, we design a progressive learning pipeline, which learns fMRI features
in multiple stages, starting from general features to more specific and semantic-related features. We will
show that the progressive learning process is reflected biologically in the evolution of fMRI attention maps.
Large-scale Pre-training with MBM Similar to [6], a large-scale pre-training with masked brain
modeling (MBM) is used to learn general features of the visual cortex. With the same setup, an asymmetric
vision-transformer-based autoencoder [25, 14] is trained on the Human Connectome Project [26] with
the visual cortex (V1 to V4) defined by [20]. Specifically, fMRI data of the visual cortex is rearranged
from 3D into 1D space in the order of visual processing hierarchy, which is then divided into patches of
the same size. The patches will be transformed into tokens, and a large portion (∼75%) of the tokens will
be randomly masked in the encoder during training. With the autoencoder architecture, a simple decoder
aims to recover the masked tokens from the unmasked token embeddings generated by the encoder. The
main idea behind the MBM is that if the training objective can be achieved with high accuracy using a
simple decoder, the token embeddings generated by the encoder will be a rich and compact description
of the original fMRI data. We refer readers to [6] for detailed descriptions and reasonings of the MBM.
Spatiotemporal Attention for Windowed fMRI For the purpose of image reconstruction, the
original fMRI encoder in [6] shifts the fMRI data by 6s, which is then averaged every 9 seconds
and processed individually. This process only considers the spatial information in its attention
layers. In the video reconstruction, if we directly map one fMRI to the video frames presented (e.g.,
6 frames), the video reconstruction task can be formulated as a one-to-one decoding task, where
each set of fMRI data corresponds to 6 frames. We call each {fMRI-frames} pair a fMRI frame
window. However, this direct mapping is sub-optimal because of the time delay between brain
activity and the associated BOLD signals in fMRI data due to the nature of hemodynamic response.
Thus, when a visual stimulus (i.e., a video frame) is
presented at time t, the fMRI data obtained at t may lag BOLD signals at T BOLD signals at T+1
not contain complete information about this frame. visual stimulus at T time
Namely, a lag occurs between the presented visual
stimulus and the underlying information recorded ... ... ... ...
by fMRI. This phenomenon is depicted in Fig. 3.
The hemodynamic response function (HRF) is usu-
ally used to model the relationship between neural Figure 3. Due to hemodynamic response, the BOLD signal
(blue) lags a few seconds behind the visual stimulus (red),
activity and BOLD signals [27]. In an LTI system, causing a discrepancy between fMRI and the stimulus.
the signal y(t) is represented as the convolution of
a stimulus function s(t) and the HR h(t), i.e., y(t) = (s∗h)(t). The h(t) is often modeled with a linear
combination of some basis functions, which can be collated into a matrix form: Y =Xβ+e, where Y
represents the observed data, β is a vector of regression coefficients, and e is a vector of unexplained error
values. However, e varies significantly across individuals and sessions due to age, cognitive state, and
specific visual stimuli, which influence the firing rate, onset latency, and neuronal activity duration. These
variations impact the estimation of e and ultimately affect the accuracy of the fMRI-based analysis. Gener-
ally, there are two ways to address individual variations: using personalized HRF models or developing
algorithms that adapt to each participant. We choose the latter due to its superior flexibility and robustness.
Aiming to obtain sufficient information to decode each scan window and account for the HR, we propose a
spatiotemporal attention layer to process multiple fMRI frames in a sliding window. Consider a sliding
window defined as xt = {xt,xt+1,...,xt+w−1}, where xt ∈ Rn×p×b are token embeddings of the fMRI
at t and n, p, b are the batch size, patch size, and embedding dimension, respectively. So we  have
T
xt ∈R n×w×p×b
, where w is the window size. Recall that the attention is given by attn=softmax QK

d
.
To calculate spatial attention, we use the network inflation trick [28], where we merge the first two
dimensions of xt and obtain xspat
t ∈Rnw×p×b. Then the query and key are calculated in Eq. (1) as
Q=xspat
t
Q
·Wspat , K =xspat
t
K
·Wspat . (1)

4
Likewise, we merge the first and the third dimension of xt to calculate the temporal attention, obtaining
xtemp
t ∈Rnp×w×b. Again, the query and key are calculated in Eq. (2) with

Q=xtemp
t
Q
·Wtemp , K =xtemp
t
K
·Wtemp . (2)
The spatial attention learns correlations among the fMRI tokens, describing the spatial correlations of
the fMRI patches. Then the temporal attention learns the correlations of fMRI from the sliding window,
including sufficient information to cover the lag due to HR, as illustrated in the “fMRI Attention” in Fig. 2.
Multimodal Contrastive Learning Recall that the fMRI encoder is pre-trained to learn general features
of the visual cortex, and then it is augmented with temporal attention heads to process a sliding window of
fMRI. In this step, we further train the augmented encoder with {fMRI, video, caption} triplets and pull the
fMRI embeddings closer to a shared CLIP space containing rich semantic information. Additionally, the
generative model is usually pre-trained with text conditioning. Thus, pulling the fMRI embeddings closer
to the text-image shared space ensures its understandability by the generative model during conditioning.
Firstly, videos in the training set are downsampled to a smaller frame rate (3FPS). Each frame is then
captioned with BLIP [29]. Generated captions in most scanning windows are similar, except when scene
changes occur in the window. In that case, two different captions will be concatenated with the conjunction
“Then”. With the CLIP text encoder and image encoder being fixed, the CLIP loss [16] is calculated for
fMRI-image and fMRI-text, respectively. Denote the pooled text embedding, image embedding, and fMRI
embedding by embt, embi, embf ∈Rn×b. The contrastive language-image-fMRI loss is given by
L=(LCLIP(embf , embt)+LCLIP(embf , embi))/2, (3)
where LCLIP(a, b)=CrossEntropy(a·bT, [0,1,...,n]), with  being a scaling factor. Extra care is needed
to reduce similar frames in a batch for better contrastive pairs. From Eq. (3), we see that the loss largely
depends on the batch size n. Thus, a large n with data augmentation on all modalities is appreciated.

3.4 Video Generative Module

The Stable Diffusion model [19] is used as the base generative model considering its excellence in
generation quality, computational requirements, and weights availability. However, as the stable diffusion
model is an image-generative model, temporal constraints need to be applied in order for video generation.
Scene-Dynamic Sparse Causal (SC) Attention Authors in [28] use a network inflation trick with sparse
temporal attention to adapt the stable diffusion to a video generative model. Specifically, the sparse temporal
attention effectively conditions each frame on its previous frame and the first frame, which ensures frame
consistency and also keeps the scene unchanged. However, the human vision consists of possible scene
changes, so the video generation should also be scene-dynamic. Thus, we relax the constraint in [28] and
condition each frame on its previous two frames, ensuring the video smoothness while allowing scene
dynamics. Using notations from [28], the SC attention is calculated with the query, key, and value given by
Q=W Q ·zvi , K =W K ·[zvi−2 , zvi−1 ], V =W V ·[zvi−2 , zvi−1 ], (4)
where zvi denotes the latent of the i-th frame during the generation.
Adversarial Guidance for fMRI Classifier-free guidance is widely used in the conditional sampling of
diffusion models for its flexibility and generation diversity, where the noise update function is given by
ˆθ (zt, c)=θ (zt)+s(θ (zt, c)−θ (zt)), (5)
where c is the condition, s is the guidance scale and θ (·) is a score estimator implemented with UNet [30].
Interestingly, Eq. (5) can be changed to an adversarial guidance version [19]
ˆθ (zt, c, c̄)=θ (zt, c̄)+s(θ (zt, c)−θ (zt, c̄)), (6)
where c̄ is the negative guidance. In effect, generated contents can be controlled through “what to generate”
(positive guidance) and “what not to generate” (negative guidance). When c̄ is a null condition, the noise
update function falls back to Eq. (5), the regular classifier-free guidance. In order to generate diverse videos
for different fMRI, guaranteeing the distinguishability of the inputs, we average all fMRI in the testing set
and use the averaged one as the negative condition. Specifically, for each fMRI input, the fMRI encoder
will generate an unpooled token embedding x∈Rl×b, where l is the latent channel number. Denote the
averaged fMRI as x̄. We have the noise update function ˆθ (zt, x, x̄)=θ (zt, x̄)+s(θ (zt, x)−θ (zt, x̄)).

5
Divide and Refine With a decoupled structure, two modules are trained separately: the fMRI encoder is
trained in a large-scale dataset and then tuned in the target dataset with contrastive learning; the generative
module is trained with videos from the target dataset using text conditioning. In the second phase, two
modules are tuned together with fMRI-video pairs, where the encoder and part of the generative model
are trained. Different from [28], we tune the whole self-attention, cross-attention, and temporal-attention
heads instead of only the query projectors, as a different modality is used for conditioning. The second
phase is also the last stage of encoder progressive learning, after which the encoder finally generates token
embeddings that contain rich semantic information and are easy to understand by the generative model.

3.5 Learning from the Brain - Interpretability

Our objectives extend beyond brain decoding and reconstruction. We also aim to understand the decoding
process’s biological principles. To this end, we visualize average attention maps from the first, middle,
and last layers of the fMRI encoder across all testing samples. This approach allows us to observe the
transition from capturing local relations in early layers to recognizing more global, abstract features in
deeper layers [31]. Additionally, attention maps are visualized for different learning stages: large-scale
pre-training, contrastive learning, and co-training. By projecting attention back to brain surface maps, we
can easily observe each brain region’s contributions and the learning progress through each stage.

4 Experiments

4.1 Datasets

Pre-training dataset Human Connectome Project (HCP) 1200 Subject Release [26]: For our upstream
pre-training dataset, we employed resting-state and task-evoked fMRI data from the HCP. Building upon
[6], we obtained 600,000 fMRI segments from a substantial amount of fMRI scan data.
Paired fMRI-Video dataset A publicly available benchmark fMRI-video dataset [10] was used, com-
prising fMRI and video clips. The fMRI were collected using a 3T MRI scanner at a TR of 2 seconds
with three subjects. The training data included 18 segments of 8-minute video clips, totaling 2.4 video
hours and yielding 4,320 paired training examples. The test data comprised 5 segments of 8-minute video
clips, resulting in 40 minutes of test video and 1,200 test fMRIs. The video stimuli were diverse, covering
animals, humans, and natural scenery, and featured varying lengths at a temporal resolution of 30 FPS.

4.2 Implementation Details

The original videos are downsampled from 30 FPS to 3 FPS for efficient training and testing, leading to 6
frames per fMRI frame. In our implementation, we reconstruct a video of 2 seconds (6 frames) from one
fMRI frame. However, thanks to the spatiotemporal attention head design that encodes multiple fMRI at
once, our method can reconstruct longer videos from multiple fMRI if more GPU memory is available.
A ViT-based fMRI encoder with a patch size of 16, a depth of 24, and an embedding dimension of 1024 is
used. After pre-training with a mask ratio of 0.75, the encoder will be augmented with a projection head
that projects the token embedding into the dimension of 77×768. The Stable Diffusion V1-5 [19] trained
at the resolution of 512×512 is used. But we tune the augmented Stable Diffusion at the resolution of
256×256 with 3 FPS. Notice that the FPS and image are downsampled for efficient experiments, and our
method can also work with full temporal and spatial resolution. All parameters in the MBM pre-training
are the same as [6] with eight RTX3090, while other stages are trained with one RTX3090. The inference
is performed with 200 DDIM [32] steps. See Supplementary for more details.

4.3 Evaluation Metrics

Following prior studies, we utilize both frame-based and video-based metrics. Frame-based metrics evaluate
each frame individually, providing a snapshot evaluation, whereas video-based metrics assess sequences of
frames, encapsulating the dynamics across frames. Both are used for a comprehensive analysis. Unless
stated otherwise, all test set videos are used for evaluating the three subjects.
Frame-based Metrics Our frame-based metrics are divided into two classes, pixel-level metrics and
semantics-level metrics. We use the structural similarity index measure (SSIM) [33] as the pixel-level
metric and the N-way top-K accuracy classification test as the semantics-level metric. Specifically, for

6
GT

Ours

Kupershmit,
2022

Wang,
2022

Wen,
2018 MinD-Vis
Chen, 2023
Figure 4. Compare with Benchmarks. We compare our results with the samples provided in the previous literature.
Our method generates samples that are more semantically meaningful and match with the groundtruth.

each frame in a scan window, we calculate the SSIM and classification test accuracy with respect to the
groundtruth frame. To perform the classification test, we basically compare the classification results of the
groundtruth (GT) and the predicted frame (PF) using an ImageNet classifier. If the GT class3 is within the
top-K probability of the PF classification results from N randomly picked classes, including the GT class,
we declare a successful trial. The test is repeated for 100 times, and the average success rate is reported.
Video-based Metric The video-based metric measures the video semantics using the classification test
as well, except that a video classifier is used. The video classifier based on VideoMAE [34] is trained on
Kinetics-400 [35], an annotated video dataset with 400 classes, including motions, human interactions, etc.

5 Results
We compare our method against three fMRI-video baselines: Wen et al. (2018) [10], Wang et al. (2022) [11]
and Kupershmidt et al. (2022) [12]. Visual comparisons are shown in Fig. 4, and quantitative comparisons
are shown in Fig. 6, where publicly available data and samples are used for comparison. As shown, we
generate high-quality videos with more semantically meaningful content. Following the literature, we
evaluate the SSIM of Subject 1 with the first testing video, achieving a score of 0.186, outperforming the
state-of-the-art by 45%. When comparing with Kupershmidt et al. (2022), we evaluate all test videos for
different subjects, and our method outperforms by 35% on average, as shown in Fig. 6. Using semantic-
level metrics, our method achieves a success rate of 0.849 and 0.2 in 2-way and 50-way top-1 accuracy
classification tests, respectively, with the video classifier. The image classifier gives a success rate of 0.795
and 0.19, respectively, with the same tests, which significantly surpasses the chance level of these two
tests (2-way: 0.5, 50-way: 0.02). Full results are shown in Tab. 1. We also compare our results with an
image-fMRI model by Chen et al. (2023) [6]. An image is produced for each fMRI, samples of which
are shown in Fig. 4 with the “walking man” as the groundtruth. Even though the results and groundtruth
are semantically matching, frame consistency and image quality are not satisfying. A lag due to the
hemodynamic response is also observed. The first frame actually corresponds to the previous groundtruth.
Different Subjects After fMRI pre-processing, each subject varies in the size of ROIs, where Subject 1, 2
and 3 have 6016, 6224, and 3744 voxels, respectively. As Subject 3 has only half the voxels of the others,
a larger batch size can be used during contrastive learning, which may lead to better results as shown in
Tab. 1. Nonetheless, all subjects are consistent in both numeric and visual evaluations (See Supplementary).
Recovered Semantics In the video reconstruction, we define the semantics as the objects, animals, persons,
and scenes in the videos, as well as the motions and scene dynamics, e.g., people running, fast-moving
scenes, close-up scenes, long-shot scenes, etc. We show that even though the fMRI has a low temporal
resolution, it contains enough information to recover the mentioned semantics. Fig. 5 shows a few examples
of reconstructed frames using our method. Firstly, we can see that the basic objects, animals, persons, and
scene types can be well recovered. More importantly, the motions, such as running, dancing, and singing,
and the scene dynamics, such as the close-up of a person, the fast-motion scenes, and the long-shot scene of
a city view, can also be reconstructed correctly. This result is also reflected in our numerical metrics, which
consider both frame semantics and video semantics, including various categories of motions and scenes.
3
Since videos cannot be well described with a single ImageNet class, we use the top-K classification results as the
GT class, and a successful event is declared if the test succeeds with any of the GT class.

7
GT

Ours

GT

Ours

Scene changes
Figure 5. Reconstruction Diversity. Various motions, scenes, persons, and animals can be correctly recovered. A
sample with a scene transition is shown on the bottom right.
Table 1. Ablation study on window sizes, multimodal contrastive learning, and adversarial guidance (AG). Evaluations
on different subjects are also shown. Full Model: win=2, Sub 1. Colors reflect statistical significance (two-sample
t-test) compared to the Full Model. p < 0.0001 (purple); p < 0.01 (pink); p < 0.05 (yellow); p > 0.05 (green)
Video-based Frame-based
Semantic-level Semantic-level Pixel-level
2-way↑ 50-way↑ 2-way↑ 50-way↑ SSIM↑
Full Model 0.853±0.03 0.202±0.02 0.792±0.03 0.172±0.01 0.171
Window Size = 1 0.851±0.03 0.195±0.02 0.759±0.03 0.165±0.01 0.169
Window Size = 3 0.826±0.03 0.161±0.01 0.765±0.03 0.137±0.01 0.161
w/o Contrastive 0.844±0.03 0.157±0.02 0.750±0.03 0.088±0.07 0.135
Text-fMRI Contra 0.839±0.03 0.185±0.01 0.78±0.03 0.154±0.01 0.164
Img-fMRI Contra 0.845±0.03 0.189±0.01 0.783±0.03 0.151±0.01 0.164
w/o AG 0.859±0.03 0.198±0.02 0.775±0.03 0.117±0.01 0.152
Subject 2 0.841±0.03 0.173±0.02 0.784±0.03 0.158±0.13 0.171
Subject 3 0.846±0.03 0.216±0.02 0.812±0.03 0.193±0.01 0.187

Figure 6. SSIM Comparision. Left: comparison in Subject 1, test video 1. Right: all subjects, all test videos.
Abalations We test our method using different window sizes, starting from a window size of 1 up to 3.
When the window size is one, the fMRI encoder falls back to a normal MBM encoder in [6]. Tab. 1 shows
that when all other parameters are fixed, a window size of 2 gives the best performance in general, which is
reasonable as the hemodynamic response usually will not be longer than two scan windows. Additionally,
we also test the effectiveness of multimodal contrastive learning. As shown in Tab. 1, without contrastive
learning, the generation quality degrades significantly. When two modalities are used, either text-fMRI or
image-fMRI, the performance is inferior to the full modalities used in contrastive learning. Actually, the
reconstructed videos are visually worse than the full model (See Supplementary). Thus, it shows that the
full progressive learning pipeline is crucial for the fMRI encoder to learn useful representations for this
task. We also assess the reconstruction results without adversarial guidance. As a result, both numeric and
visual evaluations decrease substantially. In fact, the generated videos can be highly similar sometimes,
indicating that the negative guidance is critical in increasing the distinguishability of fMRI embeddings.

5.1 Interpretation Results

We summarize the attention analysis in Fig. 7. We present the sum of the normalized attention within
Yeo17 networks [21] in the bar charts. Voxel-wise attention is displayed on a brain flat map, where we see
comprehensive structural attention throughout the whole region. The average attention across all testing
samples and attention heads is computed, revealing three insights on how transformers decode fMRI.

8
A B
VisPeri v1 v2
v3 v2 v3
v3 v4
v1
v4
VisPeri v1 v2 VisPeri
v2
DorsAttn DorsAttn

Default Default
Visual Cortex

C D E
First Layer Middle Layer Last Layer

Figure 7. Attention visualization. We visualized the attention maps for different transformer layers (C, D, E) and
learning stages (B) with bar charts and brain flat maps. Brain networks are marked on a brain surface map (A)
Dominance of visual cortex: The visual cortex emerges as the most influential region. This region,
encompassing both the central (VisCent) and peripheral visual (VisPeri) fields, consistently attracts the
highest attention across different layers and training stages (shown in Fig. 7B). In all cases, the visual cortex
is always the top predictor, which aligns with prior research, emphasizing the vital role of the visual cortex
in processing visual spatiotemporal information[36]. However, the visual cortex is not the sole determinant
of vision. Higher cognitive networks, such as the dorsal attention network (DorsAttn) involved in voluntary
visuospatial attention control [37], and the default mode network (Default) associated with thoughts and
recollations [38], also contribute to visual perceptions process [39] as shown in Fig. 7.
Layer-dependent hierarchy: The layers of the fMRI encoder function in a hierarchical manner, as shown
in Fig. 7C, D and E. In the early layers of the network (panel A & C), we observe a focus on the structural
information of the input data, marked by a clear segmentation of different brain regions by attention values,
aligning with the visual processing hierarchy [40]. As the network dives into deeper layers (panel D & E),
the learned information becomes more dispersed. The distinction between regions diminishes, indicating a
shift toward learning more holistic and abstract visual features in deeper layers.
Learning semantics progressively: To illustrate the learning progress of the fMRI encoder, we analyze
the first-layer attention after all learning stages, as shown in panel B: before contrastive learning, after
contrastive learning, and after co-training with the video generation model. We observe an increase in
attention in higher cognitive networks and a decrease in the visual cortex as learning progresses. This
indicates the encoder assimilates more semantic information as it evolves through each learning stage,
improving the learning of cognitive-related features in the early layers.

6 Discussion and Conclusion

Conclusion We propose MinD-Video, which reconstructs high-quality videos with arbitrary frame rates
from fMRI. Starting from a large-scale pre-training to multimodal contrastive learning with augmented
spatiotemporal attention, our fMRI encoder learns fMRI features progressively. Then we finetune an
augmented stable diffusion for video generations, which is co-trained together with the encoder. Finally, we
show that with fMRI adversarial guidance, MinD-Video recovers videos with accurate semantics, motions,
and scene dynamics compared with the groundtruth, establishing a new state-of-the-art in this domain. We
also show through attention maps that the trained model decodes fMRI with reliable biological principles.
Limitations Our method is still within the intra-subject level, and inter-subject generalization ability
remains unexplored due to individual variations. Additionally, our method only uses less than 10% of the
voxels from the cortex for reconstructions, while using the whole brain data remains unexploited.
Broader Impacts We believe this field has promising applications as large models develop, from neuro-
science to brain-computer interfaces. But governmental regulations and efforts from research communities
are required to ensure the privacy of one’s biological data and avoid any malicious usage of this technology.

9
References

[1] T. T. Liu, “Noise contributions to the fmri signal: An overview,” NeuroImage, vol. 143, pp. 141–151,
2016.
[2] T. Horikawa and Y. Kamitani, “Generic decoding of seen and imagined objects using hierarchical
visual features,” Nature communications, vol. 8, no. 1, pp. 1–15, 2017.
[3] P. R. Roelfsema, D. Denys, and P. C. Klink, “Mind reading and writing: The future of neurotechnology,”
Trends in cognitive sciences, vol. 22, no. 7, pp. 598–610, 2018.
[4] G. Shen, T. Horikawa, K. Majima, and Y. Kamitani, “Deep image reconstruction from human brain
activity,” PLoS computational biology, vol. 15, no. 1, p. e1006633, 2019.
[5] R. Beliy, G. Gaziv, A. Hoogi, F. Strappini, T. Golan, and M. Irani, “From voxels to pixels and
back: Self-supervision in natural-image reconstruction from fmri,” Advances in Neural Information
Processing Systems, vol. 32, 2019.
[6] Z. Chen, J. Qing, T. Xiang, W. L. Yue, and J. H. Zhou, “Seeing beyond the brain: Masked modeling
conditioned diffusion model for human vision decoding,” in Proceedings of the IEEE/CVF Conference
on Computer Vision and Pattern Recognition (CVPR), 2023.
[7] Y. Takagi and S. Nishimoto, “High-resolution image reconstruction with latent diffusion models from
human brain activity,” Proc. CVPR, 2023.
[8] R. L. Buckner, “Event-related fmri and the hemodynamic response,” Human brain mapping, vol. 6,
no. 5-6, pp. 373–377, 1998.
[9] J. Dubois and R. Adolphs, “Building a science of individual differences from fmri,” Trends in cognitive
sciences, vol. 20, no. 6, pp. 425–443, 2016.
[10] H. Wen, J. Shi, Y. Zhang, K.-H. Lu, J. Cao, and Z. Liu, “Neural encoding and decoding with deep
learning for dynamic natural vision,” Cerebral cortex, vol. 28, no. 12, pp. 4136–4160, 2018.
[11] C. Wang, H. Yan, W. Huang, J. Li, Y. Wang, Y.-S. Fan, W. Sheng, T. Liu, R. Li, and H. Chen,
“Reconstructing rapid natural vision with fmri-conditional video generative adversarial network,”
Cerebral Cortex, vol. 32, no. 20, pp. 4502–4511, 2022.
[12] G. Kupershmidt, R. Beliy, G. Gaziv, and M. Irani, “A penny for your (visual) thoughts: Self-supervised
reconstruction of natural movies from brain activity,” arXiv preprint arXiv:2206.03544, 2022.
[13] A. Radford, J. Wu, R. Child, D. Luan, D. Amodei, I. Sutskever et al., “Language models are
unsupervised multitask learners,” OpenAI blog, vol. 1, no. 8, p. 9, 2019.
[14] K. He, X. Chen, S. Xie, Y. Li, P. Dollár, and R. Girshick, “Masked autoencoders are scalable vision
learners,” in Proc. CVPR’22, 2022, pp. 16 000–16 009.
[15] J. Devlin, M.-W. Chang, K. Lee, and K. Toutanova, “Bert: Pre-training of deep bidirectional
transformers for language understanding,” arXiv preprint arXiv:1810.04805, 2018.
[16] A. Radford, J. W. Kim, C. Hallacy, A. Ramesh, G. Goh, S. Agarwal, G. Sastry, A. Askell, P. Mishkin,
J. Clark et al., “Learning transferable visual models from natural language supervision,” in Interna-
tional conference on machine learning. PMLR, 2021, pp. 8748–8763.
[17] J. Ho, A. Jain, and P. Abbeel, “Denoising diffusion probabilistic models,” in Advances in Neural
Information Processing Systems 33: Annual Conf. on Neural Information Processing Systems 2020,
NeurIPS 2020, December 6-12, 2020, virtual, H. Larochelle, M. Ranzato, R. Hadsell, M. Balcan, and
H. Lin, Eds., 2020.
[18] Y. Song and S. Ermon, “Generative modeling by estimating gradients of the data distribution,”
Advances in Neural Information Processing Systems, vol. 32, 2019.
[19] R. Rombach, A. Blattmann, D. Lorenz, P. Esser, and B. Ommer, “High-resolution image synthesis
with latent diffusion models,” in Proc. CVPR’22, 2022, pp. 10 684–10 695.
[20] M. F. Glasser, T. S. Coalson, E. C. Robinson, C. D. Hacker, J. Harwell, E. Yacoub, K. Ugurbil,
J. Andersson, C. F. Beckmann, M. Jenkinson et al., “A multi-modal parcellation of human cerebral
cortex,” Nature, vol. 536, no. 7615, pp. 171–178, 2016.
[21] B. T. Yeo, F. M. Krienen, J. Sepulcre, M. R. Sabuncu, D. Lashkari, M. Hollinshead, J. L. Roffman,
J. W. Smoller, L. Zöllei, J. R. Polimeni et al., “The organization of the human cerebral cortex estimated
by intrinsic functional connectivity,” Journal of neurophysiology, 2011.

10
[22] A. A. Rusu, N. C. Rabinowitz, G. Desjardins, H. Soyer, J. Kirkpatrick, K. Kavukcuoglu, R. Pascanu,
and R. Hadsell, “Progressive neural networks,” arXiv preprint arXiv:1606.04671, 2016.
[23] M. Tan and Q. Le, “Efficientnetv2: Smaller models and faster training,” in International conference
on machine learning. PMLR, 2021, pp. 10 096–10 106.
[24] C. Li, B. Zhuang, G. Wang, X. Liang, X. Chang, and Y. Yang, “Automated progressive learning for
efficient training of vision transformers,” in Proceedings of the IEEE/CVF Conference on Computer
Vision and Pattern Recognition, 2022, pp. 12 486–12 496.
[25] A. Dosovitskiy, L. Beyer, A. Kolesnikov, D. Weissenborn, X. Zhai, T. Unterthiner, M. Dehghani,
M. Minderer, G. Heigold, S. Gelly et al., “An image is worth 16x16 words: Transformers for image
recognition at scale,” arXiv preprint arXiv:2010.11929, 2020.
[26] D. C. Van Essen, S. M. Smith, D. M. Barch, T. E. Behrens, E. Yacoub, K. Ugurbil, W.-M. H.
Consortium et al., “The wu-minn human connectome project: an overview,” Neuroimage, vol. 80, pp.
62–79, 2013.
[27] M. A. Lindquist, J. M. Loh, L. Y. Atlas, and T. D. Wager, “Modeling the hemodynamic response
function in fmri: efficiency, bias and mis-modeling,” Neuroimage, vol. 45, no. 1, pp. S187–S198,
2009.
[28] J. Z. Wu, Y. Ge, X. Wang, W. Lei, Y. Gu, W. Hsu, Y. Shan, X. Qie, and M. Z. Shou, “Tune-a-
video: One-shot tuning of image diffusion models for text-to-video generation,” arXiv preprint
arXiv:2212.11565, 2022.
[29] J. Li, D. Li, C. Xiong, and S. Hoi, “Blip: Bootstrapping language-image pre-training for unified
vision-language understanding and generation,” in International Conference on Machine Learning.
PMLR, 2022, pp. 12 888–12 900.
[30] J. Ho and T. Salimans, “Classifier-free diffusion guidance,” in NeurIPS 2021 Workshop on Deep
Generative Models and Downstream Applications, 2022.
[31] A. Ghiasi, H. Kazemi, E. Borgnia, S. Reich, M. Shu, M. Goldblum, A. G. Wilson, and T. Goldstein,
“What do vision transformers learn? a visual exploration,” arXiv preprint arXiv:2212.06727, 2022.
[32] J. Song, C. Meng, and S. Ermon, “Denoising diffusion implicit models,” arXiv preprint
arXiv:2010.02502, 2020.
[33] Z. Wang, A. C. Bovik, H. R. Sheikh, and E. P. Simoncelli, “Image quality assessment: from error
visibility to structural similarity,” IEEE transactions on image processing, vol. 13, no. 4, pp. 600–612,
2004.
[34] Z. Tong, Y. Song, J. Wang, and L. Wang, “Videomae: Masked autoencoders are data-efficient learners
for self-supervised video pre-training,” arXiv preprint arXiv:2203.12602, 2022.
[35] W. Kay, J. Carreira, K. Simonyan, B. Zhang, C. Hillier, S. Vijayanarasimhan, F. Viola, T. Green,
T. Back, P. Natsev et al., “The kinetics human action video dataset,” arXiv preprint arXiv:1705.06950,
2017.
[36] J. H. van Hateren and D. L. Ruderman, “Independent component analysis of natural image sequences
yields spatio-temporal filters similar to simple cells in primary visual cortex,” Proceedings of the
Royal Society of London. Series B: Biological Sciences, vol. 265, no. 1412, pp. 2315–2320, 1998.
[37] J. M. Kincade, R. A. Abrams, S. V. Astafiev, G. L. Shulman, and M. Corbetta, “An event-related
functional magnetic resonance imaging study of voluntary and stimulus-driven orienting of attention,”
Journal of Neuroscience, vol. 25, no. 18, pp. 4593–4604, 2005.
[38] J. R. Andrews-Hanna, “The brain’s default network and its adaptive role in internal mentation,” The
Neuroscientist, vol. 18, no. 3, pp. 251–270, 2012.
[39] U. Hasson, O. Furman, D. Clark, Y. Dudai, and L. Davachi, “Enhanced intersubject correlations
during movie viewing correlate with successful episodic encoding,” Neuron, vol. 57, no. 3, pp.
452–462, 2008.
[40] D. C. Van Essen and J. H. Maunsell, “Hierarchical organization and functional streams in the visual
cortex,” Trends in neurosciences, vol. 6, pp. 370–375, 1983.

11
Supplementary Material

A Q&A Session

Where does the performance gain come from? Is it driven by the diffusion model only? The perfor-
mance gain in our model is not solely driven by the diffusion model. It is, in fact, a result of the combined
efforts of two major stages: the fMRI encoder and the stable diffusion model.
In the first stage, the fMRI encoder plays a crucial role in learning representations from the brain. It
effectively captures the complex spatiotemporal information embedded in the fMRI data, allowing the
model to understand and interpret the underlying neural activities. This step is particularly important as it
forms the foundation of our model and significantly influences the subsequent steps.
In the second stage, the stable diffusion model steps in to generate videos. One of the key advantages
of our stable diffusion model over other generative models, such as GANs, lies in its ability to produce
higher-quality videos. It leverages the representations learned by the fMRI encoder and utilizes its unique
diffusion process to generate videos that are not only of superior quality but also better align with the
original neural activities.
What does the fMRI encoder learn? Why don’t we train an fMRI to object classifier, followed by a
generation model? The fMRI encoder is designed to learn intricate representations from brain activity.
These representations go beyond simple categorical information to encompass more nuanced semantic
details that can’t be adequately captured by discrete class labels (e.g. image texture, depth, etc.). Due to the
richness and diversity of human thought and perception, a model that can handle continuous semantics,
rather than discrete ones, is necessary.
The proposal to train an fMRI-to-object classifier followed by a generation model does not align with our
goal of comprehensive brain decoding. This is largely due to a crucial trade-off between classification
complexity and solution space:

• Classification Complexity: Classifying fMRI data into a large number of classes (e.g., 1000
classes) is non-trivial. As reported in [2], reasonable performance can only be achieved in
a smaller classification task (less than 50-way), due to the limited data per category and the
complexity of the task.
• Limited Solution Space: The solution space of discrete classes is significantly more restricted
than that of continuous semantics. Thus, a classifier may not capture the complex, multi-faceted
nature of brain activities.

This trade-off illustrates why a classifier might not be the best approach for this task. In contrast, our
proposed method focuses on learning continuous semantic representations from the brain, which better
reflects the complexity and diversity of neural processes. This approach not only improves the quality of
the generated videos but also provides more meaningful and interpretable insights into brain decoding.
Is the fMRI-video generation pipeline simply imputing missing frames in a sequence of static images
based on the fMRI-image generation pipeline? No, the fMRI-to-video generation process is not merely
an imputation on the fMRI-to-image generation pipeline. While both involve generating visual content
based on fMRI data, the tasks and their complexities are fundamentally different.
The fMRI-to-image generation involves mapping brain activity to a static image. This task primarily
focuses on spatial information, that is, which brain regions are active and how they relate to elements in an
image.
In contrast, the fMRI-to-video generation task involves mapping brain activity to dynamic videos. This task
is considerably more complex as it requires the model to capture both spatial information and temporal
dynamics. It’s not just about predicting which brain regions are active, but also about understanding how
these activations change over time and how they relate to moving elements in a video.
Adding to the complexity is the hemodynamic response inherent in fMRI data, which introduces a delay
and blur in the timing of neural activity. This necessitates careful handling of the temporal aspects in the
data. Furthermore, the temporal resolution of fMRI is quite low, making it challenging to capture fast-paced
changes in neural activity.

12
We also use a stable diffusion process as our generative model, which is a probabilistic model. This means
that the generation process involves a degree of randomness, leading to slight differences during each
generation for video frames. Additionally, in video generation, we need to ensure consistency across video
frames, which adds another layer of complexity.

B More Implementation Details


Large-Scale Pre-training The large-scale pre-training uses the same setup as the MBM described in [6].
A ViT-large-based model with a 1-dimensional patchifier is trained with hyperparameters shown in Tab. B.1.
The training takes around 3 days using 8RTX3090 GPUs. The training is performed on the 600,000 fMRI
from HCP. Same as the literature, after the large-scale pre-training, the autoencoder is tuned with fMRI
data from the target dataset, namely, Wen (2018), using MBM as well. The tuning is performed using a
small learning rate and epochs.

parameter value parameter value parameter value parameter value


patch size 16 encoder depth 24 decoder embed dim 512 clip gradient 0.8
embedding dim 1024 encoder heads 16 learning rate 2.5e-4 weight decay 0.05
mask ratio 0.75 decoder depth 8 warm-up epochs 40 batch size 500
mlp ratio 1.0 decoder heads 16 epochs 500 optimizer AdamW
Table B.1. Hyperparameters used in the large-scale pre-training

Multimodal Contrastive Learning In this step, we will take the pre-trained fMRI encoder from the
previous step and augment it with temporal attention heads to accommodate multiple fMRI. Then contrastive
learning is performed with fMRI-image-text triplets. The image is a randomly-picked frame from an
fMRI scan window. As mentioned, there are two important factors in the contrastive: batch size and data
augmentations. Therefore, data augmentations are applied for all modalities. Random sparsification is used
for fMRI, where 20% of voxels are randomly set to zeros each time. The random crop is applied to videos
with a probability of 0.5. To augment the frame captions, we apply synonym augmentation and random
word swapping. Due to a small dataset size (∼4000), we use a dropout rate of 0.6 to avoid overfitting. For
Subject 1 and 2, the training is performed with a batch size of 20, while a batch size of 32 is used due to
fewer fMRI voxels with Subject 3. Training for all subjects is performed for 1,2000 steps with a learning
rate of 2×10−5. The training takes around 10 hours using one RTX3090.
Training of Augmented Stable Diffusion The stable diffusion model is augmented with temporal attention
heads for video generation. We train the augmented stable diffusion model with videos from the target
datasets. The videos are downsampled from 30 FPS to 3 FPS at a resolution of 256×256 due to limited
GPU memory, even though our model can work with the full time resolution. This step is important for
two reasons: 1) the augmented temporal heads are untrained; 2) the stable diffusion is pre-trained at a
resolution of 512×512, so we need to adapt it to a lower resolution.
During the training, we update the self-attention heads (“attn1”), cross-attention heads (“attn2”), and
temporal attention heads (“attn_temp”). The training is performed with text conditioning for 800 steps. We
use a learning rate 2×10−5 and a batch size of 14. The training takes around 2 hours using one RTX3090.
Visual results show that videos of high quality can be generated with text conditioning after this step.
Co-training The fMRI encoder produces embeddings of dimensions 77×768, which are used to condition
the augmented stable model during co-training. The whole fMRI encoder is updated, and only part of the
stable diffusion is updated (same as the last step). The training is performed with a batch size of 9 and a
learning rate of 3×10−5 for 1,5000 steps. The training takes around 16 hours using one RTX3090.
Inference All samples are generated with 200 diffusion steps using fMRI adversarial guidance. The fMRI
adversarial guidance uses an average fMRI as the negative guidance with a guidance scale of 12.5.

C Analysis of Visual Results


We test on all three subjects in Wen (2018) dataset. Around 6000 voxels are identified as ROI for Subject 1
and 2, while around 3000 voxels are identified for Subject 3. Thus, a larger batch size can be used when
training with Subject 3, which may be the reason for its better numeric evaluation results. Nonetheless, all
three subjects show consistent generation results. Some samples are shown in Fig. C.1.

13
GT

Sub1

Sub2

Sub3

Figure C.1. Samples from different subjects.

Visual results of the ablation studies are shown in Fig. C.2. The Full model is trained with our full pipeline
and inference with adversarial guidance. In contrastive learning ablation, we tested with incomplete
modality, namely, image-fMRI and text-fMRI, respectively. Similar to the numeric evaluations, using
incomplete contrastive gave an unsatisfactory visual result compared to using all three modality. However,
incomplete modality still outperformed inferencing without adversarial guidance significantly, which
generated visually meaningless results.

GT

Full

Image
Contrastive

Text
Contrastive

w/o
Adversarial
Guidance

Figure C.2. Reconstruction samples for ablation studies. The Full model uses full modality contrastive learning with
adversarial guidance.

14
Some fail cases are shown in Fig. C.3. It is observed that even though some fail cases generated different
animals and objects compared to the groundtruth, other semantics like the motions, color, and scene
dynamics can still be correctly reconstructed. For example, even though the airplane and flying bird are not
reconstructed, similar fast-motion scenes are recovered in Fig. C.3.

GT

Ours

GT

Ours

Figure C.3. Fail cases.

15

You might also like

pFad - Phonifier reborn

Pfad - The Proxy pFad of © 2024 Garber Painting. All rights reserved.

Note: This service is not intended for secure transactions such as banking, social media, email, or purchasing. Use at your own risk. We assume no liability whatsoever for broken pages.


Alternative Proxies:

Alternative Proxy

pFad Proxy

pFad v3 Proxy

pFad v4 Proxy