1 The captopril dataset

The captopril dataset holds information on a small experiment with 15 patients that have increased blood pressure values. More specifically, for each patient we will have four values; one value for systolic blood pressure and one for diastolyic, both before and after treating the patient with a drug named captopril.

2 Import the data

library(tidyverse)
library(readr)
library(ggplot2)
captopril <- read_csv("https://raw.githubusercontent.com/statOmics/PSLS21/data/captopril.txt")
## Rows: 15 Columns: 5
## ── Column specification ────────────────────────────────────────────────────────
## Delimiter: ","
## dbl (5): id, SBPb, DBPb, SBPa, DBPa
## 
## ℹ Use `spec()` to retrieve the full column specification for this data.
## ℹ Specify the column types or set `show_col_types = FALSE` to quiet this message.
head(captopril)

Why is this dataset not tidy?

3 Data visualization

Let’s say we now first want to visualize the data. One possibility to easily visualize the four types of blood pressure values is by adopting the gather function from tidyverse. It will reshape the dataframe, such that we have have a single variable type, which points at one of the four blood pressure types, and bp, which points at the actual value for each type for each patient.

captopril %>% 
  gather(type,bp,-id)

3.1 Barplot

Not all visualization types will be equally informative. Let us first make a barplot of the data. A barplot is a plot that you will commonly find in scientific publication The code for generating such a barplot is provided below:

captopril %>% 
  gather(type,bp,-id) %>% 
  Rmisc::summarySE(measurevar="bp",groupvars="type") %>% 
  ggplot(aes(x=type,y=bp,fill=type)) + 
    scale_fill_brewer(palette="RdGy") +
    theme_bw() +
    geom_bar(stat="identity") + 
    geom_errorbar(aes(ymin=bp-se, ymax=bp+se),width=.2) +
    ggtitle("Barplot of different blood pressure measures") +
    ylab("blood pressure (mmHg)")

A barplot, however, is not very informative. The height of the bars only provides us with information of the mean blood pressure. However, we don’t see the actual underlying values, so we for instance don’t have any information on the spread of the data. It is usually more informative to represent to underlying values as raw as possible. Note that it is possible to add the raw data on the barplot, but we still would not see any measures of the spread, such as the interquartile range.

Based on this critisism, can you think of a better visualization strategy for the captopril data?

Add your proposed visualization strategy here

3.2 Boxplot

It is usually more informative to represent to underlying values as raw as possible. Boxplots are ideal for this!

Note that it in theory it is possible to add the raw data on the barplot, but we still would not see any measures of the spread, such as the interquartile range.

captopril %>% 
  gather(type,bp,-id) %>% 
  ggplot(aes(x=type,y=bp,fill=type)) + 
    scale_fill_brewer(palette="RdGy") +
    theme_bw() +
    geom_boxplot(outlier.shape=NA) + 
    geom_jitter(width = 0.2) +
    ggtitle("Boxplot of different blood pressure measures") +
    ylab("blood pressure (mmHg)") + stat_summary(fun.y=mean, geom="point", shape=5, size=3, color="black", fill="black")
## Warning: `fun.y` is deprecated. Use `fun` instead.

With the boxplot, we get a lot of useful information. We immediately see multiple features of the spread of the data, such as the median, the 25% and 75% quantiles and outliers. Since we only have 15 raw values (patients), we can easily add them to the plot without getting messy.

In terms of interpretation, we can see that the median systolic and diastolic blood pressure values are lower after treatment with captopril than before. If we want to have visual inference on the mean values (cfr. class on t-test), we can add them to the plot stat_summary function.

3.3 Scatterplot

An important feature of this dataset is that it contains paired data; for each patient, we have blood pressure values (systolic and diastolic) before and after treatment with captopril.

We can visualize this as follows;

captopril %>% 
  gather(type,bp,-id) %>% 
  filter(type%in%c("SBPa","SBPb")) %>%
  ggplot(aes(x=id,y=bp,color=type)) +
    geom_point(size=2) +
    scale_color_manual(values = c("blue","red")) +
    theme_bw()

Or, alternatively, by creating a line plot:

captopril %>% 
  gather(type,bp,-id) %>% 
  filter(type%in%c("SBPa","SBPb")) %>%
  ggplot(aes(x=type,y=bp)) +
    geom_line(aes(group=id)) + 
    theme_bw()

We see that for all patients, the systolic blood pressure is lower after captopril treatment than before.

Note that we could not see this from the boxplot, directly;

captopril %>% 
  gather(type,bp,-id) %>% 
    filter(type%in%c("SBPa","SBPb")) %>%
    ggplot(aes(x=type,y=bp,fill=type)) + 
    scale_fill_brewer(palette="RdGy") +
    theme_bw() +
    geom_boxplot(outlier.shape=NA) + 
    geom_jitter(width = 0.2) +
    ggtitle("Boxplot of blood pressure measures before and after treatment") +
    ylab("blood pressure (mmHg)") + 
    stat_summary(fun=mean, geom="point", shape=5, size=3, color="black", fill="black")

A typical next step is to perform a test to find out whether the mean systolic blood pressure value after captopril treatment is significantly different from the mean systolic blood pressure value before treatment.

Analagously, we may subtract the after measurement from the before measurement, and test if the difference between the two sets of values is significantly different from zero.

captopril %>% 
  mutate(bp_diff = SBPa-SBPb) %>%
  select(bp_diff) %>%
  ggplot(aes(x="",y=bp_diff)) +
  geom_boxplot(outlier.shape=NA) +
  geom_jitter(width = 0.2) + 
  ggtitle("Boxplot of the difference in blood pressure") +
  ylab("blood pressure difference (mmHg)") + stat_summary(fun.y=mean, geom="point", shape=5, size=3, color="black", fill="black") +
  theme_bw()+
  ylim(-40,10) +
  geom_hline(yintercept = 0, color="red") ## adds horizontal line to plot
## Warning: `fun.y` is deprecated. Use `fun` instead.

The mean difference is lower than zero. It seems that on average the captopril treatment has lowered the blood pressure by about 20 mmHg. Tomorrow, we will show how we can test if this reduction is significantly different from 0 mmHg.

LS0tCnRpdGxlOiAiRXhlcmNpc2UgNC4zOiBFeHBsb3JpbmcgdGhlIGNhcHRvcHJpbCBkYXRhc2V0IgphdXRob3I6ICJMaWV2ZW4gQ2xlbWVudCBhbmQgSmVyb2VuIEdpbGlzIgpkYXRlOiAic3RhdE9taWNzLCBHaGVudCBVbml2ZXJzaXR5IChodHRwczovL3N0YXRvbWljcy5naXRodWIuaW8pIgpvdXRwdXQ6CiAgICBodG1sX2RvY3VtZW50OgogICAgICBjb2RlX2Rvd25sb2FkOiB0cnVlICAgIAogICAgICB0aGVtZTogY29zbW8KICAgICAgdG9jOiB0cnVlCiAgICAgIHRvY19mbG9hdDogdHJ1ZQogICAgICBoaWdobGlnaHQ6IHRhbmdvCiAgICAgIG51bWJlcl9zZWN0aW9uczogdHJ1ZQotLS0KCiMgVGhlIGNhcHRvcHJpbCBkYXRhc2V0CgpUaGUgYGNhcHRvcHJpbCBkYXRhc2V0YCBob2xkcyBpbmZvcm1hdGlvbiBvbiBhIHNtYWxsIGV4cGVyaW1lbnQgd2l0aAoxNSBwYXRpZW50cyB0aGF0IGhhdmUgaW5jcmVhc2VkIGJsb29kIHByZXNzdXJlIHZhbHVlcy4gCk1vcmUgc3BlY2lmaWNhbGx5LCBmb3IgZWFjaCBwYXRpZW50IHdlIHdpbGwgaGF2ZSBmb3VyIHZhbHVlczsKb25lIHZhbHVlIGZvciBzeXN0b2xpYyBibG9vZCBwcmVzc3VyZSBhbmQgb25lIGZvciBkaWFzdG9seWljLApib3RoIGJlZm9yZSBhbmQgYWZ0ZXIgdHJlYXRpbmcgdGhlIHBhdGllbnQgd2l0aCBhIGRydWcgbmFtZWQgY2FwdG9wcmlsLgoKIyBJbXBvcnQgdGhlIGRhdGEKCmBgYHtyLCBtZXNzYWdlPUZBTFNFLCB3YXJuaW5nPUZBTFNFfQpsaWJyYXJ5KHRpZHl2ZXJzZSkKbGlicmFyeShyZWFkcikKbGlicmFyeShnZ3Bsb3QyKQpgYGAKCmBgYHtyfQpjYXB0b3ByaWwgPC0gcmVhZF9jc3YoImh0dHBzOi8vcmF3LmdpdGh1YnVzZXJjb250ZW50LmNvbS9zdGF0T21pY3MvUFNMUzIxL2RhdGEvY2FwdG9wcmlsLnR4dCIpCmBgYAoKYGBge3J9CmhlYWQoY2FwdG9wcmlsKQpgYGAKCioqV2h5IGlzIHRoaXMgZGF0YXNldCBub3QgdGlkeT8qKgoKIyBEYXRhIHZpc3VhbGl6YXRpb24KCkxldCdzIHNheSB3ZSBub3cgZmlyc3Qgd2FudCB0byB2aXN1YWxpemUgdGhlIGRhdGEuIApPbmUgcG9zc2liaWxpdHkgdG8gZWFzaWx5IHZpc3VhbGl6ZSB0aGUgZm91ciB0eXBlcwpvZiBibG9vZCBwcmVzc3VyZSB2YWx1ZXMgaXMgYnkgYWRvcHRpbmcgdGhlIGBnYXRoZXJgCmZ1bmN0aW9uIGZyb20gdGlkeXZlcnNlLiBJdCB3aWxsIHJlc2hhcGUgdGhlIGRhdGFmcmFtZSwKc3VjaCB0aGF0IHdlIGhhdmUgaGF2ZSBhIHNpbmdsZSB2YXJpYWJsZSBgdHlwZWAsIHdoaWNoIApwb2ludHMgYXQgb25lIG9mIHRoZSBmb3VyIGJsb29kIHByZXNzdXJlIHR5cGVzLCBhbmQgYGJwYCwKd2hpY2ggcG9pbnRzIGF0IHRoZSBhY3R1YWwgdmFsdWUgZm9yIGVhY2ggdHlwZSAKZm9yIGVhY2ggcGF0aWVudC4KCmBgYHtyfQpjYXB0b3ByaWwgJT4lIAogIGdhdGhlcih0eXBlLGJwLC1pZCkKYGBgCgojIyBCYXJwbG90CgpOb3QgYWxsIHZpc3VhbGl6YXRpb24gdHlwZXMgd2lsbCBiZSBlcXVhbGx5IGluZm9ybWF0aXZlLgpMZXQgdXMgZmlyc3QgbWFrZSBhIGJhcnBsb3Qgb2YgdGhlIGRhdGEuIEEgYmFycGxvdCBpcyBhIHBsb3QgdGhhdCB5b3Ugd2lsbCAKY29tbW9ubHkgZmluZCBpbiBzY2llbnRpZmljIHB1YmxpY2F0aW9uIFRoZSBjb2RlIGZvciBnZW5lcmF0aW5nIHN1Y2ggYSBiYXJwbG90IAppcyBwcm92aWRlZCBiZWxvdzoKCmBgYHtyfQpjYXB0b3ByaWwgJT4lIAogIGdhdGhlcih0eXBlLGJwLC1pZCkgJT4lIAogIFJtaXNjOjpzdW1tYXJ5U0UobWVhc3VyZXZhcj0iYnAiLGdyb3VwdmFycz0idHlwZSIpICU+JSAKICBnZ3Bsb3QoYWVzKHg9dHlwZSx5PWJwLGZpbGw9dHlwZSkpICsgCiAgICBzY2FsZV9maWxsX2JyZXdlcihwYWxldHRlPSJSZEd5IikgKwogICAgdGhlbWVfYncoKSArCiAgICBnZW9tX2JhcihzdGF0PSJpZGVudGl0eSIpICsgCiAgICBnZW9tX2Vycm9yYmFyKGFlcyh5bWluPWJwLXNlLCB5bWF4PWJwK3NlKSx3aWR0aD0uMikgKwogICAgZ2d0aXRsZSgiQmFycGxvdCBvZiBkaWZmZXJlbnQgYmxvb2QgcHJlc3N1cmUgbWVhc3VyZXMiKSArCiAgICB5bGFiKCJibG9vZCBwcmVzc3VyZSAobW1IZykiKQpgYGAKCkEgYmFycGxvdCwgaG93ZXZlciwgaXMgbm90IHZlcnkgaW5mb3JtYXRpdmUuIFRoZSBoZWlnaHQgb2YgdGhlCmJhcnMgb25seSBwcm92aWRlcyB1cyB3aXRoIGluZm9ybWF0aW9uIG9mIHRoZSBtZWFuIGJsb29kIHByZXNzdXJlLgpIb3dldmVyLCB3ZSBkb24ndCBzZWUgdGhlIGFjdHVhbCB1bmRlcmx5aW5nIHZhbHVlcywgc28gd2UgZm9yCmluc3RhbmNlIGRvbid0IGhhdmUgYW55IGluZm9ybWF0aW9uIG9uIHRoZSBzcHJlYWQgb2YgdGhlIGRhdGEuCkl0IGlzIHVzdWFsbHkgbW9yZSBpbmZvcm1hdGl2ZSB0byByZXByZXNlbnQgdG8gdW5kZXJseWluZyAKdmFsdWVzIGFzIF9yYXdfIGFzIHBvc3NpYmxlLiBOb3RlIHRoYXQgaXQgaXMgcG9zc2libGUgdG8gYWRkIHRoZQpyYXcgZGF0YSBvbiB0aGUgYmFycGxvdCwgYnV0IHdlIHN0aWxsIHdvdWxkIG5vdCBzZWUgYW55IG1lYXN1cmVzCm9mIHRoZSBzcHJlYWQsIHN1Y2ggYXMgdGhlIGludGVycXVhcnRpbGUgcmFuZ2UuCgoqKkJhc2VkIG9uIHRoaXMgY3JpdGlzaXNtLCBjYW4geW91IHRoaW5rIG9mIGEgYmV0dGVyKioKKip2aXN1YWxpemF0aW9uIHN0cmF0ZWd5IGZvciB0aGUgY2FwdG9wcmlsIGRhdGE/KioKCioqQWRkIHlvdXIgcHJvcG9zZWQgdmlzdWFsaXphdGlvbiBzdHJhdGVneSBoZXJlKioKCiMjIEJveHBsb3QKCkl0IGlzIHVzdWFsbHkgbW9yZSBpbmZvcm1hdGl2ZSB0byByZXByZXNlbnQgdG8gdW5kZXJseWluZyAKdmFsdWVzIGFzIF9yYXdfIGFzIHBvc3NpYmxlLiBCb3hwbG90cyBhcmUgaWRlYWwgZm9yIHRoaXMhCgpOb3RlIHRoYXQgaXQgaW4gdGhlb3J5IGl0IGlzIHBvc3NpYmxlIHRvIGFkZCB0aGUgcmF3IGRhdGEgb24KdGhlIGJhcnBsb3QsIGJ1dCB3ZSBzdGlsbCB3b3VsZCBub3Qgc2VlIGFueSBtZWFzdXJlcyBvZiB0aGUKc3ByZWFkLCBzdWNoIGFzIHRoZSBpbnRlcnF1YXJ0aWxlIHJhbmdlLgoKYGBge3J9CmNhcHRvcHJpbCAlPiUgCiAgZ2F0aGVyKHR5cGUsYnAsLWlkKSAlPiUgCiAgZ2dwbG90KGFlcyh4PXR5cGUseT1icCxmaWxsPXR5cGUpKSArIAogICAgc2NhbGVfZmlsbF9icmV3ZXIocGFsZXR0ZT0iUmRHeSIpICsKICAgIHRoZW1lX2J3KCkgKwogICAgZ2VvbV9ib3hwbG90KG91dGxpZXIuc2hhcGU9TkEpICsgCiAgICBnZW9tX2ppdHRlcih3aWR0aCA9IDAuMikgKwogICAgZ2d0aXRsZSgiQm94cGxvdCBvZiBkaWZmZXJlbnQgYmxvb2QgcHJlc3N1cmUgbWVhc3VyZXMiKSArCiAgICB5bGFiKCJibG9vZCBwcmVzc3VyZSAobW1IZykiKSArIHN0YXRfc3VtbWFyeShmdW4ueT1tZWFuLCBnZW9tPSJwb2ludCIsIHNoYXBlPTUsIHNpemU9MywgY29sb3I9ImJsYWNrIiwgZmlsbD0iYmxhY2siKQpgYGAKCldpdGggdGhlIGJveHBsb3QsIHdlIGdldCBhIGxvdCBvZiB1c2VmdWwgaW5mb3JtYXRpb24uCldlIGltbWVkaWF0ZWx5IHNlZSBtdWx0aXBsZSBmZWF0dXJlcyBvZiB0aGUgc3ByZWFkIG9mCnRoZSBkYXRhLCBzdWNoIGFzIHRoZSBtZWRpYW4sIHRoZSAyNSUgYW5kIDc1JSBxdWFudGlsZXMKYW5kIG91dGxpZXJzLiBTaW5jZSB3ZSBvbmx5IGhhdmUgMTUgcmF3IHZhbHVlcyAocGF0aWVudHMpLAp3ZSBjYW4gZWFzaWx5IGFkZCB0aGVtIHRvIHRoZSBwbG90IHdpdGhvdXQgZ2V0dGluZyBtZXNzeS4KCkluIHRlcm1zIG9mIGludGVycHJldGF0aW9uLCB3ZSBjYW4gc2VlIHRoYXQgdGhlIG1lZGlhbiAKc3lzdG9saWMgYW5kIGRpYXN0b2xpYyBibG9vZCBwcmVzc3VyZSB2YWx1ZXMgYXJlIGxvd2VyIAphZnRlciB0cmVhdG1lbnQgd2l0aCBjYXB0b3ByaWwgdGhhbiBiZWZvcmUuIElmIHdlIHdhbnQgdG8KaGF2ZSB2aXN1YWwgaW5mZXJlbmNlIG9uIHRoZSBtZWFuIHZhbHVlcyAoY2ZyLiBjbGFzcyBvbiB0LXRlc3QpLAp3ZSBjYW4gYWRkIHRoZW0gdG8gdGhlIHBsb3QgYHN0YXRfc3VtbWFyeWAgZnVuY3Rpb24uCgojIyBTY2F0dGVycGxvdAoKQW4gaW1wb3J0YW50IGZlYXR1cmUgb2YgdGhpcyBkYXRhc2V0IGlzIHRoYXQgaXQgY29udGFpbnMKcGFpcmVkIGRhdGE7IGZvciBlYWNoIHBhdGllbnQsIHdlIGhhdmUgYmxvb2QgcHJlc3N1cmUgdmFsdWVzCihzeXN0b2xpYyBhbmQgZGlhc3RvbGljKSBiZWZvcmUgYW5kIGFmdGVyIHRyZWF0bWVudCB3aXRoCmNhcHRvcHJpbC4KCldlIGNhbiB2aXN1YWxpemUgdGhpcyBhcyBmb2xsb3dzOwoKYGBge3J9CmNhcHRvcHJpbCAlPiUgCiAgZ2F0aGVyKHR5cGUsYnAsLWlkKSAlPiUgCiAgZmlsdGVyKHR5cGUlaW4lYygiU0JQYSIsIlNCUGIiKSkgJT4lCiAgZ2dwbG90KGFlcyh4PWlkLHk9YnAsY29sb3I9dHlwZSkpICsKICAgIGdlb21fcG9pbnQoc2l6ZT0yKSArCiAgICBzY2FsZV9jb2xvcl9tYW51YWwodmFsdWVzID0gYygiYmx1ZSIsInJlZCIpKSArCiAgICB0aGVtZV9idygpCmBgYAoKT3IsIGFsdGVybmF0aXZlbHksIGJ5IGNyZWF0aW5nIGEgYGxpbmUgcGxvdGA6CgpgYGB7cn0KY2FwdG9wcmlsICU+JSAKICBnYXRoZXIodHlwZSxicCwtaWQpICU+JSAKICBmaWx0ZXIodHlwZSVpbiVjKCJTQlBhIiwiU0JQYiIpKSAlPiUKICBnZ3Bsb3QoYWVzKHg9dHlwZSx5PWJwKSkgKwogICAgZ2VvbV9saW5lKGFlcyhncm91cD1pZCkpICsgCiAgICB0aGVtZV9idygpCmBgYAoKV2Ugc2VlIHRoYXQgZm9yIGFsbCBwYXRpZW50cywgdGhlIHN5c3RvbGljIGJsb29kCnByZXNzdXJlIGlzIGxvd2VyIGFmdGVyIGNhcHRvcHJpbCB0cmVhdG1lbnQgdGhhbiBiZWZvcmUuCgpOb3RlIHRoYXQgd2UgY291bGQgbm90IHNlZSB0aGlzIGZyb20gdGhlIGJveHBsb3QsIGRpcmVjdGx5OwoKYGBge3J9CmNhcHRvcHJpbCAlPiUgCiAgZ2F0aGVyKHR5cGUsYnAsLWlkKSAlPiUgCiAgICBmaWx0ZXIodHlwZSVpbiVjKCJTQlBhIiwiU0JQYiIpKSAlPiUKICAgIGdncGxvdChhZXMoeD10eXBlLHk9YnAsZmlsbD10eXBlKSkgKyAKICAgIHNjYWxlX2ZpbGxfYnJld2VyKHBhbGV0dGU9IlJkR3kiKSArCiAgICB0aGVtZV9idygpICsKICAgIGdlb21fYm94cGxvdChvdXRsaWVyLnNoYXBlPU5BKSArIAogICAgZ2VvbV9qaXR0ZXIod2lkdGggPSAwLjIpICsKICAgIGdndGl0bGUoIkJveHBsb3Qgb2YgYmxvb2QgcHJlc3N1cmUgbWVhc3VyZXMgYmVmb3JlIGFuZCBhZnRlciB0cmVhdG1lbnQiKSArCiAgICB5bGFiKCJibG9vZCBwcmVzc3VyZSAobW1IZykiKSArIAogICAgc3RhdF9zdW1tYXJ5KGZ1bj1tZWFuLCBnZW9tPSJwb2ludCIsIHNoYXBlPTUsIHNpemU9MywgY29sb3I9ImJsYWNrIiwgZmlsbD0iYmxhY2siKQpgYGAKCkEgdHlwaWNhbCBuZXh0IHN0ZXAgaXMgdG8gcGVyZm9ybSBhIHRlc3QgdG8gZmluZCBvdXQKd2hldGhlciB0aGUgbWVhbiBzeXN0b2xpYyBibG9vZCBwcmVzc3VyZSB2YWx1ZSBhZnRlcgpjYXB0b3ByaWwgdHJlYXRtZW50IGlzIF9zaWduaWZpY2FudGx5XyBkaWZmZXJlbnQgZnJvbQp0aGUgbWVhbiBzeXN0b2xpYyBibG9vZCBwcmVzc3VyZSB2YWx1ZSBiZWZvcmUgdHJlYXRtZW50LgoKQW5hbGFnb3VzbHksIHdlIG1heSBzdWJ0cmFjdCB0aGUgYGFmdGVyYCBtZWFzdXJlbWVudCBmcm9tIHRoZQpgYmVmb3JlYCBtZWFzdXJlbWVudCwgYW5kIHRlc3QgaWYgdGhlIGRpZmZlcmVuY2UgYmV0d2VlbiB0aGUgCnR3byBzZXRzIG9mIHZhbHVlcyBpcyBzaWduaWZpY2FudGx5IGRpZmZlcmVudCBmcm9tIHplcm8uCgpgYGB7cn0KY2FwdG9wcmlsICU+JSAKICBtdXRhdGUoYnBfZGlmZiA9IFNCUGEtU0JQYikgJT4lCiAgc2VsZWN0KGJwX2RpZmYpICU+JQogIGdncGxvdChhZXMoeD0iIix5PWJwX2RpZmYpKSArCiAgZ2VvbV9ib3hwbG90KG91dGxpZXIuc2hhcGU9TkEpICsKICBnZW9tX2ppdHRlcih3aWR0aCA9IDAuMikgKyAKICBnZ3RpdGxlKCJCb3hwbG90IG9mIHRoZSBkaWZmZXJlbmNlIGluIGJsb29kIHByZXNzdXJlIikgKwogIHlsYWIoImJsb29kIHByZXNzdXJlIGRpZmZlcmVuY2UgKG1tSGcpIikgKyBzdGF0X3N1bW1hcnkoZnVuLnk9bWVhbiwgZ2VvbT0icG9pbnQiLCBzaGFwZT01LCBzaXplPTMsIGNvbG9yPSJibGFjayIsIGZpbGw9ImJsYWNrIikgKwogIHRoZW1lX2J3KCkrCiAgeWxpbSgtNDAsMTApICsKICBnZW9tX2hsaW5lKHlpbnRlcmNlcHQgPSAwLCBjb2xvcj0icmVkIikgIyMgYWRkcyBob3Jpem9udGFsIGxpbmUgdG8gcGxvdApgYGAKClRoZSBtZWFuIGRpZmZlcmVuY2UgaXMgbG93ZXIgdGhhbiB6ZXJvLiBJdCBzZWVtcyB0aGF0IG9uIGF2ZXJhZ2UgdGhlIGNhcHRvcHJpbAp0cmVhdG1lbnQgaGFzIGxvd2VyZWQgdGhlIGJsb29kIHByZXNzdXJlIGJ5IGFib3V0IDIwIG1tSGcuIFRvbW9ycm93LCB3ZSB3aWxsIApzaG93IGhvdyB3ZSBjYW4gdGVzdCBpZiB0aGlzIHJlZHVjdGlvbiBpcyBzaWduaWZpY2FudGx5IGRpZmZlcmVudCBmcm9tIDAgbW1IZy4KCgoKCgoKCg==