-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathcomplexity_analysis_CCLAMP_Gender.R
181 lines (131 loc) · 5.81 KB
/
complexity_analysis_CCLAMP_Gender.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
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
setwd("./Datasets")
library(readxl)
library(ggplot2)
library(matrixStats)
library(effects)
library(ggplot2)
#### Morphology ####
# read data
morph_data <- read_xlsx("zipped_morphology_CCLAMP.xlsx", col_names = TRUE)
zipped <- read_xlsx("CCLAMP_Zipped_Sizes.xlsx", col_names = TRUE)
# merge data
morph_total <- merge(zipped, morph_data, by="...1")
# make all numbers negative
morph_total[,7:106] <- morph_total[,7:106]*(-1)
# divide by full zipped size to get complexity ratio
morph_total[,7:106] <- morph_total[,7:106]/morph_total[,5]
# get means for each row = get mean complexity ratio
morph_means <- rowMeans(morph_total[,7:106])
# add mean complexity ratios to data frame
morph_total$morph_means <- morph_means
# get standard deviations
morph_std = rowSds(as.matrix(morph_total[,7:106]))
#### Syntax ####
# read data
synt_data <- read_xlsx("zipped_syntax_CCLAMP.xlsx", col_names = TRUE)
# merge data
synt_total <- merge(zipped, synt_data, by="...1")
# divide by full zipped size to get complexity ratio
synt_total[,7:106] <- synt_total[,7:106]/synt_total[,5]
# get means for each row = get mean complexity ratio
synt_means <- rowMeans(synt_total[,7:106])
# add mean complexity ratios to data frame
synt_total$synt_means <- synt_means
# get standard deviations
synt_std = rowSds(as.matrix(synt_total[,7:106]))
#### Morphology vs syntax ####
morph_and_synt <- data.frame("Morphology" = morph_total$morph_means,
"filename" = synt_total$filename,
"Syntax" = synt_total$synt_means,
"Year" = synt_total$year)
#### Gender ####
# read metadata file
metadata <- read.delim("C-CLAMP_metadata_gender.txt", header = FALSE, sep = "\t", fill = FALSE)
names(metadata)[names(metadata) == 'V1'] <- 'filename'
names(metadata)[names(metadata) == 'V4'] <- 'Author'
names(metadata)[names(metadata) == 'V10'] <- 'Gender'
names(morph_and_synt)[names(morph_and_synt) == 'synt_total.filename'] <- 'filename'
# merge data
meta_morph_and_synt <- merge(metadata, morph_and_synt, by="filename")
meta_morph_and_synt<-subset(meta_morph_and_synt, Gender!="mixed" & Gender!="NA")
meta_morph_and_synt$Gender <- as.factor(meta_morph_and_synt$Gender)
meta_morph_and_synt$Decade <- meta_morph_and_synt$Year - meta_morph_and_synt$Year %% 10 # calculate decades
# distribution of authors in dataset
author_table <- table(meta_morph_and_synt$Author)
print(author_table)
# distribution of gender in dataset
gender_table <- table(meta_morph_and_synt$Decade, meta_morph_and_synt$Gender)
print(gender_table)
plot(gender_table, col=rep(2:1), main = "Gender per decade", las=2, border = 0, cex.axis=1)
# take subset of data from 1870 to 1930
#meta_morph_and_synt <- subset(meta_morph_and_synt, Decade >= 1870 & Decade <= 1930)
#meta_morph_and_synt <- subset(meta_morph_and_synt, Decade >= 1840)
# model: morphology
morph_gender_model <- lm(Morphology ~ Gender, data=meta_morph_and_synt)
summary(morph_gender_model)
plot(allEffects(morph_gender_model))
print(ggplot(meta_morph_and_synt,
aes(x = Gender, y = Morphology))+
ggtitle("") +
xlab("Gender")+
ylab("Mean morphological complexity ratio")+
geom_boxplot())
decade_morph_gender_model <- lm(Morphology ~ Gender*Decade, data=meta_morph_and_synt)
summary(decade_morph_gender_model)
plot(allEffects(decade_morph_gender_model))
# model: syntax
synt_gender_model <- lm(Syntax ~ Gender, data=meta_morph_and_synt)
summary(synt_gender_model)
plot(allEffects(synt_gender_model))
print(ggplot(meta_morph_and_synt,
aes(x = Gender, y = Syntax))+
ggtitle("") +
xlab("Gender")+
ylab("Mean word order rigidity ratio")+
geom_boxplot())
decade_synt_gender_model <- lm(Syntax ~ Gender*Decade, data=meta_morph_and_synt)
summary(decade_synt_gender_model)
plot(allEffects(decade_synt_gender_model))
# model: manova
# check whether there is an association of the aggregate of the linguistic measures with gender
manova.model <- manova(cbind(Morphology, Syntax) ~ Gender, data=meta_morph_and_synt)
summary(manova.model)
# Visualisation
print(ggplot(meta_morph_and_synt, aes(x=Decade, y=Morphology, color=Gender)) +
geom_smooth())
print(ggplot(meta_morph_and_synt, aes(x=Decade, y=Syntax, color=Gender)) +
geom_smooth())
#### Granger Causality ####
library(lmtest)
library(CADFtest)
library(dplyr)
# make time series: morphology male
morph_male_ts <- ts((meta_morph_and_synt %>%
filter(Gender == "male") %>%
group_by(Decade) %>%
summarise(Morphology = mean(Morphology)))[, 2])
CADFtest(morph_male_ts) # not significant: no unit root
# make time series: morphology female
morph_female_ts <- ts((meta_morph_and_synt %>%
filter(Gender == "female") %>%
group_by(Decade) %>%
summarise(Morphology = mean(Morphology)))[, 2])
CADFtest(morph_female_ts) # not significant: no unit root
# granger causality test
grangertest(morph_female_ts ~ morph_male_ts, order = 1) # not significant
grangertest(morph_male_ts ~ morph_female_ts, order = 1) # not significant
# make time series: syntax male
synt_male_ts <- ts((meta_morph_and_synt %>%
filter(Gender == "male") %>%
group_by(Decade) %>%
summarise(Syntax = mean(Syntax)))[, 2])
CADFtest(synt_male_ts) # not significant: no unit root
# make time series: syntax female
synt_female_ts <- ts((meta_morph_and_synt %>%
filter(Gender == "female") %>%
group_by(Decade) %>%
summarise(Syntax = mean(Syntax)))[, 2])
CADFtest(synt_female_ts) # not significant: no unit root
# granger causality test
grangertest(synt_female_ts ~ synt_male_ts, order = 1) # not significant
grangertest(synt_male_ts ~ synt_female_ts, order = 1) # not significant