knitr::opts_chunk$set( collapse = TRUE, comment = "#>" )
Follow the instructions if you want to ...
If you want the package to help you with aggregation and (some) recoding, look at the "setup" vignettes for supported uploads
Note: the produce_other_report
function can be used to prepare any key-value pair file for an automated submission process (IPEDS or non-IPEDS)
produce_other_report
with your files.If you need assistance understanding what goes into the upload file, contact IPEDS for advice.
For a school WITH the ability to report "Another Gender" in the 2023-2024 reporting cycle
Read code comments in Part B for changes to make if you cannot report "Another Gender"
This provides a start-to-finish example of preparing an admissions submission based on sample data. Always check your results after you upload your txt file to the IPEDS submission portal.
#load packages library(dplyr) library(magrittr) library(IPEDSuploadables)
#create data adm_dat <- data.frame(StudentId = seq(1:24), FtPt = c(rep('FT', 23), 'PT'), Sex = rep(c("M", "F"), 12), GenderDetail = c(rep(c("M", "F"), 11), "U", "A"), Admit = c(rep(1, 16), rep(0, 8)), Enroll = c(rep(1, 12), rep(0, 12)), SAT = c(rep(1, 8), rep(0, 16)), SAT_V = c(500, 560, 600, 660, 700, 760, 800, 800, rep(NA, 16)), SAT_M = c(400, 460, 500, 560, 600, 660, 700, 700, rep(NA, 16)), ACT = c(rep(0, 8), rep(1, 16)), ACT_CMP = c(rep(NA, 8), 32, 32, 31, 31, 30, 30, 29, 29, 28, 28, 27, 27, 26, 26, 25, 25) )
knitr::kable(adm_dat, format = 'html')
#### PART A: General Admissions Criteria partA <- data.frame(UNITID = 999999, SURVSECT = 'ADM', PART = 'A', ADMCON1 = 2, #GPA ADMCON2 = 1, #Rank ADMCON3 = 1, #Record ADMCON4 = 2, #HS grad ADMCON5 = 1, #Recs ADMCON6 = 3, #Portfolio ADMCON7 = 5, #SAT/ACT #1 or 5 = have to do part C ADMCON8 = 2, #TOEFL ADMCON9 = 3, #other test ADMCON10 = 2, #work exp ADMCON11 = 1, #personal statement ADMCON12 = 3 #legacy )
knitr::kable(partA, format = 'html')
##### PART B: Admission Counts; FirstTime UG only partB <- data.frame(UNITID = 999999, SURVSECT = 'ADM', PART = 'B', APPLCNM = nrow(adm_dat[adm_dat$GenderDetail == 'M', ]), APPLCNW = nrow(adm_dat[adm_dat$GenderDetail == 'F', ]), APPLCNT = nrow(adm_dat), ADMSSNM = nrow(adm_dat[adm_dat$GenderDetail == 'M' & adm_dat$Admit == 1,]), ADMSSNW = nrow(adm_dat[adm_dat$GenderDetail == 'F' & adm_dat$Admit == 1,]), ADMSSNT = nrow(adm_dat[adm_dat$Admit == 1,]), ENRLFTM = nrow(adm_dat[adm_dat$GenderDetail == 'M' & adm_dat$Enroll == 1 & adm_dat$FtPt == 'FT', ]), ENRLFTW = nrow(adm_dat[adm_dat$GenderDetail == 'F' & adm_dat$Enroll == 1 & adm_dat$FtPt == 'FT', ]), ENRLFTT = nrow(adm_dat[adm_dat$Enroll == 1 & adm_dat$FtPt == 'FT', ]), ENRLPTM = nrow(adm_dat[adm_dat$GenderDetail == 'M' & adm_dat$Enroll == 1 & adm_dat$FtPt == 'PT', ]), ENRLPTW = nrow(adm_dat[adm_dat$GenderDetail == 'F' & adm_dat$Enroll == 1 & adm_dat$FtPt == 'PT', ]), ENRLPTT = nrow(adm_dat[adm_dat$Enroll == 1 & adm_dat$FtPt == 'PT', ]), #can you report another gender? 1 = yes, 2 = no ADMGU01 = 1, #if you said 1, keep the code below as-is #if you said 2, remove code, and assign -2 to all 4 columns APPLCNAG = nrow(adm_dat[adm_dat$GenderDetail == 'A', ]), ADMSSNAG = nrow(adm_dat[adm_dat$GenderDetail == 'A' & adm_dat$Admit == 1, ]), ENRLFTAG = nrow(adm_dat[adm_dat$GenderDetail == 'A' & adm_dat$Enroll == 1 & adm_dat$FtPt == 'FT', ]), ENRLPTAG = nrow(adm_dat[adm_dat$GenderDetail == 'A' & adm_dat$Enroll == 1 & adm_dat$FtPt == 'PT', ]) ) #mask data if you ARE able to report "Another Gender", # but the count is below 5 in any category #if you are NOT able to report "Another Gender", # this code will not change your data, even if you run it if((partB$APPLCNAG < 5 | partB$ADMSSNAG < 5 | partB$ENRLFTAG < 5 | partB$ENRLPTAG < 5) & partB$ADMGU01 == 1){ partB$ADMGU01 <- 3 partB$APPLCNAG <- -2 partB$ADMSSNAG <- -2 partB$ENRLFTAG <- -2 partB$ENRLPTAG <- -2 }
knitr::kable(partB, format = 'html')
#### PART C: Test Scores adm_enr <- adm_dat %>% filter(Enroll == 1) #in this example we are not supplying ACT test percentiles by subject partC <- data.frame(UNITID = 999999, SURVSECT = 'ADM', PART = 'C', SATINUM = nrow(adm_enr[adm_enr$SAT == 1, ]), SATIPCT = round(nrow(adm_enr[adm_enr$SAT == 1, ])*100/nrow(adm_enr), 0), ACTNUM = nrow(adm_enr[adm_enr$ACT == 1,]), ACTPCT = round(nrow(adm_enr[adm_enr$ACT == 1,])*100/nrow(adm_enr), 0), SATVR25 = quantile(adm_enr$SAT_V[!is.na(adm_enr$SAT_V)], .25), SATVR75 = quantile(adm_enr$SAT_V[!is.na(adm_enr$SAT_V)], .75), SATMT25 = quantile(adm_enr$SAT_M[!is.na(adm_enr$SAT_M)], .25), SATMT75 = quantile(adm_enr$SAT_M[!is.na(adm_enr$SAT_M)], .75), ACTCM25 = quantile(adm_enr$ACT_CMP[!is.na(adm_enr$ACT_CMP)], .25), ACTCM75 = quantile(adm_enr$ACT_CMP[!is.na(adm_enr$ACT_CMP)], .75), ACTEN25 = -2, ACTEN75 = -2, ACTMT25 = -2, ACTMT75 = -2, SATVR50 = quantile(adm_enr$SAT_V[!is.na(adm_enr$SAT_V)], .5), SATMT50 = quantile(adm_enr$SAT_M[!is.na(adm_enr$SAT_M)], .5), ACTCM50 = quantile(adm_enr$ACT_CMP[!is.na(adm_enr$ACT_CMP)], .5), ACTEN50 = -2, ACTMT50 = -2) #mask data for an exam if you have fewer than 5 students counted for it if(partC$SATINUM < 5){ partC <- partC %>% mutate(across(c("SATVR25", "SATVR75", "SATVR50", "SATMT25", "SATMT75", "SATMT50"), function(x) -2)) } if(partC$ACTNUM < 5){ partC <- partC %>% mutate(across(c("ACTCM25", "ACTCM75", "ACTCM50", "ACTMT25", "ACTMT75", "ACTMT50", "ACTEN25", "ACTEN75", "ACTEN50"), function(x) -2)) }
knitr::kable(partC, format = 'html', row.names = FALSE)
The file format is shown below, but the package will actually save this as a txt file at the location of your choice.
produce_other_report(partA, partB, partC, survey = "Admissions")
rbind(IPEDSuploadables:::apply_upload_format(partA), IPEDSuploadables:::apply_upload_format(partB), IPEDSuploadables:::apply_upload_format(partC)) %>% knitr::kable(format = 'html', row.names = FALSE, col.names = '')
This step is no different than any other upload.
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.