-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
0 parents
commit b535f31
Showing
165 changed files
with
80,615 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,5 @@ | ||
/data/ | ||
/data_raw/ | ||
.DS_Store | ||
.venv | ||
.ipynb_checkpoints/ |
Large diffs are not rendered by default.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,68 @@ | ||
|
||
# Vegetable Oils on Social Media | ||
Repository for the paper "Understanding the Vegetable Oil Debate and Its Implications for Sustainability through Social Media". [https://arxiv.org/abs/2308.07108](https://arxiv.org/abs/2308.07108) | ||
*** | ||
|
||
## Paper abstract | ||
|
||
The global production and consumption of vegetable oils have sparked several discussions on sustainable development. This study analyzes over 20 million tweets related to vegetable oils to explore the key factors shaping public opinion. We found that coconut, olive, and palm oils dominate social media discourse despite their lower contribution to overall global vegetable production. The discussion about olive and palm oils remarkably correlates with Twitter's growth, while coconut increases more significantly with bursts of activity. Discussions around coconut and olive oils primarily focus on health, beauty, and food, while palm draws attention to pressing environmental concerns. Overall, virality is related to environmental issues and negative connotations. In the context of Sustainable Development Goals, this study highlights the multifaceted nature of the vegetable oil debate and its disconnection from scientific discussions. Our research sheds light on the power of social media in shaping public perception, providing insights into sustainable development strategies. | ||
|
||
|
||
## Repository installation | ||
Clone this repository with the command | ||
``` | ||
git clone https://github.com/elenacandellone/vegetable-oils.git | ||
``` | ||
Install the required packages | ||
``` | ||
conda env create -f environment.yml | ||
``` | ||
## Folders | ||
* `data_id` contains all the tweets ID used in this paper. Twitter's Developer Agreement Policy does not allow users with Academic Research access to deposit the data in any public repository, but it allows them to share the ID of the tweets and the users analyzed. | ||
* `plots` contains the plots generated by each script. | ||
* `processed` contains the data used to create each plot. | ||
* `src` contains all the functions used in the scripts. | ||
|
||
## Scripts | ||
|
||
The main analyses were carried out in Python, but the figures were created using R. The analyses scripts are: | ||
|
||
* `data-processing.py` takes the raw data (here not provided) and saves information about users, dates, geolocation, user ids, metrics, text separated. Only the tweets' ids are provided in folder `data_id`. | ||
* `LSA.ipynb` performs the Latent Semantic Analysis of the tweets. | ||
* `sentiment.py` performs the Sentiment Analysis using the model *"cardiffnlp/twitter-roberta-base-sentiment"* | ||
* `virality.ipynb` performs the Cascade Size (CS) and Inter-Event Time (IET) analysis. | ||
|
||
To create the plots the R scripts are: | ||
|
||
* `zcript_Fig1.R` *Anatomy of the vegetable oils presence in Twitter*: tweets sent from 3/21/2006 to 12/31/2021 containing the bigram *type oil*, where *type* corresponds to any of the oils listed in the legends. (a) The cumulative number of tweets for each oil. There are three major oils in terms of social media presence: olive, coconut, and palm oils. (b) The monthly number of tweets for each of the three major vegetable oils. (c) Growth relative to 2007, measured as the total number of tweets in a given year over the number of tweets in 2007. We compare the growth of tweets on each vegetable oil with the growth of the 100 most common words in English as a proxy for the growth of Twitter (see Methods). Error bars indicate the standard deviation of the growth for the common words. (d) The number of geo-tagged tweets per country containing the bigram "palm oil" in 102 languages (see Methods). The total number of tweets collected in any language is 7,946,915, of which only 64,682 are geo-tagged. | ||
|
||
* `zcript_Fig2.R` *The debate around vegetable oils*: the topics associated with each vegetable oil can vary greatly. Panels a-c show the top 10 most used hashtags for each set of tweets, expressed as the percentage of tweets containing the hashtag, for coconut, olive, and palm oil, respectively. Palm oil is mainly related to environmental issues, while coconut and olive are predominantly associated with nutrition and health topics. Panel d reports the results of a Latent Semantic Analysis (LSA) applied to the set of tweets (see Methods). Each point in the plot represents a tweet, with color indicating the vegetable oil it is associated with. The closer the two points are in space, the more similar their topics are. Lastly, panel e depicts a word cloud of the top 2,000 hashtags in the palm oil dataset. Font size is proportional to the number of occurrences in the dataset so that the least used hashtags are hardly visible. *(note that this panel was created using the jupyter notebook zcript_2E.ipynb and manually inserted in the plot)* | ||
|
||
* `zcript_Fig3.R` *Sentiment Analysis*: Panels a-c contain the fraction of tweets associated with each sentiment for each of the three datasets under consideration (coconut, olive, and palm). In the three oil cases, roughly 50% of the tweets are considered neutral, but the situation is completely different for negative ones. The datasets of coconut and olive oils contain about 10% of tweets labeled as negative, while this number increases to 42% for palm oil. Panels d (coconut), e (olive), and f (palm) show the monthly number of tweets associated with each sentiment. The share of tweets in each category is fairly constant, except for a few viral events, such as the one related to coconut oil in March 2019 and the one associated with palm oil in November 2018. | ||
|
||
* `zcript_Fig4.R` *The palm oil debate in 2018*: Panel (a) displays the weekly count of tweets containing the keywords "Biodiversity", "Iceland Foods", "IUCN", and "Orangutan", illustrating the varying public attention to different facets of the issue. This showcases two significant but differently echoed events: the IUCN report on palm oil's impact on biodiversity in late June and the widely noticed campaign against palm oil by Iceland Foods and Greenpeace in Christmas. Panel (b) visualizes the sentiment (positive, neutral, negative) associated with tweets containing the terms "IUCN" or "biodiversity", demonstrating the emotional response to scientific discussions. Panel (c) presents the sentiment associated with tweets containing the terms "Orangutan" or "Iceland Foods", reflecting the emotional impact of the viral campaign. | ||
|
||
* `zcript_Fig5.R` *Virality phase diagram*: Each point represents one of the 10 most common hashtags in the coconut (orange circles), olive (blue triangles), and palm (green squares) datasets. The spatial coordinates are the scaling exponents of the interevent time (*x*-axis) and the cascade size (*y*-axis) distributions. Gray lines delimit the areas defined by the critical exponents (see Methods). Pie charts show the distribution of positive, neutral, and negative tweets with at least one hashtag in each of these areas. | ||
|
||
They were tested with R version 4.4.0 (2024-04-24) -- "Puppy Cup". | ||
|
||
|
||
|
||
## How to cite | ||
E. Candellone, A. Aleta, H.F. de Arruda, E. Meijaard, Y. Moreno. Understanding the Vegetable Oil Debate and Its Implications for Sustainability through Social Media, 2023. | ||
|
||
``` | ||
@misc{candellone2023understanding, | ||
title={Understanding the Vegetable Oil Debate and Its Implications for Sustainability through Social Media}, | ||
author={Elena Candellone and Alberto Aleta and Henrique Ferraz de Arruda and Erik Meijaard and Yamir Moreno}, | ||
year={2023}, | ||
eprint={2308.07108}, | ||
archivePrefix={arXiv}, | ||
primaryClass={physics.soc-ph}, | ||
doi={10.48550/arXiv.2308.07108} | ||
} | ||
``` | ||
|
||
|
||
## Contact | ||
- Elena Candellone [[email protected]](mailto:[email protected]) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,19 @@ | ||
from src.utils import * | ||
|
||
oils = ['canola', 'coconut', 'olive', 'palm', 'peanut', 'soybean', 'sunflower'] | ||
|
||
for oil in oils: | ||
in_path = os.path.normpath('./data_raw/'+oil) # dataset path | ||
out_path = os.path.normpath('./data/'+oil+'/') # output path | ||
out_path_anon = os.path.normpath('./data_id/'+oil) # output path | ||
pickles_gen(in_path, out_path, out_path_anon) | ||
print(f'{oil} done!') | ||
|
||
languages = os.listdir('./data_raw/palm_languages/') | ||
|
||
for language in languages: | ||
in_path = os.path.normpath('./data_raw/palm_languages/'+language) # dataset path | ||
out_path = os.path.normpath('./data/palm_languages/'+language+'/') # output path | ||
out_path_anon = os.path.normpath('./data_id/palm_languages/'+language) # output path | ||
pickles_gen(in_path, out_path, out_path_anon) | ||
print(f'{language} done!') |
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,106 @@ | ||
name: vegoils | ||
channels: | ||
- defaults | ||
dependencies: | ||
- appnope=0.1.3 | ||
- asttokens=2.0.5 | ||
- bzip2=1.0.8 | ||
- ca-certificates=2024.3.11 | ||
- comm=0.2.1 | ||
- debugpy=1.6.7 | ||
- decorator=5.1.1 | ||
- executing=0.8.3 | ||
- expat=2.6.2 | ||
- ipykernel=6.28.0 | ||
- ipython=8.20.0 | ||
- jedi=0.18.1 | ||
- jupyter_client=8.6.0 | ||
- jupyter_core=5.5.0 | ||
- libcxx=14.0.6 | ||
- libffi=3.4.4 | ||
- libsodium=1.0.18 | ||
- matplotlib-inline=0.1.6 | ||
- ncurses=6.4 | ||
- nest-asyncio=1.6.0 | ||
- openssl=3.0.13 | ||
- packaging=23.2 | ||
- parso=0.8.3 | ||
- pexpect=4.8.0 | ||
- pip=24.0 | ||
- platformdirs=3.10.0 | ||
- prompt-toolkit=3.0.43 | ||
- prompt_toolkit=3.0.43 | ||
- psutil=5.9.0 | ||
- ptyprocess=0.7.0 | ||
- pure_eval=0.2.2 | ||
- pygments=2.15.1 | ||
- python=3.12.3 | ||
- python-dateutil=2.9.0post0 | ||
- pyzmq=25.1.2 | ||
- readline=8.2 | ||
- setuptools=69.5.1 | ||
- six=1.16.0 | ||
- sqlite=3.45.3 | ||
- stack_data=0.2.0 | ||
- tk=8.6.14 | ||
- tornado=6.3.3 | ||
- traitlets=5.7.1 | ||
- wcwidth=0.2.5 | ||
- wheel=0.43.0 | ||
- xz=5.4.6 | ||
- zeromq=4.3.5 | ||
- zlib=1.2.13 | ||
- pip: | ||
- adjusttext==1.1.1 | ||
- attrs==23.2.0 | ||
- certifi==2024.2.2 | ||
- charset-normalizer==3.3.2 | ||
- click==8.1.7 | ||
- click-plugins==1.1.1 | ||
- cligj==0.7.2 | ||
- contourpy==1.2.1 | ||
- cycler==0.12.1 | ||
- filelock==3.14.0 | ||
- fiona==1.9.6 | ||
- fonttools==4.53.0 | ||
- fsspec==2024.5.0 | ||
- geopandas==0.14.4 | ||
- huggingface-hub==0.23.2 | ||
- idna==3.7 | ||
- jinja2==3.1.4 | ||
- joblib==1.4.2 | ||
- kiwisolver==1.4.5 | ||
- markupsafe==2.1.5 | ||
- matplotlib==3.9.0 | ||
- mpmath==1.3.0 | ||
- networkx==3.3 | ||
- nltk==3.8.1 | ||
- numpy==1.26.4 | ||
- pandas==2.2.2 | ||
- pillow==10.3.0 | ||
- powerlaw==1.5 | ||
- pyparsing==3.1.2 | ||
- pyproj==3.6.1 | ||
- pytz==2024.1 | ||
- pyyaml==6.0.1 | ||
- regex==2024.5.15 | ||
- requests==2.32.3 | ||
- reverse-geocode==1.6 | ||
- safetensors==0.4.3 | ||
- scikit-learn==1.5.0 | ||
- scipy==1.13.1 | ||
- seaborn==0.13.2 | ||
- shapely==2.0.4 | ||
- sympy==1.12.1 | ||
- threadpoolctl==3.5.0 | ||
- tokenizers==0.19.1 | ||
- torch==2.3.0 | ||
- torchaudio==2.3.0 | ||
- torchvision==0.18.0 | ||
- tqdm==4.66.4 | ||
- transformers==4.41.2 | ||
- typing-extensions==4.12.1 | ||
- tzdata==2024.1 | ||
- urllib3==2.2.1 | ||
- wordcloud==1.9.3 | ||
prefix: /Users/Cande007/anaconda3/envs/vegoils |
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Oops, something went wrong.