-
Notifications
You must be signed in to change notification settings - Fork 57
/
Copy pathR4Eco201707.Rmd
1161 lines (827 loc) · 29.2 KB
/
R4Eco201707.Rmd
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
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
689
690
691
692
693
694
695
696
697
698
699
700
701
702
703
704
705
706
707
708
709
710
711
712
713
714
715
716
717
718
719
720
721
722
723
724
725
726
727
728
729
730
731
732
733
734
735
736
737
738
739
740
741
742
743
744
745
746
747
748
749
750
751
752
753
754
755
756
757
758
759
760
761
762
763
764
765
766
767
768
769
770
771
772
773
774
775
776
777
778
779
780
781
782
783
784
785
786
787
788
789
790
791
792
793
794
795
796
797
798
799
800
801
802
803
804
805
806
807
808
809
810
811
812
813
814
815
816
817
818
819
820
821
822
823
824
825
826
827
828
829
830
831
832
833
834
835
836
837
838
839
840
841
842
843
844
845
846
847
848
849
850
851
852
853
854
855
856
857
858
859
860
861
862
863
864
865
866
867
868
869
870
871
872
873
874
875
876
877
878
879
880
881
882
883
884
885
886
887
888
889
890
891
892
893
894
895
896
897
898
899
900
901
902
903
904
905
906
907
908
909
910
911
912
913
914
915
916
917
918
919
920
921
922
923
924
925
926
927
928
929
930
931
932
933
934
935
936
937
938
939
940
941
942
943
944
945
946
947
948
949
950
951
952
953
954
955
956
957
958
959
960
961
962
963
964
965
966
967
968
969
970
971
972
973
974
975
976
977
978
979
980
981
982
983
984
985
986
987
988
989
990
991
992
993
994
995
996
997
998
999
1000
---
title: "R语言在经济学中的应用"
subtitle: ""
author: "南开大学周恩来政府管理学院 吕小康"
date: "`r Sys.Date()`"
output:
xaringan::moon_reader:
css: zh-CN.css
lib_dir: libs
nature:
highlightStyle: github
highlightLines: true
countIncrementalSlides: false
---
# R简介
### R是一个免费自由且跨平台通用的统计计算与绘图软件。
- 它有Windows、Mac、Linux等版本,均可免费下载使用。
### 从[R主页](https://www.r-project.org/)中选择[download R](https://cran.r-project.org/mirrors.html)链接可下载到对应操作系统的R安装程序。
- 打开链接后的网页会提示选择相应的[CRAN](https://cran.r-project.org/mirrors.html)镜像站。目前全球有超过一百个CRAN镜像站 ,用户可选择就近下载。
---
# R与STATA等统计软件的区别
### R为开源免费的软件,其他基本为商业付费软件。
- 如果你有钱,可以只选贵的、不选对的;但如果你没钱……
### R是一种脚本语言,强调英文命令操作。
- R的学习比较费时、对汉字编码不友好,但掌握之后的自由性更强
### R在数据可视化上的表现更佳,选择更丰富。
- R的统计绘图是它最有标志性的功能,可以制作达到出版的各种图形
---
# R在经济学中的综合应用
R及与之相关的配套开源软件(如RStudio)已构成一个丰富的数据分析网络生态,具有同类软件很难同时满足的多种可能性。
### 用于课程教学
### 用于数据获取与预处理
### 用于数据的计量分析
### 用于数据可视化
### 用于撰写学术报告
……
---
# R 已可方便导入各类型的数据
利用[Hadley](http://hadley.nz/)等人开发的诸多R包,已可方便导入各种类型的数据,这为R成为一种“兼容并蓄”的统计分析软件奠定了重要基础。
### readxl包: xls or xlsx
```r
library(readxl)
read_excel("file.xlsx")
```
### rvest包:在线文本
### data.table包:导入大数据文件(> 100 G)
---
# R 已可方便导入各类型的数据
### Haven包: SAS, SPSS, STATA
```r
# SAS
read_sas("mtcars.sas7bdat")
write_sas(mtcars, "mtcars.sas7bdat")
# SPSS
read_sav("mtcars.sav")
write_sav(mtcars, "mtcars.sav")
# Stata
read_dta("mtcars.dta")
write_dta(mtcars, "mtcars.dta")
```
利用R,几乎可以分析类型任何类型的数据,而避免在各类统计软件之间相互转化和跟踪。
---
# 作为课堂教学的辅助软件
可以作为两门经济学基础课程的教学辅助软件
- 《概率论与数理统计》
- 《计量经济学》
我本人在清华大学出版社2017年出版的[《R语言统计学基础》](https://www.amazon.cn/%E6%95%B0%E9%87%8F%E7%BB%8F%E6%B5%8E%E5%AD%A6%E7%B3%BB%E5%88%97%E4%B8%9B%E4%B9%A6-R%E8%AF%AD%E8%A8%80%E7%BB%9F%E8%AE%A1%E5%AD%A6%E5%9F%BA%E7%A1%80-%E5%90%95%E5%B0%8F%E5%BA%B7/dp/B06XGR6LJZ/ref=sr_1_1?ie=UTF8&qid=1490843285&sr=8-1&keywords=%E5%90%95%E5%B0%8F%E5%BA%B7),内容差不多覆盖经济学类入门概率论与数理统计的教学要求,全程使用R作为分析和绘图软件。
<img src="https://images-cn.ssl-images-amazon.com/images/I/61wcEf4ElmL.jpg" height="300px" width="300px" />
---
## 概率论与数理统计的课程教学
这里以抽样分布的教学设计为例进行说明。
#### 抽样分布(sampling distribution)的基础知识
#### 标准定义
- 抽样分布是样本统计量的分布。这显然精确而“无用”,即不能帮助人真正理解什么是抽样分布。
- 实质是重复抽样的假想前提下形成的一个统计推论框架,它在现实中是不一定存在的。
---
## 抽样分布的具体解释
- 抽样分布是对同一总体,做出相同样本容量的、重复(无限) 多次的简单随机抽样取遍样本统计量的所有可能值后所体现出来的取值规律性。
- 对这一规律性,采用概率论的基本知识加以描述,即可概括为某一**分布**(distribution),也即 $F(x) = P(X \leq x)$
- 如果能够找到 $F(x)$ 的精确数学表达形式,后续的统计推论即可基于这一概念框架而得到概率意义上的精准推导。
---
## 抽样分布的教学难点
### 理论框架的“非现实性”
- 现实中的研究通常只能有一次抽样,不可能对同一总体进行反复抽样从而得到关于样本统计量的精确分布的直观感知
### 数据并非总是随机抽样获得的
- 通过随机化实验,以及通过普通的观测收集的数据,也需要进行推论统计。但此时很难直接套用基于“重复抽样”获得的抽样分布理论。
### 某些统计量的抽样分布数学推导较为困难
- 况且,能够找到精确数学形式的分布总是少见的。很多统计量本身就是很难找到精确分布,然而推论总是要做下去……
---
## 建立经验感知的方式:模拟
抽样分布的建立需要一对互相联系的概念:总体(population)与样本(sample)。
不妨以这样的思路进行教学:
--
- 先从假想的理论分布(如正态分布、二项分布、指数分布等)总体进行重复抽样,模拟某一简单样本统计量的分布,并与数学推导的结果进行对比解释;
--
- 到假想的理论分布总体进行重复抽样,模拟某一很难或无法从数学推导获得精确分布的样本统计量的抽样分布;
--
- 再到从实际的、不满足特定分布的总体进行重复抽样,模拟对应的样本统计量的分布,验证数学推导的结果是否能够应用于现实,并理解数学推导的局限性与模拟的自由性
---
## 样本均值等常见统计量的抽样分布示例
已知总体 $X \sim Exp(0.5)$,即服从某指数分布,注意该分布本身是右偏的,且是一无限总体。现从中抽取样本量为100的样本,重复10000次,每次计算如下样本统计量,再绘制这些样本统计量的的直方图,即可在一定程度上展示该些样本统计量的抽样分布形状,以便形成直观的感知。
- 样本均值(sample mean)
- 样本标准差(samlpe standard deviation)
- 样本方差(sample variance)
- 其他需要的样本统计量
---
```{r, echo = FALSE, fig.align='center'}
opar <- par(no.readonly = T)
par(mfrow = c(2, 2))
set.seed(123)
hist(
rexp(100, 0.5),
prob = T,
main = "Exponetial Distribution(lambda=0.5)",
xlab = "X",
breaks = 20,
cex.main = 0.8
)
abline(v = 2, col = "red", lwd = 3)
sample_mean <- numeric(10000)
for (i in 1:10000) {
set.seed(i)
samples <- rexp(100, 0.5)
sample_mean[i] <- mean(samples)
}
hist(
sample_mean,
prob = T,
main = "Sampling Distribution for Sample Mean",
xlab = "Sample Mean",
breaks = 30,
cex.main = 0.8
)
abline(v = 2, col = "red", lwd = 3)
sample_sd <- numeric(10000)
for (i in 1:10000) {
set.seed(i)
samples <- rexp(100, 0.5)
sample_sd[i] <- sd(samples)
}
hist(
sample_sd,
prob = T,
main = "Sampling Distribution for Sample SD ",
xlab = "Sample SD",
breaks = 30,
cex.main = 0.8
)
abline(v = 2, col = "red", lwd = 3)
sample_variance <- numeric(10000)
for (i in 1:10000) {
set.seed(i)
samples <- rexp(100, 0.5)
sample_variance[i] <- var(samples)
}
hist(
sample_variance,
prob = T,
main = "Sampling Distribution for Sample Variance",
xlab = "Sample Variance",
breaks = 30,
cex.main = 0.8
)
abline(v = 4, col = "red", lwd = 3)
par(opar)
```
左上图为给定总体的概率密度图,右上图为样本均值的抽样分布示意图;左下图为样本标准差的抽样分布示意图,右下图为样本方差的抽样分布示意图。红色虚线为虚线表示总体均值、 总体标准差和总体方差所在位置。
---
## 生成样本均值抽样分布的代码
```r
sample_mean <- numeric(10000)
for (i in 1:10000) {
set.seed(i)
samples <- rexp(100, 0.5)
sample_mean[i] <- mean(samples)
}
hist(
sample_mean,
prob = T,
main = "Sampling Distribution for Sample Mean",
xlab = "Sample Mean",
breaks = 30,
cex.main = 0.8
)
abline(v = 2, col = "red", lwd = 3)
```
其余可交由学生思考复制。
---
### 真实的观测数据:Nile 流量
`Nile`数据是`R`自带的数据,记录了尼罗河在埃及阿斯量(Ashwan) 地
区1871-1970 年这100年间的年流量值。这一数据服从什么特定的精确分布吗?--不清楚。
```{r, fig.align="center", fig.height=4, fig.width=4}
hist(Nile, breaks = 30)
abline(v = mean(Nile), col = "red", lty = 2, lwd = 3)
```
但若以它为“总体”,再从中进行简单随机抽样,然后观察某些特定统计量(如样本均值、样本方差、样本中位数)的分布,仍可获得经验感知。
---
```{r, echo=FALSE, fig.align= "center"}
opar <- par(no.readonly = T)
x <-
data.frame(
a = numeric(10000),
b = numeric(10000),
c = numeric(10000),
d = numeric(10000)
)
par(mfrow = c(2, 2))
for (i in 1:10000)
{
set.seed(i)
samples <- sample(Nile, 5)
x$a[i] <- mean(samples)
}
hist(
x$a,
xlab = "Mean flow",
main = "n=5",
probability = T,
xlim = c(600, 1200)
)
abline(
v = mean(Nile),
lwd = 3,
lty = 2,
col = "red"
)
for (i in 1:10000)
{
set.seed(i)
samples <- sample(Nile, 10)
x$b[i] <- mean(samples)
}
hist(
x$b,
xlab = "Mean flow",
main = "n=10",
probability = T,
xlim = c(600, 1200)
)
abline(
v = mean(Nile),
lwd = 3,
lty = 2,
col = "red"
)
for (i in 1:10000)
{
set.seed(i)
samples <- sample(Nile, 30)
x$c[i] <- mean(samples)
}
hist(
x$c,
xlab = "Mean flow",
main = "n=30",
probability = T,
xlim = c(600, 1200)
)
abline(
v = mean(Nile),
lwd = 3,
lty = 2,
col = "red"
)
for (i in 1:10000)
{
set.seed(i)
samples <- sample(Nile, 50)
x$d[i] <- mean(samples)
}
hist(
x$d,
xlab = "Mean flow",
main = "n=50",
probability = T,
xlim = c(600, 1200)
)
abline(
v = mean(Nile),
lwd = 3,
lty = 2,
col = "red"
)
par(opar)
```
红色虚线表示“总体”均值所在的位置。这是不是就是中心极限定理(Central Limit Theorem)告诉我们的道理呢?
---
## 部分代码示例
```r
x <-
data.frame(
a = numeric(10000),
b = numeric(10000),
c = numeric(10000),
d = numeric(10000)
)
par(mfrow = c(2, 2))
for (i in 1:10000)
{
set.seed(i)
samples <- sample(Nile, 5)
x$a[i] <- mean(samples)
}
hist(
x$a,
xlab = "Mean flow",
main = "n=5",
probability = T,
xlim = c(600, 1200)
)
abline(
v = mean(Nile),
lwd = 3,
lty = 2,
col = "red"
)
```
---
### Nile数据,其他样本统计量的抽样分布
```{r, echo=FALSE, fig.align = "center", fig.width=6, fig.height=6}
opar <- par(no.readonly = T)
x <-
data.frame(
a = numeric(10000),
b = numeric(10000),
c = numeric(10000),
d = numeric(10000)
)
par(mfrow = c(2, 2))
for (i in 1:10000)
{
set.seed(i)
samples <- sample(Nile, 30)
x$a[i] <- min(samples)
}
hist(x$a, main = "Sampling Distribution of Min", xlab = "River Flow")
abline(
v = min(Nile),
lwd = 3,
lty = 2,
col = "red"
)
for (i in 1:10000)
{
set.seed(i)
samples <- sample(Nile, 30)
x$b[i] <- max(samples)
}
hist(x$b, main = "Sampling Distribution of Max", xlab = "River Flow")
abline(
v = max(Nile),
lwd = 3,
lty = 2,
col = "red"
)
for (i in 1:10000)
{
set.seed(i)
samples <- sample(Nile, 30)
x$c[i] <- median(samples)
}
hist(x$c, main = "Sampling Distribution of Median", xlab = "River Flow")
abline(
v = median(Nile),
lwd = 3,
lty = 2,
col = "red"
)
for (i in 1:10000)
{
set.seed(i)
samples <- sample(Nile, 30)
x$d[i] <- quantile(samples, 0.25)
}
hist(x$d, main = "Sampling Distribution of First Quartile", xlab = "River Flow")
abline(
v = quantile(Nile, 0.25),
lwd = 3,
lty = 2,
col = "red"
)
par(opar)
```
样本最小值、样本最大值、样本中位数、样本第一四分位数的抽样分布示意图(样本容量为30)。红色虚线分别表示“总体”最小值、最大值、中位数和第一四分位数所在的位置。
---
### 关于代码教学的建议
教师只需在课堂讲解说明并提供一个图形的原始代码,即可要求学生仿照此代码,自行绘制其他图形,并作为作业进行布置。如此可加深学生对抽样分布形成过程的直观认识。
--
实际上关于抽样分布还有一些基于`RStudio`的`shiny`平台搭建的动态呈现模式,例如[Nicole Radziwill](https://radziwill.shinyapps.io/sdm-clt)就制作了相关的简单结果展示。这可以作为课堂教学的参考。
如果教师本人精力允许,可以带领学生自行制作相关网页。这样收获更大。
--
实际上,有了重复抽样情形下的抽样分布及模拟,教师还可利用`R`进行自助分布(Bootstrap Distribution)、随机化分布(Randomization Distribution)等理论分布的模拟,如此可将推论的背景框架推广至其他观测数据或实验数据的情形。
---
## 计量经济学的课程教学
这里使用一个经常在计量经济学中使用到的数据(`Affairs`)进行示例。这是美国 *Psychology Today* 杂志于1969年采集的关于婚外情的数据。该数据经常用于广义线性模型的示例。
```{r, message=FALSE}
if(!require(AER)) install.packages("AER")
data("Affairs")
head(Affairs)
```
---
## OLS回归
```{r}
fm_ols <- lm(affairs ~ age + yearsmarried + religiousness + occupation + rating,
data = Affairs)
summary(fm_ols)
```
---
## OLS 回归
### 查看模型拟合值
```{r}
fit <- fitted(fm_ols)
head(fit)
```
### 查看模型残差
```{r}
re <- residuals(fm_ols)
head(re)
```
---
## 查看用于模型诊断的相关图示
```{r, fig.align='center', fig.width=6.5, fig.height=6.5}
opar <- par(no.readonly = T)
par(mfrow = c(2, 2))
plot(fm_ols)
par(opar)
```
---
## 关于回归假设诊断的一个常见范例
线性模型最大的优点可能在于数学形式上的简单性。但这仍依赖于许多基本假定(assumptions)。对这些假定进行检验,是经济学教学和实证研究环节中不可忽视的内容。
通过一些“极端”的教学示例,可培养学生检验模型基本假定的良好习惯。
[Frank Anscombe](https://en.wikipedia.org/wiki/Frank_Anscombe)(1918-2001) 是20世纪著名的英国统计学家, 他于1973年发表了一篇具有深远影响的文章,讨论图形在统计检验中的作用。其所构造的一组数据经常被作为演示数据。
![](https://upload.wikimedia.org/wikipedia/en/d/d5/Francis_Anscombe.jpeg)
---
## Anscombe 四重奏(Anscombe’s Quartet)
请观察以下数据。
```{r}
anscombe
```
x1, x2, x3这三列完全相同,x4 与前三例不同;y1, y2, y3, y4各不相同。
---
## Anscombe的“四个”回归方程
```{r}
fit1 <- lm(y1 ~ x1, data = anscombe)
coefficients(fit1)
fit2 <- lm(y2 ~ x2, data = anscombe)
coefficients(fit2)
fit3 <- lm(y3 ~ x3, data = anscombe)
coefficients(fit3)
fit4 <- lm(y4 ~ x4, data = anscombe)
coefficients(fit4)
```
---
## Anscombe的“四个”线性相关系数
```{r, message=FALSE}
attach(anscombe)
cor(x1, y1)
cor(x2, y2)
cor(x3, y3)
cor(x4, y4)
detach(anscombe)
```
---
## 相同的回归系数,相同的相关系数
从近似角度看,这几乎可以统一为一个回归方程:
$$ \hat{y} = 0.5 x + 3 $$
从近似的角度看,它们还拥有相同的相关系数:0.816。
## 但是,如果绘制各自的散点图……
---
```{r, echo=FALSE, fig.align='center', fig.width=8, fig.height=8}
attach(anscombe)
opar <- par(no.readonly = T)
par(mfrow = c(2, 2))
plot(x1, y1, col = "orange", pch = 20, cex = 2)
abline(lm(y1~x1), col = "blue", lwd = 2)
plot(x2, y2, col = "orange", pch = 20, cex = 2)
abline(lm(y2~x2), col = "blue", lwd = 2)
plot(x3, y3, col = "orange", pch = 20, cex = 2)
abline(lm(y3~x3), col = "blue", lwd = 2)
plot(x4, y4, col = "orange", pch = 20, cex = 2)
abline(lm(y4~x4), col = "blue", lwd = 2)
par(opar)
detach(anscombe)
```
---
## 结论:统计数字会骗人!
--
### 不能迷信回归系数
--
### 结合可视化进行模型检验有其优势
--
### 结合R来做可视化较为便利
---
## 相关代码
```r
attach(anscombe)
opar <- par(no.readonly = T)
par(mfrow = c(2, 2))
plot(x1, y1, col = "orange", pch = 20, cex = 2)
abline(lm(y1~x1), col = "blue", lwd = 2)
plot(x2, y2, col = "orange", pch = 20, cex = 2)
abline(lm(y2~x2), col = "blue", lwd = 2)
plot(x3, y3, col = "orange", pch = 20, cex = 2)
abline(lm(y3~x3), col = "blue", lwd = 2)
plot(x4, y4, col = "orange", pch = 20, cex = 2)
abline(lm(y4~x4), col = "blue", lwd = 2)
par(opar)
detach(anscombe)
```
---
# 广义线性模型
广义线性模型(Generalized Linear Models)的一般形式:
$$f(\mu_Y)=\beta _0 + \beta _1 X_1 + \beta _2 X_2 + \cdots + \beta _k X_k=\beta _0 + \sum ^k _{j=1} \beta _j X_j$$
其中
- $f(\mu_Y)$表示响应变量的条件均值的某种函数(称为连接函数,link function)。
- 此时对 $Y$ 不再有服从正态分布的要求,而可以服从任何指数分布族中的某一分布。
- 设定好连接函数与分布类型后,就可以利用极大似然法通过多次迭代推导出各参数值。
---
# 常用的广义线性模型
- Probit/Logistic 回归模型
- Poisson 回归模型
- Negative Binomial 回归模型
- Zero Inflation 回归模型
- Tobit 回归模型
- ……
## 这些都可通过R的相关函数方便求得。
---
# 广义线性模型
## Probit 回归
```{r}
fm_probit <- glm(I(affairs > 0) ~ age + yearsmarried + religiousness + occupation + rating,
data = Affairs, family = binomial(link = "probit"))
summary(fm_probit)
```
注:`I(affairs > 0)`用于生成是否有婚外情的虚拟变量,> 0 则赋值为1,否则为0。
---
## Probit 回归
## 查看模型拟合值
```{r}
fit <- fitted(fm_probit)
head(fit)
```
---
## Logistic/Logit 回归
```{r}
fm_logit <- glm(I(affairs > 0) ~ age + yearsmarried + religiousness + occupation + rating,
data = Affairs, family = binomial(link = "logit"))
summary(fm_logit)
```
---
## Poisson 回归
```{r}
fm_pois <- glm(affairs ~ age + yearsmarried + religiousness + occupation + rating,
data = Affairs, family = poisson)
summary(fm_pois)
```
---
## Negative Binomial 回归
```{r, message=FALSE}
if(!require(MASS)) install.packages("MASS")
fm_nb <- glm.nb(affairs ~ age + yearsmarried + religiousness + occupation + rating,
data = Affairs)
summary(fm_nb)
```
---
## Zero Inflation 回归
```{r, message=FALSE}
if(!require(pscl)) install.packages("pscl")
fm_zero <- zeroinfl(affairs ~ age + yearsmarried + religiousness + occupation + rating | age +
yearsmarried + religiousness + occupation + rating, data = Affairs)
summary(fm_zero)
```
---
## Tobit 回归
```{r, message=FALSE}
library(AER)
fm_tobit <- tobit(affairs ~ age + yearsmarried + religiousness + occupation + rating,
data = Affairs)
summary(fm_tobit)
```
---
# 在数据获取、预处理和可视化中的应用
- tidyverse系列数据处理包
- dplyr: 数据操纵
- tidyr: 数据操纵
- stringr: 文本数据操纵
- rvest: 在线抓取文本
- ……
- 可视化系列数据处理包
- ggplot2
- ggtheme
- ggvis
- shiny
- wordcloud2
- ……
---
## 数据处理示例1:一手问卷调查数据
[我们项目组](https://github.com/xkdog/Seminar)目前正在编制《中国医患社会心态调查问卷》,问卷已经基本完成编制并已进行预测试。对初测数据的统计分析工作正在进行。初测问卷使用问卷星填答,要求被调查者使用自身手机或在访问员的手机上完成填答。数据示例见Excel文件。
以下命令可简单地统计被试的地理位置分布。
```r
library(readxl)
library(stringr)
library(tidyverse)
PDSurveyBasic <- read_excel("PDSurveyBasic.xlsx")
ip.location <- str_extract(PDSurveyBasic$ip, "(?<=\\().*(?=\\))") %>%
str_split("-", n = 2, simplify = TRUE) %>%
as_tibble %>%
transmute(province = .[[1]], city = .[[2]]) %>%
group_by(province) %>%
summarise(n=n()) %>%
arrange(desc(n))
```
---
class: center
## 地理位置信息分布结果
```{r, echo=FALSE, message=FALSE, warning=FALSE}
library(readxl)
library(stringr)
library(tidyverse)
PDSurveyBasic <- read_excel("PDSurveyBasic.xlsx")
ip.location <- str_extract(PDSurveyBasic$ip, "(?<=\\().*(?=\\))") %>%
str_split("-", n = 2, simplify = TRUE) %>%
as_tibble %>%
transmute(province = .[[1]], city = .[[2]]) %>%
group_by(province) %>%
summarise(n=n()) %>%
arrange(desc(n))
ip.location
```
---
## 数据获取与处理示例2
### 政府工作报告抓取与分析
传统社会科学的量化分析以对数字数据(numeric data)的量化分析为主,对文本数据(text data)的分析较少。这主要是受研究工具的局限所致。
R及Python等开源软件的出现,很大程度上改变这种现状,使得文本分析成为当下社会科学研究的一大潮流。
[中国政府网](http://www.gov.cn/guowuyuan/baogao.htm)提供了自1954年以来所有的政府工作报告全文。这里以中国政府工作报告(2017)为例做一简单的R语言示例(该示例得益于雪晴数据网陈堰平老师的讲座)。
---
## 政府工作报告的抓取与简单分析
[2017政府工作报告](http://www.gov.cn/premier/2017-03/16/content_5177940.htm)
```{r, message=FALSE, warning=FALSE}
if (!require(rvest)) install.packages('rvest')
if (!require(wordcloud2)) install.packages('wordcloud2')
if (!require(jiebaR)) install.packages('jiebaR')
if (!require(stringr)) install.packages('stringr')
url2017 <-
"http://www.gov.cn/premier/2017-03/16/content_5177940.htm"
report2017 <- read_html(url2017)
text2017 <- report2017 %>%
html_nodes("p") %>%
html_text() %>%
paste(collapse = "")
writeLines(text2017, "report2017.txt")
library(jiebaR)
cutter <- worker(
bylines = T,
user = "./UsrWords.txt",
stop_word = "./stopWords.txt",
output = "report2017output.txt"
)
report_seg_file <- cutter["./report2017.txt"]
report_segged <-
readLines("./report2017output.txt", encoding = "UTF-8")
report <- as.list(report_segged)
doc.list <- strsplit(as.character(report), split = " ")
term.table <- table(unlist(doc.list))
term.table <- sort(term.table, decreasing = TRUE)
del <- term.table < 5 | nchar(names(term.table)) < 2
term.table <- term.table[!del]
vocabDF <- as.data.frame(term.table)
```
---
## 政府工作报告的抓取与简单分析
```{r}
head(vocabDF, 10)
```
---
## 政府工作报告的抓取与简单分析
```{r}
library(wordcloud2)
wordcloud2(vocabDF, color = "random-light", backgroundColor = "grey")
```
---
如何通过循环来遍历所有年份政府工作报告的链接,留待大家作为思考题。
提示如下:
```{r}
url <- "http://www.gov.cn/guowuyuan/baogao.htm"
reports <- read_html(url)
links <- reports %>%
html_nodes(".history_report a") %>%
html_attr("href") %>%
str_trim()
head(links)
```
---
## 数据获取、处理与可视化
### 经济学研究的常用数据、世界银行数据可使用两个R包获取:
- [WDI](https://cran.r-project.org/web/packages/WDI/index.html)
- [wbstats](https://cran.r-project.org/web/packages/wbstats/vignettes/Using_the_wbstats_package.html)
### 一个复制Hans Rosling的[Gapminder](https://www.gapminder.org/)软件的动态交互式气泡图
- [Hans Rosling](https://www.ted.com/speakers/hans_rosling)的[TED演讲](https://www.ted.com/talks/hans_rosling_shows_the_best_stats_you_ve_ever_seen),[中文翻译版](http://open.163.com/movie/2011/12/L/6/M8H1NPQM9_M8H1USJL6.html)
- [R中的复制](https://www.r-bloggers.com/new-r-package-to-access-world-bank-data/)
---
## ggplot系列图形
利用ggplot2及ggthemes、ggsci等包,可便捷产生符合特定杂志风格的图形。
### 常用ggplot系列可视化包
- ggplot2
- ggthemes
- ggsci
- ggcorrplot
- ……
---
### ggplot2 原始风格
```{r ggplot2 style, fig.align='center', fig.width=7, fig.height=6}
library(ggplot2)
ggplot(iris) +
geom_boxplot(aes(x = Species, y = Sepal.Length, fill = Species))
```
---
### *The Economist* 风格图形
```{r Economist style, message=FALSE, fig.height=5, fig.width=5, fig.align='center'}
ggplot(iris) +
geom_boxplot(aes(x = Species, y = Sepal.Length, fill = Species)) +
ggthemes::theme_economist()
```