forked from tomasbarcellos/2020-09-esferas
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy path01_rend_desp_COD.R
executable file
·125 lines (106 loc) · 4.02 KB
/
01_rend_desp_COD.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
library(pof)
library(tidyverse)
# O script está montado para ter 4 partes: cada uma uma função
# As funções usadas estão no script 00_funcoes.R
# 1) Ler os dados de acordo com as intruções do IBGE
# 2) Classificar os rendimentos nas esferas alta/baixa
# A ideia é que só precisemos mexer nessa etapa
# 3) Identificar as UC nas esferas
# baseado em corte vindo da análise dos dados (0.63)
# 4) Vincular os gastos das UCs com as esferas
# Etapa 0 ------------------ preparar repoditório -------------------
# downaload_pof(2018)
# unzip_pof(2018)
#
## Tive que usar essa linha de baixo pq o IBGE mudou
## a forma de extrair os arquivos
# dir(glue::glue("dados/2018/Arquivos de dados"),
# full.names = TRUE) %>%
# file.rename(str_remove(., "Arquivos de dados/"))
source("00_funcoes.R")
# Etapa 1 -----------------------------------------------------------
rendas2018 <- ler_rendimentos2018()
km <- rendas2018 %>%
group_by(cod_uc) %>%
summarise(peso_final = first(peso_final),
valor = sum(valor_mensal)) %>%
pull(valor) %>%
kmeans(3)
rendas2018 %>%
group_by(cod_uc) %>%
summarise(peso_final = first(peso_final),
valor = sum(valor_mensal)) %>%
ggplot(aes(seq_along(valor), valor, col = factor(km$cluster))) +
geom_point(alpha = 0.3) +
# scale_y_log10() +
scale_y_continuous(limits = c(0, 50e3)) +
geom_hline(yintercept = 20e3)
rendas2018 %>%
group_by(cod_uc) %>%
summarise(peso = first(peso_final),
valor = sum(valor_mensal)) %>%
mutate(grupo = kmeans(valor, 3)$cluster,
centros = list(kmeans(valor, 3)$centers %>% as.vector()),
grupo_tipo = centros[[]]) %>%
group_by(grupo) %>%
summarise(soma = sum(valor * 12 * peso / 1e9),
media = weighted.mean(valor, peso)) %>%
arrange(desc(media))
teste2 <- teste %>%
mutate(teste = map2_dbl(centros, grupo, ~.x[[.y]] == min(.x)))
teste2 %>%
ggplot(aes(valor, seq_along(valor), col = factor(grupo))) +
geom_point(alpha = 0.3) +
geom_vline(xintercept = 20e3) +
scale_x_log10()
# Etapa 2 -----------------------------------------------------------
rendas_classificadas <- classificar_rendimentos(rendas2018,cod = T)
names(rendas_classificadas)[18] <- "forma"
rendas_ucs <- rendas_classificadas %>%
group_by(cod_uc, forma) %>%
summarise(renda = sum(valor_mensal)) %>%
pivot_wider(names_from = forma, values_from = renda,
values_fill = list(renda = 0)) %>%
mutate(total = alta + baixa,
p_cv = case_when(total == 0 ~ 1,total > 0 ~ baixa/total)) %>%
ungroup()
# K-Means usadas para estabelecer corte alta/baixa
# k_rendas <- kmeans(rendas_ucs$p_cv, c(0.2, 0.5))
# k_rendas$centers
#
# ggplot(rendas_ucs, aes(p_cv, total, col = factor(k_rendas$cluster))) +
# geom_point(shape = ".", alpha = 0.5) +
# geom_vline(xintercept = 0.63, lty = 2) +
# scale_y_continuous(limits = c(0, 20e3)) +
# theme_classic() +
# theme(legend.position = "none")
# A análise acima propor o corte de 63% para esfera alta/baixa
corte <- 0.95
# Etapa 3 -----------------------------------------------------------
rendas_esferas <- rendas_ucs %>%
mutate(esfera = ifelse(p_cv > corte, "baixa", "alta"))
rendas_esferas %>%
group_by(esfera) %>%
summarise(v= sum(total), n = n()) %>%
mutate(tx = v/last(v), p = n / sum(n))
esferas_ucs <- rendas_esferas %>%
select(cod_uc, esfera)
# Etapa 4 -----------------------------------------------------------
despesas_esferas <- ler_despesas2018() %>%
left_join(esferas_ucs, by = "cod_uc") %>%
select(cod_uc, codigo, nivel_0:esfera)
# Estimativa geral esferas
despesas_esferas %>%
group_by(esfera) %>%
summarise(soma = sum(valor) * 12 / 1e9) %>% # Em bilhões
mutate(partic = soma / sum(soma))
# Estimativa um produto: livros (cod: 110803)
despesas_esferas %>%
group_by(nivel = nivel_4, esfera) %>%
summarise(soma = sum(valor) * 12 / 1e6) %>%
filter(nivel == 110803) %>%
mutate(partic = soma / sum(soma))
despesas_esferas %>%
mutate(ano = 2018) %>%
select(-starts_with("nivel")) %>%
write_csv("gastos_esferas_2018.csv")