Soham Deshmukh d19700fd98 README updates
2022-11-08 11:02:15 -08:00
2022-11-08 10:55:31 -08:00
2022-11-02 17:55:32 +00:00
2022-11-02 10:55:49 -07:00
2022-11-08 11:02:15 -08:00
2022-11-08 11:02:15 -08:00
2022-11-02 10:55:51 -07:00
2022-11-02 10:55:51 -07:00

CLAP

CLAP (Contrastive Language-Audio Pretraining) is a neural network model that learns acoustic concepts from natural language supervision. It achieves SoTA in “Zero-Shot” classification, Audio-Text & Text-Audio Retrieval, and in some datasets when finetuned.

clap_diagram_v3

Citation

https://arxiv.org/pdf/2206.04769.pdf

@article{elizalde2022clap,
  title={Clap: Learning audio concepts from natural language supervision},
  author={Elizalde, Benjamin and Deshmukh, Soham and Ismail, Mahmoud Al and Wang, Huaming},
  journal={arXiv preprint arXiv:2206.04769},
  year={2022}
}

Setup

  • The setup assumes Anaconda is installed
  • Open the anaconda terminal and follow the below commands. The symbol {..} indicates user input.
> git clone https://github.com/microsoft/CLAP.git
> cd CLAP
> conda create -n clap python=3.8
> conda activate clap
> pip install -r requirements.txt

CLAP weights:

Request CLAP weights by filling this form: link{:target="_blank"}

Usage

  • Load model
from CLAP_API import CLAP 

clap_model = CLAP("<PATH TO WEIGHTS>", use_cuda=False)
  • Extract text embeddings
text_embeddings = clap_model.get_text_embeddings(class_labels: List[str])
  • Extract audio embeddings
audio_embeddings = clap_model.get_audio_embeddings(file_paths: List[str])
  • Compute similarity
sim = clap_model.compute_similarity(audio_embeddings, text_embeddings)

Zero-Shot inference on an audio file from ESC50 dataset

from CLAP_API import CLAP
from esc50_dataset import ESC50
import time
import torch.nn.functional as F

# Load CLAP
weights_path = 'best.pth' # Add weight path here
clap_model = CLAP(weights_path, use_cuda=False)

# Load dataset
dataset = ESC50(root='data', download=True) # set download=True when dataset is not downloaded
audio_file, target, one_hot_target = dataset[1000]
audio_file = [audio_file]
prompt = 'this is a sound of '
y = [prompt + x for x in dataset.classes]

print('Computing text embeddings')
text_embeddings = clap_model.get_text_embeddings(y)
print('Computing audio embeddings')
audio_embeddings = clap_model.get_audio_embeddings(audio_file, resample=True)
similarity = clap_model.compute_similarity(audio_embeddings, text_embeddings)

similarity = F.softmax(similarity, dim=1)
values, indices = similarity[0].topk(5)
# Print the result
print("Ground Truth: {}".format(target))
print("Top predictions:\n")
for value, index in zip(values, indices):
    print(f"{dataset.classes[index]:>16s}: {100 * value.item():.2f}%")

The output (the exact numbers may vary):

Ground Truth: coughing
Top predictions:

        coughing: 86.34%
        sneezing: 9.30%
drinking sipping: 1.31%
        laughing: 1.20%
  glass breaking: 0.81%

Zero-Shot Classification of ESC50 dataset

from CLAP_API import CLAP
from esc50_dataset import ESC50
import torch.nn.functional as F
import numpy as np
from tqdm import tqdm
from sklearn.metrics import accuracy_score

# Load CLAP
weights_path = # Add weight path here
clap_model = CLAP(weights_path, use_cuda=False)

# Load dataset
dataset = ESC50(root='data', download=False)
prompt = 'this is a sound of '
Y = [prompt + x for x in dataset.classes]

# Computing text embeddings
text_embeddings = clap_model.get_text_embeddings(Y)

# Computing audio embeddings
y_preds, y_labels = [], []
for i in tqdm(range(len(dataset))):
    x, _, one_hot_target = dataset.__getitem__(i)
    audio_embeddings = clap_model.get_audio_embeddings([x], resample=True)
    similarity = clap_model.compute_similarity(audio_embeddings, text_embeddings)
    y_pred = F.softmax(similarity.detach().cpu(), dim=1).numpy()
    y_preds.append(y_pred)
    y_labels.append(one_hot_target.detach().cpu().numpy())

y_labels, y_preds = np.concatenate(y_labels, axis=0), np.concatenate(y_preds, axis=0)
acc = accuracy_score(np.argmax(y_labels, axis=1), np.argmax(y_preds, axis=1))
print('ESC50 Accuracy {}'.format(acc))

The output:

ESC50 Accuracy: 82.6%

Contributing

This project welcomes contributions and suggestions. Most contributions require you to agree to a Contributor License Agreement (CLA) declaring that you have the right to, and actually do, grant us the rights to use your contribution. For details, visit https://cla.opensource.microsoft.com.

When you submit a pull request, a CLA bot will automatically determine whether you need to provide a CLA and decorate the PR appropriately (e.g., status check, comment). Simply follow the instructions provided by the bot. You will only need to do this once across all repos using our CLA.

This project has adopted the Microsoft Open Source Code of Conduct. For more information see the Code of Conduct FAQ or contact opencode@microsoft.com with any additional questions or comments.

Trademarks

This project may contain trademarks or logos for projects, products, or services. Authorized use of Microsoft trademarks or logos is subject to and must follow Microsoft's Trademark & Brand Guidelines. Use of Microsoft trademarks or logos in modified versions of this project must not cause confusion or imply Microsoft sponsorship. Any use of third-party trademarks or logos are subject to those third-party's policies.

S
Description
Learning audio concepts from natural language supervision
Readme 625 KiB
Languages
Python 100%