forked from jdwor/gendercitation
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathStep8_PrepReferenceLists.R
87 lines (73 loc) · 3.8 KB
/
Step8_PrepReferenceLists.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
setwd("/Users/erteich/Desktop/gendercitation") # Change to your project folder path
source("HelperFunctions.R")
library(pbmcapply);library(mgcv)
library(textclean); library(stringr)
# Load in article dataset from step 7
load("df7_articledata_withgenders.RData")
# Clean up reference list column (may take a little while)
Encoding(article.data$CR)="latin1"
article.data$CR=replace_non_ascii(article.data$CR)
article.data$CR=tolower(article.data$CR)
# Save number of cores on machine
cores=detectCores()
# Get indices of cited papers within reference lists
cited.papers=pbmclapply(1:nrow(article.data),get.cited.indices,
DI=article.data$DI,CR=article.data$CR,
mc.cores=cores)
# Isolate author information
all_auth_names=lapply(article.data$AF,authsplit)
first_auths=unlist(lapply(all_auth_names,head,1))
last_auths=unlist(lapply(all_auth_names,tail,1))
# Find potential self-citations
self.authored=pbmclapply(1:length(first_auths),get.self.cites,
first_auths,last_auths,mc.cores=cores)
# Get variables for article gender model
num_papers=unlist(lapply(self.authored,str_count, ", "))+1
log_seniority=log(num_papers)
review=article.data$DT=="REVIEW"
log_teamsize=log(lengths(all_auth_names))
journal=article.data$SO
table(is.na(article.data$PD)) # do you have missing months? if so, consider filling them in with July so they don't get dropped
# article.data$PD[is.na(article.data$PD)] = 6
month_from_base=(article.data$PY-min(article.data$PY))+(article.data$PD/12)
gender_cat=unlist(pbmclapply(article.data$AG,transform.cat,mc.cores=cores))
# Create new variables in article.data for new measures
article.data$LS=log_seniority
article.data$LT=log_teamsize
article.data$MB=month_from_base
article.data$GC=gender_cat
article.data$CP=unlist(cited.papers)
article.data$SA=unlist(self.authored)
# Get unconditional gender proportions of citable papers (random draw model)
# I.e., proportions for each gender category among all papers
# published before a given paper
unique_months=unique(month_from_base)
uncond_expecs=pbmclapply(unique_months,get.uncond.exp,
gender_cat,month_from_base,mc.cores=cores)
uncond_expecs=pbmclapply(month_from_base,match.uncond.exp,
uncond_expecs,unique_months,mc.cores=cores)
uncond_expecs=do.call(rbind,uncond_expecs)
# Run GAM for predicted gender categories given relevant article characteristics
# To be used for estimating expected conditional citation proportions in step 9
# Note: Some settings on the GAM should be checked manually (e.g., spline DFs)
# See the documentation by running "?gam"
# genderGAM=gam(list(gender_cat~s(month_from_base)+s(log_seniority)+
# s(log_teamsize)+journal+review,
# ~s(month_from_base)+s(log_seniority)+
# s(log_teamsize)+journal+review,
# ~s(month_from_base)+s(log_seniority)+
# s(log_teamsize)+journal+review),family=multinom(K=3))
# cond_expecs=predict(genderGAM,newdata=data.frame(month_from_base=month_from_base,
# log_seniority=log_seniority,log_teamsize=log_teamsize,
# journal=journal,review=review),type="response")
genderGAM=gam(list(gender_cat~s(month_from_base)+s(log_seniority)+
s(log_teamsize),
~s(month_from_base)+s(log_seniority)+
s(log_teamsize),
~s(month_from_base)+s(log_seniority)+
s(log_teamsize)),family=multinom(K=3))
cond_expecs=predict(genderGAM,newdata=data.frame(month_from_base=month_from_base,
log_seniority=log_seniority,log_teamsize=log_teamsize),type="response")
# Save article data and citation expectation data
save(article.data,uncond_expecs,cond_expecs,
file="df8_articledata_expecdata.RData")