knitr::opts_chunk$set( collapse = TRUE, comment = "#>" )
library(samplingR)
La población está compuesta por 2 estratos generados sintéticamente a partir de dos distribuciones normales.
N1<-585479 pen<-rnorm(N1, 750, 100)
N2<-932992 ass<-rnorm(N2, 1500, 500)
datos<-cbind(c(pen, ass), c(rep("pensionista", N1), rep("asalariado", N2))) N<-N1+N2
Nh<-c(N1, N2) n<-800 strata.allocation(Nh=Nh, n=n, alloc="unif")
C<-12000 Cini<-5000 ch<-c(45, 20) size<-strata.samplesize.cost(Nh=Nh, C=C, cini=Cini, ch=ch, alloc="unif") paste("Tamaño de muestra", size) nh.unif<-strata.allocation(Nh=Nh, n=size, alloc="unif") paste(c("Estrato 1:", "Estrato 2"), nh.unif) paste("Coste:", Cini+sum(ch*nh.unif))
Como los tamaños de muestra deben ser enteros redondeamos al entero inferior.
nh.unif<-floor(nh.unif) paste(c("Estrato 1:", "Estrato 2"), nh.unif) paste("Coste:", Cini+sum(ch*nh.unif))
strata.allocation(Nh=Nh, n=n, alloc="prop")
size<-strata.samplesize.cost(Nh=Nh, C=C, cini=Cini, ch=ch, alloc="prop") paste("Tamaño de muestra", size) nh.unif<-floor(strata.allocation(Nh=Nh, n=size, alloc="prop")) paste(c("Estrato 1:", "Estrato 2"), nh.unif) paste("Coste:", Cini+sum(ch*nh.unif))
La afijación de Neyman depende de las cuasivarianzas de los estratos, por lo que se deben estimar.
Opción 1: usar las varianzas reales como estimadores (solución teórica)
vart<-c(var(pen), var(ass)) strata.allocation(Nh=Nh, n=n, var=vart, alloc="min")
Opción 2: tomar una muestra previa para estimar las cuasivarianzas de los estratos.
sample<-strata.sample(data=datos, n=c(20, 20)) var<-c(var(sample[which(sample[,2]=="asalariado"),1]), var(sample[which(sample[,2]=="pensionista"),1])) strata.allocation(Nh=Nh, n=n, var=var, alloc="min")
Opción 3: estimación más conservadora. Suponemos cuasivarianza máxima en todos los estratos = $\frac{N_h}{N_h-1}p(1-p)$ con p=0.5
var<-c(Nh/(Nh-1)*0.5*(1-0.5)) strata.allocation(Nh=Nh, n=n, var=var, alloc="min")
Si no se fija la varianza en la función se mostrará un warning y la varianza declarada en la función será la máxima para cada estrato.
strata.allocation(Nh=Nh, n=n, alloc="min")
La estimación conservadora coincide con el cálculo de afijación proporcional.
En la afijación de mínima varianza optimizando con una función de costes es equivalente a utilizar la afijación óptima.
size<-strata.samplesize.cost(Nh=Nh, var=vart, C=C, cini=Cini, ch=ch, alloc="optim") paste("Tamaño de muestra", size) nh.optim<-floor(strata.allocation(Nh=Nh, n=size, var=vart, alloc="optim", C=C, cini=Cini, ch=ch)) paste(c("Estrato 1:", "Estrato 2"), nh.optim) paste("Coste:", Cini+sum(ch*nh.optim))
Any scripts or data that you put into this service are public.
Add the following code to your website.
For more information on customizing the embed code, read Embedding Snippets.