Nothing

```
weights.subclass <- function(psclass, treat, estimand = "ATT") {
NAsub <- is.na(psclass)
i1 <- treat == 1 & !NAsub
i0 <- treat == 0 & !NAsub
weights <- setNames(rep(0, length(treat)), names(treat))
if (!is.factor(psclass)) {
psclass <- factor(psclass, nmax = min(sum(i1), sum(i0)))
levels(psclass) <- seq_len(nlevels(psclass))
}
treated_by_sub <- setNames(tabulate(psclass[i1], nlevels(psclass)), levels(psclass))
control_by_sub <- setNames(tabulate(psclass[i0], nlevels(psclass)), levels(psclass))
total_by_sub <- treated_by_sub + control_by_sub
psclass <- as.character(psclass)
if (estimand == "ATT") {
weights[i1] <- 1
weights[i0] <- (treated_by_sub/control_by_sub)[psclass[i0]]
#Weights average 1
weights[i0] <- weights[i0]*sum(i0)/sum(weights[i0])
}
else if (estimand == "ATC") {
weights[i1] <- (control_by_sub/treated_by_sub)[psclass[i1]]
weights[i0] <- 1
#Weights average 1
weights[i1] <- weights[i1]*sum(i1)/sum(weights[i1])
}
else if (estimand == "ATE") {
weights[i1] <- (total_by_sub/treated_by_sub)[psclass[i1]]
weights[i0] <- (total_by_sub/control_by_sub)[psclass[i0]]
#Weights average 1
weights[i1] <- weights[i1]*sum(i1)/sum(weights[i1])
weights[i0] <- weights[i0]*sum(i0)/sum(weights[i0])
}
if (sum(weights)==0)
stop("No units were matched.", call. = FALSE)
else if (sum(weights[treat == 1])==0)
stop("No treated units were matched.", call. = FALSE)
else if (sum(weights[treat == 0])==0)
stop("No control units were matched.", call. = FALSE)
return(weights)
}
```

**Any scripts or data that you put into this service are public.**

Embedding an R snippet on your website

Add the following code to your website.

For more information on customizing the embed code, read Embedding Snippets.