Stablecoins mktcap data

On choisit les stablecoins suivant : USDT, USDC, DAI, PYUSD, FDUSD, EURC. Ces tokens structurent l’essentiel des volumes/market cap USD sur les classements “stablecoins” et catégories stablecoins, et parce qu’elles ont suffisamment d’observations pour cette étude.

On récolte ensuite la market capitalization de ces stablecoins sur Artemis.xyz, une plateforme d’analyse des données de crypto.

Pourquoi la market cap ?

  • La market capitalization est définit par : Supply x Price

  • un choc (speech positif envers CBDC) va impacter la demande de stablecoin pour différentes raisons,

  • demande < offre -> pression à la baisse sur les prix,

  • donc baisse des prix des cryptos -> baisse market cap qui ne serait pas captée par la supply uniquement,

  • si pressions trop fortes, l’émetteur intervient en réduisant la supply (burn);

  • donc baisse de la supply -> baisse market cap;

  • En utilisant la supply, on ne capte qu’une partie des effets. A la rigueur, la supply peut être représentative dans le cas des algorithmic stablecoins car l’ajustement de l’offre est fait de manière automatique.

Data import

We also collect price and supply for those stablecoins from Artemis. We fill NAs with linear interpolation.

In this article https://www.artemisanalytics.com/resources/outstanding-supply by Artemis.xyz, they suggest to use the Outstanding Supply of stablecoin to be closer to stock supply (Outstanding Shares in stocks) and have a good representation of the true circulating supply. We gather data on Outstanding Supply from TokenTerminal (https://tokenterminal.com/explorer/metrics/outstanding-supply) : (The data are available on this link : https://tokenterminal.com/explorer/studio/charts/new?v=ZGRlNjhlMWJkNDYzZDM0ZDdjNGMxZmUy).

Final Database

We drop dates of stablecoins supply after July 2025 because the last observation is 2025-06-16 for speeches about CBDC, and adding too much after this dates will just add zeros.

Note : je n’ai pas les données de prix et de circulating supply avant 2020 parce que j’ai épuisé mon quotas d’extraction de données, je pourrai en récupérer plus à partir du 1er février.

Models

We estimate the following local projection model :

\[ Y_{i,t+h}-Y_{i,t-1}= \alpha_i + \beta^h X_t + \gamma Z_t + \mu_{i,t} \] Where \(Y\) is the log-difference of stablecoin supply, \(\alpha_i\) is an individual FE, and \(X_t\) is our index of speech CBDC-related sentiment/stance. \(Z_t\) are control variables representing the VIX and the GPRD and their lags, and dummies representing Terra-Luna and FTX crashes. We include individual (\(\alpha_i\)) fixed-effects.
Note : we take the 90% interval confidences for all estimations. Standard errors are heteroskedasticity robusts (clusterized by stablecoin).

Daily

Sentiment / Stance

Sentiment, as measured by Auer & al. (2021) tend not to capture the effect of CBDC’s related communications on stablecoin supplies. However, the Machine Learning framework does capture the negative effect of an increasing sentiment/stance from Central Banks, suggesting a substitution between stablecoins and CBDC. This effect is relatively small yet significant, and may be due to the fact that an important number of speeches are not particularly focused on CBDC, but may treat several subjects that Central Banks take care of and mention marginally CBDC eventually just to talk about it without really using a forward guidance design. We thus focus on important speeches, i.e. communications that explicitly focus on CBDC in their title (Note : another approach could be to weight the speeches by the number of sentences related to CBDC, or the share of these sentences in the total number of sentences).

Immediate effect following important CBDC-related speeches, i.e. speeches that explicitly mention CBDC or related keywords in their title. The effect is almost immediate, and the communications tend to decrease stablecoins supply by 0.3% after about a month.

In addition, we can decompose the market capitalization effect on two effects : the price effect, and the supply effect. We retrieve both price and supply from Artemis.xyz.

Overall, we can see that an increase in sentiment/stance of CB towards CBDC tend to decrease the market capitalization of stablecoins, mainly through a decrease in supply to defend the parity. Indeed, the price do not tend to move while the supply does, implying a decrease in demand for stablecoins to ensure that demand = supply so that price is at par.

We can also test with the Outstanding Supply :

Decomposition by type

Une hausse du sentiment/stance à propos des MNBC general ou non-spécifié ne tend pas à créer une baisse de la demande pour les stablecoins

Decomposition by Process

Decomposition by type and process

Features

Process

Risk-Benefits

Decomposition by Markets/Central Banks

DevEme

ECB vs other

What we observe overall : - An increase in sentiment/stance tend to decrease the demand for stablecoins - This results hides heterogeneity - An increase in sentiment/stance for retail and wholesale CBDC decrease the demand for stablecoins, while an increase in sentiment/stance for General/Unspecified CBDC tend to increase the demand or have no effect depending on the discourse associated. - An interpretation is that when Central Bank talk about General/Unspecified CBDC, it contains information about the project of other central banks “central banks of major countries are carrying out in-depth research recently on digital currencies” or be interpreted - in some cases - as a sign that central banks will adopt an already-existing stablecoin. - However, when the speech clearly states that it aims to issue a retail/wholesale stablecoins, it is perceived as a substitute for existing stablecoins. - Notably, when central banks announce progress on Wholesale (Features particularly) or Retail (Process particularly) CBDC, it dampens the demand for stablecoins. - The effect is particularly visible when Central Banks from Developed Markets communicate about CBDC - and especially ECB.

Important speeches only

Decomposition by type

Decomposition by Discourse in important speeches

Decomposition by type and process in important speeches

Features

Process

Risk-Benefit

Note : Je pense qu’on peut utiliser uniquement les speeches importants, ils donnent des résultats plus clairs et c’est assez facile de justifier leur utilisation + les résultats sont robustes mais moins marquants quand on utilise tous les speeches.

---
title: "R Notebook: Artemis MKTCAP"
output:
  html_notebook: 
    toc: true
    toc_depth: 3
    toc_float: true
  html_document:
    df_print: paged
  word_document: default
  pdf_document: default
---


# Stablecoins mktcap data

On choisit les stablecoins suivant : USDT, USDC, DAI, PYUSD, FDUSD, EURC. Ces tokens structurent l’essentiel des volumes/market cap USD sur les classements “stablecoins” et catégories stablecoins, et parce qu'elles ont suffisamment d'observations pour cette étude.

On récolte ensuite la market capitalization de ces stablecoins sur Artemis.xyz, une plateforme d'analyse des données de crypto. 

Pourquoi la market cap ? 

  - La market capitalization est définit par : Supply x Price
  
  - un choc (speech positif envers CBDC) va impacter la demande de stablecoin pour différentes raisons,
  
  - demande < offre -> pression à la baisse sur les prix,
  
  - donc baisse des prix des cryptos -> baisse market cap qui ne serait pas captée par la supply uniquement,
  
  - si pressions trop fortes, l'émetteur intervient en réduisant la supply (burn);
  
  - donc baisse de la supply -> baisse market cap;
  
  - En utilisant la supply, on ne capte qu'une partie des effets. A la rigueur, la supply peut être représentative dans le cas des algorithmic stablecoins car l'ajustement de l'offre est fait de manière automatique. 
  
  
## Data import

```{r, message=FALSE, echo=FALSE}
artemis <- readr::read_csv2(
  "C:/Users/fkraus/Desktop/Articles/effects of CB speeches on stablecoins/Artemis data/Stablecoin Supply by Stablecoin.csv",
  show_col_types = FALSE
)
names(artemis) <- c("Date","AUSD","BUSD","DAI","EURC","FDUSD","PYUSD","USD0","USDC",                "USDGLO","USDP","USDS","USDT","USDY","USDe","cEUR","cKES","cREAL","cUSD")


artemis_raw <- artemis %>%
  mutate(
    Date = dmy_hm(Date, tz = "UTC")  
  )
```



```{r, echo=FALSE, warning=FALSE, message=FALSE}

panel_artemis <- artemis_raw %>%
  mutate(Date = as.Date(Date, format="%d/%m/%y")) %>%
  pivot_longer(
    cols = -Date,
    names_to = "stablecoin",
    values_to = "supply",
    values_transform = list(supply = as.numeric)  
  ) %>%
   mutate(stablecoin = if_else(stablecoin == "USDS", "DAI", stablecoin)) %>%
  group_by(Date, stablecoin) %>%
  summarise(
    supply = max(supply, na.rm = TRUE),   # si les 2 existent même jour, on garde la valeur non-NA (ou la plus grande)
    .groups = "drop"
  ) %>%
  arrange(stablecoin, Date)  %>% 

  group_by(stablecoin)%>%
  mutate(log_supply = log(1+supply), dlog_supply = log_supply - dplyr::lag(log_supply)) %>%
  #mutate(
  #  q01 = quantile(dlog_supply, 0.05, na.rm = TRUE),
  #  q99 = quantile(dlog_supply, 0.95, na.rm = TRUE)
  #) %>%
  #filter(is.finite(dlog_supply),
  #       !is.na(q01), !is.na(q99),
  #       dlog_supply >= q01,
  #       dlog_supply <= q99)%>%
  #select(-c(q01, q99, dlog_supply))%>%
  ungroup()%>%
  filter(stablecoin %in% c("USDT", "USDC", "DAI", "PYUSD", "USDe", "EURC"))




```


```{r, echo=FALSE}
ggplot(panel_artemis, aes(x=Date, y=log_supply))+
  geom_line(lwd=1)+
  labs(x="Date", y="log(supply)")+
  facet_wrap(~stablecoin, scales="free")
```

We also collect price and supply for those stablecoins from Artemis. We fill NAs with linear interpolation. 

```{r, echo=FALSE}
price <- readxl::read_excel("C:/users/fkraus/Desktop/artemiss.xlsx", sheet = "price2")
supply<- readxl::read_excel("C:/users/fkraus/Desktop/artemiss.xlsx", sheet = "supply2")

price_long <- price %>%
  pivot_longer(-Date, names_to = "stablecoin", values_to = "price")

supply_long <- supply %>%
  pivot_longer(-Date, names_to = "stablecoin", values_to = "supply")
panel_prices <- price_long %>%
  full_join(supply_long, by = c("Date", "stablecoin")) %>%
  arrange(Date, stablecoin)%>%
  filter(stablecoin %in% c("usdt", "usdc", "dai", "pyusd", "eurc", "usde"))%>%
  mutate(stablecoin =case_when(
    stablecoin == "dai" ~ "DAI", 
    stablecoin=="usdc"~"USDC",
    stablecoin=="usdt"~"USDT", 
    stablecoin=="eurc"~"EURC", 
    stablecoin=="usde"~"USDe",
    stablecoin=="pyusd"~"PYUSD"))
```




In this article https://www.artemisanalytics.com/resources/outstanding-supply by Artemis.xyz, they suggest to use the Outstanding Supply of stablecoin to be closer to stock supply (Outstanding Shares in stocks) and have a good representation of the true circulating supply. We gather data on Outstanding Supply from TokenTerminal (https://tokenterminal.com/explorer/metrics/outstanding-supply) : (The data are available on this link : https://tokenterminal.com/explorer/studio/charts/new?v=ZGRlNjhlMWJkNDYzZDM0ZDdjNGMxZmUy).  



```{r, echo=FALSE}
tokenterminal_supply <- read_excel("C:/Users/fkraus/Desktop/tokenterminal_supply.xlsx", 
    col_types = c("date", "numeric", "numeric", 
         "numeric", "numeric", "numeric", 
         "numeric", "numeric", "numeric", 
         "numeric", "numeric", "numeric", 
         "numeric", "numeric", "numeric", 
         "numeric", "numeric", "numeric", 
         "numeric", "numeric", "numeric", 
         "numeric", "numeric", "numeric", 
         "numeric", "numeric", "numeric", 
         "numeric", "numeric", "numeric", 
         "numeric", "numeric", "numeric", 
         "numeric", "numeric", "numeric", 
         "numeric", "numeric", "numeric", 
         "numeric", "numeric", "numeric", 
         "numeric", "numeric", "numeric", 
         "numeric", "numeric", "numeric", 
         "numeric", "numeric", "numeric", 
         "numeric", "numeric", "numeric"))


tokenterminal_long <- tokenterminal_supply  %>%
  pivot_longer(-Date, names_to = "stablecoin", values_to = "supply")%>%
  mutate(log_supply = log(supply))%>%
  na.omit()%>%
  filter(Date < as.Date("2025-07-01"))

tokenterminal_long2 <- tokenterminal_long %>%   # <-- replace df with your object name
  mutate(
    stablecoin_raw = str_remove(stablecoin, "\\s*-\\s*Outstanding supply \\(\\$\\)\\s*$"),
    symbol   = str_trim(str_remove(stablecoin_raw, "\\s*\\([^)]*\\)\\s*$")),
    name = str_match(stablecoin_raw, "\\(([^)]*)\\)")[,2]
  ) %>%
  select(-c( stablecoin))

data_tokenterminal <-tokenterminal_long2%>%
  mutate(symbol=ifelse(symbol=="USDS", "DAI", symbol))%>%
  mutate(symbol=ifelse(symbol=="USDE", "USDe", symbol))%>%

  filter(symbol%in% c("USDT", "USDC", "DAI", "PYUSD", "EURC", "USDe"))%>%
  rename("outstanding_supply"="supply", 
         "log_outstanding_supply"="log_supply")%>%
  select(-c(stablecoin_raw, name))

```


# Final Database


```{r, echo=FALSE, message=FALSE}
GPR <- readxl::read_excel("C:/users/fkraus/Desktop/Articles/effects of CB speeches on stablecoins/2025/GPR.xlsx")%>%
  mutate(date=as.Date(date))%>%
  select(-c(DAY))
require(quantmod)
VIX <- getSymbols("^VIX", src="yahoo", auto.assign = FALSE) 
vix_data <- data.frame(date = index(VIX), coredata(VIX))%>%
  dplyr::rename("VIX_close" = `VIX.Close`)%>%
  select(date, VIX_close)
vix_data_weekly <- data.frame(date = index(VIX), coredata(VIX))%>%
  dplyr::rename("VIX_close" = `VIX.Close`)%>%
  select(date, VIX_close)%>%
  mutate(week = floor_date(date, "week", week_start=1))%>%
  group_by(week)%>%
  summarize(VIX_close = mean(VIX_close, na.rm=T))

GPR_data_weekly <- readxl::read_excel("C:/Users/fkraus/Desktop/Articles/effects of CB speeches on stablecoins/2025/GPR.xlsx")%>%
  mutate(date=as.Date(date))%>%
  select(-c(DAY) )%>%
  mutate(week=floor_date(date, "week", week_start = 1))%>%
  group_by(week)%>%
  summarize(N10D = mean(N10D), GPRD = mean(GPRD), 
            GPRD_ACT = mean(GPRD_ACT), GPRD_THREAT=mean(GPRD_THREAT))%>%
  filter(week > as.Date("2017-01-01"))

data_artemis <-panel_artemis%>%
  na.omit()%>%
  left_join(database_daily, by=c("Date"="date"))%>%
  mutate(quarteryear = paste0(quarter(Date), year(Date)))%>%
  left_join(GPR, by=c("Date"="date"))%>%
  left_join(vix_data, by=c("Date"="date"))%>%
  arrange(stablecoin, Date)%>%
  mutate(FTX = ifelse(Date > as.Date("2022-11-01") & Date < as.Date("2023-01-01"),1,0 ))%>%
  mutate(Luna = ifelse(Date > as.Date("2022-05-01") & Date < as.Date("2022-07-01"),1,0 ))%>%
  
  mutate(across(-Date, ~ tidyr::replace_na(.x, 0))) %>% # remove this to replace 0 with NA when there's no speech
  mutate(pegType = case_when(
    stablecoin == "USDT"~ "USD",
    stablecoin == "USDC"~ "USD",
    stablecoin == "DAI"~ "USD",
    stablecoin == "EURC"~ "EUR",
    stablecoin == "FDUSD"~ "USD",
    stablecoin == "PYUSD"~ "USD"
    ))%>%
  mutate(pegMechanism = case_when(
    stablecoin == "USDT"~ "fiat",
    stablecoin == "USDC"~ "fiat",
    stablecoin == "DAI"~ "crypto",
    stablecoin == "EURC"~ "fiat",
    stablecoin == "FDUSD"~ "fiat",
    stablecoin == "PYUSD"~ "fiat"

  ))%>%
  left_join(panel_prices, by=c("stablecoin","Date" ), suffix=c("", "_sup"))%>%
  left_join(data_tokenterminal, by=c("stablecoin"="symbol", "Date"))%>%
  group_by(stablecoin)%>%
  mutate(price = na.approx(price, na.rm=F))%>%
    mutate(supply_sup = na.approx(supply_sup, na.rm=F))%>%
  mutate(log_supply_sup = log(supply_sup))%>%

  janitor::clean_names()%>%
  filter(date <=as.Date("2025-07-01"))
  
```

We drop dates of stablecoins supply after July 2025 because the last observation is 2025-06-16 for speeches about CBDC, and adding too much after this dates will just add zeros. 


```{r}
#write.csv(data_artemis, "C:/users/fkraus/Desktop/Articles/effect of CB speeches on stablecoins/2025/DATA_ARTEMIS.csv" )
#write.dta(data_artemis, "C:/users/fkraus/Desktop/Articles/effect of CB speeches on stablecoins/2025/DATA_ARTEMIS.dta" )

```



```{r, echo=FALSE}

ggplot(data_artemis, aes(x = date, y = supply, fill = stablecoin)) +
  geom_area() +
  labs(x = "", y = "", title = "Cumulated Market Capitalization") +
  theme_minimal() +
  theme(legend.position = "bottom")


ggplot(data_artemis, aes(x = date, y = supply_sup, fill = stablecoin)) +
  geom_area() +
  labs(x = "", y = "", title = "Cumulated Supply") +
  theme_minimal() +
  theme(legend.position = "bottom")
```
Note : je n'ai pas les données de prix et de circulating supply avant 2020 parce que j'ai épuisé mon quotas d'extraction de données, je pourrai en récupérer plus à partir du 1er février.



```{r, include=FALSE}
make_irf_plot_2 <- function(data, title = NULL) {
  ggplot(
    data,
    aes(
      x = h, y = irf,
      ymin = low, ymax = up,
      color = type, fill = type
    )
  ) +
    geom_hline(yintercept = 0, linetype = "dashed") +
    geom_ribbon(alpha = 0.3, color = NA) +
    geom_line(linewidth = 0.7) +
    scale_color_manual(values = cols_type) +
    scale_fill_manual(values = cols_type) +
    labs(
      x = "Horizon (weeks)",
      y = "Response of Supply (log)",
      color = NULL, fill = NULL,
      title = title
    ) +
    theme_minimal(base_size = 12) +
    theme(
      legend.position = "bottom",
      plot.title = element_text(hjust = 0.5)
    )
}

cols_type <- c(
  "Sentiment" = "#1f77b4",  # bleu
  "Stance"    = "#d62728",  # rouge
  "Sentiment (Auer)"     = "#d95f02"   # au cas où (Auer sentiment seul, etc.)
)

shock_var <- c("stance_auer", "index_stance", "index_sent", "index_sent_type_wholesale_cbdc", "index_stance_type_wholesale_cbdc", "index_sent_type_retail_cbdc", "index_sent_type_general_unspecified", "index_stance_type_general_unspecified", "index_stance_type_retail_cbdc", "index_sent_disc_feature", "index_stance_disc_feature", "index_sent_disc_process", "index_stance_disc_process", "index_sent_disc_risk_benefit", "index_stance_disc_risk_benefit", "index_sent_type_disc_general_unspecified_feature",     "index_sent_type_disc_general_unspecified_process", "index_sent_type_disc_general_unspecified_risk_benefit","index_sent_type_disc_retail_cbdc_feature",             
 "index_sent_type_disc_retail_cbdc_risk_benefit",  "index_sent_type_disc_wholesale_cbdc_feature",        
 "index_sent_type_disc_retail_cbdc_process",  "index_sent_type_disc_wholesale_cbdc_risk_benefit",     
 "index_sent_type_disc_wholesale_cbdc_process", "index_stance_type_disc_general_unspecified_feature" ,  
"index_stance_type_disc_general_unspecified_process", "index_stance_type_disc_general_unspecified_risk_benefit", "index_stance_type_disc_retail_cbdc_feature", "index_stance_type_disc_retail_cbdc_risk_benefit",      
 "index_stance_type_disc_wholesale_cbdc_feature" , "index_stance_type_disc_retail_cbdc_process",          
 "index_stance_type_disc_wholesale_cbdc_risk_benefit", "index_stance_type_disc_wholesale_cbdc_process",         
 "index_sent_deveme_developed" , "index_sent_deveme_emerging", "index_stance_deveme_developed", "index_stance_deveme_emerging" , "index_sent_cb_others", "index_sent_cb_ecb_fed_boj","index_stance_cb_others", "index_stance_cb_ecb_fed_boj" ,        "index_sent_cb_other" , "index_sent_cb_ecb" ,  "index_stance_cb_other" ,  "index_stance_cb_ecb" , "index_sent_cbdctitle" , "index_stance_cbdctitle")

plot_lp <- function(lp_model,
                    ...,
                    type = "",
                    title = "",
                    conf.level = 0.9,
                    vcov = "HC1",
                    keep_term = NULL) {

  # Accept: plot_lp(lp1) OR plot_lp(lp1, lp2, ...) OR plot_lp(list(lp1, lp2))
  models <- list(lp_model, ...)
  if (length(models) == 1 && is.list(models[[1]]) && !inherits(models[[1]][[1]], "fixest")) {
    # If user passed a plain list of models: plot_lp(list(lp1, lp2))
    models <- models[[1]]
  }

  stopifnot(length(models) > 0)

  # recycle / validate type labels
  if (length(type) == 1) type <- rep(type, length(models))
  if (length(type) != length(models)) {
    stop("`type` must have length 1 or the same length as the number of LP models.")
  }

  # helper: extract df for ONE lp object
  one_lp_to_df <- function(one_lp, one_type) {
    stopifnot(is.list(one_lp), length(one_lp) > 0)
    H <- length(one_lp) - 1

    purrr::map2_dfr(
      one_lp,
      0:H,
      ~{
        tt <- broom::tidy(.x, conf.int = TRUE, conf.level = conf.level, vcov = vcov)

        shock_term <- if (is.null(keep_term)) {
          tt$term[!tt$term %in% c("(Intercept)", "(intercept)", "Intercept")][1]
        } else {
          keep_term
        }

        tt %>%
          dplyr::filter(.data$term == shock_term) %>%
          dplyr::transmute(
            h   = .y,
            irf = .data$estimate,
            low = .data$conf.low,
            up  = .data$conf.high,
            term = .data$term,
            type = one_type
          )
      }
    )
  }

  irf_df <- purrr::map2_dfr(models, type, one_lp_to_df)

  ggplot(
    irf_df,
    aes(
      x = h, y = irf,
      ymin = low, ymax = up,
      color = type, fill = type
    )
  ) +
    geom_hline(yintercept = 0, linetype = "dashed") +
    geom_ribbon(alpha = 0.3, color = NA) +
    geom_line(linewidth = 0.7) +
    scale_color_manual(values = cols_type) +
    scale_fill_manual(values = cols_type) +
    labs(
      x = "Horizon",
      y = "Response of Supply (log)",
      color = NULL, fill = NULL,
      title = title
    ) +
    theme_minimal(base_size = 12) +
    theme(
      legend.position = "bottom",
      plot.title = element_text(hjust = 0.5)
    )
}
```


# Models
We estimate the following local projection model :

$$
Y_{i,t+h}-Y_{i,t-1}= \alpha_i + \beta^h  X_t + \gamma Z_t + \mu_{i,t}
$$
Where $Y$ is the log-difference of stablecoin supply, $\alpha_i$ is an individual FE, and $X_t$ is our index of speech CBDC-related sentiment/stance. $Z_t$ are control variables representing the VIX and the GPRD and their lags, and dummies representing Terra-Luna and FTX crashes. We include individual ($\alpha_i$) fixed-effects.  
Note : we take the 90% interval confidences for all estimations. Standard errors are heteroskedasticity robusts (clusterized by stablecoin).

## Daily
```{r, echo=FALSE, message=FALSE}
h = 30
lp_auer <- feols(
  f(log_supply, 0:h)- l(log_supply,1) ~ stance_auer +  l(gprd,0:1)+l(vix_close, 0:1)+luna+ftx | stablecoin,
  data = data_artemis, panel.id=c("stablecoin", "date")
)

lp_sent <- feols(
  f(log_supply, 0:h)- l(log_supply,1) ~ index_sent +  l(gprd,0:1)+l(vix_close, 0:1)+luna+ftx | stablecoin,
  data = data_artemis, panel.id=c("stablecoin", "date")
)

lp_stance <- feols(
  f(log_supply, 0:h)- l(log_supply, 1) ~ index_stance +  l(gprd,0:1)+l(vix_close, 0:1)+luna+ftx | stablecoin,
  data = data_artemis, panel.id=c("stablecoin", "date")
)

```
### Sentiment / Stance
```{r, echo=FALSE, message=FALSE}
plot_lp(lp_auer, type="Sentiment (Auer)", title="Daily response of Market Capitalization to increase in Auer & al. (2021) sentiment")
plot_lp(lp_sent, lp_stance, type=c("Sentiment", "Stance"), title="Daily response of Market Capitalization to increase in sentiment/stance")

```


Sentiment, as measured by Auer & al. (2021) tend not to capture the effect of CBDC's related communications on stablecoin supplies. However, the Machine Learning framework does capture the negative effect of an increasing sentiment/stance from Central Banks, suggesting a substitution between stablecoins and CBDC. This effect is relatively small yet significant, and may be due to the fact that an important number of speeches are not particularly focused on CBDC, but may treat several subjects that Central Banks take care of and mention marginally CBDC eventually just to talk about it without really using a forward guidance design. We thus focus on important speeches, i.e. communications that explicitly focus on CBDC in their title (Note : another approach could be to weight the speeches by the number of sentences related to CBDC, or the share of these sentences in the total number of sentences).   


```{r, message=FALSE, echo=FALSE}
h=30
lp_sent_important <- feols(
  f(log_supply, 0:h)- l(log_supply,1) ~ index_sent_cbdctitle +  l(gprd,0:1)+l(vix_close, 0:1)+luna+ftx | stablecoin,
  data = data_artemis, panel.id=c("stablecoin", "date")
)

lp_stance_important  <- feols(
  f(log_supply, 0:h)- l(log_supply,1) ~ index_stance_cbdctitle +  l(gprd,0:1)+l(vix_close, 0:1)+luna+ftx | stablecoin,
  data = data_artemis, panel.id=c("stablecoin", "date")
)

plot_lp(lp_sent_important, lp_stance_important, type=c("Sentiment", "Stance"), title="Important Speeches Only")
```
Immediate effect following important CBDC-related speeches, i.e. speeches that explicitly mention CBDC or related keywords in their title. The effect is almost immediate, and the communications tend to decrease stablecoins supply by 0.3% after about a month. 


In addition, we can decompose the market capitalization effect on two effects : the price effect, and the supply effect. We retrieve both price and supply from Artemis.xyz. 

```{r, message=FALSE, echo=FALSE}
lp_sent_p <- feols(
  f(price, 0:h)- l(price,1) ~ index_sent +  l(gprd,0:1)+l(vix_close, 0:1)+luna+ftx | stablecoin,
  data = data_artemis, panel.id=c("stablecoin", "date")
)
lp_sent_s <- feols(
  f(log_supply_sup, 0:h)- l(log_supply_sup,1) ~ index_sent+  l(gprd,0:1)+l(vix_close, 0:1)+luna+ftx | stablecoin,
  data = data_artemis, panel.id=c("stablecoin", "date")
)

lp_stance_p  <- feols(
  f(price, 0:h)- l(price,1) ~ index_stance +  l(gprd,0:1)+l(vix_close, 0:1)+luna+ftx | stablecoin,
  data = data_artemis, panel.id=c("stablecoin", "date")
)

lp_stance_s  <- feols(
  f(log_supply_sup, 0:h)- l(log_supply_sup,1) ~ index_stance +  l(gprd,0:1)+l(vix_close, 0:1)+luna+ftx | stablecoin,
  data = data_artemis, panel.id=c("stablecoin", "date")
)

plot_lp(lp_sent_p, lp_stance_p, type=c("Sentiment", "Stance"), title="Reaction of prices to increase in sentiment/stance")
plot_lp(lp_sent_s, lp_stance_s, type=c("Sentiment", "Stance"), title="Reaction of supply to increase in sentiment/stance")

```

Overall, we can see that an increase in sentiment/stance of CB towards CBDC tend to decrease the market capitalization of stablecoins, mainly through a decrease in supply to defend the parity. Indeed, the price do not tend to move while the supply does, implying a decrease in demand for stablecoins to ensure that demand = supply so that price is at par. 

We can also test with the Outstanding Supply :


```{r, echo=FALSE, message=FALSE}
lp_sent_os <- feols(
  f(log_outstanding_supply, 0:h)- l(log_outstanding_supply,1) ~ index_sent+  l(gprd,0:1)+l(vix_close, 0:1)+luna+ftx | stablecoin,
  data = data_artemis, panel.id=c("stablecoin", "date")
)
lp_stance_os <- feols(
  f(log_outstanding_supply, 0:h)- l(log_outstanding_supply,1) ~ index_stance+  l(gprd,0:1)+l(vix_close, 0:1)+luna+ftx | stablecoin,
  data = data_artemis, panel.id=c("stablecoin", "date")
)

lp_sent_os_imp <- feols(
  f(log_outstanding_supply, 0:h)- l(log_outstanding_supply,1) ~ index_sent_cbdctitle+  l(gprd,0:1)+l(vix_close, 0:1)+luna+ftx | stablecoin,
  data = data_artemis, panel.id=c("stablecoin", "date")
)
lp_stance_os_imp <- feols(
  f(log_outstanding_supply, 0:h)- l(log_outstanding_supply,1) ~ index_stance_cbdctitle+  l(gprd,0:1)+l(vix_close, 0:1)+luna+ftx | stablecoin,
  data = data_artemis, panel.id=c("stablecoin", "date")
)

plot_lp(lp_sent_os, lp_stance_os, type=c("Sentiment", "Stance"), title="Reaction of Outstanding Supply to increase in sentiment/stance ")
plot_lp(lp_sent_os_imp, lp_stance_os_imp, type=c("Sentiment", "Stance"), title="Reaction of Outstanding Supply to increase in sentiment/stance (Important Speeches) ")

```


### Decomposition by type
```{r, echo=FALSE, message=FALSE}
# types
#h = 100

## General
lp_gensent <- feols(
  f(log_supply, 0:h)- l(log_supply,1) ~ index_sent_type_general_unspecified + l(gprd,0:1)+l(vix_close, 0:1)+luna+ftx  | stablecoin,
  data = data_artemis, panel.id=c("stablecoin", "date")
)

lp_genstance <- feols(
  f(log_supply, 0:h)- l(log_supply,1) ~ index_stance_type_general_unspecified +  l(gprd,0:1)+l(vix_close, 0:1)+luna+ftx | stablecoin,
  data = data_artemis, panel.id=c("stablecoin", "date")
)

## Wholesale

lp_whosent <- feols(
  f(log_supply, 0:h)- l(log_supply,1) ~ index_sent_type_wholesale_cbdc +  l(gprd,0:1)+l(vix_close, 0:1)+luna+ftx | stablecoin,
  data = data_artemis, panel.id=c("stablecoin", "date")
)

lp_whostance <- feols(
  f(log_supply, 0:h)- l(log_supply,1) ~ index_stance_type_wholesale_cbdc +  l(gprd,0:1)+l(vix_close, 0:1)+luna+ftx | stablecoin,
  data = data_artemis, panel.id=c("stablecoin", "date")
)

## Retail

lp_retsent <- feols(
  f(log_supply, 0:h)- l(log_supply,1) ~ index_sent_type_retail_cbdc +  l(gprd,0:1)+l(vix_close, 0:1)+luna+ftx | stablecoin,
  data = data_artemis, panel.id=c("stablecoin", "date")
)

lp_retstance <- feols(
  f(log_supply, 0:h)- l(log_supply,1) ~ index_stance_type_retail_cbdc +  l(gprd,0:1)+l(vix_close, 0:1)+luna+ftx | stablecoin,
  data = data_artemis, panel.id=c("stablecoin", "date")
)

```

```{r, echo=FALSE}
plot_lp(lp_gensent, lp_genstance, type=c("Sentiment", "Stance"), title="General/Unspecified (daily)")
plot_lp(lp_whosent, lp_whostance, type=c("Sentiment", "Stance"), title="Wholesale (daily)")
plot_lp(lp_retsent, lp_retstance, type=c("Sentiment", "Stance"), title="Retail (daily)")

```
Une hausse du sentiment/stance à propos des MNBC general ou non-spécifié ne tend pas à créer une baisse de la demande pour les stablecoins




### Decomposition by Process 

```{r, echo=FALSE, message=FALSE}
#h = 100

lp_feature_sent <- feols(
  f(log_supply, 0:h)- l(log_supply,1) ~ index_sent_disc_feature +  l(gprd,0:1)+l(vix_close, 0:1)+luna+ftx | stablecoin,
  data = data_artemis, panel.id=c("stablecoin", "date"))

lp_feature_stance <- feols(
  f(log_supply, 0:h)- l(log_supply,1) ~ index_stance_disc_feature +  l(gprd,0:1)+l(vix_close, 0:1)+luna+ftx | stablecoin,
  data = data_artemis, panel.id=c("stablecoin", "date"))

lp_process_sent <- feols(
  f(log_supply, 0:h)- l(log_supply,1) ~ index_sent_disc_process +  l(gprd,0:1)+l(vix_close, 0:1)+luna+ftx | stablecoin,
  data = data_artemis, panel.id=c("stablecoin", "date"))

lp_process_stance <- feols(
  f(log_supply, 0:h)- l(log_supply,1) ~ index_stance_disc_process +  l(gprd,0:1)+l(vix_close, 0:1)+luna+ftx | stablecoin,
  data = data_artemis, panel.id=c("stablecoin", "date"))

lp_riskbenef_sent <- feols(
  f(log_supply, 0:h)- l(log_supply,1) ~ index_sent_disc_risk_benefit +  l(gprd,0:1)+l(vix_close, 0:1)+luna+ftx | stablecoin,
  data = data_artemis, panel.id=c("stablecoin", "date"))

lp_riskbenef_stance <- feols(
  f(log_supply, 0:h)- l(log_supply,1) ~ index_stance_disc_risk_benefit +  l(gprd,0:1)+l(vix_close, 0:1)+luna+ftx | stablecoin,
  data = data_artemis, panel.id=c("stablecoin", "date"))
```
```{r, echo=FALSE}
plot_lp(lp_feature_sent, lp_feature_stance, type=c("Sentiment", "Stance"), title="Feature")
plot_lp(lp_process_sent, lp_process_stance, type=c("Sentiment", "Stance"), title="Process")
plot_lp(lp_riskbenef_sent, lp_riskbenef_stance, type=c("Sentiment", "Stance"), title="Risks/Benefits")

```


### Decomposition by type and process
```{r, echo=FALSE, message=FALSE}
#Feature
lp_feature_sent_gen <- feols(
  f(log_supply, 0:h)- l(log_supply,1) ~ index_sent_type_disc_general_unspecified_feature +  l(gprd,0:1)+l(vix_close, 0:1)+luna+ftx | stablecoin,
  data = data_artemis, panel.id=c("stablecoin", "date"))

lp_feature_stance_gen <- feols(
  f(log_supply, 0:h)- l(log_supply,1) ~ index_stance_type_disc_general_unspecified_feature +  l(gprd,0:1)+l(vix_close, 0:1)+luna+ftx | stablecoin,
  data = data_artemis, panel.id=c("stablecoin", "date"))


lp_feature_sent_ret <- feols(
  f(log_supply, 0:h)- l(log_supply,1) ~ index_sent_type_disc_retail_cbdc_feature +  l(gprd,0:1)+l(vix_close, 0:1)+luna+ftx | stablecoin,
  data = data_artemis, panel.id=c("stablecoin", "date"))

lp_feature_stance_ret <- feols(
  f(log_supply, 0:h)- l(log_supply,1) ~ index_stance_type_disc_retail_cbdc_feature +  l(gprd,0:1)+l(vix_close, 0:1)+luna+ftx | stablecoin,
  data = data_artemis, panel.id=c("stablecoin", "date"))

lp_feature_sent_who<- feols(
  f(log_supply, 0:h)- l(log_supply,1) ~ index_sent_type_disc_wholesale_cbdc_feature +  l(gprd,0:1)+l(vix_close, 0:1)+luna+ftx | stablecoin,
  data = data_artemis, panel.id=c("stablecoin", "date"))

lp_feature_stance_who<- feols(
  f(log_supply, 0:h)- l(log_supply,1) ~ index_stance_type_disc_wholesale_cbdc_feature +  l(gprd,0:1)+l(vix_close, 0:1)+luna+ftx | stablecoin,
  data = data_artemis, panel.id=c("stablecoin", "date"))

# Process
lp_process_sent_gen <- feols(
  f(log_supply, 0:h)- l(log_supply,1) ~ index_sent_type_disc_general_unspecified_process +  l(gprd,0:1)+l(vix_close, 0:1)+luna+ftx | stablecoin,
  data = data_artemis, panel.id=c("stablecoin", "date"))

lp_process_stance_gen <- feols(
  f(log_supply, 0:h)- l(log_supply,1) ~ index_stance_type_disc_general_unspecified_process +  l(gprd,0:1)+l(vix_close, 0:1)+luna+ftx | stablecoin,
  data = data_artemis, panel.id=c("stablecoin", "date"))


lp_process_sent_ret <- feols(
  f(log_supply, 0:h)- l(log_supply,1) ~ index_sent_type_disc_retail_cbdc_process +  l(gprd,0:1)+l(vix_close, 0:1)+luna+ftx | stablecoin,
  data = data_artemis, panel.id=c("stablecoin", "date"))

lp_process_stance_ret <- feols(
  f(log_supply, 0:h)- l(log_supply,1) ~ index_stance_type_disc_retail_cbdc_process +  l(gprd,0:1)+l(vix_close, 0:1)+luna+ftx | stablecoin,
  data = data_artemis, panel.id=c("stablecoin", "date"))


lp_process_sent_who <- feols(
  f(log_supply, 0:h)- l(log_supply,1) ~ index_sent_type_disc_wholesale_cbdc_process +  l(gprd,0:1)+l(vix_close, 0:1)+luna+ftx | stablecoin,
  data = data_artemis, panel.id=c("stablecoin", "date"))

lp_process_stance_who <- feols(
  f(log_supply, 0:h)- l(log_supply,1) ~ index_stance_type_disc_wholesale_cbdc_process +  l(gprd,0:1)+l(vix_close, 0:1)+luna+ftx | stablecoin,
  data = data_artemis, panel.id=c("stablecoin", "date"))


# Risk-Benefits

lp_riskbenef_sent_gen <- feols(
  f(log_supply, 0:h)- l(log_supply,1) ~ index_sent_type_disc_general_unspecified_risk_benefit +  l(gprd,0:1)+l(vix_close, 0:1)+luna+ftx | stablecoin,
  data = data_artemis, panel.id=c("stablecoin", "date"))

lp_riskbenef_stance_gen <- feols(
  f(log_supply, 0:h)- l(log_supply,1) ~ index_stance_type_disc_general_unspecified_risk_benefit +  l(gprd,0:1)+l(vix_close, 0:1)+luna+ftx | stablecoin,
  data = data_artemis, panel.id=c("stablecoin", "date"))


lp_riskbenef_sent_ret <- feols(
  f(log_supply, 0:h)- l(log_supply,1) ~ index_sent_type_disc_retail_cbdc_risk_benefit +  l(gprd,0:1)+l(vix_close, 0:1)+luna+ftx | stablecoin,
  data = data_artemis, panel.id=c("stablecoin", "date"))

lp_riskbenef_stance_ret <- feols(
  f(log_supply, 0:h)- l(log_supply,1) ~ index_stance_type_disc_retail_cbdc_risk_benefit +  l(gprd,0:1)+l(vix_close, 0:1)+luna+ftx | stablecoin,
  data = data_artemis, panel.id=c("stablecoin", "date"))


lp_riskbenef_sent_who <- feols(
  f(log_supply, 0:h)- l(log_supply,1) ~ index_sent_type_disc_wholesale_cbdc_risk_benefit +  l(gprd,0:1)+l(vix_close, 0:1)+luna+ftx | stablecoin,
  data = data_artemis, panel.id=c("stablecoin", "date"))

lp_riskbenef_stance_who <- feols(
  f(log_supply, 0:h)- l(log_supply,1) ~ index_stance_type_disc_wholesale_cbdc_risk_benefit +  l(gprd,0:1)+l(vix_close, 0:1)+luna+ftx | stablecoin,
  data = data_artemis, panel.id=c("stablecoin", "date"))


```

#### Features
```{r, echo=FALSE}
plot_lp(lp_feature_sent_gen, lp_feature_stance_gen, 
        type=c("Sentiment", "Stance"), 
        title="Increase in Sentiment towards General/Unspecified CBDC Features")

plot_lp(lp_feature_sent_ret, lp_feature_stance_ret, 
        type=c("Sentiment", "Stance"), 
        title="Increase in Sentiment towards Retail CBDC Features")

plot_lp(lp_feature_sent_who, lp_feature_stance_who, 
        type=c("Sentiment", "Stance"), 
        title="Increase in Sentiment towards Wholesale CBDC Features")

```

#### Process
```{r, echo=FALSE}
plot_lp(lp_process_sent_gen, lp_process_stance_gen, 
        type=c("Sentiment", "Stance"), 
        title="Increase in Sentiment towards General/Unspecified CBDC Process")

plot_lp(lp_process_sent_ret, lp_process_stance_ret, 
        type=c("Sentiment", "Stance"), 
        title="Increase in Sentiment towards Retail CBDC Process")

plot_lp(lp_process_sent_who, lp_process_stance_who, 
        type=c("Sentiment", "Stance"), 
        title="Increase in Sentiment towards Wholesale CBDC Process")

```


#### Risk-Benefits

```{r, echo=FALSE}
plot_lp(lp_riskbenef_sent_gen, lp_riskbenef_stance_gen, 
        type=c("Sentiment", "Stance"), 
        title="Increase in Sentiment towards General/Unspecified CBDC Risk-Benefits")

plot_lp(lp_riskbenef_sent_ret, lp_riskbenef_stance_ret, 
        type=c("Sentiment", "Stance"), 
        title="Increase in Sentiment towards Retail CBDC Risk-Benefits")

plot_lp(lp_riskbenef_sent_who, lp_riskbenef_stance_who, 
        type=c("Sentiment", "Stance"), 
        title="Increase in Sentiment towards Wholesale CBDC Risk-Benefits")

```

### Decomposition by Markets/Central Banks
#### DevEme
```{r, echo=FALSE, message=FALSE}
lp_deveme_sent_dev <- feols(
  f(log_supply, 0:h)- l(log_supply,1) ~ index_sent_deveme_developed  +  l(gprd,0:1)+l(vix_close, 0:1)+luna+ftx | stablecoin,
  data = data_artemis, panel.id=c("stablecoin", "date"))

lp_deveme_stance_dev <- feols(
  f(log_supply, 0:h)- l(log_supply,1) ~ index_stance_deveme_developed +  l(gprd,0:1)+l(vix_close, 0:1)+luna+ftx | stablecoin,
  data = data_artemis, panel.id=c("stablecoin", "date"))



lp_deveme_sent_eme <- feols(
  f(log_supply, 0:h)- l(log_supply,1) ~ index_sent_deveme_emerging  +  l(gprd,0:1)+l(vix_close, 0:1)+luna+ftx | stablecoin,
  data = data_artemis, panel.id=c("stablecoin", "date"))

lp_deveme_stance_eme <- feols(
  f(log_supply, 0:h)- l(log_supply,1) ~ index_stance_deveme_emerging +  l(gprd,0:1)+l(vix_close, 0:1)+luna+ftx | stablecoin,
  data = data_artemis, panel.id=c("stablecoin", "date"))
```

```{r, echo=FALSE}
plot_lp(lp_deveme_sent_dev, lp_deveme_stance_dev, type=c("Sentiment", "Stance"), title="Developed")
plot_lp(lp_deveme_sent_eme, lp_deveme_stance_eme, type=c("Sentiment", "Stance"), title="Emerging")

```

#### ECB vs other
```{r, warning=FALSE, message=FALSE, echo=FALSE}
lp_sent_ecb <- feols(
  f(log_supply, 0:h)- l(log_supply,1) ~ index_sent_cb_ecb  +  l(gprd,0:1)+l(vix_close, 0:1)+luna+ftx | stablecoin,
  data = data_artemis, panel.id=c("stablecoin", "date"))

lp_stance_ecb <- feols(
  f(log_supply, 0:h)- l(log_supply,1) ~ index_stance_cb_ecb +  l(gprd,0:1)+l(vix_close, 0:1)+luna+ftx | stablecoin,
  data = data_artemis, panel.id=c("stablecoin", "date"))

lp_sent_other <- feols(
  f(log_supply, 0:h)- l(log_supply,1) ~ index_sent_cb_other  +  l(gprd,0:1)+l(vix_close, 0:1)+luna+ftx | stablecoin,
  data = data_artemis, panel.id=c("stablecoin", "date"))

lp_stance_other <- feols(
  f(log_supply, 0:h)- l(log_supply,1) ~ index_stance_cb_other +  l(gprd,0:1)+l(vix_close, 0:1)+luna+ftx | stablecoin,
  data = data_artemis, panel.id=c("stablecoin", "date"))

plot_lp(lp_sent_ecb, lp_stance_ecb, type=c("Sentiment", "Stance"), title="ECB")
plot_lp(lp_sent_other, lp_stance_other, type=c("Sentiment", "Stance"), title="Other")

```




What we observe overall :
- An increase in sentiment/stance tend to decrease the demand for stablecoins 
- This results hides heterogeneity
- An increase in sentiment/stance for retail and wholesale CBDC decrease the demand for stablecoins, while an increase in sentiment/stance for General/Unspecified CBDC tend to increase the demand or have no effect depending on the discourse associated.
- An interpretation is that when Central Bank talk about General/Unspecified CBDC, it contains information about the project of other central banks "central banks of major countries are carrying out in-depth research recently on digital currencies" or be interpreted - in some cases - as a sign that central banks will adopt an already-existing stablecoin.
- However, when the speech clearly states that it aims to issue a retail/wholesale stablecoins, it is perceived as a substitute for existing stablecoins.
- Notably, when central banks announce progress on Wholesale (Features particularly) or Retail (Process particularly) CBDC, it dampens the demand for stablecoins. 
- The effect is particularly visible when Central Banks from Developed Markets communicate about CBDC - and especially ECB.



### Important speeches only
#### Decomposition by type


```{r, echo=FALSE, message=FALSE}
lp_sent_important_general <- feols(
  f(log_supply, 0:h)- l(log_supply,1) ~ index_sent_type_cbdctitle_general_unspecified +  l(gprd,0:1)+l(vix_close, 0:1)+luna+ftx | stablecoin,
  data = data_artemis, panel.id=c("stablecoin", "date")
)
lp_stance_important_general <- feols(
  f(log_supply, 0:h)- l(log_supply,1) ~ index_stance_type_cbdctitle_general_unspecified +  l(gprd,0:1)+l(vix_close, 0:1)+luna+ftx | stablecoin,
  data = data_artemis, panel.id=c("stablecoin", "date")
)


lp_sent_important_retail <- feols(
  f(log_supply, 0:h)- l(log_supply,1) ~ index_sent_type_cbdctitle_retail_cbdc +  l(gprd,0:1)+l(vix_close, 0:1)+luna+ftx | stablecoin,
  data = data_artemis, panel.id=c("stablecoin", "date")
)

lp_stance_important_retail  <- feols(
  f(log_supply, 0:h)- l(log_supply,1) ~ index_stance_type_cbdctitle_retail_cbdc +  l(gprd,0:1)+l(vix_close, 0:1)+luna+ftx | stablecoin,
  data = data_artemis, panel.id=c("stablecoin", "date")
)

lp_sent_important_wholesale <- feols(
  f(log_supply, 0:h)- l(log_supply,1) ~ index_sent_type_cbdctitle_wholesale_cbdc +  l(gprd,0:1)+l(vix_close, 0:1)+luna+ftx | stablecoin,
  data = data_artemis, panel.id=c("stablecoin", "date")
)

lp_stance_important_wholesale <- feols(
  f(log_supply, 0:h)- l(log_supply,1) ~ index_stance_type_cbdctitle_wholesale_cbdc +  l(gprd,0:1)+l(vix_close, 0:1)+luna+ftx | stablecoin,
  data = data_artemis, panel.id=c("stablecoin", "date")
)


```

 
```{r, echo=FALSE}
plot_lp(lp_sent_important_general, lp_stance_important_general, type=c("Sentiment", "Stance"), title="General/Unspecified increase in sentiment (important speeches)")

plot_lp(lp_sent_important_retail, lp_stance_important_retail, type=c("Sentiment", "Stance"), title="Retail CBDC increase in sentiment (important speeches)")

plot_lp(lp_sent_important_wholesale, lp_stance_important_wholesale, type=c("Sentiment", "Stance"), title="Wholesale CBDC increase in sentiment (important speeches)")
```
#### Decomposition by Discourse  in important speeches
```{r, echo=FALSE, message=FALSE}
lp_sent_important_feature <- feols(
  f(log_supply, 0:h)- l(log_supply,1) ~ index_sent_discourse_cbdctitle_feature +  l(gprd,0:1)+l(vix_close, 0:1)+luna+ftx | stablecoin,
  data = data_artemis, panel.id=c("stablecoin", "date")
)


lp_stance_important_feature <- feols(
  f(log_supply, 0:h)- l(log_supply,1) ~ index_stance_discourse_cbdctitle_feature +  l(gprd,0:1)+l(vix_close, 0:1)+luna+ftx | stablecoin,
  data = data_artemis, panel.id=c("stablecoin", "date")
)


lp_sent_important_process <- feols(
  f(log_supply, 0:h)- l(log_supply,1) ~ index_sent_discourse_cbdctitle_process +  l(gprd,0:1)+l(vix_close, 0:1)+luna+ftx | stablecoin,
  data = data_artemis, panel.id=c("stablecoin", "date")
)

lp_stance_important_process  <- feols(
  f(log_supply, 0:h)- l(log_supply,1) ~ index_stance_discourse_cbdctitle_process +  l(gprd,0:1)+l(vix_close, 0:1)+luna+ftx | stablecoin,
  data = data_artemis, panel.id=c("stablecoin", "date")
)

lp_sent_important_riskbenef <- feols(  f(log_supply, 0:h)- l(log_supply,1) ~ index_sent_discourse_cbdctitle_risk_benefit +  l(gprd,0:1)+l(vix_close, 0:1)+luna+ftx | stablecoin,
  data = data_artemis, panel.id=c("stablecoin", "date")
)

lp_stance_important_riskbenef <- feols(
  f(log_supply, 0:h)- l(log_supply,1) ~ index_stance_discourse_cbdctitle_risk_benefit +  l(gprd,0:1)+l(vix_close, 0:1)+luna+ftx | stablecoin,
  data = data_artemis, panel.id=c("stablecoin", "date")
)
```
```{r, echo=FALSE}
plot_lp(lp_sent_important_feature, lp_stance_important_feature, type=c("Sentiment", "Stance"), title="Features increase in sentiment (important speeches)")

plot_lp(lp_sent_important_process, lp_stance_important_process, type=c("Sentiment", "Stance"), title="Process increase in sentiment (important speeches)")

plot_lp(lp_sent_important_riskbenef, lp_stance_important_riskbenef, type=c("Sentiment", "Stance"), title="Risk-Benefit increase in sentiment (important speeches)")
```






#### Decomposition by type and process in important speeches
```{r, echo=FALSE, message=FALSE}
#Feature
lp_feature_sent_gen_cbdctitle <- feols(
  f(log_supply, 0:h)- l(log_supply,1) ~ index_sent_disc_type_cbdctitle_feature_general_unspecified +  l(gprd,0:1)+l(vix_close, 0:1)+luna+ftx | stablecoin,
  data = data_artemis, panel.id=c("stablecoin", "date"))

lp_feature_stance_gen_cbdctitle <- feols(
  f(log_supply, 0:h)- l(log_supply,1) ~ index_stance_disc_type_cbdctitle_feature_general_unspecified +  l(gprd,0:1)+l(vix_close, 0:1)+luna+ftx | stablecoin,
  data = data_artemis, panel.id=c("stablecoin", "date"))


lp_feature_sent_ret_cbdctitle <- feols(
  f(log_supply, 0:h)- l(log_supply,1) ~ index_sent_disc_type_cbdctitle_feature_retail_cbdc +  l(gprd,0:1)+l(vix_close, 0:1)+luna+ftx | stablecoin,
  data = data_artemis, panel.id=c("stablecoin", "date"))

lp_feature_stance_ret_cbdctitle <- feols(
  f(log_supply, 0:h)- l(log_supply,1) ~ index_stance_disc_type_cbdctitle_feature_retail_cbdc +  l(gprd,0:1)+l(vix_close, 0:1)+luna+ftx | stablecoin,
  data = data_artemis, panel.id=c("stablecoin", "date"))

lp_feature_sent_who_cbdctitle<- feols(
  f(log_supply, 0:h)- l(log_supply,1) ~ index_sent_disc_type_cbdctitle_feature_wholesale_cbdc +  l(gprd,0:1)+l(vix_close, 0:1)+luna+ftx | stablecoin,
  data = data_artemis, panel.id=c("stablecoin", "date"))

lp_feature_stance_who_cbdctitle<- feols(
  f(log_supply, 0:h)- l(log_supply,1) ~ index_stance_disc_type_cbdctitle_feature_wholesale_cbdc +  l(gprd,0:1)+l(vix_close, 0:1)+luna+ftx | stablecoin,
  data = data_artemis, panel.id=c("stablecoin", "date"))


# Process
lp_process_sent_gen_cbdctitle <- feols(
  f(log_supply, 0:h)- l(log_supply,1) ~ index_sent_disc_type_cbdctitle_process_general_unspecified +  l(gprd,0:1)+l(vix_close, 0:1)+luna+ftx | stablecoin,
  data = data_artemis, panel.id=c("stablecoin", "date"))

lp_process_stance_gen_cbdctitle <- feols(
  f(log_supply, 0:h)- l(log_supply,1) ~ index_stance_disc_type_cbdctitle_process_general_unspecified +  l(gprd,0:1)+l(vix_close, 0:1)+luna+ftx | stablecoin,
  data = data_artemis, panel.id=c("stablecoin", "date"))


lp_process_sent_ret_cbdctitle <- feols(
  f(log_supply, 0:h)- l(log_supply,1) ~ index_sent_disc_type_cbdctitle_process_retail_cbdc +  l(gprd,0:1)+l(vix_close, 0:1)+luna+ftx | stablecoin,
  data = data_artemis, panel.id=c("stablecoin", "date"))

lp_process_stance_ret_cbdctitle <- feols(
  f(log_supply, 0:h)- l(log_supply,1) ~ index_stance_disc_type_cbdctitle_process_retail_cbdc +  l(gprd,0:1)+l(vix_close, 0:1)+luna+ftx | stablecoin,
  data = data_artemis, panel.id=c("stablecoin", "date"))


lp_process_sent_who_cbdctitle <- feols(
  f(log_supply, 0:h)- l(log_supply,1) ~ index_sent_disc_type_cbdctitle_process_wholesale_cbdc +  l(gprd,0:1)+l(vix_close, 0:1)+luna+ftx | stablecoin,
  data = data_artemis, panel.id=c("stablecoin", "date"))

lp_process_stance_who_cbdctitle <- feols(
  f(log_supply, 0:h)- l(log_supply,1) ~ index_stance_disc_type_cbdctitle_process_wholesale_cbdc +  l(gprd,0:1)+l(vix_close, 0:1)+luna+ftx | stablecoin,
  data = data_artemis, panel.id=c("stablecoin", "date"))


# Risk-Benefits

lp_riskbenef_sent_gen_cbdctitle <- feols(
  f(log_supply, 0:h)- l(log_supply,1) ~ index_sent_disc_type_cbdctitle_risk_benefit_general_unspecified +  l(gprd,0:1)+l(vix_close, 0:1)+luna+ftx | stablecoin,
  data = data_artemis, panel.id=c("stablecoin", "date"))

lp_riskbenef_stance_gen_cbdctitle <- feols(
  f(log_supply, 0:h)- l(log_supply,1) ~ index_stance_disc_type_cbdctitle_risk_benefit_general_unspecified +  l(gprd,0:1)+l(vix_close, 0:1)+luna+ftx | stablecoin,
  data = data_artemis, panel.id=c("stablecoin", "date"))


lp_riskbenef_sent_ret_cbdctitle <- feols(
  f(log_supply, 0:h)- l(log_supply,1) ~ index_sent_disc_type_cbdctitle_risk_benefit_retail_cbdc +  l(gprd,0:1)+l(vix_close, 0:1)+luna+ftx | stablecoin,
  data = data_artemis, panel.id=c("stablecoin", "date"))

lp_riskbenef_stance_ret_cbdctitle <- feols(
  f(log_supply, 0:h)- l(log_supply,1) ~ index_stance_disc_type_cbdctitle_risk_benefit_retail_cbdc +  l(gprd,0:1)+l(vix_close, 0:1)+luna+ftx | stablecoin,
  data = data_artemis, panel.id=c("stablecoin", "date"))


lp_riskbenef_sent_who_cbdctitle <- feols(
  f(log_supply, 0:h)- l(log_supply,1) ~ index_sent_disc_type_cbdctitle_risk_benefit_wholesale_cbdc +  l(gprd,0:1)+l(vix_close, 0:1)+luna+ftx | stablecoin,
  data = data_artemis, panel.id=c("stablecoin", "date"))

lp_riskbenef_stance_who_cbdctitle <- feols(
  f(log_supply, 0:h)- l(log_supply,1) ~ index_stance_disc_type_cbdctitle_risk_benefit_wholesale_cbdc +  l(gprd,0:1)+l(vix_close, 0:1)+luna+ftx | stablecoin,
  data = data_artemis, panel.id=c("stablecoin", "date"))

```


##### Features
```{r, echo=FALSE}
plot_lp(lp_feature_sent_gen_cbdctitle, lp_feature_stance_gen_cbdctitle, 
        type=c("Sentiment", "Stance"), 
        title="Increase in Sentiment towards General/Unspecified CBDC Features (Important Speeches)")

plot_lp(lp_feature_sent_ret_cbdctitle, lp_feature_stance_ret_cbdctitle, 
        type=c("Sentiment", "Stance"), 
        title="Increase in Sentiment towards Retail CBDC Features (Important Speeches)")

plot_lp(lp_feature_sent_who_cbdctitle, lp_feature_stance_who_cbdctitle, 
        type=c("Sentiment", "Stance"), 
        title="Increase in Sentiment towards Wholesale CBDC Features (Important Speeches)")

```
##### Process
```{r, echo=FALSE}
plot_lp(lp_process_sent_gen_cbdctitle, lp_process_stance_gen_cbdctitle, 
        type=c("Sentiment", "Stance"), 
        title="Increase in Sentiment towards General/Unspecified CBDC Process (Important Speeches)")

plot_lp(lp_process_sent_ret_cbdctitle, lp_process_stance_ret_cbdctitle, 
        type=c("Sentiment", "Stance"), 
        title="Increase in Sentiment towards Retail CBDC Process (Important Speeches)")

plot_lp(lp_process_sent_who_cbdctitle, lp_process_stance_who_cbdctitle, 
        type=c("Sentiment", "Stance"), 
        title="Increase in Sentiment towards Wholesale CBDC Process (Important Speeches)")
```


##### Risk-Benefit
```{r, echo=FALSE}
plot_lp(lp_riskbenef_sent_gen_cbdctitle, lp_riskbenef_stance_gen_cbdctitle, 
        type=c("Sentiment", "Stance"), 
        title="Increase in Sentiment towards General/Unspecified CBDC Risk-Benefit (Important Speeches)")

plot_lp(lp_riskbenef_sent_ret_cbdctitle, lp_riskbenef_stance_ret_cbdctitle, 
        type=c("Sentiment", "Stance"), 
        title="Increase in Sentiment towards Retail CBDC Risk-Benefit (Important Speeches)")

plot_lp(lp_riskbenef_sent_who_cbdctitle, lp_riskbenef_stance_who_cbdctitle, 
        type=c("Sentiment", "Stance"), 
        title="Increase in Sentiment towards Wholesale CBDC Risk-Benefit (Important Speeches)")

```


Note : Je pense qu'on peut utiliser uniquement les speeches importants, ils donnent des résultats plus clairs et c'est assez facile de justifier leur utilisation + les résultats sont robustes mais moins marquants quand on utilise tous les speeches.



