Skip to content

Latest commit

 

History

History
32 lines (21 loc) · 2.62 KB

File metadata and controls

32 lines (21 loc) · 2.62 KB

multilabel-movie-genre-classifier

Objective

The primary objective of this initiative was to develop a multi-label text classification model tailored to predict movie genres based on their descriptions. The scope of the project encompassed various phases, including data acquisition, preprocessing, model development, deployment, and seamless integration with application programming interfaces (APIs). The keys of deployment\genre_types_encoded.json shows the book genres.

Data Collection

Data has been sourced from the official IMDB website listing.

The process of scraping movie details, including titles, descriptions, and genres, has been executed utilizing the Selenium library. The corresponding code is available in the scraper/movie_details_scrapper.py directory.

The data collection endeavor remains ongoing, and all gathered information is being stored in the data/imdv_movies.csv file.

Update: The number of collected movies has now reached 25000, pending further processing and training.

Data Preprocessing

Through meticulous preprocessing detailed in notebooks/Multilabel_Texr_Classification.ipynb, duplicates and missing values were efficiently handled. To enhance model accuracy, infrequent genres from 24 genres. This strategic decision ensures optimal training outcomes, as training with rare genres could compromise model performance. The resulting refined dataset can be accessed in the designated data folder, reflecting our commitment to meticulous data management and model optimization.

Model Training

Crafted with precision, I finetuned a "distilroberta-base" model sourced from HuggingFace Transformers utilizing Fastai and Blurr frameworks. Through meticulous training across two stages, employing both freeze and unfreeze techniques, I distilled the essence of optimal performance. Ultimately, the pinnacle of excellence emerged, boasting an impressive accuracy of 87.6%. For a deeper understanding of the model's evolution, the comprehensive training notebook awaits exploration at notebooks/Multilabel_Text_Classifier.ipynb

Model Compression and ONNX Inference

The trained model has a memory of 300+MB. This model was compressed using ONNX . The compression code can be found in notebooks/onnx_inference(1).ipynb and the model links can be found in models folder.

Model Deployment

The compressed model is deployed to HuggingFace Spaces Gradio App. I utilized the Gradio App to deploy the model. HuggingFace Spaces Here Screenshot_18