Last updated:
0 purchases
bellatdsa 0.3.29
Bella
Target Dependent Sentiment Analysis (TDSA) framework. The paper associated with this repository is the following:
@InProceedings{C18-1097,
author = "Moore, Andrew
and Rayson, Paul",
title = "Bringing replication and reproduction together with generalisability in NLP: Three reproduction studies for Target Dependent Sentiment Analysis",
booktitle = "Proceedings of the 27th International Conference on Computational Linguistics",
year = "2018",
publisher = "Association for Computational Linguistics",
pages = "1132--1144",
location = "Santa Fe, New Mexico, USA",
url = "http://aclweb.org/anthology/C18-1097"
}
Requirements and Installation
Python 3.6
pip install bella-tdsa
Install docker
Start Stanford CoreNLP server: docker run -p 9000:9000 -d --rm mooreap/corenlp
Start the TweeboParser API server: docker run -p 8000:8000 -d --rm mooreap/tweeboparserdocker
If you want to use the moses tokeniser that has been taken from the Moses project the following will need to be installed:
python -m nltk.downloader perluniprops
python -m nltk.downloader nonbreaking_prefixes
The docker Stanford and Tweebo server are only required if you are going to use the TDParse methods/models or if you are going to use any of the Stanford Tools else you do not need them.
To stop the docker servers running:
Find the name assigned to the docker image using: docker ps
Then stop the relevant docker image: docker stop name_of_image
NOTE
Both of these servers will run with as many threads as your machine has CPUs to limit this do the following:
For stanford: docker run -p 9000:9000 -d --rm mooreap/corenlp -threads 6 will run it with 6 threads
For TweeboParser: docker run -p 8000:8000 -d --rm mooreap/tweeboparserdocker --threads 6 will run it with 6 threads
Dataset
All of the dataset are required to be downloaded and are not stored in this repository. We recomend using the config file to state where the datasets are stored like we did but this is not a requirement as you can state where they are stored explictly in the code. For more details on the datasets and downloading them see the dataset notebook The datasets used:
SemEval 2014 Resturant dataset. We used Train dataset version 2 and the test dataset of which the gold standatd test can be found here.
SemEval 2014 Laptop dataset. We used Train dataset version2 and the test dataset of which the gold standard test can be found here.
Election dataset
Dong et al. Twitter dataset
Youtubean dataset by Marrese-Taylor et al.
Mitchell dataset which was released with this paper.
NOTE Before using Mitchell and YouTuBean datasets please go through these pre-processing notebooks: Mitchell YouTuBean for splitting their data and also in Mitchell case which train test split to use.
Lexicons
These lexicons are required to be downloaded if you use any methods that require them. Please see the use of the config file for storing the location of the lexicons:
MPQA can be found here
NRC here
Hu and Liu here
Word Vectors
All the word vectors are automatically downloaded for you and they are stored in the root directory called .Bella/Vectors which is created in your user directory e.g. on Linux that would be ~/.Bella/Vectors/. The word vectors included in this repository are the following:
SSWE
Word Vectors trained on sentences that contain emojis
Glove Common Crawl
Glove Twitter
Glove Wiki Giga
Model Zoo
The model zoo can be found on the Git Lab repository here.
These models can be automatically downloaded through the code like the word vectors and stored in the .Bella/Models directory which is automatically placed in your home directory for instance on Linux that would be ~/.Bella/Models. An example of how to download and use a model is shown below:
from bella import helper
from bella.models.target import TargetDep
target_dep = helper.download_model(TargetDep, 'SemEval 14 Restaurant')
test_example_multi = [{'text' : 'This bread is tasty but the sauce is too rich', 'target': 'sauce',
'spans': [(28, 33)]}]
target_dep.predict(test_example_multi)
This example will download the Target Dependent model which is from Vo and Zhang paper that has been trained on the SemEval 2014 Resturant data and predict the sentiment of sauce from that example. As you can see the example is not simple as it has two different sentiments within the same sentence with two targets; 1. bread with a positive sentiment and 2. sauce which has a negative sentiment of which that target is the one being predicted for in this example.
To see a more in depth guide to the pre-trained models and output from them go to this notebook.
The notebooks
Can be found here
The best order to look at the notebooks is first look at the data with this notebook. Then looking at the notebook that describes how to load and use the saved models from the model zoo. Then go and explore the rest if you would like:
The Mass evaluation notebooks are the following
Mass Evaluation - TDParse for the Target dependent models
Mass Evaluation - Target Dependent for the TDParse models
Mass Evaluation LSTM for the LSTM models
All of these do not contain any analysis just demostartes how we gathered the results. Lastly they also create the model zoo. For the analysis of the Mass evaluations see Mass Evaluation Result Analysis notebook
For the analysis of the reproduction of the Target Dependent model of Vo and Zhang see this notebook
For the analysis of the reproduction of the TDParse model of Wang et al. see this notebook
For the analysis of the reproduction of the LSTM models of Tang et al. see this notebook
For the statistics of the datasets and where to find them see this notebook
For the code on creating training and test splits for the YouTuBean dataset see this notebook
For the code on creating training and test splits for Mitchell et al. dataset see this notebook
Pre-Trained Model examples notebook
Docker Servers
Both Tweebo and Stanford by default will run on your localhost and port 8000 and 9000 respectively by default. If you would like to run them on a different port or hostname you can change the .Bella/config.yaml file which is created in your local home directory the first time you run something successfully through the Stanford or Tweebo tools. The file once created which is only done automatically for you when you successfully run something through the Stanford or Tweebo tools will look like this which is a yaml formatted file:
tweebo_parser:
hostname: 0.0.0.0
port: 7000
stanford_core_nlp:
hostname: http://localhost
port: 8000
If you want Tweebo or Stanford to run on a different port or hostname just change this file. For instance the example shown above is different to default as Stanford is running on port 8000 and not 9000 and Tweebo is running on port 7000 instead of 8000.
If you would like the tools to run on different hostname and port from the start without having to successfully run them through the tools before hand just create this file .Bella/config.yaml in your local home directory with the same structure as the example but with the hostname and port you want to use.
Different Licenses
As we use a lot of tools we list here if any of the tools that we use are licensed under a different license to that of this repository:
The Moses tokeniser is licensed under GNU Lesser General Public License version 2.1 or, at your option, any later version.
For personal and professional use. You cannot resell or redistribute these repositories in their original state.
There are no reviews.