Índice
- O Curso R
-
- Tutoriais
-
- Apostila
-
- 6. Testes de Hipótese (em preparação!)
- Exercícios
-
- Material de Apoio
-
- Área dos Alunos
-
- Cursos Anteriores
-
IBUSP
Outras Insitutições
Linques
Visitantes
Outras Insitutições
Graduada em Gestão Ambienta pela EACH (USP - leste). Atualmente está desenvolvendo um projeto de pesquisa sobre o Bolsa Família e o uso de recursos naturais.
TRABALHO FINAL
Isadora, siga com a proposta A
. Mas importante, faça com que sua função opere um data frame com um conjunto de dados de várias famílias. Ou seja, nos dados de entrada as colunas são as variáveis e as linhas as famílias. Como as variáveis podem ser agrupadas em 3 categorias, utilize um outro argumento de entrada que defina a classe de cada variável (um vetor com as 3 categorias na posição de cada coluna do dados de entrada), assim vc. pode operar os dados definido qual tipo de variável deve ser utilizada. Sugiro tb. que calcule o Gini e o Gini decomposto como vc. mesma sugeriu. Arrume a propostas com essas modificações e pode começar a trabalhar.
— Alexandre Adalardo de Oliveira 2016/04/30 08:52
Resposta Isadora 04/05
Obrigada,
Isadora
Dificuldade encontrada 12/05
Obrigada, Isadora
Proposta A
Contextualização
As famílias pobres que habitam as áreas rurais de países em desenvolvimento costumam apresentar formas de geração de renda altamente diversificadas (SUNDERLIN et al, 2005). A sobrevivência desses grupos pode depender de recursos originários de ambientes não cultivados, como florestas e rios (ANGELSEN, 2011). Dessa forma, a compreensão das diferentes dimensões dos meios de vida rurais e da pobreza não deve se restringir a medidas quantitativas de renda em dinheiro (SUNDERLIN et al, 2005). É possível distinguir as fontes de renda de famílias rurais em pelo menos três categorias principais: (i) renda ambiental que diz respeito à contribuição de produtos ambientais provenientes de terras não agrícolas (i.e. madeira, lenha, carne de caça, frutas e animais silvestres); (ii) renda agrícola que refere-se à soma de rendimentos de produção de subsistência e de rendimentos da pecuária e salários de atividades relacionadas; (iii) renda não agrícolas que compreende salários, pensões e transferências do governo.
Utilidade da função
A função proposta tem a finalidade de facilitar a operacionalização de dados referentes aos rendimentos de populações pobres rurais. Para tanto, realizará análises comuns neste tipo de estudo a partir de uma variável categórica ou quantitativa contínua definida pelo usuário. A função permitirá estimar a participação relativa e absoluta de cada fonte de renda e de seus componentes, o grau de desigualdade de renda por meio do coeficiente de Gini e a contribuição de cada fonte renda para o coeficiente de Gini.
Entrada
Primeiro argumento: um data.frame que contenha um conjunto de dados referente as fontes de renda das amostras (i.e. famílias, unidades domésticas, indivíduos). O data.frame deve estar organizado da seguinte maneira: a) as linhas devem corresponder às amostras, ou seja, famílias, unidades domésticas ou indivíduos para os quais as informações de renda foram coletadas.
b) A primeira coluna deve conter a identificação das amostras.
c) As demais colunas devem corresponder as variáveis de renda já convertidas para uma unidade comum (i.e. reais, dólares).
Segundo argumento: variável categórica ou quantitativa contínua utilizada como critério para apresentação e divisão dos dados.
Terceiro argumento: corresponderá às categorias que o usuário pretende incluir na análise da renda, ou seja, ao total de categorias nas quais as variáveis de renda serão agrupadas. O usuário deverá indicar as colunas do data frame que correspondem a cada categoria de renda e assim definir como o agrupamento deve ser realizado.
Saída
Para cada critério estabelecido no segundo argumento da função (variável categórica ou contínua) a função retornará:
a) um data frame em que as linhas corresponderão às categorias de renda e seus componentes e as colunas corresponderão ao valor absoluto e relativo para cada categoria de renda e seus componentes.
b) um data frame em que as linhas corresponderão às categorias de renda, a primeira coluna corresponderá à identificação das categorias de renda e a segunda coluna corresponderá ao coeficiente de Gini¹ para cada categoria.
c) um data frame em que as linhas corresponderão às categorias de renda, a primeira coluna corresponderá à identificação das categorias de renda e as colunas seguintes corresponderão à decomposição do coeficiente de Gini² para cada categoria de renda.
¹ O coeficiente de Gini reflete o grau de desigualdade de renda através de um grupo e varia de 0 (completa igualdade) a 1 (apenas 1 família tem toda a renda).
² A decomposição do coeficiente de Gini mostra a contribuição de cada fonte de renda para o coeficiente de Gini e o efeito marginal de cada fonte sobre a desigualdade de renda total
Referências
SUNDERLIN, W. D; ANGELSEN, A; BELCHER, B., BURGUES, P.; NASI, R.; SANTOSO, L.; WUNDER, S. Livelihoods, forests, and conservation in developing countries: an overview. World development, v. 33, n. 9, p. 1383-1402, 2005.
ANGELSEN, A.; LARSEN, H. O.; LUND, J., F.; SMITH-HALL, C.; WUNDER, S. Measuring livelihoods and environmental dependence: Methods for research and fieldwork. London: Earthscan, 2011.
Proposta B
Contextualização
A função será utilizada na etapa de análise exploratória do dados, etapa que costuma consumir grande parte do tempo das análises e na qual os gráficos são muito importantes, pois permitem assimilação clara e rápida das informações coletadas. A ideia é fornecer um panorama geral ao usuário relacionando a variável preditora com as demais.
Função rela.data()
A função proposta utilizará técnicas de estatística descritiva para relacionar as variáveis de um data. frame aos pares, retornando ao usuário gráficos exploratórios e testes de hipóteses. O usuário deverá indicar a variável preditora que deseja associar com as demais variáveis do data frame, sendo que esta poderá ser categórica ou quantitativa.
Entrada: data frame em que cada coluna refere-se a uma variável.
Saída: a função retornará gráficos e testes diferentes de acordo com os tipos de variáveis envolvidas, conforme descrito abaixo:
a) Ambas são categóricas – a função retornará um teste Qui-Quadrado e a tabela de análise dos resíduos, bem como o gráfico de colunas por estratos da segunda variável;
b) Ambas são quantitativas (contínuas ou discretas) - a função retornará um histograma com as frequências absolutas, um histograma com as frequências relativas, um diagrama de dispersão entre as duas variáveis e sua respectiva linha de tendência e o Coeficiente de Correlação de Pearson.
c) Uma variável é categórica e outra quantitativa – a função retornará um gráfico de colunas por estratos da variável categórica e o gráfico BOX-PLOT por categoria.
Comentários Bruno
Na proposta A, gostaria que você me explicasse melhor o objeto de entrada e saída. Pelo que eu entendi o objeto de saída é o objeto de entrada “resumido”.
Na proposta B, o que você quer dizer com “relacionar a variável preditora com as demais” Seria uma preditora e várias respostas? Além isso, acho que você precisar tomar cuidado com o que a função vai fazer com os NAs presentes no conjunto de dados. No objeto de saída b), talvez você possa verificar a normalidade dos seus dados, e caso não sejam normais, usar outros testes de correlação quem lidam com dados não normais.
Bruno
Resposta Isadora
Logo, não se trata de resumir , mas apresentar os valores absolutos e relativos da soma de todos os tipos de renda (ambiental, agrícola e não agrícola), tendo como critério uma variável categórica ou quantitativa contínua escolhida pelo usuário, . No caso da minha pesquisa, por exemplo, seria interessante separar quem recebe renda do programa bolsa família de quem não recebe. Eu gostaria bastante de trabalhar com as rendas na função, caso você tenha achado simples, há também outras análises que seriam interessantes que a função devolvesse, como o desvio padrão, o valor mínimo e máximo para cada fonte de renda. Outro retorno possível é o coeficiente de Gini ou ainda, a decomposição do coeficiente de Gini . O coeficiente de Gini reflete o grau de desigualdade de renda através de um grupo e varia de 0 (completa igualdade) a 1 (apenas 1 família tem toda a renda). Já a decomposição mostra a contribuição de cada fonte de renda para o coeficiente de Gini e o efeito marginal de cada fonte sobre a desigualdade de renda total. Veja exemplos (a) coeficiente de Gini, (b) decomposição do coeficiente. Obs: não inclui por receio de que a execução fosse muito complicada, mas notei que já existe uma função para o cálculo do coeficiente de Gini.
Quanto ao plano B, inicialmente pensei que seria interessante uma função que relacionasse uma variável preditora com as variáveis resposta (sempre aos pares), você acha que não poderia ser assim? Quanto aos NAs, acredito que seria interessante incluir um teste lógico e uma mensagem de alerta para a presença de Nas em cada relação (preditora e resposta) desenvolvida. Mas o que você sugere é que eu pense eu como a função tratará os NAs em cada caso? Gostei bastante da sua proposta de verificar a normalidade dos dados, certamente vou incluir caso eu siga com a proposta B.
Obrigada!
Isadora
Função desenvolvida - Proposta A
Página de Ajuda
renda.opera package: nenhum R Documentation Função para calcular a renda absoluta, a renda relativa e o coeficiente de desigualdade de Gini para três categorias de renda definidas pelo usuário. Description: A partir de um dataframe, divide os dados em subconjuntos de acordo com variável categórica binária ou quantitativa contínua. Depois disso, as variáveis de renda que compõe cada subconjunto são agrupadas em três categorias e para cada categoria são calculados a renda relativa, a renda absoluta e o índice de Gini. Usage: renda.opera <-function(renda, var, cat1, cat2, cat3) Arguments: renda: Data.frame que deve estar organizado da seguinte maneira: (i) as linhas devem corresponder às amostras, ou seja, famílias, unidades domésticas ou indivíduos para os quais as informações de renda foram coletadas; (ii) a primeira coluna deve conter a identificação das amostras; (iii) as demais colunas devem corresponder as variáveis de renda. Var: Valor numérico; número que indica a coluna do data.frame correspondente a variável categórica binária ou quantitativa contínua que orientará a divisão do data.frame nos subgrupos da análise. Cat1: Valor numérico; número ou sequência de números que indicam a(s) coluna(s) do data.frame correspondente(s) a primeira categoria. Cat2: Valor numérico; número ou sequência de números que indicam a(s) coluna(s) do data.frame correspondente(s) a segunda categoria. Cat3: Valor numérico; número ou sequência de números que indicam a(s) coluna(s) do data.frame correspondente(s) a terceira categoria. Details: As variáveis de renda devem estar convertidas em uma unidade comum (i.e. reais, dólares). Todos os argumentos da função precisam ser fornecidos. O pacote ‘ineq’ deve estar instalado. O pacote ‘data.table’ deve estar instalado. Value: comp1 : No console, um data frame correspondente a cada subgrupo do data frame “renda” fornecido na entrada dos dados, em que as linhas correspondem às categorias de renda e seus componentes e as colunas correspondem ao valor absoluto e relativo para cada categoria de renda, seus componentes e o total para todas as categorias. comp2 : No console, também para cada subgrupo do data frame “renda”, a função retornara um data frame em que as linhas correspondem as categorias de renda, a primeira coluna corresponde à identificação das categorias de renda e a segunda coluna corresponde ao coeficiente de Gini para cada categoria. comp3 : retorna uma lista contendo os data.frames criados. Warning: A função será interrompida e retornará mensagens de erro caso o objeto de entrada renda não seja data.frame; caso a coluna com que compõe a variável que dividirá o data.frame em subgrupos (var) não seja indicada corretamente; caso os pacote ‘ineq’ e data.table não estejam instalados. Por fim, na primeira vez em que for executada a função exibirá uma mensagem referente a instalação do pacote ‘ineq’ e referente a instalação do pacote ‘data.table’. Note: Esteja atento a presença de NAs nos dados, pois estes serão excluídos. Author(s): Isadora Aguirra isadora.aguirra@usp.br References: Pacote 'ineq': https://cran.r-project.org/web/packages/ineq/index.html Pacote 'data.table': https://cran.r-project.org/web/packages/data.table/index.html See Also: Funções: for(), subset(), unique() Acknowledgments: Aos monitores Diogo Melo e Vitor Rios pelos esclarecimentos, dicas e sugestões. Examples: #Exemplo 1: #criando vetores para incluir no dataframe familia <- c("a1", "a2", "a3", "a4", "a5", "a6", "a7", "a8", "a9", "a10" ) var1 <- c(0,1,0,1,1,0,1,1,1,0) fruta.col <- round((runif(10, min = 15, max = 20)), digits = 0) caça<- round((runif(10, min = 0, max = 15)), digits = 0) madeira <- round((runif(10, min = 15, max = 150)), digits = 0) sementes <- round((runif(10, min = 0, max = 15)), digits = 0) verduras.quintal <- round((runif(10, min = 15, max = 100)), digits = 0) verduras.roca <- round((runif(10, min = 10, max = 190)), digits = 0) bolsa.familia <- round((runif(10, min = 77, max = 175)), digits = 0) aposentaria <- round((runif(10, min = 678, max = 4159)), digits = 0) trabalho.externo <- round((runif(10, min = 678, max = 2000)), digits = 0) #criando dataframe para exemplo renda <- data.frame(familia,var1, fruta.col, caça, madeira, sementes, verduras.quintal, + verduras.roca, bolsa.familia, aposentaria, trabalho.externo) renda.opera (renda, var=2, cat1=3:6, cat2=7:8, cat3=9:11) renda.opera (renda, var=2, cat1=8:11, cat2=5:7, cat3=3:14) #Exemplo 2: #semelhante ao exemplo 1, mas com var não binária. familia <- c("a1", "a2", "a3", "a4", "a5", "a6", "a7", "a8", "a9", "a10" ) fruta.col <- round((runif(10, min = 15, max = 20)), digits = 0) caça<- round((runif(10, min = 0, max = 15)), digits = 0) madeira <- round((runif(10, min = 15, max = 150)), digits = 0) sementes <- round((runif(10, min = 0, max = 15)), digits = 0) var1 <- c(20,10,20,30,40,20,30,30,40,30) verduras.quintal <- round((runif(10, min = 15, max = 100)), digits = 0) verduras.roca <- round((runif(10, min = 10, max = 190)), digits = 0) trabalho.externo <- round((runif(10, min = 678, max = 2000)), digits = 0) #criando dataframe para exemplo renda <- data.frame(familia, fruta.col, caça, madeira, sementes, var1, verduras.quintal, + verduras.roca, trabalho.externo) renda.opera (renda, var=6, cat1=2:5, cat2=7:8, cat3=9)
Código da Função
renda.opera <-function(renda, var, cat1, cat2, cat3) { # # # # Verificando os agurmentos fornecidos pelo usuário # # # # #Verica se renda é um data.frame e em caso negativo exibe mensagem de erro if (class (renda)!="data.frame") stop("\n renda nao é um dataframe.\n") #Verifica se a coluna com os dados da variável que orientará a divisao do data.frame em subgrupos foi indicada corretamente e em caso negativo exibe mensagem de erro if (class(var) != "numeric") stop("\n Coluna nao indicada corretamente.\n") #Verifica se o pacote 'data.table' foi instalado e apresenta mensagem de erro em caso negativo. if (require(data.table) == "FALSE") stop("\n O Pacote 'data.table' não foi instalado corretamente.\n") #Verifica se o pacote 'ineq' foi instalado e apresenta mensagem de erro em caso negativo. if (require(ineq) == "FALSE") stop("\n O Pacote 'ineq' não foi instalado corretamente.\n") # # # # Arrumando os dados e determinando critérios de divisao # # # # # Os passos a seguir correspondem aos procedimentos para idetificar os criterios que orientarao: (i) divisao do data.frame em subgrupos; (ii) variaveis que formarao cada categoria de renda. renda = na.omit(renda) # remove os NAs subgrupos <- unique(renda[,var])# identifica os diferentes valores presentes na coluna "var" e portanto, os valores que a variavel devera assumir durante os ciclos list.subgrupos <- length(subgrupos) # conta o numero de subgrupos totais que serao formados a partir do data.frame renda saida1 <- vector("list", list.subgrupos)# cria uma lista em que os data.frames gerados para os diferentes subgrupos serão guardados library(data.table)# carrega o pacote data.table, o pacote foi necessario pois apresenta maior facilidade do que a funçao "for" para guardar em uma lista a seuqencia de data.frame gerados nos ciclos. # # # # Ciclo 1 # # # # # O primeiro ciclo gera um data.frame para cada subgrupo do data.frame renda que contem os valores absolutos e relativos para cada categoria de renda e também para o total (categoria1 + categoria2 + categoria2) ciclo1 <- lapply(subgrupos, function(i) # os valores assumidos pela variável i no ciclo devem corresponder ao vetor de subgrupos correspondentes aos valores do argumento "var" # Nas linhas abaixo sao selecionadas as colunas que compoe as categorias 1, 2 e 3 segundo os cristerio definidos pelo usuario. Note que sao gerados subgrupos do data.frame "renda" - subset(renda, renda[,var]==i. { categoria1 <- (subset(renda, renda[,var]==i)[,cat1]) categoria2<- (subset(renda, renda[,var]==i)[,cat2]) categoria3<- (subset(renda, renda[,var]==i)[,cat3]) # # # # # # # # Calculando valores absolutos por Categoria # # # # # # # # #Categoria 1 - valores absolutos col.sums <- apply(categoria1, 2, sum) # soma total de cada variavel que compoe a categoria 1 a<- ncol(categoria1) # conta as colunas da categoria 1 total1 <- sum(col.sums[1:a]) # soma de todas as variaveis que compoe a categoria 1 e gera um valor total absoluto para a categoria 1 #Categoria 2 -valores absolutos col.sums2 <- apply(categoria2, 2, sum)# soma total de cada variavel que compoe a categoria 2 b<- ncol(categoria2)# conta as colunas da categoria 2 total2 <- sum(col.sums2[1:b]) # soma de todas as variaveis que compoe a categoria 2 e gera um valor total absoluto para a categoria 2 #Categoria 3 -valores absolutos col.sums3 <- apply(categoria3, 2, sum)# soma total de cada variavel que compoe a categoria 3 c<- ncol(categoria3)# conta as colunas da categoria 3 total3 <- sum(col.sums3[1:c])# soma de todas as variaveis que compoe a categoria 3 e gera um valor total absoluto para a categoria 3 # # # # # # # Calculando os valores relativos por Categoria # # # # # # # totalt <- sum (total1,total2,total3) #soma do total absoluto das três categorias #Categoria 1 - valores relativos col.sumsrelativo <- round((col.sums/totalt*100), digits=1) # gera o total relativo para cada variavel que compoe a categoria 1 tendo como referencia o total abslouto das tres categorias totalrelativo <- sum(col.sumsrelativo[1:a]) # gera o total relativo para a soma de todos os elementos que compoe a Categoria 1 #Categoria 2 - valores relativos col.sumsrelativo2 <- round((col.sums2/totalt*100), digits=1)# gera o total relativo para cada variavel que compoe a categoria 2 tendo como referencia o total abslouto das tres categorias totalrelativo2 <- sum(col.sumsrelativo2)# gera o total relativo para a soma de todos os elementos que compoe a Categoria 2 #Categoria 3 - valores relativos col.sumsrelativo3 <- round((col.sums3/totalt*100), digits=1)# gera o total relativo para cada variavel que compoe a categoria 3 tendo como referencia o total abslouto das tres categorias totalrelativo3 <- sum(col.sumsrelativo3)# gera o total relativo para a soma de todos os elementos que compoe a Categoria 3 # # # # # # # # Adequando os dados para o data.frame # # # # # # # # cat1 <- names(col.sums)#cria um vetor com os nomes das variaveis que compe a categoria 1 nomes1 <- c("categoria1", cat1) # cria novo vetor que adicona o termo "categoria 1" ao vetor cat1 vetorab1<- as.vector (c( total1, col.sums)) # cria um vetor com totais absolutos de cada variavel que compoe a categoria 1 e concatena com o total da categoria vetorrel1<- as.vector(c(totalrelativo, col.sumsrelativo)) # cria um vetor com totais relativos de cada variavel que compoe a categoria 1 e concatena com o total relativo da categoria cat2 <- names(col.sums2)#cria um vetor com os nomes das variaveis que compe a categoria 2 nomes2 <- c("categoria2", cat2) # cria novo vetor que adicona o termo "categoria 2" ao vetor cat2 vetorab2<- as.vector (c( total2, col.sums2)) # cria um vetor com totais absolutos de cada variavel que compoe a categoria 2 e concatena com o total da categoria vetorrel2<- as.vector(c(totalrelativo2, col.sumsrelativo2))# cria um vetor com totais relativos de cada variavel que compoe a categoria 2 e concatena com o total relativo da categoria cat3 <- names(col.sums3)#cria um vetor com os nomes das variaveis que compe a categoria 2 class(cat3) nomes3 <- c("categoria3", cat3) # cria novo vetor que adicona o termo "categoria 3" ao vetor cat3 vetorab3<- as.vector (c( total3, col.sums3))# cria um vetor com totais absolutos de cada variavel que compoe a categoria 3 e concatena com o total da categoria vetorrel3<- as.vector(c(totalrelativo3, col.sumsrelativo3))# cria um vetor com totais relativos de cada variavel que compoe a categoria 3 e concatena com o total relativo da categoria categoria <- c(nomes1,nomes2,nomes3)# cria vetor com o nomes das três categorias absoluto <- c(vetorab1, vetorab2, vetorab3)# cria vetor com os valores absolutos das três categorias relativo <- c(vetorrel1, vetorrel2,vetorrel3)# cria vetor com os valores relativos das tres categorias # # # # # # # # Incluindo o total # # # # # # # # totalrel<- sum(totalrelativo, totalrelativo2, totalrelativo3)# soma o total relativo das três categorias, evidentemente 100% vetorabtotal <- as.vector(totalt) # torna a soma absoluta das categorias um vetor vetorreltotal <- as.vector(totalrel) # torna a soma relativa das categorias um vetor Categoria <- c(categoria, "total") # cria vetor que inclui os nomes das categoria, seus elementos e o nome "total" Absoluto <- c(absoluto, vetorabtotal) # cria vetor que inclui o valor absoluto de cada categoria e de seus componentes e o valor absoluto total. Relativo <- c(relativo,vetorreltotal)# cria vetor que inclui o valor relativo de cada categoria e de seus componentes e o valor relativo total. print(data.frame(Categoria, Absoluto, Relativo))# gera data.frame com o }) result <- do.call(rbind, ciclo1)# guarda o resultado dos ciclos gerados # retorna uma lista com os data.frames gerados para cada subgrupo # # # # # # # # Calculando o índide de Gini # # # # # # # # library(ineq)#carrega o pacote ineq para acessar função que permite calcular o índice de Gini saida2 <- vector("list", list.subgrupos)# cria lista em que os data.frames gerados para os diferentes subgrupos serão guardados #iniciando novo ciclo: no ciclo a seguir sera calculado o coeficiente de Gini para cada categoria de renda e tambem para o total (considerando as tres categorias) para cada subgrupo do data.frame "renda" ciclo2 <- lapply(subgrupos, function(k) { # Nas linhas abaixo sao selecionadas as colunas que compoe as categorias 1, 2 e 3 segundo os cristerio definidos pelo usuario. Note que sao gerados subgrupos do data.frame "renda" - subset(renda, renda[,var]==i. categoria1 <- (subset(renda, renda[,var]==k)[,cat1]) categoria2<- (subset(renda, renda[,var]==k)[,cat2]) categoria3<- (subset(renda, renda[,var]==k)[,cat3]) # # # # # # # # Calculando valores absolutos por Categoria # # # # # # # # # Essas operações precisaram ser retormados, pois objetos gerados no ciclo anterior não ficam registrados. #Categoria 1 - valores absolutos col.sums <- apply(categoria1, 2, sum) # soma total de cada variavel que compoe a categoria 1 a<- ncol(categoria1) # conta as colunas da categoria 1 total1 <- sum(col.sums[1:a]) # soma de todas as variaveis que compoe a categoria 1 e gera um valor total absoluto para a categoria 1 #Categoria 2 -valores absolutos col.sums2 <- apply(categoria2, 2, sum)# soma total de cada variavel que compoe a categoria 2 b<- ncol(categoria2)# conta as colunas da categoria 2 total2 <- sum(col.sums2[1:b]) # soma de todas as variaveis que compoe a categoria 2 e gera um valor total absoluto para a categoria 2 #Categoria 3 -valores absolutos col.sums3 <- apply(categoria3, 2, sum)# soma total de cada variavel que compoe a categoria 3 c<- ncol(categoria3)# conta as colunas da categoria 3 total3 <- sum(col.sums3[1:c])# soma de todas as variaveis que compoe a categoria 3 e gera um valor total absoluto para a categoria 3 totalt <- sum (total1,total2,total3) #soma do total absoluto das três # # # # # # # # Categoria 1 # # # # # # # # renda.familia1 <- rowSums(categoria1[,1:a]) #resgata "a" que é o número de colunas da categoria1 e obtem a renda total por familia para a categoria 1 G1 <- ineq(renda.familia1, parameter = NULL, type = c("Gini"), na.rm = TRUE)#usa a função ineq para calcular o gini para a categoria 1 # # # # # # # # Categoria 2 # # # # # # # # renda.familia2 <- rowSums(categoria2[,1:b])#resgata "b" que é o número de colunas da categoria 2 e obtem a renda total por familia para a categoria 2 G2 <- ineq(renda.familia2, parameter = NULL, type = c("Gini"), na.rm = TRUE)##usa a função ineq para calcular o gini para a categoria 2 # # # # # # # # Categoria 3 # # # # # # # # renda.familia3 <- rowSums(categoria3[,1:c])#resgata "c" que é o número de colunas da categoria 3 e obtem a renda total por familia G3 <- ineq(renda.familia3, parameter = NULL, type = c("Gini"), na.rm = TRUE)##usa a função ineq para calcular o gini para a categoria 3 # # # # # # # # Somando as três categorias # # # # # # # # renda.familia.total <- renda.familia1 + renda.familia2 + renda.familia3 #calcula a renda total por familia considerando as tres categorias Gtotal <- ineq(renda.familia.total, parameter = NULL, type = c("Gini"), na.rm = TRUE)#usando a função ineq para calcular o Gini total Categorias <- c("Categoria1", "Categoria2", "Categoria3", "Total")#cria vetor com nome de todas as categorias Gini <- c(G1,G2,G3,Gtotal) #cria vetor com os resultados de Gini correspondentes a cada categoria e tambem com o valor total print(data.frame(Categorias,Gini)) # cria e registra no console um data.frame contendo o Gini para cada Categoria e também o total }) result2 <- do.call(rbind, ciclo2)# armazena o resultado gerado pelo ciclo lista3 <- list(result,result2)# cria lista com os data.frames gerados return(lista3)# retorna lista criada }
Arquivos da Função