Data Imputation & Cleanup
# In order to leverage missForest for imputation, it only supports consuming / predicting factor
# and numeric data types so all applicable passed-in features should be in one of those two formats.
combi$Age <- as.factor(combi$Age)
combi$Sex <- as.factor(combi$Sex)
combi$Embarked <- as.factor(combi$Embarked)
combi$SocioEconomic <- as.factor(combi$SocioEconomic)
glimpse(combi, width = 105)
Rows: 1,309
Columns: 19
$ PassengerId <dbl> 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 2…
$ Survived <dbl> 0, 1, 1, 1, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 1, 0, 1, 0, 1, 0, 1, 1, 1, 0, 1, 0,…
$ Pclass <dbl> 3, 1, 3, 1, 3, 3, 1, 3, 3, 2, 3, 1, 3, 3, 3, 2, 3, 2, 3, 3, 2, 2, 3, 1, 3, 3, 3,…
$ Name <chr> "Braund, Mr. Owen Harris", "Cumings, Mrs. John Bradley (Florence Briggs Thayer)"…
$ Sex <fct> male, female, female, female, male, male, male, male, female, female, female, fe…
$ Age <fct> Adult, Adult, Adult, Adult, Adult, NA, Elder, Child, Adult, Child, Child, Elder,…
$ SibSp <dbl> 1, 1, 0, 1, 0, 0, 0, 3, 0, 1, 1, 0, 0, 1, 0, 0, 4, 0, 1, 0, 0, 0, 0, 0, 3, 1, 0,…
$ Parch <dbl> 0, 0, 0, 0, 0, 0, 0, 1, 2, 0, 1, 0, 0, 5, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 5, 0,…
$ Ticket <chr> "A/5 21171", "PC 17599", "STON/O2. 3101282", "113803", "373450", "330877", "1746…
$ Fare <dbl> 7.2500, 71.2833, 7.9250, 53.1000, 8.0500, 8.4583, 51.8625, 21.0750, 11.1333, 30.…
$ Cabin <chr> NA, "C85", NA, "C123", NA, NA, "E46", NA, NA, NA, "G6", "C103", NA, NA, NA, NA, …
$ Embarked <fct> S, C, S, S, S, Q, S, S, S, C, S, S, S, S, S, S, Q, S, S, C, S, S, Q, S, S, S, C,…
$ Title <fct> Mr, Mrs, Miss, Mrs, Mr, Mr, Mr, Master, Mrs, Mrs, Miss, Miss, Mr, Mr, Miss, Mrs,…
$ Surname <chr> "Braund", "Cumings", "Heikkinen", "Futrelle", "Allen", "Moran", "McCarthy", "Pal…
$ FamilySize <dbl> 2, 2, 1, 2, 1, 1, 1, 5, 3, 2, 3, 1, 1, 7, 1, 1, 6, 1, 2, 1, 1, 1, 1, 1, 5, 7, 1,…
$ FamilyOnBoard <dbl> 1, 1, 0, 1, 0, 0, 0, 1, 1, 1, 1, 0, 0, 1, 0, 0, 1, 0, 1, 0, 0, 0, 0, 0, 1, 1, 0,…
$ CabinLetter <fct> NA, C, NA, C, NA, NA, E, NA, NA, NA, G, C, NA, NA, NA, NA, NA, NA, NA, NA, NA, D…
$ HasCabin <dbl> 0, 1, 0, 1, 0, 0, 1, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 0, 0,…
$ SocioEconomic <fct> 3X, 1C, 3X, 1C, 3X, 3X, 1E, 3X, 3X, 2X, 3G, 1C, 3X, 3X, 3X, 2X, 3X, 2X, 3X, 3X, …
# Examining how many NA's and blanks our dataset has.
sapply(combi, function(x) sum(is.na(x) | x == "")) %>%
as.data.frame()
.
PassengerId 0
Survived 418
Pclass 0
Name 0
Sex 0
Age 263
SibSp 0
Parch 0
Ticket 0
Fare 1
Cabin 1014
Embarked 2
Title 0
Surname 0
FamilySize 0
FamilyOnBoard 0
CabinLetter 1014
HasCabin 0
SocioEconomic 0
# Imputation Step: excluding irrelevant / unsupported data type features, plus casting to dataframe
# for missForest.
set.seed(420)
combi.imp <- combi %>%
select(-c("Survived", "Name", "Ticket", "Surname", "Cabin", "CabinLetter")) %>%
as.data.frame() %>%
missForest()
missForest iteration 1 in progress...done!
missForest iteration 2 in progress...done!
missForest iteration 3 in progress...done!
missForest iteration 4 in progress...done!
# Observing results + error rates for imputation (~4.72% for numeric, and ~9.82% for factors).
combi.imp$OOBerror
NRMSE PFC
0.04723969 0.09826029
# Merging imputed features back into "combi".
combi$Age <- combi.imp$ximp$Age
combi$Fare <- combi.imp$ximp$Fare
combi$Embarked <- combi.imp$ximp$Embarked
# Examining how many NA's and blanks our dataset has.
sapply(combi, function(x) sum(is.na(x) | x == "")) %>%
as.data.frame()
.
PassengerId 0
Survived 418
Pclass 0
Name 0
Sex 0
Age 0
SibSp 0
Parch 0
Ticket 0
Fare 0
Cabin 1014
Embarked 0
Title 0
Surname 0
FamilySize 0
FamilyOnBoard 0
CabinLetter 1014
HasCabin 0
SocioEconomic 0
ggplot(combi) +
aes(x = Age) +
geom_bar(width = 0.2,
stat = "count") +
theme_clean(base_size = 10) +
labs(x = "Age", y = "Frequency")
![](data:image/png;base64,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CR1Y3SJAgAABAgQIECBAgAABAgQIEOh+AsK67jdmWkyAAAECBAgQIECAAAECBAgQILCECgjrltCB1S0CBAgQIECAAAECBAgQIECAAIHuJyCs635jpsUECBAgQIAAAQIECBAgQIAAAQJLqICwbgkdWN0iQIAAAQIECBAgQIAAAQIECBDofgLCuu43ZlpMgAABAgQIECBAgAABAgQIECCwhAoI65bQgdUtAgQIECBAgAABAgQIECBAgACB7icgrOt+Y6bFBAgQIECAAAECBAgQIECAAAECS6iAsG4JHVjdIkCAAAECBAgQIECAAAECBAgQ6H4CwrruN2ZaTIAAAQIECBAgQIAAAQIECBAgsIQKCOuW0IHVLQIECBAgQIAAAQIECBAgQIAAge4nIKzrfmOmxQQIECBAgAABAgQIECBAgAABAkuogLBuCR1Y3SJAgAABAgQIECBAgAABAgQIEOh+AsK67jdmWkyAAAECBAgQIECAAAECBAgQILCECgjrltCB1S0CBAgQIECAAAECBAgQIECAAIHuJ9C77E3+7ne/G9/4xjdin332WaSpr7zySkyYMCEmTZoUG2+8cVZm6623blVu/vz52fvXXXddvP3227HjjjvGyJEjY9lll20u15UyzYXtECBAgAABAgQIECBAgAABAgQIEChIoNQr6+6+++749a9/HU8//fQi3X/99ddjiy22iJNPPjmWWmqp+NOf/pQFcbfcckursqeeemrstttuMW3atHj//fdjzJgxsd9++8XHH3/cXK4rZZoL2yFAgAABAgQIECBAgAABAgQIECBQkEApw7ozzzwzWyW36667ttvttOKud+/e8eCDD8aVV16ZhXFp1dz+++8fH330UXbeQw89lIV5Y8eOjTvuuCNbhXfjjTdGCvTOOeecLpdptxHeIECAAAECBAgQIECAAAECBAgQILAYBUoZ1j355JPRq1ev+NrXvtZmV9MKuauvvjoOO+ywWGONNbIyPXr0iEMPPTS71HXixInZscsvvzx69uyZraZrqmjEiBGx3nrrZQFfOtaVMk3n+k2AAAECBAgQIECAAAECBAgQIECgSIFS3rPuf//3f7M+P/fcc1mwtjBACvPSloK3ltvgwYOzl+mS13SPuyeeeCK23HLL6N+/f8tikcql1XULFizoUpkUBC68pRV8r732WvPh9957r3l/5syZ8eKLL8baa6/dfKzlzhtvvBGPPfZYdmj48OHZZbwt32/anz59erz11luxyiqrxJe//OWmw61+p1WE999/f3Zsk002iZVWWqnV+00vnn/++axNSy+9dCx8X7+mMun35MmT45NPPolBgwZpP//mr4bvTzNF+PObW5h/cou0Z/7MPfz9lVuYP3ML82duYf7MLdKe+TP3MH/mFubP3ML8mVuYP3OLtGf+zD26w/y5ww475A3uZK+UYV0nbY4UhqVttdVWa1V0o402yl7PmTMn+53KpQdPLLylcjfddFO8+eabWV2dlUlh2cLbPffcEy+//PLCh7PXaeXf3//+9zbfSwfT/fLShJu29HCL9rZ33303K5fuydfels5vqqvlffgWLp/ak8r17dt34bdavU4mqZ5VV1211fGWL7Q/1+CfW6Q935/cw5/f3ML8k1uYP3ML82dukfbMn7mH+TO3MH/mFubP3ML8mVukPfNn7mH+zC3Mn7mF+TO3+KLnz7wlne91y7AuPQU2bcsss0yrHq6wwgrZ5bNpZVjaUrn0EIqFt5VXXjk7lMp1pczC56fX6RLc9HTZpi2tsrvqqquylynoam+FWyqQnkSbLsVNW7rct71t4MCB0a9fv1h++eXbK5Kd31TXwh4tT0rtSeU6Cv5S+bSibt68edr/mQX//Bvk+5Nb+PObW6T5y/yTe5g/cwvzZ25h/swtzJ+5hfkzt0h75s/cw/yZW5g/cwvzZ25h/swt0p75M/foDvNn3trO99L1nQvScsEhQ4Z0XvpzLtF0GezZZ58d3//+95s//bLLLsvuT5cuZW35EIp33nknVlxxxTjxxBPjlFNOifXXXz/WXHPNSE+VbbmNHj06e8BESpjTKrvOynQWcKW6p06dGsOGDcs+JrXvkEMOafmR9gkQIECAAAECBAgQIECAAAECBAh0KDBjxowo5QMmOmz1Z2+utdZaWZFnnnmmVdGmy1I32GCD7Hgqt3CZ9EYqt84662SrzLpSptWHeEGAAAECBAgQIECAAAECBAgQIECgIIFuGdalm/KlFXR/+ctfWrFMmDAh0sMg9thjj+z43nvvHbNmzWp+mEM6+MEHH0R6Wuxee+3V5TJZQf8hQIAAAQIECBAgQIAAAQIECBAgULBAtwzr0hNNjz766PjDH/4Qv/zlL7NA7uqrr47TTjstjj322OxeY8ktXYqaHg6R7i83ZcqUeOqpp+Kggw6K3r17x5gxYzLarpQpeAxUT4AAAQIECBAgQIAAAQIECBAgQCAT6JYPmEgtP/XUU2P27NmR7j/3ve99L3vQwj777BPp/nZNW7oXXVpFt+eee8bWW2+dHV599dVj/Pjx0XSpbFfKNNXnN4GqCvz3f/93Vbve5X6fccYZXS6rIAECBAgQIECAAAECBAgQaE+g1GHduuuuGwsWLGiz7T179oyLL744C+ceeuih7Kmv6dLYhbetttoqC/WmTZuW1bX55ptnl8q2LNeVMi3L2ydQNYGHH364al3WXwIECBAgQIAAAQIECBAg8IUIlDqs64pIeqT3zjvv3GHRdB+7FNJ1tHWlTEfne48AAQIECBAgQIAAAQIECBAgQIBAowLd8p51jXba+QQIECBAgAABAgQIECBAgAABAgTKKCCsK+OoaBMBAgQIECBAgAABAgQIECBAgEAlBYR1lRx2nSZAgAABAgQIECBAgAABAgQIECijgLCujKOiTQQIECBAgAABAgQIECBAgAABApUUENZVcth1mgABAgQIECBAgAABAgQIECBAoIwCwroyjoo2ESBAgAABAgQIECBAgAABAgQIVFJAWFfJYddpAgQIECBAgAABAgQIECBAgACBMgoI68o4KtpEgAABAgQIECBAgAABAgQIECBQSQFhXSWHXacJECBAgAABAgQIECBAgAABAgTKKCCsK+OoaBMBAgQIECBAgAABAgQIECBAgEAlBYR1lRx2nSZAgAABAgQIECBAgAABAgQIECijgLCujKOiTQQIECBAgAABAgQIECBAgAABApUUENZVcth1mgABAgQIECBAgAABAgQIECBAoIwCwroyjoo2ESBAgAABAgQIECBAgAABAgQIVFJAWFfJYddpAgQIECBAgAABAgQIECBAgACBMgoI68o4KtpEgAABAgQIECBAgAABAgQIECBQSQFhXSWHXacJECBAgAABAgQIECBAgAABAgTKKCCsK+OoaBMBAgQIECBAgAABAgQIECBAgEAlBYR1lRx2nSZAgAABAgQIECBAgAABAgQIECijgLCujKOiTQQIECBAgAABAgQIECBAgAABApUUENZVcth1mgABAgQIECBAgAABAgQIECBAoIwCwroyjoo2ESBAgAABAgQIECBAgAABAgQIVFJAWFfJYddpAgQIECBAgAABAgQIECBAgACBMgoI68o4KtpEgAABAgQIECBAgAABAgQIECBQSQFhXSWHXacJECBAgAABAgQIECBAgAABAgTKKCCsK+OoaBMBAgQIECBAgAABAgQIECBAgEAlBYR1lRx2nSZAgAABAgQIECBAgAABAgQIECijgLCujKOiTQQIECBAgAABAgQIECBAgAABApUUENZVcth1mgABAgQIECBAgAABAgQIECBAoIwCwroyjoo2ESBAgAABAgQIECBAgAABAgQIVFJAWFfJYddpAgQIECBAgAABAgQIECBAgACBMgoI68o4KtpEgAABAgQIECBAgAABAgQIECBQSQFhXSWHXacJECBAgAABAgQIECBAgAABAgTKKCCsK+OoaBMBAgQIECBAgAABAgQIECBAgEAlBYR1lRx2nSZAgAABAgQIECBAgAABAgQIECijgLCujKOiTQQIECBAgAABAgQIECBAgAABApUUENZVcth1mgABAgQIECBAgAABAgQIECBAoIwCwroyjoo2ESBAgAABAgQIECBAgAABAgQIVFJAWFfJYddpAgQIECBAgAABAgQIECBAgACBMgoI68o4KtpEgAABAgQIECBAgAABAgQIECBQSQFhXSWHXacJECBAgAABAgQIECBAgAABAgTKKCCsK+OoaBMBAgQIECBAgAABAgQIECBAgEAlBYR1lRx2nSZAgAABAgQIECBAgAABAgQIECijgLCujKOiTQQIECBAgAABAgQIECBAgAABApUUENZVcth1mgABAgQIECBAgAABAgQIECBAoIwCwroyjoo2ESBAgAABAgQIECBAgAABAgQIVFJAWFfJYddpAgQIECBAgAABAgQIECBAgACBMgoI68o4KtpEgAABAgQIECBAgAABAgQIECBQSQFhXSWHXacJECBAgAABAgQIECBAgAABAgTKKCCsK+OoaBMBAgQIECBAgAABAgQIECBAgEAlBYR1lRx2nSZAgAABAgQIECBAgAABAgQIECijgLCujKOiTQQIECBAgAABAgQIECBAgAABApUUENZVcth1mgABAgQIECBAgAABAgQIECBAoIwCwroyjoo2ESBAgAABAgQIECBAgAABAgQIVFJAWFfJYddpAgQIECBAgAABAgQIECBAgACBMgoI68o4KtpEgAABAgQIECBAgAABAgQIECBQSQFhXSWHXacJECBAgAABAgQIECBAgAABAgTKKCCsK+OoaBMBAgQIECBAgAABAgQIECBAgEAlBYR1lRx2nSZAgAABAgQIECBAgAABAgQIECijgLCujKOiTQQIECBAgAABAgQIECBAgAABApUUENZVcth1mgABAgQIECBAgAABAgQIECBAoIwCwroyjoo2ESBAgAABAgQIECBAgAABAgQIVFJAWFfJYddpAgQIECBAgAABAgQIECBAgACBMgoI68o4KtpEgAABAgQIECBAgAABAgQIECBQSQFhXSWHXacJECBAgAABAgQIECBAgAABAgTKKCCsK+OoaBMBAgQIECBAgAABAgQIECBAgEAlBYR1lRx2nSZAgAABAgQIECBAgAABAgQIECijgLCujKOiTQQIECBAgAABAgQIECBAgAABApUUENZVcth1mgABAgQIECBAgAABAgQIECBAoIwCwroyjoo2ESBAgAABAgQIECBAgAABAgQIVFJAWFfJYddpAgQIECBAgAABAgQIECBAgACBMgoI68o4KtpEgAABAgQIECBAgAABAgQIECBQSQFhXSWHXacJECBAgAABAgQIECBAgAABAgTKKCCsK+OoaBMBAgQIECBAgAABAgQIECBAgEAlBYR1lRx2nSZAgAABAgQIECBAgAABAgQIECijgLCujKOiTQQIECBAgAABAgQIECBAgAABApUUENZVcth1mgABAgQIECBAgAABAgQIECBAoIwCwroyjoo2ESBAgAABAgQIECBAgAABAgQIVFJAWFfJYddpAgQIECBAgAABAgQIECBAgACBMgoI68o4KtpEgAABAgQIECBAgAABAgQIECBQSQFhXSWHXacJECBAgAABAgQIECBAgAABAgTKKCCsK+OoaBMBAgQIECBAgAABAgQIECBAgEAlBYR1lRx2nSZAgAABAgQIECBAgAABAgQIECijgLCujKOiTQQIECBAgAABAgQIECBAgAABApUUENZVcth1mgABAgQIECBAgAABAgQIECBAoIwCwroyjoo2ESBAgAABAgQIECBAgAABAgQIVFJAWFfJYddpAgQIECBAgAABAgQIECBAgACBMgoI68o4KtpEgAABAgQIECBAgAABAgQIECBQSQFhXSWHXacJECBAgAABAgQIECBAgAABAgTKKCCsK+OoaBMBAgQIECBAgAABAgQIECBAgEAlBYR1lRx2nSZAgAABAgQIECBAgAABAgQIECijgLCujKOiTQQIECBAgAABAgQIECBAgAABApUUENZVcth1mgABAgQIECBAgAABAgQIECBAoIwCwroyjoo2ESBAgAABAgQIECBAgAABAgQIVFJAWFfJYddpAgQIECBAgAABAgQIECBAgACBMgoI68o4KtpEgAABAgQIECBAgAABAgQIECBQSQFhXSWHXacJECBAgAABAgQIECBAgAABAgTKKCCsK+OoaBMBAgQIECBAgAABAgQIECBAgEAlBYR1lRx2nSZAgAABAgQIECBAgAABAgQIECijgLCujKOiTQQIECBAgAABAgQIECBAgAABApUUENZVcth1mgABAgQIECBAgAABAgQIECBAoIwCwroyjoo2ESBAgAABAgQIECBAgAABAgQIVFJAWFfJYddpAgQIECBAgAABAgQIECBAgACBMgoI68o4KtpEgAABAgQIECBAgAABAgQIECBQSQFhXSWHXacJECBAgAABAgQIECBAgAABAgTKKCCsK+OoaBMBAgQIECBAgAABAgQIECBAgEAlBYR1lRx2nSZAgAABAgQIECBAgAABAgQIECijgLCujKOiTQQIECBAgAABAgQIECBAgAABApUUENZVcth1mgABAgQIECBAgAABAgQIECBAoIwCwroyjoo2ESBAgAABAgQIECBAgAABAgQIVFJAWFfJYddpAgQIECBAgAABAgQIECBAgACBMgoI68o4KtpEgAABAgQIECBAgAABAgQIECBQSQFhXSWHXacJECBAgAABAgQIECBAgAABAgTKKCCsK+OoaBMBAgQIECBAgAABAgQIECBAgEAlBYR1lRx2nSZAgAABAgQIECBAgAABAgQIECijgLCujKOiTQQIECBAgAABAgQIECBAgAABApUUENZVcth1mgABAgQIECBAgAABAgQIECBAoIwCwroyjoo2ESBAgAABAgQIECBAgAABAgQIVFJAWFfJYddpAgQIECBAgAABAgQIECBAgACBMgoI68o4KtpEgAABAgQIECBAgAABAgQIECBQSQFhXSWHXacJECBAgAABAgQIECBAgAABAgTKKCCsK+OoaBMBAgQIECBAgAABAgQIECBAgEAlBYR1lRx2nSZAgAABAgQIECBAgAABAgQIECijgLCujKOiTQQIECBAgAABAgQIECBAgAABApUUENZVcth1mgABAgQIECBAgAABAgQIECBAoIwCwroyjoo2ESBAgAABAgQIECBAgAABAgQIVFJAWFfJYddpAgQIECBAgAABAgQIECBAgACBMgoI68o4KtpEgAABAgQIECBAgAABAgQIECBQSQFhXSWHXacJECBAgAABAgQIECBAgAABAgTKKCCsK+OoaBMBAgQIECBAgAABAgQIECBAgEAlBYR1lRx2nSZAgAABAgQIECBAgAABAgQIECijgLCujKOiTQQIECBAgAABAgQIECBAgAABApUUENZVcth1mgABAgQIECBAgAABAgQIECBAoIwCwroyjoo2ESBAgAABAgQIECBAgAABAgQIVFJAWFfJYddpAgQIECBAgAABAgQIECBAgACBMgoI68o4KtpEgAABAgQIECBAgAABAgQIECBQSQFhXSWHXacJECBAgAABAgQIECBAgAABAgTKKCCsK+OoaBMBAgQIECBAgAABAgQIECBAgEAlBYR1lRx2nSZAgAABAgQIECBAgAABAgQIECijgLCujKOiTQQIECBAgAABAgQIECBAgAABApUUENZVcth1mgABAgQIECBAgAABAgQIECBAoIwCwroyjoo2ESBAgAABAgQIECBAgAABAgQIVFJAWFfJYddpAgQIECBAgAABAgQIECBAgACBMgoI68o4KtpEgAABAgQIECBAgAABAgQIECBQSQFhXSWHXacJECBAgAABAgQIECBAgAABAgTKKCCsK+OoaBMBAgQIECBAgAABAgQIECBAgEAlBYR1lRx2nSZAgAABAgQIECBAgAABAgQIECijQO8yNqqzNt13331x1VVXtVtsnXXWiVGjRmXvX3rppfHII48sUnavvfaKnXfeOTs+f/78mDRpUlx33XXx9ttvx4477hgjR46MZZdddpHzHCBAgAABAgQIECBAgAABAgQIECBQlEC3DOueeOKJuOiii9o0eeedd7KwrSmsu+CCCyKVX2GFFVqV33DDDZvDulNPPTXGjh2bnbfyyivHmDFj4tprr43rr78++vTp0+o8LwgQIECAAAECBAgQIECAAAECBAgUJdAtL4NNq97eeuutRX6uuOKKbDXc+eef3+z11FNPxTnnnBPPPfdcq5+jjz46K/PQQw/FySefnIV1d9xxR0yYMCFuvPHGuOWWW7LzmiuyQ4AAAQIECBAgQIAAAQIECBAgQKBggW4Z1rVl8vrrr8cRRxwRP//5z2PTTTfNiqRA780334yNNtqorVOyY5dffnn07NkzW03XVGjEiBGx3nrrxZVXXtl0yG8CBAgQIECAAAECBAgQIECAAAEChQt0y8tg21I56qijYu211470u2lLq+rS9vHHH8dZZ50Vr732WgwdOjQOOOCAWHrppbP30iWyW265ZfTv3z973fSfwYMHZ6vrFixYED169Gg63Px76tSp8dFHHzW/njlzZvP++++/Hx988EEss8wyzcda7qT2pDJpW3HFFbOwsOX7TfvvvfdefPLJJ7HUUkvFcsst13S41e90v710n720pTKpbFtbak/6ScFk+sz2thRwpj6ntms///a+J453LuDPb25k/sktzP+5hb+/cou05+/f3MP8mVuYP3ML82duYf7MLdKe+TP3MH/mFubP3ML8mVt80fNnuu1aV7denxX86THHHBOrrrpqV88pXblrrrkmu5T1D3/4QwwaNKi5fXfeeWf88Y9/jHHjxsXzzz8fkydPzvavvvrq+OY3vxnLL798nHTSSdk5Bx54YPN5aWfKlClxzz33xLHHHtvmgya23nrr7DLZdO+89POnP/2p+fx0P7wU9g0YMKD5WMudOXPmxN/+9rd44YUXYv3114/evdvOTFMg+Nhjj2Uh25e+9KWWVTTvf/jhh9nDMVJdq6yyyiKhY1PBFFw++OCDMXv27Ejta2+7/fbb49lnn81CP+3n3/Q9SX+GbB0LpMvzW27+/OYa5p/cwvyfW/j7K7dIe/7+zT3Mn7mF+TO3MH/mFubP3CLtmT9zD/NnbmH+zC3Mn7nFFz1/brzxxnljOthLC82WiMtg0wMi9t1339hhhx1adTetfEur5lJol0Kvl156Kbu0Na2CO/LII7Oyr7zySpsryJoSz7SyzUaAAAECBAgQIECAAAECBAgQIEDg8xBI13cumD59egwZMuTz+LzF/hk333xz7L777nHrrbfGLrvs0qX6t9tuu2zlXFomnPq95pprxt13393q3NGjR2cr59KS0bYuLU0r1D799NPmcx555JGsHenAhRdeGIceemi7K+bSeanetPXt27fNy2zTe6lMKturV692n0qbLllN6XDa0pNrU9m2thQ6zps3L/us9JntbamuVGfqc3sr/rQ/16uKf/ozZutYYOLEia0K+PObc5h/cgvzZ25RlfnT9z8fc9//3ML3P7dIe/79mXv490NuYf7MLcyfuYX5M7dIe+bP3KM7zJ/t3Wos78X/35sxY0Z0+7Bu1113jaeffjqeeeaZdkOvhTveFMSle73tvffe2flphV3Lbf/9988um02Xz3ZlS0uOhw0blhW97LLL4pBDDunKacoQ6BYCwrrOh2nhsK7zM5QgQIAAAQIECBAgQIAAAQKtBVJY160vg33nnXeyexQcfPDBbQZ16amwba22u/7662PdddeNFVZYIQvrZs2alV0m28STbkaZ/of3Xnvt1XTIbwIECBAgQIAAAQIECBAgQIAAAQKFC3TrsC7dTDQtCW4rkEtyaXXcpEmT4rTTTotXX301Uih3/PHHZ6vwTjjhhAw3rYBLD2Y47LDDsktj040oDzrooOwS0DFjxhQ+AD6AAAECBAgQIECAAAECBAgQIECAQJNA76ad7vg73acu3aNtm222abP5J554YqQnn4wdOzaawrl0X7ef/exnzQ+YSPerS6vo9txzz0hPeE3b6quvHuPHj48NNtigzXodJECAAAECBAgQIECAAAECBAgQIFCEQLcO684777xIP+1tPXv2zN5PYV265nfFFVeMwYMHZw91aHnOVlttFemBEdOmTcserrD55pu3eVlty3PsEyBAgAABAgQIECBAgAABAgQIEFjcAt06rOsqxoABA2KnnXbqsHiPHj0ihXQ2AgQIECBAgAABAgQIECBAgAABAl+UQLe+Z90XheZzCRAgQIAAAQIECBAgQIAAAQIECBQhIKwrQlWdBAgQIECAAAECBAgQIECAAAECBOoQENbVgeYUAgQIECBAgAABAgQIECBAgAABAkUICOuKUFUnAQIECBAgQIAAAQIECBAgQIAAgToEhHV1oDmFAAECBAgQIECAAAECBAgQIECAQBECwroiVNVJgAABAgQIECBAgAABAgQIECBAoA4BYV0daE4hQIAAAQIECBAgQIAAAQIECBAgUISAsK4IVXUSIECAAAECBAgQIECAAAECBAgQqENAWFcHmlMIECBAgAABAgQIECBAgAABAgQIFCEgrCtCVZ0ECBAgQIAAAQIECBAgQIAAAQIE6hAQ1tWB5hQCBAgQIECAAAECBAgQIECAAAECRQgI64pQVScBAgQIECBAgAABAgQIECBAgACBOgSEdXWgOYUAAQIECBAgQIAAAQIECBAgQIBAEQLCuiJU1UmAAAECBAgQIECAAAECBAgQIECgDgFhXR1oTiFAgAABAgQIECBAgAABAgQIECBQhICwrghVdRIgQIAAAQIECBAgQIAAAQIECBCoQ0BYVweaUwgQIECAAAECBAgQIECAAAECBAgUISCsK0JVnQQIECBAgAABAgQIECBAgAABAgTqEBDW1YHmFAIECBAgQIAAAQIECBAgQIAAAQJFCAjrilBVJwECBAgQIECAAAECBAgQIECAAIE6BIR1daA5hQABAgQIECBAgAABAgQIECBAgEARAsK6IlTVSYAAAQIECBAgQIAAAQIECBAgQKAOAWFdHWhOIUCAAAECBAgQIECAAAECBAgQIFCEgLCuCFV1EiBAgAABAgQIECBAgAABAgQIEKhDQFhXB5pTCBAgQIAAAQIECBAgQIAAAQIECBQhIKwrQlWdBAgQIECAAAECBAgQIECAAAECBOoQENbVgeYUAgQIECBAgAABAgQIECBAgAABAkUICOuKUFUnAQIECBAgQIAAAQIECBAgQIAAgToEhHV1oDmFAAECBAgQIECAAAECBAgQIECAQBECwroiVNVJgAABAgQIECBAgAABAgQIECBAoA4BYV0daE4hQIAAAQIECBAgQIAAAQIECBAgUISAsK4IVXUSIECAAAECBAgQIECAAAECBAgQqENAWFcHmlMIECBAgAABAgQIECBAgAABAgQIFCEgrCtCVZ0ECBAgQIAAAQIECBAgQIAAAQIE6hAQ1tWB5hQCBAgQIECAAAECBAgQIECAAAECRQgI64pQVScBAgQIECBAgAABAgQIECBAgACBOgSEdXWgOYUAAQIECBAgQIAAAQIECBAgQIBAEQLCuiJU1UmAAAECBAgQIECAAAECBAgQIECgDgFhXR1oTiFAgAABAgQIECBAgAABAgQIECBQhICwrghVdRIgQIAAAQIECBAgQIAAAQIECBCoQ0BYVweaUwgQIECAAAECBAgQIECAAAECBAgUISCsK0JVnQQIECBAgAABAgQIECBAgAABAgTqEBDW1YHmFAIECBAgQIAAAQIECBAgQIAAAQJFCAjrilBVJwECBAgQIECAAAECBAgQIECAAIE6BIR1daA5hQABAgQIECBAgAABAgQIECBAgEARAsK6IlTVSYAAAQIECBAgQIAAAQIECBAgQKAOAWFdHWhOIUCAAAECBAgQIECAAAECBAgQIFCEgLCuCFV1EiBAgAABAgQIECBAgAABAgQIEKhDQFhXB5pTCBAgQIAAAQIECBAgQIAAAQIECBQhIKwrQlWdBAgQIECAAAECBAgQIECAAAECBOoQENbVgeYUAgQIECBAgAABAgQIECBAgAABAkUICOuKUFUnAQIECBAgQIAAAQIECBAgQIAAgToEhHV1oDmFAAECBAgQIECAAAECBAgQIECAQBECwroiVNVJgAABAgQIECBAgAABAgQIECBAoA4BYV0daE4hQIAAAQIECBAgQIAAAQIECBAgUISAsK4IVXUSIECAAAECBAgQIECAAAECBAgQqENAWFcHmlMIECBAgAABAgQIECBAgAABAgQIFCEgrCtCVZ0ECBAgQIAAAQIECBAgQIAAAQIE6hAQ1tWB5hQCBAgQIECAAAECBAgQIECAAAECRQgI64pQVScBAgQIECBAgAABAgQIECBAgACBOgSEdXWgOYUAAQIECBAgQIAAAQIECBAgQIBAEQLCuiJU1UmAAAECBAgQIECAAAECBAgQIECgDgFhXR1oTiFAgAABAgQIECBAgAABAgQIECBQhICwrghVdRIgQIAAAQIECBAgQIAAAQIECBCoQ0BYVweaUwgQIECAAAECBAgQIECAAAECBAgUISCsK0JVnQQIECBAgAABAgQIECBAgAABAgTqEBDW1YHmFAIECBAgQIAAAQIECBAgQIAAAQJFCAjrilBVJwECBAgQIECAAAECBAgQIECAAIE6BIR1daA5hQABAgQIECBAgAABAgQIECBAgEARAsK6IlTVSYAAAQIECBAgQIAAAQIECBAgQKAOAWFdHWhOIUCAAAECBAgQIECAAAECBAgQIFCEgLCuCFV1EiBAgAABAgQIECBAgAABAgQIEKhDQFhXB5pTCBAgQIAAAQIECBAgQIAAAQIECBQhIKwrQlWdBAgQIECAAAECBAgQIECAAAECBOoQENbVgeYUAgQIECBAgAABAgQIECBAgAABAkUICOuKUFUnAQIECBAgQIAAAQIECBAgQIAAgToEhHV1oDmFAAECBAgQIECAAAECBAgQIECAQBECwroiVNVJgAABAgQIECBAgAABAgQIECBAoA4BYV0daE4hQIAAAQIECBAgQIAAAQIECBAgUISAsK4IVXUSIECAAAECBAgQIECAAAECBAgQqENAWFcHmlMIECBAgAABAgQIECBAgAABAgQIFCEgrCtCVZ0ECBAgQIAAAQIECBAgQIAAAQIE6hAQ1tWB5hQCBAgQIECAAAECBAgQIECAAAECRQgI64pQVScBAgQIECBAgAABAgQIECBAgACBOgSEdXWgOYUAAQIECBAgQIAAAQIECBAgQIBAEQLCuiJU1UmAAAECBAgQIECAAAECBAgQIECgDgFhXR1oTiFAgAABAgQIECBAgAABAgQIECBQhICwrghVdRIgQIAAAQIECBAgQIAAAQIECBCoQ0BYVweaUwgQIECAAAECBAgQIECAAAECBAgUISCsK0JVnQQIECBAgAABAgQIECBAgAABAgTqEBDW1YHmFAIECBAgQIAAAQIECBAgQIAAAQJFCAjrilBVJwECBAgQIECAAAECBAgQIECAAIE6BIR1daA5hQABAgQIECBAgAABAgQIECBAgEARAsK6IlTVSYAAAQIECBAgQIAAAQIECBAgQKAOAWFdHWhOIUCAAAECBAgQIECAAAECBAgQIFCEgLCuCFV1EiBAgAABAgQIECBAgAABAgQIEKhDQFhXB5pTCBAgQIAAAQIECBAgQIAAAQIECBQhIKwrQlWdBAgQIECAAAECBAgQIECAAAECBOoQENbVgeYUAgQIECBAgAABAgQIECBAgAABAkUICOuKUFUnAQIECBAgQIAAAQIECBAgQIAAgToEhHV1oDmFAAECBAgQIECAAAECBAgQIECAQBECwroiVNVJgAABAgQIECBAgAABAgQIECBAoA4BYV0daE4hQIAAAQIECBAgQIAAAQIECBAgUISAsK4IVXUSIECAAAECBAgQIECAAAECBAgQqENAWFcHmlMIECBAgAABAgQIECBAgAABAgQIFCEgrCtCVZ0ECBAgQIAAAQIECBAgQIAAAQIE6hAQ1tWB5hQCBAgQIECAAAECBAgQIECAAAECRQgI64pQVScBAgQIECBAgAABAgQIECBAgACBOgSEdXWgOYUAAQIECBAgQIAAAQIECBAgQIBAEQLCuiJU1UmAAAECBAgQIECAAAECBAgQIECgDgFhXR1oTiFAgAABAgQIECBAgAABAgQIECBQhEBDYd0TTzwRc+fOLaJd6iRAgAABAgQIECBAgAABAgQIECBQOYGGwroLL7wwVl999TjkkEPi5ptvjk8//bRygDpMgAABAgQIECBAgAABAgQIECBAYHEJNBTWbb/99jFo0KAYN25c7L777rHWWmvF6NGjY8qUKYurfeohQIAAAQIECBAgQIAAAQIECBAgUBmBhsK6b37zmzF9+vTs56c//WkMGDAgzjnnnNh6661jyJAhcfrpp8crr7xSGUwdJUCAAAECBAgQIECAAAECBAgQINCIQENhXdMHp2Bu7Nix8eijj8aMGTPipJNOit69e8fxxx+frbzbb7/9sstk58+f33SK3wQIECBAgAABAgQIECBAgAABAgQILCSwWMK6lnV++ctfjiOPPDKOOuqoWG+99WLevHkxYcKE7DLZTTfdNK677rqWxe0TIECAAAECBAgQIECAAAECBAgQIPAPgcUW1r344ovZJbA77LBDfOlLX4pRo0bFhx9+GN///vdj8uTJcfHFF0evXr0irbK79dZbDQABAgQIECBAgAABAgQIECBAgAABAgsJ9F7odU0vX3755Rg/fnxcc801WSC3YMGC6N+/f/Z02JEjR8bXv/71LKBLlW6zzTbx7W9/O7uv3U033RS77rprTZ+lMAECBAgQIECAAAECBAgQIECAAIElXaChsO6Xv/xlnHXWWdn96fbYY49IAd0+++wTyy67bJtuSy+9dLbqLgV6NgIECBAgQIAAAQIECBAgQIAAAQIEWgs0FNal+9Ode+65ccABB8Rqq63WuuY2XvXo0SMef/zxNt5xiAABAgQIECBAgAABAgQIECBAgACBhsK6ww8/vFlw7ty50a9fv+x1uhz2o48+ir59+za/b4cAAQIECBAgQIAAAQIECBAgQIAAgY4FGn7AxG233RZf+cpXYvjw4c2f9P7778cqq6ySPUwi3dfORoAAAQIECBAgQIAAAQIECBAgQIBA5wINhXVTp06Nf/7nf44ZM2a0emBEujfdVlttFRMmTIhhw4bFW2+91XlLlCBAgAABAgQIECBAgAABAgQIECBQcYGGwrrzzjsv5s+fH/fcc0+cc845zZR9+vSJO+64I66++uqYPXt2dl+75jftECBAgAABAgQIECBAgAABAgQIECDQpkBDYd3MmTNj0003zVbRtVX7v/zLv8RGG20UDzzwQFtvO0aAAAECBAgQIECAAAECBAgQIECAQAuBhsK6lVZaKT788MMW1S26m54SO2/evEXfcIQAAQIECBAgQIAAAQIECBAgQIAAgVYCDYV1X/3qV+PJJ5+M3/72t60qbXpx1113xeTJk9tdeddUzm8CBAgQIECAAAECBAgQIECAAAECBCJ6N4IwevToGD9+fPzHf/xHXHLJJdnDJDbZZJN4/vnnY9KkSdnlr2uttVaMGjWqkY9xLgECBAgQIECAAAECBAgQIECAAIFKCDQU1i2zzDIxceLEOP7442PcuHFx7733tkLbZZdd4vzzz48BAwa0Ou4FAQIECBAgQIAAAQIECBAgQIAAAQKLCjQU1qXq1lxzzbj00kvj1FNPjRkzZsSzzz4b6V52Q4YMiaFDhy76iY4QIECAAAECBAgQIECAAAECBAgQINCmQMNh3fz58+Ppp5+ORx55JGbNmhULFiyIOXPmZD+333579qHbbLNNpB8bAQIECBAgQIAAAQIECBAgQIAAAQLtCzQU1s2dOzf23nvvaArl2vuYsWPHCuvaw3GcAAECBAgQIECAAAECBAgQIECAwD8EGgrrzj333CyoGzFiROy///4xaNCgNmEHDx7c5nEHCRAgQIAAAQIECBAgQIAAAQIECBDIBRoK6+6///5YddVV45Zbbomllloqr9UeAQIECBAgQIAAAQIECBAgQIAAAQI1C/Ss+YwWJyy33HKxzjrrCOpamNglQIAAAQIECBAgQIAAAQIECBAgUK9AQ2HdzjvvnD0B9plnnqn3851HgAABAgQIECBAgAABAgQIECBAgMA/BBoK6w499NDsARPf+ta34qGHHsqeBEuWAAECBAgQIECAAAECBAgQIECAAIH6BBoK684+++yYMmVKTJ06NbbYYovo06dPrLLKKjFgwIBWP2eeeWZ9rXMWAQIECBAgQIAAAQIECBAgQIAAgQoJNPSAiX79+sVaa62V/XRklh5CYSNAgAABAgQIECBAgAABAgQIECBAoGOBhsK673znO5F+bAQIECBAgAABAgQIECBAgAABAgQINC7Q0GWwjX+8GggQIECAAAECBAgQIECAAAECBAgQaBJYLGFdumfdqFGjYvvtt4+hQ4fGvHnz4pJLLonbbrut6XP8JkCAAAECBAgQIECAAAECBAgQIECgE4GGw7rf/OY3MWzYsDjvvPOyh01Mnz49+8hbb701dt111zjuuOM6aYK3CRAgQIAAAQIECBAgQIAAAQIECBBIAg2FdQ888EAce+yxsdNOO8XkyZPj8ssvb1b9xS9+EQceeGCkJ8GmlXc2AgQIECBAgAABAgQIECBAgAABAgQ6FmgorLvhhhuib9++8ec//zm22Wab6NWrV/OnrbbaanHppZfGoEGD4owzzmg+bocAAQIECBAgQIAAAQIECBAgQIAAgbYFGgrrpkyZEptvvnn069evzdr79OkTw4cPj5kzZ7b5voMECBAgQIAAAQIECBAgQIAAAQIECOQCDYV1adXcSy+9FAsWLMhrXGhv1qxZkVbZ2QgQIECAAAECBAgQIECAAAECBAgQ6Figd8dvd/xueoDEBRdcECeccEL86Ec/alU4BXjjx4+Pu+66K04++eRW7y2OFykEPPvssxepaqmllorTTjut+fj8+fNj0qRJcd1118Xbb78dO+64Y4wcOTKWXXbZmso0F7ZDgAABAgQIECBAgAABAgQIECBAoCCBhlbW7bvvvlnwdfrpp8caa6zRHJ4dccQRMXDgwDjooINiyJAhMWbMmMXe/Iceeih+/vOfxzXXXNPqZ8KECa0+69RTT43ddtstpk2bFu+//37Wlv322y8+/vjj5nJdKdNc2A4BAgQIECBAgAABAgQIECBAgACBggQaCutSmy6++OJIT37t3bt33HPPPVkzf//738drr70WKbRLq9rSQygW9/bUU09lD6947rnnouXP448/3vxRKdBLq/rGjh0bd9xxR6Qg78Ybb4xbbrklzjnnnKxcV8o0V2iHAAECBAgQIECAAAECBAgQIECAQIECDYd16bLT733vezFnzpzsQRI33XRTpAdPvPPOO3HRRRfFqquuWkjzU1i30UYbdVj35ZdfHj179my1sm/EiBGx3nrrxZVXXpmd25UyHX6INwkQIECAAAECBAgQIECAAAECBAgsJoGG7lnXsg1pZd3gwYOzn5bHi9pPYV0K3VLY9vDDD8cqq6wSe+yxR2y22WbNH/nEE0/ElltuGf37928+lnZSO9PqunRfva6U6dGjR6vz04vDDjss3njjjebjKZxs2lLbXn755VhrrbWaDrX6/eabb2afmw4OGzYsUuDZ1pZWCab77K200krtBpMfffRRPPjgg9npG2+8cay44optVRUvvvhi1qall146tthiizbLpIMPPPBAfPLJJ7H22mtrP/92vyfe6FzAn9/cyPyTW5j/cwt/f+UWac/fv7mH+TO3MH/mFubP3ML8mVukPfNn7mH+zC3Mn7mF+TO3+KLnz2233TZvTCd7DYV1Keh65plnOvmIiA033DD76bRgDQVSIHbzzTfHFVdcEeuvv34W2J144olxyimnxHHHHZfVNHPmzEgB1sJbWpGXVgCmL21XyqQgcOHt1ltvzcKvhY+n1ym4S/fHa29LX5DZs2dnb6cHYLS3vfXWW9mKxbbCwqZz0vlNdaXwsr0ttSeV6+yS5LRCMt3PLwWE7W3an8tUxT/vsb2uCvjzm0uZf3IL82duUZX50/c/H3Pf/9zC9z+3SHv+/Zl7+PdDbmH+zC3Mn7mF+TO3SHvmz9yjO8yfeWs732sorLvwwgvjrLPO6vRTfvrTn2b3jeu0YA0FUph05JFHxnnnnZetTHvhhRey1W7pybQ77bRTbL/99vHKK6+0uYps5ZVXzj4prSDrSpm2mvWtb30r0pehaUur7NL98NKWwr0VVlih6a1Ffi+zzDLZyrX0RrpMt70tXUKcVsK1t1ounderV6/mulK97W2pPWm1XJ8+fdorkh1PqwHnzZun/Z9p8O/wq+LNTgR8f3Ig809uYf7PLfz9lVukPX//5h7mz9zC/JlbmD9zC/NnbpH2zJ+5h/kztzB/5hbmz9zii54/85Z0vpeu71wwffr07KmtnRdvXeLee+/NVrS1PPrhhx/G008/HY888kjcfvvtWaD2gx/8oN3LOFue2+h+Wmm3++67R9MKu7Tibs0114y77767VdWjR4/OHjCRVpClVXadlWnvMtWWlU6dOjW7pDUdu+yyy+KQQw5p+bZ9At1aIP25snUsMHHixI4LeJcAAQIECBAgQIAAAQIECHQiMGPGjGhoZV263raja27TAyb+/d//PX784x930pTF8/bw4cOziubOnZv9Tv8vSwoOF97S/eTWWWedbEVeV8osfL7XBAgQIECAAAECBAgQIECAAAECBIoQaP8azMXwaf/2b/8Wa6yxRlx99dWLoba8imuuuSa7fPTOO+/MD362d/3112evv/KVr2S/995775g1a1Y89thjzeU++OCDSCtg9tprry6XaT7ZDgECBAgQIECAAAECBAgQIECAAIECBQoN61K7Bw4cGH/5y18Waxe+/vWvZ/eFO+aYY2Ly5MnZwxzSpa4nnXRS9oTYAw88MPu8dClqun9cenLrlClTIj2U4qCDDor05NoxY8Z0ucxibbzKCBAgQIAAAQIECBAgQIAAAQIECLQjUFhYlx7ecNVVV2X3tPunf/qndj6+vsPpARE33HBDpM9Il+Eut9xyseOOO8aAAQPi//7v/7KHMqSa073o0iq6Z599NrbeeutI7fjb3/4W48ePjw022CD78K6Uqa+VziJAgAABAgQIECBAgAABAgQIECBQm0BD96xLK9nS01jb2t57771ID3Do169fIQ9bSCFdejBGusQ1PYk1BXEpeFt422qrrWL27Nkxbdq0WLBgQWy++ebRo0d6rka+daVMXtoeAQIECBAgQIAAAQIECBAgQIAAgWIEGgrrVlpppVh33XXbbFla7TZs2LA44IADmp+S2mbBBg6mx+4OHTq00xpSOJdCuo62rpTp6HzvESBAgAABAgQIECBAgAABAgQIEGhUoKGwbtSoUZF+bAQIECBAgAABAgQIECBAgAABAgQINC7QUFh3zz33xNSpU2tuxTbbbBPpx0aAAAECBAgQIECAAAECBAgQIECAQC7QUFh33XXXxVlnnZXX1sW9sWPHCuu6aKUYAQIECBAgQIAAAQIECBAgQIBAdQQaCutGjx4dzz33XFx//fVx9NFHZ/emGzRoUPb01Ycffjh+/etfZ8d+8pOftBJtehJrq4NeECBAgAABAgQIECBAgAABAgQIEKi4QENhXXoS69VXXx233357jBgxoplyp512yvZHjhyZraBLT2M95JBDmt+3Q4AAAQIECBAgQIAAAQIECBAgQIDAogI9Fz3U9SM33HBDbLjhhq2CupZnb7nlljF8+PCYOHFiy8P2CRAgQIAAAQIECBAgQIAAAQIECBBoQ6ChsC5dArvUUku1UW1+aMGCBfHiiy/mB+wRIECAAAECBAgQIECAAAECBAgQINCmQENh3XbbbRfpUthx48a1Wfmdd94Z9913X6QVdjYCBAgQIECAAAECBAgQIECAAAECBDoWaOiedd/97nfjyiuvzO5Hd8UVV8Quu+wSAwcOjBdeeCEeeeSRuOqqq2KFFVaIH/7whx23wrsECBAgQIAAAQIECBAgQIAAAQIECERDYV3//v3jpptuihNPPDEuu+yybL+l6bBhw+J//ud/Ys0112x52D4BAgQIECBAgAABAgQIECBAgAABAm0INBTWpfrSSrqLLrooTjnllHj00Ucj3cdupZVWyh48sdlmm0XPng1dadtGkx0iQIAAAQIECBAgQIAAAQIECBAgsGQKNBzWNbGsscYakX5sBAgQIECAAAECBAgQIECAAAECBAjUJ7BYlr1NnTo1Ro0aFdtvv30MHTo05s2bF5dcckncdttt9bXKWQQIECBAgAABAgQIECBAgAABAgQqKNBwWPeb3/wm0r3pzjvvvJgyZUpMnz49Y7z11ltj1113jeOOO66CrLpMgAABAgQIECBAgAABAgQIECBAoHaBhsK6Bx54II499tjYaaedYvLkyXH55Zc3t+AXv/hFHHjggXHmmWdGWnlnI0CAAAECBAgQIECAAAECBAgQIECgY4GGwrobbrgh+vbtG3/+859jm222iV69ejV/2mqrrRaXXnppDBo0KM4444zm43YIECBAgAABAgQIECBAgAABAgQIEGhboKGwLl32uvnmm0e/fv3arL1Pnz4xfPjwmDlzZpvvO0iAAAECBAgQIECAAAECBAgQIECAQC7QUFiXVs299NJLsWDBgrzGhfZmzZoVaZWdjQABAgQIECBAgAABAgQIECBAgACBjgUaCuvSAySef/75OOGEE2Lu3LmtPikFeFdeeWXcddddMWLEiFbveUGAACMR/fwAAEAASURBVAECBAgQIECAAAECBAgQIECAwKICvRc91PUj++67b4wcOTJOP/30+NWvfhWbbrppdvIRRxwRN998c8yZMyc22WSTGDNmTNcrVZIAAQIECBAgQIAAAQIECBAgQIBARQUaWlmXzC6++OJIT37t3bt33HPPPRnj73//+3jttdcihXaTJk3KHkJRUV/dJkCAAAECBAgQIECAAAECBAgQINBlgYZW1qVLYN9///0YNWpU/Od//mc888wz2c+qq64agwcPjuWWW67LDVGQAAECBAgQIECAAAECBAgQIECAQNUFGgrrRo8eHRMmTIh33303C+ZSQJd+bAQIECBAgAABAgQIECBAgAABAgQI1C7Q0GWwhx9+ePaJf/3rX2v/ZGcQIECAAAECBAgQIECAAAECBAgQINBKoKGwbq+99sougT3yyCPjggsuiDfeeKNV5V4QIECAAAECBAgQIECAAAECBAgQINB1gYbCuvQU2GuvvTZeffXVOOaYY2K11VbLHibRt2/fVr9POeWUrrdISQIECBAgQIAAAQIECBAgQIAAAQIVFWjonnUDBw6MoUOHZj8d+a233nodve09AgQIECBAgAABAgQIECBAgAABAgQ+E2gorDviiCMi/dgIECBAgAABAgQIECBAgAABAgQIEGhcoKbLYN9777148MEH4/XXX2/8k9VAgAABAgQIECBAgAABAgQIECBAgEArgZrCunvvvTe23HLLuOqqq1pV8vLLL8ett94ab7/9dqvjXhAgQIAAAQIECBAgQIAAAQIECBAg0HWBmsK69qq98cYbY7fddotHH320vSKOEyBAgAABAgQIECBAgAABAgQIECDQicBiCes6+QxvEyBAgAABAgQIECBAgAABAgQIECDQBQFhXReQFCFAgAABAgQIECBAgAABAgQIECDweQgI6z4PZZ9BgAABAgQIECBAgAABAgQIECBAoAsCwrouIClCgAABAgQIECBAgAABAgQIECBA4PMQENZ9Hso+gwABAgQIECBAgAABAgQIECBAgEAXBHp3ocwiRdLTX2fPnt18/IEHHsj2L7roorjllluajzft7LzzzvG1r32t6aXfBAgQIECAAAECBAgQIECAAAECBAi0IVBXWHfTTTdF+ll4+93vfrfwoex1z549hXVtyjhIgAABAgQIECBAgAABAgQIECBAIBeoKazbdNNNY9y4cfnZXdzbbLPNulhSMQIECBAgQIAAAQIECBAgQIAAAQLVFagprBs4cGAcfPDB1dXScwIECBAgQIAAAQIECBAgQIAAAQIFCnjARIG4qiZAgAABAgQIECBAgAABAgQIECBQi4CwrhYtZQkQIECAAAECBAgQIECAAAECBAgUKCCsKxBX1QQIECBAgAABAgQIECBAgAABAgRqERDW1aKlLAECBAgQIECAAAECBAgQIECAAIECBYR1BeKqmgABAgQIECBAgAABAgQIECBAgEAtAsK6WrSUJUCAAAECBAgQIECAAAECBAgQIFCggLCuQFxVEyBAgAABAgQIECBAgAABAgQIEKhFQFhXi5ayBAgQIECAAAECBAgQIECAAAECBAoUENYViKtqAgQIECBAgAABAgQIECBAgAABArUICOtq0VKWAAECBAgQIECAAAECBAgQIECAQIECwroCcVVNgAABAgQIECBAgAABAgQIECBAoBYBYV0tWsoSIECAAAECBAgQIECAAAECBAgQKFBAWFcgrqoJECBAgAABAgQIECBAgAABAgQI1CIgrKtFS1kCBAgQIECAAAECBAgQIECAAAECBQoI6wrEVTUBAgQIECBAgAABAgQIECBAgACBWgSEdbVoKUuAAAECBAgQIECAAAECBAgQIECgQAFhXYG4qiZAgAABAgQIECBAgAABAgQIECBQi4CwrhYtZQkQIECAAAECBAgQIECAAAECBAgUKCCsKxBX1QQIECBAgAABAgQIECBAgAABAgRqERDW1aKlLAECBAgQIECAAAECBAgQIECAAIECBYR1BeKqmgABAgQIECBAgAABAgQIECBAgEAtAsK6WrSUJUCAAAECBAgQIECAAAECBAgQIFCggLCuQFxVEyBAgAABAgQIECBAgAABAgQIEKhFQFhXi5ayBAgQIECAAAECBAgQIECAAAECBAoUENYViKtqAgQIECBAgAABAgQIECBAgAABArUICOtq0VKWAAECBAgQIECAAAECBAgQIECAQIECwroCcVVNgAABAgQIECBAgAABAgQIECBAoBYBYV0tWsoSIECAAAECBAgQIECAAAECBAgQKFBAWFcgrqoJECBAgAABAgQIECBAgAABAgQI1CIgrKtFS1kCBAgQIECAAAECBAgQIECAAAECBQoI6wrEVTUBAgQIECBAgAABAgQIECBAgACBWgSEdbVoKUuAAAECBAgQIECAAAECBAgQIECgQAFhXYG4qiZAgAABAgQIECBAgAABAgQIECBQi4CwrhYtZQkQIECAAAECBAgQIECAAAECBAgUKCCsKxBX1QQIECBAgAABAgQIECBAgAABAgRqERDW1aKlLAECBAgQIECAAAECBAgQIECAAIECBYR1BeKqmgABAgQIECBAgAABAgQIECBAgEAtAsK6WrSUJUCAAAECBAgQIECAAAECBAgQIFCggLCuQFxVEyBAgAABAgQIECBAgAABAgQIEKhFQFhXi5ayBAgQIECAAAECBAgQIECAAAECBAoUENYViKtqAgQIECBAgAABAgQIECBAgAABArUICOtq0VKWAAECBAgQIECAAAECBAgQIECAQIECwroCcVVNgAABAgQIECBAgAABAgQIECBAoBYBYV0tWsoSIECAAAECBAgQIECAAAECBAgQKFBAWFcgrqoJECBAgAABAgQIECBAgAABAgQI1CIgrKtFS1kCBAgQIECAAAECBAgQIECAAAECBQoI6wrEVTUBAgQIECBAgAABAgQIECBAgACBWgSEdbVoKUuAAAECBAgQIECAAAECBAgQIECgQAFhXYG4qiZAgAABAgQIECBAgAABAgQIECBQi4CwrhYtZQkQIECAAAECBAgQIECAAAECBAgUKCCsKxBX1QQIECBAgAABAgQIECBAgAABAgRqERDW1aKlLAECBAgQIECAAAECBAgQIECAAIECBYR1BeKqmgABAgQIECBAgAABAgQIECBAgEAtAsK6WrSUJUCAAAECBAgQIECAAAECBAgQIFCggLCuQFxVEyBAgAABAgQIECBAgAABAgQIEKhFQFhXi5ayBAgQIECAAAECBAgQIECAAAECBAoUENYViKtqAgQIECBAgAABAgQIECBAgAABArUICOtq0VKWAAECBAgQIECAAAECBAgQIECAQIECwroCcVVNgAABAgQIECBAgAABAgQIECBAoBYBYV0tWsoSIECAAAECBAgQIECAAAECBAgQKFBAWFcgrqoJECBAgAABAgQIECBAgAABAgQI1CIgrKtFS1kCBAgQIECAAAECBAgQIECAAAECBQoI6wrEVTUBAgQIECBAgAABAgQIECBAgACBWgSEdbVoKUuAAAECBAgQIECAAAECBAgQIECgQAFhXYG4qiZAgAABAgQIECBAgAABAgQIECBQi4CwrhYtZQkQIECAAAECBAgQIECAAAECBAgUKCCsKxBX1QQIECBAgAABAgQIECBAgAABAgRqERDW1aKlLAECBAgQIECAAAECBAgQIECAAIECBYR1BeKqmgABAgQIECBAgAABAgQIECBAgEAtAsK6WrSUJUCAAAECBAgQIECAAAECBAgQIFCggLCuQFxVEyBAgAABAgQIECBAgAABAgQIEKhFQFhXi5ayBAgQIECAAAECBAgQIECAAAECBAoUENYViKtqAgQIECBAgAABAgQIECBAgAABArUICOtq0VKWAAECBAgQIECAAAECBAgQIECAQIECwroCcVVNgAABAgQIECBAgAABAgQIECBAoBYBYV0tWsoSIECAAAECBAgQIECAAAECBAgQKFBAWFcgrqoJECBAgAABAgQIECBAgAABAgQI1CIgrKtFS1kCBAgQIECAAAECBAgQIECAAAECBQoI6wrEVTUBAgQIECBAgAABAgQIECBAgACBWgSEdbVoKUuAAAECBAgQIECAAAECBAgQIECgQAFhXYG4qiZAgAABAgQIECBAgAABAgQIECBQi4CwrhYtZQkQIECAAAECBAgQIECAAAECBAgUKCCsKxBX1QQIECBAgAABAgQIECBAgAABAgRqERDW1aKlLAECBAgQIECAAAECBAgQIECAAIECBYR1BeKqmgABAgQIECBAgAABAgQIECBAgEAtAsK6WrSUJUCAAAECBAgQIECAAAECBAgQIFCggLCuQFxVEyBAgAABAgQIECBAgAABAgQIEKhFQFhXi5ayBAgQIECAAAECBAgQIECAAAECBAoUENYViKtqAgQIECBAgAABAgQIECBAgAABArUICOtq0VKWAAECBAgQIECAAAECBAgQIECAQIECwroCcVVNgAABAgQIECBAgAABAgQIECBAoBYBYV0tWsoSIECAAAECBAgQIECAAAECBAgQKFBAWFcgrqoJECBAgAABAgQIECBAgAABAgQI1CIgrKtFS1kCBAgQIECAAAECBAgQIECAAAECBQoI6wrEVTUBAgQIECBAgAABAgQIECBAgACBWgSEdbVoKUuAAAECBAgQIECAAAECBAgQIECgQAFhXYG4qiZAgAABAgQIECBAgAABAgQIECBQi4CwrhYtZQkQIECAAAECBAgQIECAAAECBAgUKCCsKxBX1QQIECBAgAABAgQIECBAgAABAgRqERDW1aKlLAECBAgQIECAAAECBAgQIECAAIECBYR1BeKqmgABAgQIECBAgAABAgQIECBAgEAtAsK6WrSUJUCAAAECBAgQIECAAAECBAgQIFCggLCuQFxVEyBAgAABAgQIECBAgAABAgQIEKhFQFhXi5ayBAgQIECAAAECBAgQIECAAAECBAoUENYViKtqAgQIECBAgAABAgQIECBAgAABArUICOtq0VKWAAECBAgQIECAAAECBAgQIECAQIECwroCcVVNgAABAgQIECBAgAABAgQIECBAoBYBYV0tWsoSIECAAAECBAgQIECAAAECBAgQKFCgd4F1F171tGnTYvz48TF16tTo379/bLvttjFq1Kjo06dP82dfeuml8cgjjzS/btrZa6+9Yuedd85ezp8/PyZNmhTXXXddvP3227HjjjvGyJEjY9lll20q7jcBAgQIECBAgAABAgQIECBAgACBwgW6bVh39913x5577hkrrbRSFq6lwO6Pf/xj9nPXXXdF797/v2sXXHBBPPHEE7HCCiu0wtxwww2bw7pTTz01xo4dm9Wz8sorx5gxY+Laa6+N66+/vlXw16oCLwgQIECAAAECBAgQIECAAAECBAgsZoFuexnsj370o1hnnXUira4bN25czJgxI3784x/Hvffem71ucnrqqafinHPOieeee67Vz9FHH50Veeihh+Lkk0/Owro77rgjJkyYEDfeeGPccsst2XlN9fhNgAABAgQIECBAgAABAgQIECBAoGiBbrmybt68eXH//ffHD3/4w1Yr5o466qgseJs8eXIcdthh8dZbb8Wbb74ZG220UbuOl19+efTs2TNbTddUaMSIEbHeeuvFlVdemX1G0/GWvx9//PH45JNPmg89+eSTzfsffPBBfPTRR7H00ks3H2u5k85LZdK23HLLRY8ePVq+3bz/97//PVJf0yrB9i7JTZfwvv/++9k5yyyzTCy11FLN57fc+fDDD+Pjjz/OPit9Znvbe++9FwsWLMja3h3b/+6772ZdS23X/sX3/Wnv++J4+wL+/OY25p/cwvyfW/j7K7dIe93971/tz8fT/J9bVGX+9/3Px9z3P7fw/c8t/Psnt/Dvn9wi7VVt/lx++eVbA3TwqluGdXPnzo0zzzwzdtttt1Zda7o33eqrr54dT6vq0pZCqrPOOitee+21GDp0aBxwwAHNQU66RHbLLbfM7nmXFf7HfwYPHpytrkvBVVth2q677hovv/xyy1Oa99Mqv+c+W8nXXkj4+uuvx3333ZeV33333Zvb0lzBP3YefvjhmDNnTgwcODCGDx++8NvZ6xQKpvvtpS3ds6+p79mBFv959tlns8uB+/btG9/4xjdavNN6N11enLw23njjbtn+v/71r9r/jyFdnN+f1t8Sr7oisDj9q/Ln1/yTf7N8f3IL3//cwr8fcgv//skt0l53nz+1Px9P839uYf7PLcz/uYX5P7dIe+bP3KM7zJ/77LNP3uBO9rrlZbDp/nPHHHNMpECtaXvxxRfjxBNPjH79+sW//uu/ZoebwrpddtklLr744rjsssvi0EMPjc033zxeeumlrMzMmTNjtdVWa6qm+XcK2tKqtrQyz0aAAAECBAgQIECAAAECBAgQIEDg8xBI118umD59egwZMuTz+LzF/hlpGekll1wSP/jBD6JXr17ZpatNK+5+97vfxXnnnRfnn39+bLfddln4ds0118S3v/3tbHXZxIkTIy1DTE+GTZe8ttzS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CBAgQIAAAQIECFSNQI+qKYmCECBAgAABAgQILJXAiSeeuFTH1/vBZ511Vr1XUf0IECBAgACBOhAQrKuDRlQFAgQIECBAgEAIPPTQQyAIECBAgAABAgRqXMBjsDXegIpPgAABAgQIECBAgAABAgQIECBQPwKCdfXTlmpCgAABAgQIECBAgAABAgQIECBQ4wKCdTXegIpPgAABAgQIECBAgAABAgQIECBQPwKCdfXTlmpCgAABAgQIECBAgAABAgQIECBQ4wKCdTXegIpPgAABAgQIECBAgAABAgQIECBQPwKCdfXTlmpCgAABAgQIECBAgAABAgQIECBQ4wKCdTXegIpPgAABAgQIECBAgAABAgQIECBQPwKCdfXTlmpCgAABAgQIECBAgAABAgQIECBQ4wKCdTXegIpPgAABAgQIECBAgAABAgQIECBQPwKCdfXTlmpCgAABAgQIECBAgAABAgQIECBQ4wKCdTXegIpPgAABAgQIECBAgAABAgQIECBQPwKCdfXTlmpCgAABAgQIECBAgAABAgQIECBQ4wKCdTXegIpPgAABAgQIECBAgAABAgQIECBQPwKCdfXTlmpCgAABAgQIECBAgAABAgQIECBQ4wKCdTXegIpPgAABAgQIECBAgAABAgQIECBQPwKCdfXTlmpCgAABAgQIECBAgAABAgQIECBQ4wKCdTXegIpPgAABAgQIECBAgAABAgQIECBQPwKCdfXTlmpCgAABAgQIECBAgAABAgQIECBQ4wKCdTXegIpPgAABAgQIECBAgAABAgQIECBQPwKCdfXTlmpCgAABAgQIECBAgAABAgQIECBQ4wKCdTXegIpPgAABAgQIECBAgAABAgQIECBQPwKCdfXTlmpCgAABAgQIECBAgAABAgQIECBQ4wKCdTXegIpPgAABAgQIECBAgAABAgQIECBQPwKCdfXTlmpCgAABAgQIECBAgAABAgQIECBQ4wKCdTXegIpPgAABAgQIECBAgAABAgQIECBQPwKCdfXTlmpCgAABAgQIECBAgAABAgQIECBQ4wKCdTXegIpPgAABAgQIECBAgAABAgQIECBQPwKCdfXTlmpCgAABAgQIECBAgAABAgQIECBQ4wKCdTXegIpPgAABAgQIECBAgAABAgQIECBQPwKCdfXTlmpCgAABAgQIECBAgAABAgQIECBQ4wKCdTXegIpPgAABAgQIECBAgAABAgQIECBQPwI96qcqakKAAAECBAgQIECAAAECBKpb4MQTT6zuAlZB6c4666wqKIUiEOg6AcG6rrN3ZgIECBAgQIAAAQIECBBoMIGHHnqowWqsugQI5BXwGGxeMekJECBAgAABAgQIECBAgAABAgQIFCQgWFcQrGwJECBAgAABAgQIECBAgAABAgQI5BUQrMsrJj0BAgQIECBAgAABAgQIECBAgACBggQE6wqClS0BAgQIECBAgAABAgQIECBAgACBvAKCdXnFpCdAgAABAgQIECBAgAABAgQIECBQkIBgXUGwsiVAgAABAgQIECBAgAABAgQIECCQV0CwLq+Y9AQIECBAgAABAgQIECBAgAABAgQKEhCsKwhWtgQIECBAgAABAgQIECBAgAABAgTyCgjW5RWTngABAgQIECBAgAABAgQIECBAgEBBAoJ1BcHKlgABAgQIECBAgAABAgQIECBAgEBeAcG6vGLSEyBAgAABAgQIECBAgAABAgQIEChIQLCuIFjZEiBAgAABAgQIECBAgAABAgQIEMgrIFiXV0x6AgQIECBAgAABAgQIECBAgAABAgUJCNYVBCtbAgQIECBAgAABAgQIECBAgAABAnkFBOvyiklPgAABAgQIECBAgAABAgQIECBAoCABwbqCYGVLgAABAgQIECBAgAABAgQIECBAIK+AYF1eMekJECBAgAABAgQIECBAgAABAgQIFCQgWFcQrGwJECBAgAABAgQIECBAgAABAgQI5BUQrMsrJj0BAgQIECBAgAABAgQIECBAgACBggQE6wqClS0BAgQIECBAgAABAgQIECBAgACBvAKCdXnFpCdAgAABAgQIECBAgAABAgQIECBQkIBgXUGwsiVAgAABAgQIECBAgAABAgQIECCQV0CwLq+Y9AQIECBAgAABAgQIECBAgAABAgQKEhCsKwhWtgQIECBAgAABAgQIECBAgAABAgTyCgjW5RWTngABAgQIECBAgAABAgQIECBAgEBBAoJ1BcHKlgABAgQIECBAgAABAgQIECBAgEBeAcG6vGLSEyBAgAABAgQIECBAgAABAgQIEChIQLCuIFjZEiBAgAABAgQIECBAgAABAgQIEMgrIFiXV0x6AgQIECBAgAABAgQIECBAgAABAgUJCNYVBCtbAgQIECBAgAABAgQIECBAgAABAnkFBOvyiklPgAABAgQIECBAgAABAgQIECBAoCABwbqCYGVLgAABAgQIECBAgAABAgQIECBAIK+AYF1eMekJECBAgAABAgQIECBAgAABAgQIFCQgWFcQrGwJECBAgAABAgQIECBAgAABAgQI5BUQrMsrJj0BAgQIECBAgAABAgQIECBAgACBggQE6wqClS0BAgQIECBAgAABAgQIECBAgACBvAKCdXnFpCdAgAABAgQIECBAgAABAgQIECBQkIBgXUGwsiVAgAABAgQIECBAgAABAgQIECCQV0CwLq+Y9AQIECBAgAABAgQIECBAgAABAgQKEhCsKwhWtgQIECBAgAABAgQIECBAgAABAgTyCgjW5RWTngABAgQIECBAgAABAgQIECBAgEBBAoJ1BcHKlgABAgQIECBAgAABAgQIECBAgEBeAcG6vGLSEyBAgAABAgQIECBAgAABAgQIEChIQLCuIFjZEiBAgAABAgQIECBAgAABAgQIEMgrIFiXV0x6AgQIECBAgAABAgQIECBAgAABAgUJCNYVBCtbAgQIECBAgAABAgQIECBAgAABAnkFBOvyiklPgAABAgQIECBAgAABAgQIECBAoCABwbqCYGVLgAABAgQIECBAgAABAgQIECBAIK+AYF1eMekJECBAgAABAgQIECBAgAABAgQIFCQgWFcQrGwJECBAgAABAgQIECBAgAABAgQI5BUQrMsrJj0BAgQIECBAgAABAgQIECBAgACBggQE6wqClS0BAgQIECBAgAABAgQIECBAgACBvAKCdXnFpCdAgAABAgQIECBAgAABAgQIECBQkIBgXUGwsiVAgAABAgQIECBAgAABAgQIECCQV0CwLq+Y9AQIECBAgAABAgQIECBAgAABAgQKEhCsKwhWtgQIECBAgAABAgQIECBAgAABAgTyCgjW5RWTngABAgQIECBAgAABAgQIECBAgEBBAoJ1BcHKlgABAgQIECBAgAABAgQIECBAgEBeAcG6vGLSEyBAgAABAgQIECBAgAABAgQIEChIQLCuIFjZEiBAgAABAgQIECBAgAABAgQIEMgrIFiXV0x6AgQIECBAgAABAgQIECBAgAABAgUJCNYVBCtbAgQIECBAgAABAgQIECBAgAABAnkFBOvyiklPgAABAgQIECBAgAABAgQIECBAoCABwbqCYGVLgAABAgQIECBAgAABAgQIECBAIK+AYF1eMekJECBAgAABAgQIECBAgAABAgQIFCQgWFcQrGwJECBAgAABAgQIECBAgAABAgQI5BUQrMsrJj0BAgQIECBAgAABAgQIECBAgACBggQE6wqClS0BAgQIECBAgAABAgQIECBAgACBvAKCdXnFpCdAgAABAgQIECBAgAABAgQIECBQkIBgXUGwsiVAgAABAgQIECBAgAABAgQIECCQV0CwLq+Y9AQIECBAgAABAgQIECBAgAABAgQKEhCsKwhWtgQIECBAgAABAgQIECBAgAABAgTyCgjW5RWTngABAgQIECBAgAABAgQIECBAgEBBAoJ1BcHKlgABAgQIECBAgAABAgQIECBAgEBeAcG6vGLSEyBAgAABAgQIECBAgAABAgQIEChIQLCuIFjZEiBAgAABAgQIECBAgAABAgQIEMgrIFiXV0x6AgQIECBAgAABAgQIECBAgAABAgUJCNYVBCtbAgQIECBAgAABAgQIECBAgAABAnkFBOvyiklPgAABAgQIECBAgAABAgQIECBAoCCBHgXlW1PZLliwIE2ZMiXdcMMNac6cOWmbbbZJ48ePT3379q2peigsAQIECBAgQIAAAQIECBAgQIBAbQvoWfdx+5155plp3Lhx6eGHH07vvPNOOv7449Oee+6ZPvzww9puXaUnQIAAAQIECBAgQIAAAQIECBCoKYGGD9Y9+OCD6fTTT0+nnHJK+vvf/55+//vfp1tuuSX99a9/TZMnT66pxlRYAgQIECBAgAABAgQIECBAgACB2hZo+GDdlVdemZZbbrmsN12pKbfbbru09tprp6uvvrq0y08CBAgQIECAAAECBAgQIECAAAEChQs0/Jh1TzzxRNp8881Tv379WmAPGzYs6123cOHC1K1btxavxcaECRPS66+/3rS/fP2ZZ55JL7zwQho0aFDT6+Urb7zxRnr66aezXSNHjkw9e/Ysf7lpPcr21ltvpRVXXDENHTq0aX/5SjyqG4/vxrLeeuulFVZYofzlpvXnn38+vfjii6lXr15pk002adpfuRI9DT/66KOs7MrPv/L9YbvjAn5/m61cf5otXP+bLfz9araItc78+9syZ1sdEehMf9f/ZnHX/2YL1/9mC9f/Zgtr+QW8f1qa+fvV7FELf3+32GKL5gIvZq3hg3WPP/54Gj58eCum9ddfP/3pT3/KAnIrr7xyq9dvvPHGFDcgbS3xx/jtt99u66Vs39y5c5uO3XjjjdtNN3v27PTKK6+k+fPntxusi9dK5Rg8eHC7wboI+kW6Pn36LDJYFwG9uAD279+/3XIpfzNNo/gfeeSRadasWVmwd/To0c0AFWv33ntvmjdvXhoyZEiK92NbS7yvZ8yYkb00ZsyYdoPV06dPT/G7NGDAgLTBBhu0lVX64IMP0n333Ze9NmLEiLTSSiu1mW7mzJnLvPx+f5ubwvWn2cL1s9miUa6fy/r9P2nSpFTr18+uKL/7n+bfTX+/mi2W9e9vnJl/Y/jHtbq0uH8uSaQWf7+a97Zcc//Q0sPfr2aPWrh+CtY1t9di16IH3GabbdYqXQQIYonAQ1vLLrvskv0xLb0WQYXbb78924yecIsKdkXAbI011sjSxiO47S1Rhu7du7cbgIjj4vVSXr17924vq6w8kS561i1qGThwYFZn5U9ZkIj//94to0aNyt5n8f7ZdNNN230LRU/U+J1Za621FtmztPT+irza61m6/PLLpzfffDN7/0ev0baWCCyXer5Gb9j43WtrWWWVVZZ5+f3+NrdEtLfrz/88XP+b3xf+fjVbxFpn/f2N62qtXz+7ovyd5R9t6fofCv9bXP9LEin7wLx0z+7+3/8v5ffT7p+bf0/Kr//Ne1uuuX9o6eHvV7NHLfz9bS7t4tfi+c6F06ZNS9ErpRGXddZZJwsq3HnnnS2q/53vfCebYCKCAe0FE8oPmDp1aoqARiyXXXZZOuCAA8pftk6AAAECBAgQIECAAAECBAgQIEBgkQLxlEH73boWeWj9vLjmmmumGGOucolHRuNRvo4E6iqPtU2AAAECBAgQIECAAAECBAgQIEBgSQQaPli36667ZhMvPPbYY01+77//fvrzn/+c4lFXCwECBAgQIECAAAECBAgQIECAAIFlJdDwwbp4XDUmkDj44IOzgeqfeuqptN9++6UePXqk448/flm1g/MQIECAAAECBAgQIECAAAECBAgQSA0/G+ygQYOyXnQ777xzKs1yufrqq6ff/va3ad111/UWIUCAAAECBAgQIECAAAECBAgQILDMBBo+WBfSMX3uyy+/nB5++OEUs/GMHDmyaYbJZdYSTkSAAAECBAgQIECAAAECBAgQINDwAoJ1//8t0K1btyxI1/DvCAAECBAgQIAAAQIECBAgQIAAAQJdJtDwY9Z1mbwTEyBAgAABAgQIECBAgAABAgQIEKgQEKyrALFJgAABAgQIECBAgAABAgQIECBAoKsEBOu6St55CRAgQIAAAQIECBAgQIAAAQIECFQICNZVgNgkQIAAAQIECBAgQIAAAQIECBAg0FUCgnVdJe+8BAgQIECAAAECBAgQIECAAAECBCoEBOsqQGwSIECAAAECBAgQIECAAAECBAgQ6CoBwbqukndeAgQIECBAgAABAgQIECBAgAABAhUCgnUVIDYJECBAgAABAgQIECBAgAABAgQIdJWAYF1XyTsvAQIECBAgQIAAAQIECBAgQIAAgQoBwboKEJsECBAgQIAAAQIECBAgQIAAAQIEukpAsK6r5J2XAAECBAgQIECAAAECBAgQIECAQIWAYF0FiE0CBAgQIECAAAECBAgQIECAAAECXSUgWNdV8s5LgAABAgQIECBAgAABAgQIECBAoEJAsK4CxCYBAgQIECBAgAABAgQIECBAgACBrhIQrOsqeeclQIAAAQIECBAgQIAAAQIECBAgUCEgWFcBYpMAAQIECBAgQIAAAQIECBAgQIBAVwkI1nWVvPMSIECAAAECBAgQIECAAAECBAgQqBAQrKsAsUmAAAECBAgQIECAAAECBAgQIECgqwQE67pK3nkJECBAgAABAgQIECBAgAABAgQIVAgI1lWA2CRAgAABAgQIECBAgAABAgQIECDQVQKCdV0l77wECBAgQIAAAQIECBAgQIAAAQIEKgQE6ypAbBIgQIAAAQIECBAgQIAAAQIECBDoKoEeXXXiej7vmWeemS644IJ6rqK6ESBAgAABAgQIECBAgAABAgQIdFDgL3/5S+rTp0+HUgvWdYhp8YkGDhyYfvCDH6TJkyenxx9/PPta/FFSECBAgAABAgQIECBAgAABAgQI1LvA/PnzO1xFwboOUy064aBBg1L0qPvXv/6V3njjjUUn9ioBAkssMH369DR37ty0xhprZF9LnJEDCRAgQKAwgXnz5qVHHnkky3/YsGGpX79+hZ1LxgQIECCw5AKzZ89OM2fOTN26dUubbbbZkmfkSAIEFivQvXv3xaYpJRCsK0l00s/bbrutk3KSDQECbQmMGDEiPfbYY+nII49MJ598cltJ7CNAgACBLhZ48cUXU3yQGcvFF1+cxo4d28UlcnoCBAgQaEvgiiuuSAcccEDq3bt3uv/++9tKYh8BAl0gYIKJLkB3SgIECBAgQIAAAQIECBAgQIAAAQJtCQjWtaViHwECBAgQIECAAAECBAgQIECAAIEuEBCs6wJ0pyRAgAABAgQIECBAgAABAgQIECDQloAx69pSsY8AgaoVmDhxYnr11VfTdtttV7VlVDACBAg0ukD//v3TqaeemjEMGTKk0TnUnwABAlUrMHLkyOx63aOH0EDVNpKCNaRAt49rvXDatGkpBm23ECBAgAABAgQIECBAgAABAgQIECDQNQLTp09PHoPtGntnJUCAAAECBAgQIECAAAECBAgQINBKQLCuFYkdBAgQIECAAAECBAgQIECAAAECBLpGQLCua9ydlQABAgQIECBAgAABAgQIECBAgEArAaNItiKxgwCBZSGwYMGC9N5776UYzLZPnz4dOuVHH32UZs+enQYMGJB69uzZoWMi0bvvvpudp3fv3h0+RkICBAgQ+J/Af//73/TAAw+kXr16pfXXXz+tvfbarWhi4p+4lsfEEu0tldfiyu22jnvzzTdT/L1YaaWV2nrZPgIECDS0wAcffJDmzZu3SIO+ffum5ZZbrkP3w0t6r73IAniRAIElEtCzbonYHESAwNIKnH/++dk/daNHj+5wVjNmzEgDBw5Md999d4ePiYQbbrhh+va3v50dEzc1d9xxR3rllVdy5SExAQIEGk3gvvvuS0OHDk0xm+vuu++edtppp7TOOuuknXfeOT377LMtOOI6+3//938t9lVuRJDvuOOOa9pdfm1u2lmxcthhh6WvfvWrFXttEiBAgEAInHjiidn9dHxQ0t7Xvffem2F15Jq7pPfaWoMAgc4X0LOu803lSIBABwQuueSSrJfGo48+mh588MG06aabduCopU/y0ksvpW233TZdeuml6cADD1z6DOVAgACBOhS46aab0t57753WWmutdN1116UxY8ak6GF38803p1/96ldp3Lhx6f77708rrLBCh2u/7777pjwf0HQ4YwkJECDQ4ALnnntu9hRJWwyf/vSn29ptHwECVS4gWFflDaR4BOpR4OGHH05Tp05NkyZNSieddFK6/PLLl1mwrh491YkAAQKdKRA9kKM38qBBg7Jr9Sc/+cks+8GDB6exY8em+MfviCOOSJMnT06nnHJKh0/905/+tMNpJSRAgACB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ngQIECBAgACBZSgQgbq5c+em/v37Z2eNoF0EAO+4444WpXjvvffSgw8+mF555ZUsQOcD5BY8NggQIECAAIEGE4hgncdgG6zRVZcAAQIECBAgUJTAhRdemLbffvt03333pZ49ezYF6h599NEUPe622mqrVqfu27dvGjt2bIrHYQXqWvHYQYAAAQIECDSggNlgG7DRVZkAAQIECBAgUIRABNui59xBBx2UjjjiiLTllltms8Ceeuqp2Th0EydOLOK08iRAgAABAgQI1JWAYF1dNafKECBAgAABAgS6TiB6zl111VXpF7/4RTapxIcffpj1sBs1alSK8eliFlgLAQIECBAgQIDAogWMWbdoH68SIECAAAECBAgsgcC7776bYgKK4cOHp969ey9BDg4hQIAAAQIECDSeQIxZp2dd47W7GhMgQIAAAQIEChf4xCc+kUaOHFn4eZyAAAECBAgQIFBvAiaYqLcWVR8CBAgQIECAAAECBAgQIECAAIGaFRCsq9mmU3ACBAgQIECAAAECBAgQIECAAIF6ExCsq7cWVR8CBAgQIECAAAECBAgQIECAAIGaFRCsq9mmU3ACBAgQIECAAAECBAgQIECAAIF6ExCsq7cWVR8CBAgQIECAAAECBAgQIECAAIGaFRCsq9mmU3ACBAgQIECAAAECBAgQIECAAIF6ExCsq7cWVR8CBAgQIECAAAECBAgQIECAAIGaFRCsq9mmU3ACBAgQIECAAAECBAgQIECAAIF6E+gRFXr66afrrV7qQ4AAAQIECBAgQIAAAQIECBAgQKCmBCJG1+3jEi+sqVIrLAECBAgQIECAAAECBAgQIECAAIE6Ffh/Sg8h0AyDUekAAAAASUVORK5CYII=)
Dummy Coding
# All features selected for dummification must be character or factor columns. Also decided to remove
# said selected columns after they have been dummified to conserve space and boost future correlation
# performance.
combi <- dummy_cols(combi,
select_columns = c("Age", "Sex", "Embarked", "Title", "SocioEconomic"),
remove_selected_columns = TRUE)
glimpse(combi, width = 105)
Rows: 1,309
Columns: 48
$ PassengerId <dbl> 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22…
$ Survived <dbl> 0, 1, 1, 1, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 1, 0, 1, 0, 1, 0, 1, 1, 1, 0, 1,…
$ Pclass <dbl> 3, 1, 3, 1, 3, 3, 1, 3, 3, 2, 3, 1, 3, 3, 3, 2, 3, 2, 3, 3, 2, 2, 3, 1, 3, 3,…
$ Name <chr> "Braund, Mr. Owen Harris", "Cumings, Mrs. John Bradley (Florence Briggs Thaye…
$ SibSp <dbl> 1, 1, 0, 1, 0, 0, 0, 3, 0, 1, 1, 0, 0, 1, 0, 0, 4, 0, 1, 0, 0, 0, 0, 0, 3, 1,…
$ Parch <dbl> 0, 0, 0, 0, 0, 0, 0, 1, 2, 0, 1, 0, 0, 5, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 5,…
$ Ticket <chr> "A/5 21171", "PC 17599", "STON/O2. 3101282", "113803", "373450", "330877", "1…
$ Fare <dbl> 7.2500, 71.2833, 7.9250, 53.1000, 8.0500, 8.4583, 51.8625, 21.0750, 11.1333, …
$ Cabin <chr> NA, "C85", NA, "C123", NA, NA, "E46", NA, NA, NA, "G6", "C103", NA, NA, NA, N…
$ Surname <chr> "Braund", "Cumings", "Heikkinen", "Futrelle", "Allen", "Moran", "McCarthy", "…
$ FamilySize <dbl> 2, 2, 1, 2, 1, 1, 1, 5, 3, 2, 3, 1, 1, 7, 1, 1, 6, 1, 2, 1, 1, 1, 1, 1, 5, 7,…
$ FamilyOnBoard <dbl> 1, 1, 0, 1, 0, 0, 0, 1, 1, 1, 1, 0, 0, 1, 0, 0, 1, 0, 1, 0, 0, 0, 0, 0, 1, 1,…
$ CabinLetter <fct> NA, C, NA, C, NA, NA, E, NA, NA, NA, G, C, NA, NA, NA, NA, NA, NA, NA, NA, NA…
$ HasCabin <dbl> 0, 1, 0, 1, 0, 0, 1, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 0,…
$ Age_Adult <int> 1, 1, 1, 1, 1, 1, 0, 0, 1, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 1, 1, 1, 0, 1, 0, 1,…
$ Age_Child <int> 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 0, 1, 0, 1, 0,…
$ Age_Elder <int> 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,…
$ Sex_female <int> 0, 1, 1, 1, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 0, 1, 1,…
$ Sex_male <int> 1, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 1, 1, 0, 1, 0, 0,…
$ Embarked_C <int> 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0,…
$ Embarked_Q <int> 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0,…
$ Embarked_S <int> 1, 0, 1, 1, 1, 0, 1, 1, 1, 0, 1, 1, 1, 1, 1, 1, 0, 1, 1, 0, 1, 1, 0, 1, 1, 1,…
$ Title_Col <int> 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,…
$ Title_Dr <int> 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,…
$ Title_Lady <int> 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,…
$ Title_Master <int> 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0,…
$ Title_Miss <int> 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0,…
$ Title_Mlle <int> 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,…
$ Title_Mr <int> 1, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 1, 0, 0, 1, 1, 0, 1, 0, 0,…
$ Title_Mrs <int> 0, 1, 0, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1,…
$ Title_Ms <int> 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,…
$ Title_Rev <int> 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,…
$ Title_Sir <int> 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,…
$ SocioEconomic_1A <int> 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0,…
$ SocioEconomic_1B <int> 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,…
$ SocioEconomic_1C <int> 0, 1, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,…
$ SocioEconomic_1D <int> 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,…
$ SocioEconomic_1E <int> 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,…
$ SocioEconomic_1T <int> 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,…
$ SocioEconomic_1X <int> 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,…
$ SocioEconomic_2D <int> 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0,…
$ SocioEconomic_2E <int> 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,…
$ SocioEconomic_2F <int> 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,…
$ SocioEconomic_2X <int> 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0,…
$ SocioEconomic_3E <int> 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,…
$ SocioEconomic_3F <int> 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,…
$ SocioEconomic_3G <int> 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,…
$ SocioEconomic_3X <int> 1, 0, 1, 0, 1, 1, 0, 1, 1, 0, 0, 0, 1, 1, 1, 0, 1, 0, 1, 1, 0, 0, 1, 0, 1, 1,…
---
title: "Titanic Survivor Analysis"
output: html_notebook
---

## Library Includes

```{r message=FALSE}
library(tidyverse)      # General utility packages
library(party)          # Random Forest conditional inference tree utilization
library(missForest)     # Imputation (for both factor and numeric)
library(cowplot)        # Plotting ggplot's side by side
library(corrplot)       # Visual correlation plotting
library(fastDummies)    # Used for dummy coding
library(caret)          # Used for k-fold cross validation
library(ggthemes)       # Provides extra themes for styling ggplots.
```

## Data Loading

```{r message=FALSE}
train <- read_csv("data/train.csv") # Returns tibble
test <- read_csv("data/test.csv")   # Returns tibble
test$Survived <- NA
combi <- rbind(train, test)
```

## Utility Functions

```{r}
createSubmission <- function(submissionName = "submit.csv", prediction) {
  submit <- data.frame(PassengerId = test$PassengerId, Survived = prediction)
  write_csv(submit, submissionName)
}
```

## Feature Eng. (Categorical / Factors)

```{r}
# Creating a new Title feature by parsing it using a regular expression.
combi$Title <- sapply(combi$Name, FUN = function(x) { strsplit(x, split = "[,.]")[[1]][2]})
combi$Title <- sub(' ', '', combi$Title)

# Combining some rare Title values to simplify our factor counts.
combi$Title[combi$Title %in% c("Mme", "Mlle")] <- "Mlle"
combi$Title[combi$Title %in% c("Capt", "Don", "Major", "Sir")] <- "Sir"
combi$Title[combi$Title %in% c("Dona", "Lady", "the Countess", "Jonkheer")] <- "Lady"
combi$Title <- factor(combi$Title)

# Creating a new Surname feature by parsing it using a regular expression.
combi$Surname <- sapply(combi$Name, FUN = function(x) { strsplit(x, split = "[,.]")[[1]][1]})

# Creating a new FamilySize feature including self, parents, siblings, spouse, and children.
combi$FamilySize <- combi$SibSp + combi$Parch + 1

# Creating simple flag indicating whether person has any family on board.
combi$FamilyOnBoard <- ifelse(combi$SibSp + combi$Parch > 0, 1, 0)

# Creating a new CabinLetter feature by parsing it using a regular expression.
combi$CabinLetter <- sapply(combi$Cabin, 
                            FUN = function(x) { ifelse(is.na(x), NA_character_, substr(x, 1, 1)) })
combi$CabinLetter <- factor(combi$CabinLetter)

# Keeping track of whether an observation had a Cabin noted at all
combi$HasCabin <- ifelse(is.na(combi$Cabin), 0, 1)

# Creating socioeconomic feature
combi$SocioEconomic <- ifelse(
  is.na(combi$CabinLetter), 
  paste(combi$Pclass, "X", sep=""),
  paste(combi$Pclass, combi$CabinLetter, sep=""))
```

## Feature Eng. (Continuous)

#### Normalization (Standardization)

#### Binning (Discretization)

```{r}
# Binning Age into 3 factor bins (so that future imputation picks a factor before conversion).
combi$Age <- sapply(combi$Age, 
                    FUN = function(x) { 
                      if (is.na(x)) NA
                      else if (x < 18) "Child"
                      else if (x >= 18 & x < 50) "Adult"
                      else "Elder"
                    })
```

```{r}
ggplot(combi) +
  aes(x = Age) +
  geom_bar(width = 0.2,
           stat = "count") +
  theme_clean(base_size = 10) +
  labs(x = "Age", y = "Frequency")
```

## Data Imputation & Cleanup

```{r}
# In order to leverage missForest for imputation, it only supports consuming / predicting factor 
# and numeric data types so all applicable passed-in features should be in one of those two formats.
combi$Age <- as.factor(combi$Age)
combi$Sex <- as.factor(combi$Sex)
combi$Embarked <- as.factor(combi$Embarked)
combi$SocioEconomic <- as.factor(combi$SocioEconomic)
glimpse(combi, width = 105)
```

```{r paged.print=FALSE}
# Examining how many NA's and blanks our dataset has.
sapply(combi, function(x) sum(is.na(x) | x == "")) %>%
  as.data.frame()
```

```{r}
# Imputation Step: excluding irrelevant / unsupported data type features, plus casting to dataframe 
# for missForest.
set.seed(420)
combi.imp <- combi %>%
  select(-c("Survived", "Name", "Ticket", "Surname", "Cabin", "CabinLetter")) %>%
  as.data.frame() %>%
  missForest()
```

```{r}
# Observing results + error rates for imputation (~4.72% for numeric, and ~9.82% for factors).
combi.imp$OOBerror
```

```{r}
# Merging imputed features back into "combi".
combi$Age <- combi.imp$ximp$Age
combi$Fare <- combi.imp$ximp$Fare
combi$Embarked <- combi.imp$ximp$Embarked
```

```{r paged.print=FALSE}
# Examining how many NA's and blanks our dataset has.
sapply(combi, function(x) sum(is.na(x) | x == "")) %>%
  as.data.frame()
```

```{r}
ggplot(combi) +
  aes(x = Age) +
  geom_bar(width = 0.2,
           stat = "count") +
  theme_clean(base_size = 10) +
  labs(x = "Age", y = "Frequency")
```

## Dimensional Reduction

#### Feature Selection

#### Feature Extraction

## Dummy Coding

```{r}
# All features selected for dummification must be character or factor columns. Also decided to remove 
# said selected columns after they have been dummified to conserve space and boost future correlation
# performance.
combi <- dummy_cols(combi, 
                    select_columns = c("Age", "Sex", "Embarked", "Title", "SocioEconomic"),
                    remove_selected_columns = TRUE)
```

```{r}
glimpse(combi, width = 105)
```

## Data Splitting & Sampling

```{r}
train <- combi[1:891,]
test <- combi[892:1309,]
```

## Feature Correlation Analysis

```{r fig.height=7, fig.width=7}
# Examine correlations between dependent Survived feature and independent input features. Excluding
# specific features.
trainCor <- cor(
  train %>%
    select(-PassengerId, -Name, -Ticket, -Cabin, -Surname, -CabinLetter)
)
corrplot(trainCor, type = "upper")
```

```{r}
# Examining frequency distribution for all dummy coding values to get a sense of which features
# have the widest usage.
trainDummies <- train[sapply(train, is.numeric)] %>%
  colSums(na.rm = TRUE) %>%
  t() %>%
  data.frame() %>%
  select(contains("_")) %>%
  t() %>%
  data.frame()
```

```{r}
# Moving the row names into a new column, and updating the row names to simply be numbers.
trainDummies <- cbind(DummyCode = rownames(trainDummies), trainDummies)
rownames(trainDummies) <- 1:nrow(trainDummies)
```

```{r}
# Plotting the dummy-coded features from most to least used.
ggplot(trainDummies) +
  aes(x = reorder(DummyCode,.), weight = .) +
  geom_bar() +
  coord_flip() +
  theme_clean(base_size = 10) +
  labs(x = "Dummy Code", y = "Frequency")
```

## Model Creation & Tuning

```{r}
#Defining our repeated k-fold cross validation to split into c chunks, and cycle process t times.
train_control <- trainControl(method = "repeatedcv", number = 5, repeats = 3)
survivalModel <- train(as.factor(Survived) ~ 
                         FamilyOnBoard + 
                         Title_Miss + 
                         Sex_female + 
                         Title_Mrs + 
                         Fare + 
                         HasCabin + 
                         Embarked_C +
                         Title_Mr + 
                         Sex_male + 
                         Age_Child +
                         Pclass + 
                         Embarked_S + 
                         Age_Adult +
                         Title_Master +
                         SocioEconomic_3X,
                       data = train,
                       method = "cforest",
                       trControl = train_control,
                       controls = party::cforest_unbiased(ntree = 1000))
```

## Model Scoring & Prediction

```{r}
# Examining the model scoring after cross validation (uses portions of the train set as validation).
survivalModel
```

```{r}
# Make predictions based on resulting trained model.
predictions <- predict(survivalModel, newdata = test, OOB = TRUE, type = "raw")

# Creating submission.
createSubmission("submit.csv", predictions)
```
