Skip to content

JustAname12345/ai-take-home-test-solution

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

11 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Pantheon Lab Programming Assignment

PyTorch Lightning Config: Hydra Template

What is all this?

This repository features a GAN for MNIST digit generation and a Stable Diffusion model for creating flower images from text descriptions. It includes training routines for both networks, showcasing deep learning approaches to generative modeling in response to a "programming assignment."

Questions and Answers?

  1. What is the role of the discriminator in a GAN model? Use this project's discriminator as an example. In a GAN (Generative Adversarial Network) model, the role of the discriminator is to distinguish between real and fake data. The discriminator is trained to maximize its ability to correctly label real data as real and generated (fake) data as fake. In this specific project, the discriminator takes flattened images as input and outputs a single scalar representing the probability that the given image is real. The model uses a series of linear layers and leaky ReLU activations to process the input, concluding with a sigmoid function to squish the output between 0 and 1, where 1 indicates 'real' and 0 'fake'.

  2. The generator network in this code base takes two arguments: noise and labels. What are these inputs and how could they be used at inference time to generate an image of the number 5? The generator in a GAN takes noise vectors as input, which provide a source of randomness that allows the generator to produce a variety of outputs. The optional labels argument could be used in a conditional GAN setup, where the labels help guide the generation process to produce outputs specific to the given labels. To generate an image of the number 5 at inference time, you would feed the generator a noise vector along with the label for '5', assuming the generator has been trained in a conditional manner to recognize and generate images corresponding to specific labels.

  3. What steps are needed to deploy a model into production? To deploy a model into production, several steps are typically involved:

Model Validation: Ensure the model meets performance criteria on a validation set. Model Serialization: Save the trained model using a format like ONNX or TorchScript. Deployment Environment: Set up the environment where the model will run, which could be a cloud platform, on-premises servers, or edge devices. Integration: Integrate the model with the existing production infrastructure, which may involve API development for model inference. Monitoring and Maintenance: Monitor the model's performance over time and update it as necessary to handle new data or performance issues.

4.If you wanted to train with multiple GPUs, what can you do in pytorch lightning to make sure data is allocated to the correct GPU?

To train with multiple GPUs in PyTorch Lightning efficiently, you can utilize the built-in Trainer class which simplifies setting up GPU configurations:

  1. Setting Up the Trainer You can specify the number of GPUs and the distribution strategy directly in the Trainer:

    from pytorch_lightning import Trainer trainer = Trainer(gpus=2, accelerator='gpu', strategy='ddp')

  2. Selecting a Strategy DDP (Distributed Data Parallel) is recommended as it creates a complete model replica on each GPU, ensuring efficient parallel training.

  3. Adjusting Batch Size The total batch size specified is divided among the GPUs, so each GPU processes total_batch_size / num_gpus.

  4. Environment Configuration Ensure CUDA, cuDNN, and NCCL (on Linux) are properly installed to support multi-GPU training.

    trainer = Trainer(gpus=2, accelerator='gpu', strategy='ddp') model = YourLightningModule() trainer.fit(model) This setup maximizes training efficiency by ensuring each GPU is effectively utilized and data is correctly distributed.

All implementation tasks in the code are marked with completed

For example, training the model for around 2 epochs will give you results like this:

example_train

The best model is selected based on val_loss(loss of discriminator+ loss of generator), like following example_train

Getting started

After cloning this repo, install dependencies

# [OPTIONAL] create conda environment
conda create --name pantheon-py38 python=3.8
conda activate pantheon-py38

# install requirements
pip install -r requirements.txt

To ensure proper logging of training data via wandb, please replace 'xxxx' with your API key in the .env file as follows: WANDB_API_KEY="xxxx"

Train model with experiment configuration

# default
python run.py experiment=train_mnist_gan.yaml


# train on CPU
python run.py experiment=train_mnist_gan.yaml trainer.gpus=0

# train on GPU
python run.py experiment=train_mnist_gan.yaml trainer.gpus=1

it will train a GAN that could generate fake MNIST data

You also can override experiment configuration to train a additional stable diffusion model (generate flower Figure based on description) Due to computational constraints, we've downscaled the Stable Diffusion model—for instance, opting for ResNet18 over ViT. Consequently, this serves as a proof of concept rather than a fully-fledged application. Regarding the variant of Stable Diffusion, I used a transformer for feature fusion and image reconstruction. This choice was due to hardware limitations, which prevented me from using a traditional DDPM-based framework, so I opted for a transformer as a proof of concept.

python run.py experiment=stable_diffusion.yaml

About

No description, website, or topics provided.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages