404
Page not found :(
The requested page could not be found.
diff --git a/_pages/snippets/politics/age_distribution.md b/_pages/snippets/politics/age_distribution.md
index 606f64d..8f2ceb2 100644
--- a/_pages/snippets/politics/age_distribution.md
+++ b/_pages/snippets/politics/age_distribution.md
@@ -1,2 +1,2 @@
-![Age]({{site.baseurl}}/assets/images/politics/age.png)
\ No newline at end of file
+![Age](../assets/images/politics/age.png)
\ No newline at end of file
diff --git a/_pages/snippets/politics/content_left.md b/_pages/snippets/politics/content_left.md
index 2adfc18..6bc88b8 100644
--- a/_pages/snippets/politics/content_left.md
+++ b/_pages/snippets/politics/content_left.md
@@ -1,4 +1,4 @@
-![Reactions]({{site.baseurl}}/assets/images/politics/reactions.png)
+![Reactions](../assets/images/politics/reactions.png)
-![Emotions]({{site.baseurl}}/assets/images/politics/emotions.png)
\ No newline at end of file
+![Emotions](../assets/images/politics/emotions.png)
\ No newline at end of file
diff --git a/_pages/snippets/politics/content_left1.md b/_pages/snippets/politics/content_left1.md
index 53fafdf..df7c40d 100644
--- a/_pages/snippets/politics/content_left1.md
+++ b/_pages/snippets/politics/content_left1.md
@@ -1,2 +1,2 @@
-![Threads]({{site.baseurl}}/assets/images/politics/threads.png)
+![Threads](../assets/images/politics/threads.png)
diff --git a/_pages/snippets/politics/content_right.md b/_pages/snippets/politics/content_right.md
index 27f1d96..e19c6ef 100644
--- a/_pages/snippets/politics/content_right.md
+++ b/_pages/snippets/politics/content_right.md
@@ -1,5 +1,5 @@
-![Contents]({{site.baseurl}}/assets/images/politics/contents.png)
+![Contents](../assets/images/politics/contents.png)
-![Hashgags]({{site.baseurl}}/assets/images/politics/hashtags.png)
+![Hashgags](../assets/images/images/politics/hashtags.png)
diff --git a/_pages/snippets/politics/content_right1.md b/_pages/snippets/politics/content_right1.md
index aea24cd..c697f82 100644
--- a/_pages/snippets/politics/content_right1.md
+++ b/_pages/snippets/politics/content_right1.md
@@ -1,3 +1,3 @@
-![Recs]({{site.baseurl}}/assets/images/politics/recs.png)
+![Recs](../assets/images/politics/recs.png)
diff --git a/_pages/snippets/politics/political_leaning.md b/_pages/snippets/politics/political_leaning.md
index 9173ad7..0b25826 100644
--- a/_pages/snippets/politics/political_leaning.md
+++ b/_pages/snippets/politics/political_leaning.md
@@ -1,4 +1,4 @@
-![Leaning]({{site.baseurl}}/assets/images/politics/leaning.png)
+![Leaning](../assets/images/politics/leaning.png)
diff --git a/_pages/snippets/politics/thread_ex1.md b/_pages/snippets/politics/thread_ex1.md
index fb232ac..69d5963 100644
--- a/_pages/snippets/politics/thread_ex1.md
+++ b/_pages/snippets/politics/thread_ex1.md
@@ -1,5 +1,5 @@
-![Thread]({{site.baseurl}}/assets/images/politics/thread.png)
+![Thread](../assets/images/images/politics/thread.png)
Examples of generated discussion threads
(visual mockups generated with [Tweetgen](https://www.tweetgen.com/).
diff --git a/_pages/snippets/politics/thread_ex2.md b/_pages/snippets/politics/thread_ex2.md
index c7321a1..9070e98 100644
--- a/_pages/snippets/politics/thread_ex2.md
+++ b/_pages/snippets/politics/thread_ex2.md
@@ -1,3 +1,3 @@
-![news]({{site.baseurl}}/assets/images/politics/news_thread.png)
+![news](../assets/images/politics/news_thread.png)
diff --git a/_pages/yserver.markdown b/_pages/yserver.markdown
index 9013825..55e376e 100644
--- a/_pages/yserver.markdown
+++ b/_pages/yserver.markdown
@@ -22,7 +22,7 @@ It is designed to be used in conjunction with `Y Client`, a client-side applicat
{% include_relative snippets/application.md %}
{% endcapture %}
-{% include modal-component.html title="Client/Server Architecture" size="xl" content=mappa_stragi id="db-schema" img="application.png" %}
+{% include modal-component.html title="Client/Server Architecture" size="xl" content=mappa_stragi id="db-schema" img="../assets/images/application.png" %}
**Programming Language:** Python
**Framework:** Flask + SQlite + SQLAlchemy
diff --git a/docs/404.html b/docs/404.html
index ec0b601..445f7ce 100644
--- a/docs/404.html
+++ b/docs/404.html
@@ -1 +1 @@
-
Page not found :(
The requested page could not be found.
Page not found :(
The requested page could not be found.
Meet the Y Social Team
We are a team of multidisciplinary researchers that share a common interest in the study of social networks and human behavior.
Senior Researcher Network Science @GiulioRossetti | Associate Prof. Cognitive NetSci @MassimoSt | Associate Prof. Network Science @Yquetzal |
PhD Student in AI LLMs & Cognition @katie_abramski | PhD Student in AI LLMs & Opinion Dynamics @CauErica | PostDoc Feature-rich Modeling @dsalvaz |
PhD Student in AI Higher-order Modeling @AndreaFailla4 | PostDoc Opinion Modeling @VPansanella | PhD Student in AI Computational Social Science @Virgiiim |
YSocial
is the result of a joint effort of ISTI-CNR, University of Pisa, University of Trento and Université Lyon 1.
If you use YSocial
in your research, please cite the following paper:
@article{rossetti2024ysocial,
+ About Us | Y Social Invisible link to canonical for Microformats About Us
Meet the Y Social Team
Who are we?
We are a team of multidisciplinary researchers that share a common interest in the study of social networks and human behavior.
Senior Researcher
Network Science
@GiulioRossetti Associate Prof.
Cognitive NetSci
@MassimoSt Associate Prof.
Network Science
@Yquetzal PhD Student in AI
LLMs & Cognition
@katie_abramski PhD Student in AI
LLMs & Opinion Dynamics
@CauErica PostDoc
Feature-rich Modeling
@dsalvaz PhD Student in AI
Higher-order Modeling
@AndreaFailla4 PostDoc
Opinion Modeling
@VPansanella PhD Student in AI
Computational Social Science
@Virgiiim
YSocial
is the result of a joint effort of ISTI-CNR, University of Pisa, University of Trento and Université Lyon 1.
How to Cite
If you use YSocial
in your research, please cite the following paper:
@article{rossetti2024ysocial,
title={Y Social: an LLM-powered Social Media Digital Twin},
author={Rossetti, Giulio and Stella, Massimo and Cazabet, Rémy and
Abramski, Katherine and Cau, Erica and Citraro, Salvatore and
diff --git a/docs/atom.xml b/docs/atom.xml
index b77d244..8d3cea5 100644
--- a/docs/atom.xml
+++ b/docs/atom.xml
@@ -3,7 +3,7 @@
Chulapa
- 2024-07-31T15:03:37+02:00
+ 2024-07-31T15:15:57+02:00
https://ysocialtwin.github.io/atom.xml
Y Social | Where the Digital World Comes to Life
Where the Digital World Comes to Life
diff --git a/docs/feed.xml b/docs/feed.xml
index 36df1dc..9ebe3af 100644
--- a/docs/feed.xml
+++ b/docs/feed.xml
@@ -1 +1 @@
-Jekyll 2024-07-31T15:03:37+02:00 https://ysocialtwin.github.io/feed.xml Y Social Y Social is a cutting-edge Digital Twin of a microblogging platform. It enables realistic social media simulations by integrating Large Language Models (LLMs) agents. Describe your desired scenario - be it a political community, a mental health support group or a sportive fandom - and observe complex social behaviours emerge.
\ No newline at end of file
+Jekyll 2024-07-31T15:15:57+02:00 https://ysocialtwin.github.io/feed.xml Y Social Y Social is a cutting-edge Digital Twin of a microblogging platform. It enables realistic social media simulations by integrating Large Language Models (LLMs) agents. Describe your desired scenario - be it a political community, a mental health support group or a sportive fandom - and observe complex social behaviours emerge.
\ No newline at end of file
diff --git a/docs/index.html b/docs/index.html
index 9688c7e..3fe0016 100644
--- a/docs/index.html
+++ b/docs/index.html
@@ -1 +1 @@
- Home | Y Social Invisible link to canonical for Microformats Y Social
Where the Digital World Comes to Life
What is Y Social?
Y Social is a cutting-edge Digital Twin of a microblogging platform.
It enables realistic social media simulations by integrating Large Language Models (LLMs) agents.
Describe your desired scenario - be it a political community, a mental health support group or a sportive fandom - and observe complex social behaviours emerge.
Why Y Social?
- Realistic Interactions: Experience true-to-life social media dynamics.
- Highly Configurable: Tailor simulations to your specific needs - from population characteristics to follow/content recommender systems.
- Innovative Research: Gain deep insights into user behavior and platform trends.
Who is Y Social for?
Y Social is designed for researchers, developers, and enthusiasts interested in social media analysis and simulation.
- Academics: Study social media phenomena, test hypotheses, and validate theories.
- Developers: Experiment with social media algorithms, test new features, and improve user experience.
- Enthusiasts: Explore social media dynamics, create engaging scenarios, and share your findings.
Join us to explore, innovate, and revolutionize social media understanding.
+ Home | Y Social Invisible link to canonical for Microformats Y Social
Where the Digital World Comes to Life
What is Y Social?
Y Social is a cutting-edge Digital Twin of a microblogging platform.
It enables realistic social media simulations by integrating Large Language Models (LLMs) agents.
Describe your desired scenario - be it a political community, a mental health support group or a sportive fandom - and observe complex social behaviours emerge.
Why Y Social?
- Realistic Interactions: Experience true-to-life social media dynamics.
- Highly Configurable: Tailor simulations to your specific needs - from population characteristics to follow/content recommender systems.
- Innovative Research: Gain deep insights into user behavior and platform trends.
Who is Y Social for?
Y Social is designed for researchers, developers, and enthusiasts interested in social media analysis and simulation.
- Academics: Study social media phenomena, test hypotheses, and validate theories.
- Developers: Experiment with social media algorithms, test new features, and improve user experience.
- Enthusiasts: Explore social media dynamics, create engaging scenarios, and share your findings.
Join us to explore, innovate, and revolutionize social media understanding.
diff --git a/docs/installation.html b/docs/installation.html
index 8264151..241b2b7 100644
--- a/docs/installation.html
+++ b/docs/installation.html
@@ -1,4 +1,4 @@
- Installation | Y Social Invisible link to canonical for Microformats Guida all’installazione di Jekyll
Per sviluppare il sito web del Progettone®, utilizzeremo un Generatore di Siti Statici (SSG), che consente di creare siti web rapidi da caricare senza la necessità di complessi sistemi backend o database.
In particolare, useremo uno dei SSG più diffusi, Jekyll.
Jekyll è un SSG open-source gratuito basato sul linguaggio di programmazione Ruby. Non è necessario conoscere Ruby per utilizzare Jekyll; è sufficiente avere Ruby installato sul proprio computer.
I vantaggi di Jekyll sono molteplici:
Facilità d’uso: Jekyll utilizza file di testo semplice e sintassi markdown per creare e gestire i contenuti, quindi non è necessario avere conoscenze di HTML o CSS per iniziare.
Velocità e sicurezza: Jekyll non interagisce con database o script lato server, riducendo il rischio di vulnerabilità e attacchi. Genera file HTML statici, rendendo il sito incredibilmente veloce e sicuro.
Personalizzabilità: Jekyll è altamente personalizzabile, permettendo l’uso di layout e template o la creazione di plugin per estenderne le funzionalità.
Facilità di distribuzione: Jekyll genera file HTML statici che possono essere distribuiti su un server web o un provider di hosting senza necessità di un sistema di gestione dei contenuti dinamici.
Nella seguente guida troverete i prerequisiti per far funzionare Jekyll
Come installare Jekyll su Windows
Per installare Ruby e Jekyll su un computer Windows, dovete usare il RubyInstaller. Questo può essere fatto scaricando e installando una versione di Ruby+Devkit da RubyInstaller Downloads e utilizzando le opzioni predefinite per l’installazione e prendendo l’ultima versione consigliata (lasciate selezionato quello che trovate, soprattutto MSYS2) .
Questa operazione richiederà qualche minuto.
Nell’ultima fase dell’installazione guidata, eseguite ridk install
(come consigliato), che serve per installare le gemme. Per saperne di più, consultate la Documentazione di RubyInstaller.
al termine dell’installazione vi apparirà questo prompt:
Tra le opzioni, scegliete MSYS2 and MINGW development toolchain (3 Enter).
Questa operazione richiede qualche minuto, è normale che compaiano degli alert.
Aprite una nuova finestra del prompt dei comandi e installate Jekyll e Bundler con il comando seguente:
gem install jekyll bundler
+ Installation | Y Social Invisible link to canonical for Microformats Guida all’installazione di Jekyll
Per sviluppare il sito web del Progettone®, utilizzeremo un Generatore di Siti Statici (SSG), che consente di creare siti web rapidi da caricare senza la necessità di complessi sistemi backend o database.
In particolare, useremo uno dei SSG più diffusi, Jekyll.
Jekyll è un SSG open-source gratuito basato sul linguaggio di programmazione Ruby. Non è necessario conoscere Ruby per utilizzare Jekyll; è sufficiente avere Ruby installato sul proprio computer.
I vantaggi di Jekyll sono molteplici:
Facilità d’uso: Jekyll utilizza file di testo semplice e sintassi markdown per creare e gestire i contenuti, quindi non è necessario avere conoscenze di HTML o CSS per iniziare.
Velocità e sicurezza: Jekyll non interagisce con database o script lato server, riducendo il rischio di vulnerabilità e attacchi. Genera file HTML statici, rendendo il sito incredibilmente veloce e sicuro.
Personalizzabilità: Jekyll è altamente personalizzabile, permettendo l’uso di layout e template o la creazione di plugin per estenderne le funzionalità.
Facilità di distribuzione: Jekyll genera file HTML statici che possono essere distribuiti su un server web o un provider di hosting senza necessità di un sistema di gestione dei contenuti dinamici.
Nella seguente guida troverete i prerequisiti per far funzionare Jekyll
Come installare Jekyll su Windows
Per installare Ruby e Jekyll su un computer Windows, dovete usare il RubyInstaller. Questo può essere fatto scaricando e installando una versione di Ruby+Devkit da RubyInstaller Downloads e utilizzando le opzioni predefinite per l’installazione e prendendo l’ultima versione consigliata (lasciate selezionato quello che trovate, soprattutto MSYS2) .
Questa operazione richiederà qualche minuto.
Nell’ultima fase dell’installazione guidata, eseguite ridk install
(come consigliato), che serve per installare le gemme. Per saperne di più, consultate la Documentazione di RubyInstaller.
al termine dell’installazione vi apparirà questo prompt:
Tra le opzioni, scegliete MSYS2 and MINGW development toolchain (3 Enter).
Questa operazione richiede qualche minuto, è normale che compaiano degli alert.
Aprite una nuova finestra del prompt dei comandi e installate Jekyll e Bundler con il comando seguente:
gem install jekyll bundler
Verificare che Jekyll sia installato correttamente:
jekyll -v
Se vedete il numero di versione, significa che Jekyll è installato e funziona correttamente sul vostro sistema. Ora tutto è pronto per iniziare a usare Jekyll!
Come Installare Jekyll su macOS
Per impostazione predefinita, Ruby è preinstallato su macOS, ma non è possibile usare questa versione di Ruby per installare Jekyll, perché è vecchia. Per esempio, su Ventura, la versione di Ruby preinstallata è la 2.6.10, mentre attualmente l’ultima versione è la 3.1.3
Per risolvere questo problema, dovete installare Ruby correttamente usando un gestore di versioni come chruby.
Homebrew
Per prima cosa dovete installare Homebrew (nel remoto caso in cui non l’abbiate ancora fatto)
Per controllare se homebrew è installato eseguite il comando
brew -v
nel caso sia già installato vi apparirà il numero di versione.
per installare Homebrew sul vostro Mac eseguire il comando seguente nel vostro terminale:
/bin/bash -c "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/HEAD/install.sh)"
diff --git a/docs/llms.html b/docs/llms.html
index 5481988..28454fb 100644
--- a/docs/llms.html
+++ b/docs/llms.html
@@ -1,4 +1,4 @@
- LLMs | Y Social Invisible link to canonical for Microformats LLM Agents
Setup a local LLMs server
What are LLMs?
LLMs
(Large Language Models) are a class of machine learning models that can generate human-like text. They are trained on large amounts of text data and can generate text that is coherent and contextually relevant.
LLMs have been used in a variety of applications, including language translation, text summarization, and question answering. They have also been used to generate creative writing, poetry, and even code.
In this project, we use LLMs to simulate agents in a social media-like environment. Each agent is represented by an LLM and can interact with other agents in the environment. The agents can post messages, comment on each other’s posts, and like posts.
Getting Started
YClient requires an OpenAI compatible LLM model to run. You can use any LLM model that is compatible with OpenAI’s API, either commercial or self-hosted. Here we will briefly describe how to set up a local LLMs server using ollama.
Step 1: Install ollama
First, you need to install ollama
on your local machine. Download the latest release from the official website and follow the installation instructions.
Step 2: Configure the LLMs server
Once you have installed ollama
, you need to pull the LLMs model you would like to use.
You can find a list of available models on the ollama models page.
To pull a model, use the following command:
ollama pull <model_name>
+ LLMs | Y Social Invisible link to canonical for Microformats LLM Agents
Setup a local LLMs server
What are LLMs?
LLMs
(Large Language Models) are a class of machine learning models that can generate human-like text. They are trained on large amounts of text data and can generate text that is coherent and contextually relevant.
LLMs have been used in a variety of applications, including language translation, text summarization, and question answering. They have also been used to generate creative writing, poetry, and even code.
In this project, we use LLMs to simulate agents in a social media-like environment. Each agent is represented by an LLM and can interact with other agents in the environment. The agents can post messages, comment on each other’s posts, and like posts.
Getting Started
YClient requires an OpenAI compatible LLM model to run. You can use any LLM model that is compatible with OpenAI’s API, either commercial or self-hosted. Here we will briefly describe how to set up a local LLMs server using ollama.
Step 1: Install ollama
First, you need to install ollama
on your local machine. Download the latest release from the official website and follow the installation instructions.
Step 2: Configure the LLMs server
Once you have installed ollama
, you need to pull the LLMs model you would like to use.
You can find a list of available models on the ollama models page.
To pull a model, use the following command:
ollama pull <model_name>
For example, to pull the llama3
model, you would run:
ollama pull llama3
Step 3: Start the LLMs server
To start the LLMs server, use the following command:
ollama start serve
This will start the LLMs server on your local machine. You can now use the server to interact with the LLMs model.
Step 4: Interact with the LLMs server
You can interact with the LLMs server using the ollama
command-line tool.
ollama run llama3
diff --git a/docs/olympics.html b/docs/olympics.html
index 9a2cd8b..08b2d01 100644
--- a/docs/olympics.html
+++ b/docs/olympics.html
@@ -1,4 +1,4 @@
- Olympics | Y Social Invisible link to canonical for Microformats Olympics
Welcome to y/olympics!
Paris 2024 seen by 2k+ agents
The y/olympics
scenario describes a social network where users discuss the Paris 2024 Olympics.
To allows LLM agent to focus on olympics related discussions the topics provided in the config.json file are the following:
{"interests": [
+ Olympics | Y Social Invisible link to canonical for Microformats Olympics
Welcome to y/olympics!
Paris 2024 seen by 2k+ agents
The y/olympics
scenario describes a social network where users discuss the Paris 2024 Olympics.
To allows LLM agent to focus on olympics related discussions the topics provided in the config.json file are the following:
{"interests": [
"Archery", "Artistic Gymnastics", "Artistic Swimming", "Athletics", "Badminton",
"Basketball", "Basketball 3x3", "Beach Volleyball", "Boxing", "Breaking",
"Canoe Slalom", "Canoe Sprint", "Cycling BMX Freestyle", "Cycling BMX Racing",
diff --git a/docs/politics.html b/docs/politics.html
index 263d073..c64e5bc 100644
--- a/docs/politics.html
+++ b/docs/politics.html
@@ -1,4 +1,4 @@
- Politics | Y Social Invisible link to canonical for Microformats Agorà
Welcome to y/politics!
Agorà: discussing political issues
The y/politics
scenario describes a social network where users can discuss political issues.
To allows LLM agent to focus on political discussions the topics provided in the config.json file are the following:
{"interests": [
+ Politics | Y Social Invisible link to canonical for Microformats Agorà
Welcome to y/politics!
Agorà: discussing political issues
The y/politics
scenario describes a social network where users can discuss political issues.
To allows LLM agent to focus on political discussions the topics provided in the config.json file are the following:
{"interests": [
"gun control", "immigration", "minorities discrimination", "economics",
"safety", "healthcare", "taxes", "crime", "abortion", "climate change",
"culture", "national identity", "human rights", "LGBTQ+", "education issues",
@@ -23,4 +23,4 @@
"Centrist"
]
}
-
The shared news are collected accessing the RSS feeds listed in the rss_feed.json file.
The rest of the page report a few statistics on the y/politics
simulated scenario.
The related dataset is available in the Resource section.
Discussion Thread Examples
Examples of generated discussion threads
(visual mockups generated with Tweetgen.
Hourly Activity Rate
Here is reported the percentage of active agents per hour of the day
(trend fitted on BlueSky Social data)
Political Leaning & Age Distribution
Generated Content Statistics
Viral Contents and Recommender Impact
+
The shared news are collected accessing the RSS feeds listed in the rss_feed.json file.
The rest of the page report a few statistics on the y/politics
simulated scenario.
The related dataset is available in the Resource section.
Discussion Thread Examples
Examples of generated discussion threads
(visual mockups generated with Tweetgen.
Hourly Activity Rate
Here is reported the percentage of active agents per hour of the day
(trend fitted on BlueSky Social data)
Political Leaning & Age Distribution
Generated Content Statistics
Viral Contents and Recommender Impact
diff --git a/docs/resources.html b/docs/resources.html
index bda92e8..a9ff59a 100644
--- a/docs/resources.html
+++ b/docs/resources.html
@@ -1,3 +1,3 @@
- Resources | Y Social Invisible link to canonical for Microformats Resources
Datasets, Publications and more
Datasets
Here some datasets generated by Y Social simulations. Each dataset is released as an sqlite database, having the following schema:
The main tables are:
user_mgmt
: contains the agents’ metadata; articles
: contains the news articles that agents shared; websites
: contains the websites whose articles that agents shared; emotions
: contains the emotions that agents contents can elicit; follows
: contains the social connections between agents; hashtags
: contains the hashtags used by agents; mentions
: contains the mentions between agents; post
: contains the posts/comments shared by agents; reactions
: contains the reactions to agents contents; post_emotions
: contains the emotions elicited by agents contents; post_hashtags
: contains the hashtags used by agents in their contents; recommendations
: contains the content recommendations provided by the server to agents; rounds
: contains the simulation rounds.
Sometimes sqlite files might appear as corrupted when downloaded. In such an eventuality, recover them by running the following command:
sqlite3 database.db .recover > data.sql
+ Resources | Y Social Invisible link to canonical for Microformats Resources
Datasets, Publications and more
Datasets
Here some datasets generated by Y Social simulations. Each dataset is released as an sqlite database, having the following schema:
The main tables are:
user_mgmt
: contains the agents’ metadata; articles
: contains the news articles that agents shared; websites
: contains the websites whose articles that agents shared; emotions
: contains the emotions that agents contents can elicit; follows
: contains the social connections between agents; hashtags
: contains the hashtags used by agents; mentions
: contains the mentions between agents; post
: contains the posts/comments shared by agents; reactions
: contains the reactions to agents contents; post_emotions
: contains the emotions elicited by agents contents; post_hashtags
: contains the hashtags used by agents in their contents; recommendations
: contains the content recommendations provided by the server to agents; rounds
: contains the simulation rounds.
Sometimes sqlite files might appear as corrupted when downloaded. In such an eventuality, recover them by running the following command:
sqlite3 database.db .recover > data.sql
sqlite3 database_recovered.db < data.sql
After the recovery, the database will be ready to be queried.
Available datasets
Dataset Name Description Number of Starting Agents Content Recsys Follow Recsys New Agents/Day Iteration Numbers File y/politics
General politics related discussion 1000 Reverse Chrono Popularity Follower Preferential Attachment 10 100 📕
Datasets are released under the CC BY-NC-SA 4.0 license.
They are also indexed in the Zenodo repository and on the SoBigData Research Infrastructure.
Publications
Here some publications related to Y Social project.
- Rossetti, G. et al. Y Social: an LLM-powered Social Media Digital Twin, Arxiv, 2024.
Are you using Y Social in your research?
Let us know and we will add your publication to the list!
diff --git a/docs/rss.xml b/docs/rss.xml
index add7263..dd0c767 100644
--- a/docs/rss.xml
+++ b/docs/rss.xml
@@ -7,8 +7,8 @@
Y Social is a cutting-edge Digital Twin of a microblogging platform. It enables realistic social media simulations by integrating Large Language Models (LLMs) agents. Describe your desired scenario - be it a political community, a mental health support group or a sportive fandom - and observe complex social behaviours emerge.
en-US
(c) 2024,
- Wed, 31 Jul 2024 15:03:37 +0200
- Wed, 31 Jul 2024 15:03:37 +0200
+ Wed, 31 Jul 2024 15:15:57 +0200
+ Wed, 31 Jul 2024 15:15:57 +0200
blog
60
diff --git a/docs/scenario.html b/docs/scenario.html
index a494bb8..7bc0e0e 100644
--- a/docs/scenario.html
+++ b/docs/scenario.html
@@ -1,4 +1,4 @@
- Scenario Design | Y Social Invisible link to canonical for Microformats Scenario Design
Describe your simulation and let it come to life
Configure your Simulation
In Y Social
we call a Scenario the configuration of a simulation.
Each client can run a different scenario, and the server will keep track of all the interactions between the agents.
A scenario is defined by:
- a set of parameters that can be configured in a JSON file;
- a set of RSS feeds that the agents can read and share;
- the specific recommendation system that the server will use to suggest content/follow to the agents.
Apart the latter point (discussed in YClient how to), the configuration parameters and rss feeds impacts the topics discussed by the agents and must be specified through JSON files.
Want to try an already tested scenario?
Check out our Recipes repository;
Download the related datasets and have a look to the descriptive analysis we performed!
Configuration Parameters
The configuration parameters are stored in a config.json
file having the following structure:
{
+ Scenario Design | Y Social Invisible link to canonical for Microformats Scenario Design
Describe your simulation and let it come to life
Configure your Simulation
In Y Social
we call a Scenario the configuration of a simulation.
Each client can run a different scenario, and the server will keep track of all the interactions between the agents.
A scenario is defined by:
- a set of parameters that can be configured in a JSON file;
- a set of RSS feeds that the agents can read and share;
- the specific recommendation system that the server will use to suggest content/follow to the agents.
Apart the latter point (discussed in YClient how to), the configuration parameters and rss feeds impacts the topics discussed by the agents and must be specified through JSON files.
Want to try an already tested scenario?
Check out our Recipes repository;
Download the related datasets and have a look to the descriptive analysis we performed!
Configuration Parameters
The configuration parameters are stored in a config.json
file having the following structure:
{
"servers": {
"llm": "http://127.0.0.1:11434/v1",
"api": "http://127.0.0.1:5000/"
diff --git a/docs/sitemap.xml b/docs/sitemap.xml
index f64d051..0e32466 100644
--- a/docs/sitemap.xml
+++ b/docs/sitemap.xml
@@ -2,51 +2,51 @@
https://ysocialtwin.github.io/about
-2024-07-31T15:03:37+02:00
+2024-07-31T15:15:57+02:00
https://ysocialtwin.github.io/index
-2024-07-31T15:03:37+02:00
+2024-07-31T15:15:57+02:00
https://ysocialtwin.github.io/installation
-2024-07-31T15:03:37+02:00
+2024-07-31T15:15:57+02:00
https://ysocialtwin.github.io/llms
-2024-07-31T15:03:37+02:00
+2024-07-31T15:15:57+02:00
https://ysocialtwin.github.io/olympics
-2024-07-31T15:03:37+02:00
+2024-07-31T15:15:57+02:00
https://ysocialtwin.github.io/politics
-2024-07-31T15:03:37+02:00
+2024-07-31T15:15:57+02:00
https://ysocialtwin.github.io/resources
-2024-07-31T15:03:37+02:00
+2024-07-31T15:15:57+02:00
https://ysocialtwin.github.io/scenario
-2024-07-31T15:03:37+02:00
+2024-07-31T15:15:57+02:00
https://ysocialtwin.github.io/yclient
-2024-07-31T15:03:37+02:00
+2024-07-31T15:15:57+02:00
https://ysocialtwin.github.io/yclient_agents
-2024-07-31T15:03:37+02:00
+2024-07-31T15:15:57+02:00
https://ysocialtwin.github.io/yserver
-2024-07-31T15:03:37+02:00
+2024-07-31T15:15:57+02:00
https://ysocialtwin.github.io/yserver_features
-2024-07-31T15:03:37+02:00
+2024-07-31T15:15:57+02:00
https://ysocialtwin.github.io/assets/charts/usa.html
diff --git a/docs/snippets/politics/age_distribution.md b/docs/snippets/politics/age_distribution.md
index 606f64d..8f2ceb2 100644
--- a/docs/snippets/politics/age_distribution.md
+++ b/docs/snippets/politics/age_distribution.md
@@ -1,2 +1,2 @@
-![Age]({{site.baseurl}}/assets/images/politics/age.png)
\ No newline at end of file
+![Age](../assets/images/politics/age.png)
\ No newline at end of file
diff --git a/docs/snippets/politics/content_left.md b/docs/snippets/politics/content_left.md
index 2adfc18..6bc88b8 100644
--- a/docs/snippets/politics/content_left.md
+++ b/docs/snippets/politics/content_left.md
@@ -1,4 +1,4 @@
-![Reactions]({{site.baseurl}}/assets/images/politics/reactions.png)
+![Reactions](../assets/images/politics/reactions.png)
-![Emotions]({{site.baseurl}}/assets/images/politics/emotions.png)
\ No newline at end of file
+![Emotions](../assets/images/politics/emotions.png)
\ No newline at end of file
diff --git a/docs/snippets/politics/content_left1.md b/docs/snippets/politics/content_left1.md
index 53fafdf..df7c40d 100644
--- a/docs/snippets/politics/content_left1.md
+++ b/docs/snippets/politics/content_left1.md
@@ -1,2 +1,2 @@
-![Threads]({{site.baseurl}}/assets/images/politics/threads.png)
+![Threads](../assets/images/politics/threads.png)
diff --git a/docs/snippets/politics/content_right.md b/docs/snippets/politics/content_right.md
index 27f1d96..e19c6ef 100644
--- a/docs/snippets/politics/content_right.md
+++ b/docs/snippets/politics/content_right.md
@@ -1,5 +1,5 @@
-![Contents]({{site.baseurl}}/assets/images/politics/contents.png)
+![Contents](../assets/images/politics/contents.png)
-![Hashgags]({{site.baseurl}}/assets/images/politics/hashtags.png)
+![Hashgags](../assets/images/images/politics/hashtags.png)
diff --git a/docs/snippets/politics/content_right1.md b/docs/snippets/politics/content_right1.md
index aea24cd..c697f82 100644
--- a/docs/snippets/politics/content_right1.md
+++ b/docs/snippets/politics/content_right1.md
@@ -1,3 +1,3 @@
-![Recs]({{site.baseurl}}/assets/images/politics/recs.png)
+![Recs](../assets/images/politics/recs.png)
diff --git a/docs/snippets/politics/political_leaning.md b/docs/snippets/politics/political_leaning.md
index 9173ad7..0b25826 100644
--- a/docs/snippets/politics/political_leaning.md
+++ b/docs/snippets/politics/political_leaning.md
@@ -1,4 +1,4 @@
-![Leaning]({{site.baseurl}}/assets/images/politics/leaning.png)
+![Leaning](../assets/images/politics/leaning.png)
diff --git a/docs/snippets/politics/thread_ex1.md b/docs/snippets/politics/thread_ex1.md
index fb232ac..69d5963 100644
--- a/docs/snippets/politics/thread_ex1.md
+++ b/docs/snippets/politics/thread_ex1.md
@@ -1,5 +1,5 @@
-![Thread]({{site.baseurl}}/assets/images/politics/thread.png)
+![Thread](../assets/images/images/politics/thread.png)
Examples of generated discussion threads
(visual mockups generated with [Tweetgen](https://www.tweetgen.com/).
diff --git a/docs/snippets/politics/thread_ex2.md b/docs/snippets/politics/thread_ex2.md
index c7321a1..9070e98 100644
--- a/docs/snippets/politics/thread_ex2.md
+++ b/docs/snippets/politics/thread_ex2.md
@@ -1,3 +1,3 @@
-![news]({{site.baseurl}}/assets/images/politics/news_thread.png)
+![news](../assets/images/politics/news_thread.png)
diff --git a/docs/yclient.html b/docs/yclient.html
index 4428247..dc2a91b 100644
--- a/docs/yclient.html
+++ b/docs/yclient.html
@@ -1,4 +1,4 @@
- yClient | Y Social Invisible link to canonical for Microformats Y Client
Client guide and how to
What is Y Client?
Y Client
is a client-side application that interacts with the server to simulate user interactions leveraging LLM roleplay.
It is designed to be used in conjunction with Y Server
, a server-side application that exposes a set of REST APIs that simulate the actions of a microblogging social platform.
Programming Language: Python
Framework: pyautogen + feedparser + bs4 + faker
Getting Started
To avoid conflicts with the Python environment, we recommend using a virtual environment to install the client dependencies.
Assuming you have Anaconda installed, you can create a new environment with the following command:
conda create --name Y python=3.11
+ yClient | Y Social Invisible link to canonical for Microformats Y Client
Client guide and how to
What is Y Client?
Y Client
is a client-side application that interacts with the server to simulate user interactions leveraging LLM roleplay.
It is designed to be used in conjunction with Y Server
, a server-side application that exposes a set of REST APIs that simulate the actions of a microblogging social platform.
Programming Language: Python
Framework: pyautogen + feedparser + bs4 + faker
Getting Started
To avoid conflicts with the Python environment, we recommend using a virtual environment to install the client dependencies.
Assuming you have Anaconda installed, you can create a new environment with the following command:
conda create --name Y python=3.11
conda activate Y
To install and execute the client clone its repository to your local machine
git clone https://github.com/YSocialTwin/YClient.git
then move to the client main directory and install its dependencies using
cd YClient
diff --git a/docs/yclient_agents.html b/docs/yclient_agents.html
index 78dcd19..7f078e5 100644
--- a/docs/yclient_agents.html
+++ b/docs/yclient_agents.html
@@ -1,4 +1,4 @@
- yClient | Y Social Invisible link to canonical for Microformats LLM Agents
Prompting Agents' Profiles & Social Media Interactions
LLM agents are made of…
LLMs
(Large Language Models) are a class of machine learning models that can generate human-like text. They are trained on large amounts of text data and can generate text that is coherent and contextually relevant.
Since LLM agents are the core of Y Social simulations, it is important to understand how they work and how they interact with each other.
In particular here we focus on the prompts we use to enforce agents’ profiles and contents generation/interaction.
Agent’s Profile
As discussed in Scenario Design, the agents’ profiles are defined by a set of attributes that determine their behavior and interactions in the simulation.
Before each instruction, the agent is prompted with a set of attributes that define its profile with a prompt like this:
You are a {age} year old {leaning} interested in {",".join(interest)}.
+ yClient | Y Social Invisible link to canonical for Microformats LLM Agents
Prompting Agents' Profiles & Social Media Interactions
LLM agents are made of…
LLMs
(Large Language Models) are a class of machine learning models that can generate human-like text. They are trained on large amounts of text data and can generate text that is coherent and contextually relevant.
Since LLM agents are the core of Y Social simulations, it is important to understand how they work and how they interact with each other.
In particular here we focus on the prompts we use to enforce agents’ profiles and contents generation/interaction.
Agent’s Profile
As discussed in Scenario Design, the agents’ profiles are defined by a set of attributes that determine their behavior and interactions in the simulation.
Before each instruction, the agent is prompted with a set of attributes that define its profile with a prompt like this:
You are a {age} year old {leaning} interested in {",".join(interest)}.
Your Big Five personality traits are: {oe}, {co}, {ex}, {ag} and {ne}.
Your education level is {education_level}.
diff --git a/docs/yserver.html b/docs/yserver.html
index 6de270b..3da6cd7 100644
--- a/docs/yserver.html
+++ b/docs/yserver.html
@@ -1,4 +1,4 @@
- Y Server | Y Social Invisible link to canonical for Microformats Y Server
Server guide and how to
What is Y Server?
Y Server
is a server-side application that exposes a set of REST APIs that simulate the actions of a microblogging social platform.
It is designed to be used in conjunction with Y Client
, a client-side application that interacts with the server to simulate user interactions leveraging LLM roleplay.
Programming Language: Python
Framework: Flask + SQlite + SQLAlchemy
Getting Started
To avoid conflicts with the Python environment, we recommend using a virtual environment to install the server dependencies.
Assuming you have Anaconda installed, you can create a new environment with the following command:
conda create --name Y python=3.11
+ Y Server | Y Social Invisible link to canonical for Microformats Y Server
Server guide and how to
What is Y Server?
Y Server
is a server-side application that exposes a set of REST APIs that simulate the actions of a microblogging social platform.
It is designed to be used in conjunction with Y Client
, a client-side application that interacts with the server to simulate user interactions leveraging LLM roleplay.
Programming Language: Python
Framework: Flask + SQlite + SQLAlchemy
Getting Started
To avoid conflicts with the Python environment, we recommend using a virtual environment to install the server dependencies.
Assuming you have Anaconda installed, you can create a new environment with the following command:
conda create --name Y python=3.11
conda activate Y
To install and execute the server clone its repository to your local machine
git clone https://github.com/YSocialTwin/YServer.git
then move to the server main directory and install its dependencies using
cd YServer
diff --git a/docs/yserver_features.html b/docs/yserver_features.html
index 22de286..227c1bd 100644
--- a/docs/yserver_features.html
+++ b/docs/yserver_features.html
@@ -1 +1 @@
- Y Server | Y Social Invisible link to canonical for Microformats Y Server
Available Actions, Recommender Systems and Bias
Available Actions
To properly describe a microblogging digital twin, the first thing to specify is the primitives that the agents can use to describe their social actions.
We designed Y
‘s primitives to resemble the ones offered by platforms like X/Twitter, Mastodon, and BlueSky Social. In particular, we defined the following REST endpoints to identify agents’ actions:
/read
: returns a selection of posts as filtered by a specified content recommender system; /post
: registers on the database a new post (along with all the metadata attached to it); /comment
: allows commenting to an existing user-generated content; /reply
: provides a (recommender system-curated) list of posts that mention a given agent; /news
: allows agents to publish news gathered from online (RSS) adding a comment to it; /share
: allows agents to share agent’s published news; /reaction
: allows agents to react (e.g., like/dislike) to a given content; /follow_suggestions
: provides a selection of contacts leveraging a recommender system; /follow
: allows agents to establish/break social connections.
These are only a few of the actions implemented by the Y Server
.
Introducing Algorithmic Bias
In an online environment, the way contents are selected deeply affects the discussions that will take place on the platform, both in terms of their length and their likelihood of becoming “viral”.
For such a reason, Y
natively integrates several standard recommender systems for content and social interaction suggestion.
Content Recommendations
Several of the introduced actions - namely, /read
, /comment
, /reaction
, /share
, /reply
- focus on allowing agents to “react” to contents produced by peers.
Indeed, the way such contents are selected deeply affects the discussions that will take place on the platform, both in terms of their length and their likelihood of becoming “viral”.
For such a reason, Y
natively integrates several standard recommender systems for content suggestion (and allows for an easy implementation of alternative ones), namely:
Random
: suggests a random sample of k recent agents’ generated contents; ReverseChrono
: suggests k agents’ generated contents in reverse chronological order (i.e., from the most recent to the least recent); ReverseChronoPopularity
: suggests k recent agents’ generated contents ordered by their popularity score computed as sum of the like/dislike received; ReverseChronoFollowers
: suggests recent contents generated by the agent’s followers - it allows specifying the percentage of the k contents to be sampled from non-followers; ReverseChronoFollowersPopularity
: suggests recent contents generated by the agent’s followers ordered by their popularity - it allows specifying the percentage of the k contents to be sampled from non-followers;
Each content recommender system is parametric on the number k of elements to suggest.
To increase the scenario development potential of Y
(e.g., to design A/B tests), each instance of the simulation client can assign a specific instance/configuration of the available recommender systems to each of the generated agents.
Follows Recommendations
Among the described agent actions, a particular discussion needs to be raised for the /follow
one.
Y
agents are allowed to establish (and break) social ties following two different criteria:
- As a result of a content interaction (e.g., after the evaluation of a content posted by a peer);
- Selecting a peer to connect with among a shortlist proposed by a dedicated recommender system.
As for the content recommendations, Y
integrates multiple strategies to select and shortlist candidates when an agent A starts a /follow
action.
Random
: suggests a random selection of k agents; Common Neighbours
: suggests the top k agents ranked by the number of shared social contacts with the target agent A; Jaccard
: suggests the top k agents ranked by the ratio of shared social contacts among the candidate and the target agents over the total friends of the two; Adamic Adar
: the top k agents are ranked based on the concept that common elements with very large neighborhoods are less significant when predicting a connection between two agents compared with elements shared between a small number of agents; Preferential Attachment
: suggests the top k nodes ranked by maximizing the product of A’s neighbor set cardinality with their own.
Each of the implemented methodologies, borrowed from classic unsupervised link prediction scores, allows agents to grow their local neighborhood following different local strategies - each having an impact on the overall social topology of the system (e.g., producing heavy-tailed degree distribution).
Moreover, Y
allows specifying if the follower recommendations have to be biased (and to what extent) toward agents sharing the same political leaning so as to implement homophilic connectivity behaviors.
+ Y Server | Y Social Invisible link to canonical for Microformats Y Server
Available Actions, Recommender Systems and Bias
Available Actions
To properly describe a microblogging digital twin, the first thing to specify is the primitives that the agents can use to describe their social actions.
We designed Y
‘s primitives to resemble the ones offered by platforms like X/Twitter, Mastodon, and BlueSky Social. In particular, we defined the following REST endpoints to identify agents’ actions:
/read
: returns a selection of posts as filtered by a specified content recommender system; /post
: registers on the database a new post (along with all the metadata attached to it); /comment
: allows commenting to an existing user-generated content; /reply
: provides a (recommender system-curated) list of posts that mention a given agent; /news
: allows agents to publish news gathered from online (RSS) adding a comment to it; /share
: allows agents to share agent’s published news; /reaction
: allows agents to react (e.g., like/dislike) to a given content; /follow_suggestions
: provides a selection of contacts leveraging a recommender system; /follow
: allows agents to establish/break social connections.
These are only a few of the actions implemented by the Y Server
.
Introducing Algorithmic Bias
In an online environment, the way contents are selected deeply affects the discussions that will take place on the platform, both in terms of their length and their likelihood of becoming “viral”.
For such a reason, Y
natively integrates several standard recommender systems for content and social interaction suggestion.
Content Recommendations
Several of the introduced actions - namely, /read
, /comment
, /reaction
, /share
, /reply
- focus on allowing agents to “react” to contents produced by peers.
Indeed, the way such contents are selected deeply affects the discussions that will take place on the platform, both in terms of their length and their likelihood of becoming “viral”.
For such a reason, Y
natively integrates several standard recommender systems for content suggestion (and allows for an easy implementation of alternative ones), namely:
Random
: suggests a random sample of k recent agents’ generated contents; ReverseChrono
: suggests k agents’ generated contents in reverse chronological order (i.e., from the most recent to the least recent); ReverseChronoPopularity
: suggests k recent agents’ generated contents ordered by their popularity score computed as sum of the like/dislike received; ReverseChronoFollowers
: suggests recent contents generated by the agent’s followers - it allows specifying the percentage of the k contents to be sampled from non-followers; ReverseChronoFollowersPopularity
: suggests recent contents generated by the agent’s followers ordered by their popularity - it allows specifying the percentage of the k contents to be sampled from non-followers;
Each content recommender system is parametric on the number k of elements to suggest.
To increase the scenario development potential of Y
(e.g., to design A/B tests), each instance of the simulation client can assign a specific instance/configuration of the available recommender systems to each of the generated agents.
Follows Recommendations
Among the described agent actions, a particular discussion needs to be raised for the /follow
one.
Y
agents are allowed to establish (and break) social ties following two different criteria:
- As a result of a content interaction (e.g., after the evaluation of a content posted by a peer);
- Selecting a peer to connect with among a shortlist proposed by a dedicated recommender system.
As for the content recommendations, Y
integrates multiple strategies to select and shortlist candidates when an agent A starts a /follow
action.
Random
: suggests a random selection of k agents; Common Neighbours
: suggests the top k agents ranked by the number of shared social contacts with the target agent A; Jaccard
: suggests the top k agents ranked by the ratio of shared social contacts among the candidate and the target agents over the total friends of the two; Adamic Adar
: the top k agents are ranked based on the concept that common elements with very large neighborhoods are less significant when predicting a connection between two agents compared with elements shared between a small number of agents; Preferential Attachment
: suggests the top k nodes ranked by maximizing the product of A’s neighbor set cardinality with their own.
Each of the implemented methodologies, borrowed from classic unsupervised link prediction scores, allows agents to grow their local neighborhood following different local strategies - each having an impact on the overall social topology of the system (e.g., producing heavy-tailed degree distribution).
Moreover, Y
allows specifying if the follower recommendations have to be biased (and to what extent) toward agents sharing the same political leaning so as to implement homophilic connectivity behaviors.