-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathstrat_sample.R
42 lines (32 loc) · 1.54 KB
/
strat_sample.R
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
# Title: Stratified sampling for sentiment validation
# Context: APART
# Author: Nicolai B.
# Date: Fri Jan 15 12:10 2020
# 0. Content ---------------------------------------------------------
#
#
# 1. Preparation -----------------------------------------------------
# __Loading Packages -------------------------------------------------
rm(list=ls())
usePackage <- function(p) {if (!is.element(p, installed.packages()[,1]))install.packages(p,dep = TRUE, repos = "http://cran.wu.ac.at"); library(p, character.only = TRUE)}
for (i in c('dplyr', 'beepr')){usePackage(i)}; rm(i, usePackage)
# __global vars -----------------------------------------------------
prop <- 0.01 # proportion of original data to be sampled
# __preprocess full set------------------------------------------------
setwd("C:/Users/samunico/Dropbox/Studium/Amsterdam/Studies/Semester 3/Block I/Internship/data")
dta <- readRDS("df_windows_full_2020-01-22_x2.rds"); beep(10)
dta_r <- dta %>% select(legper, keyword, window_for_sent, window_id)
rm(dta)
setwd("~/GitHub/samunico/Apart/data")
write.csv(dta_r, "windows_df_230120.csv"); beep(10)
# 2. Sampling --------------------------------------------------------
set.seed(312) # ensures reproducability
sample <- dta_r %>%
group_by(legper) %>%
sample_frac(prop)
# 3. write to csv
# general sample
data.table::fwrite(sample,"StratSample_01-23.csv"); beep(10)
# figure eight sample
f8_sample <- as.data.frame(sample)[, c('window_id', 'window_for_sent', 'keyword')]
data.table::fwrite(f8_sample,"f8Val_StratSample_01-23.csv"); beep(10)