--- license: mit --- # Polemo Intensity Model This model is fine-tuned for emotion intensity detection in Polish political texts. It is based on the RoBERTa transformer model and has been specifically trained to recognize a range of emotions in text data scraped from various social media platforms. ## Model Details ### Database Preparation Our research utilizes a comprehensive database of Polish political texts from social media profiles (i.e., YouTube, Twitter, Facebook) of 25 journalists, 25 politicians, and 19 non-governmental organizations (NGOs). For each profile, all available posts from each platform were scraped going back to the beginning of 2019. In addition, we included texts written by non-professional commentators of social affairs. Our dataset consists of 1,246,337 text snippets: - Twitter: 789,490 tweets - YouTube: 42,252 comments - Facebook: 414,595 posts The texts were processed to fit transformer models' length constraints. Facebook texts were split into sentences, and all texts longer than 280 characters were removed. Non-Polish texts were filtered out using the `langdetect` software, and all online links and usernames were replaced with placeholders. We focused on texts with higher emotional content for training, resulting in a final dataset of 10,000 texts, annotated by 20 expert annotators. ### Annotation Process The final dataset was annotated for the following emotions: - Happiness - Sadness - Anger - Disgust - Fear - Pride - Valence - Arousal Annotators used a 5-point scale for each emotion and dimension. The annotation process ensured consistency and minimized subjectivity, with each text being annotated by five different annotators. ### Model Training We considered two base models: the Trelbert transformer model and the Polish Roberta model. The final model relied on the Roberta transformer model and was fine-tuned using a Bayesian grid search for hyperparameter optimization. The training involved: - Dropout: 0.6 - Learning rate: 5e-5 - Weight decay: 0.3 - Warmup steps: 600 ### Results The model demonstrated strong correlations with human ratings, particularly in predicting happiness and valence, achieving correlations of 0.87. The results for other emotions were also substantial, indicating the model's ability to capture a wide range of emotional states. ### K-Fold Validation A 10-fold cross-validation showed high reliability across different emotional dimensions: - Happiness: 0.83 - Sadness: 0.68 - Anger: 0.81 - Disgust: 0.75 - Fear: 0.67 - Pride: 0.76 - Valence: 0.84 - Arousal: 0.71 ## Usage You can use the model and tokenizer as follows: ```python from transformers import AutoTokenizer, AutoModel import torch # Load the tokenizer tokenizer = AutoTokenizer.from_pretrained("hplisiecki/polemo-intensity") # Load the model model = AutoModel.from_pretrained("hplisiecki/polemo-intensity") # Define emotion columns emotion_columns = ['Happiness', 'Sadness', 'Anger', 'Disgust', 'Fear', 'Pride', 'Valence', 'Arousal'] # Test the model with a sample input inputs = tokenizer("This is a test input.", return_tensors="pt") outputs = model(**inputs) # Print out the emotion ratings for emotion, rating in zip(emotion_columns, outputs): print(f"{emotion}: {rating.item()}")