Skip to content

Commit

Permalink
Release v0.1.5
Browse files Browse the repository at this point in the history
Release v0.1.5
  • Loading branch information
anthonysena authored Apr 3, 2024
2 parents 32bfbdb + 213d736 commit 3fb59ec
Show file tree
Hide file tree
Showing 65 changed files with 1,123 additions and 1,970 deletions.
6 changes: 3 additions & 3 deletions DESCRIPTION
Original file line number Diff line number Diff line change
@@ -1,8 +1,8 @@
Package: Characterization
Type: Package
Title: Characterizations of Cohorts
Version: 0.1.4
Date: 2024-02-26
Version: 0.1.5
Date: 2024-04-03
Authors@R: c(
person("Jenna", "Reps", , "[email protected]", role = c("aut", "cre")),
person("Patrick", "Ryan", , "[email protected]", role = c("aut"))
Expand Down Expand Up @@ -42,6 +42,6 @@ Remotes:
ohdsi/ShinyAppBuilder,
ohdsi/DatabaseConnector
NeedsCompilation: no
RoxygenNote: 7.2.3
RoxygenNote: 7.3.1
Encoding: UTF-8
VignetteBuilder: knitr
6 changes: 5 additions & 1 deletion NEWS.md
Original file line number Diff line number Diff line change
@@ -1,3 +1,7 @@
Characterization 0.1.5
======================
Changed export to csv approach to use batch export from SQLite (#41)

Characterization 0.1.4
======================
Added extra error logging
Expand All @@ -21,7 +25,7 @@ Fixing bug where cohort_counts were not being saved in the database
Characterization 0.1.0
======================

- added support to enable target cohorts with multiple cohort entries for the aggregate covariate analysis by restructing to first cohort entry and ensuring the subject has a user specified minPriorObservation days observation in the database at first entry and also perform analysis on first outcomes and any outcome that is recorded during TAR.
- added support to enable target cohorts with multiple cohort entries for the aggregate covariate analysis by restricting to first cohort entry and ensuring the subject has a user specified minPriorObservation days observation in the database at first entry and also perform analysis on first outcomes and any outcome that is recorded during TAR.
- added shiny app


Expand Down
127 changes: 60 additions & 67 deletions R/AggregateCovariates.R
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
# Copyright 2022 Observational Health Data Sciences and Informatics
# Copyright 2024 Observational Health Data Sciences and Informatics
#
# This file is part of Characterization
#
Expand Down Expand Up @@ -27,27 +27,25 @@
#'
#' @export
createAggregateCovariateSettings <- function(
targetIds,
outcomeIds,
minPriorObservation = 0,
riskWindowStart = 1,
startAnchor = 'cohort start',
riskWindowEnd = 365,
endAnchor = 'cohort start',
covariateSettings
){

targetIds,
outcomeIds,
minPriorObservation = 0,
riskWindowStart = 1,
startAnchor = "cohort start",
riskWindowEnd = 365,
endAnchor = "cohort start",
covariateSettings) {
errorMessages <- checkmate::makeAssertCollection()
# check targetIds is a vector of int/double
.checkCohortIds(
cohortIds = targetIds,
type = 'target',
type = "target",
errorMessages = errorMessages
)
# check outcomeIds is a vector of int/double
.checkCohortIds(
cohortIds = outcomeIds,
type = 'outcome',
type = "outcome",
errorMessages = errorMessages
)

Expand Down Expand Up @@ -81,12 +79,12 @@ createAggregateCovariateSettings <- function(
minPriorObservation = minPriorObservation,
riskWindowStart = riskWindowStart,
startAnchor = startAnchor,
riskWindowEnd = riskWindowEnd ,
riskWindowEnd = riskWindowEnd,
endAnchor = endAnchor,
covariateSettings = covariateSettings
)

class(result) <- 'aggregateCovariateSettings'
class(result) <- "aggregateCovariateSettings"
return(result)
}

Expand All @@ -106,19 +104,17 @@ createAggregateCovariateSettings <- function(
#'
#' @export
computeAggregateCovariateAnalyses <- function(
connectionDetails = NULL,
cdmDatabaseSchema,
cdmVersion = 5,
targetDatabaseSchema,
targetTable,
outcomeDatabaseSchema = targetDatabaseSchema, # remove
outcomeTable = targetTable, # remove
tempEmulationSchema = getOption("sqlRenderTempEmulationSchema"),
aggregateCovariateSettings,
databaseId = 'database 1',
runId = 1
) {

connectionDetails = NULL,
cdmDatabaseSchema,
cdmVersion = 5,
targetDatabaseSchema,
targetTable,
outcomeDatabaseSchema = targetDatabaseSchema, # remove
outcomeTable = targetTable, # remove
tempEmulationSchema = getOption("sqlRenderTempEmulationSchema"),
aggregateCovariateSettings,
databaseId = "database 1",
runId = 1) {
# check inputs

start <- Sys.time()
Expand All @@ -128,7 +124,7 @@ computeAggregateCovariateAnalyses <- function(
)
on.exit(
DatabaseConnector::disconnect(connection)
)
)

# select T, O, create TnO, TnOc, Onprior T
# into temp table #agg_cohorts
Expand All @@ -145,11 +141,11 @@ computeAggregateCovariateAnalyses <- function(
)

## get counts
sql <- 'select cohort_definition_id, count(*) row_count, count(distinct subject_id) person_count from #agg_cohorts group by cohort_definition_id;'
sql <- "select cohort_definition_id, count(*) row_count, count(distinct subject_id) person_count from #agg_cohorts group by cohort_definition_id;"
sql <- SqlRender::translate(
sql = sql,
targetDialect = connectionDetails$dbms
)
)
counts <- DatabaseConnector::querySql(
connection = connection,
sql = sql,
Expand All @@ -162,7 +158,7 @@ computeAggregateCovariateAnalyses <- function(
connection = connection,
oracleTempSchema = tempEmulationSchema,
cdmDatabaseSchema = cdmDatabaseSchema,
cohortTable = '#agg_cohorts',
cohortTable = "#agg_cohorts",
cohortTableIsTemp = T,
cohortId = -1,
covariateSettings = aggregateCovariateSettings$covariateSettings,
Expand All @@ -176,7 +172,7 @@ computeAggregateCovariateAnalyses <- function(
# could add settings table with this and just have setting id
# as single extra column?

for(tableName in names(result)){
for (tableName in names(result)) {
result[[tableName]] <- result[[tableName]] %>%
dplyr::mutate(
runId = !!runId,
Expand All @@ -185,16 +181,16 @@ computeAggregateCovariateAnalyses <- function(
dplyr::relocate(
"databaseId",
"runId"
)
)
}

# cohort details:
# cohort details:

result$cohortDetails <- DatabaseConnector::querySql(
connection = connection,
sql = SqlRender::translate(
sql = " select * from #cohort_details;",
targetDialect = connectionDetails$dbms
sql = " select * from #cohort_details;",
targetDialect = connectionDetails$dbms
),
snakeCaseToCamelCase = T
) %>%
Expand All @@ -218,14 +214,14 @@ computeAggregateCovariateAnalyses <- function(
)

result$settings <- data.frame(
runId = runId,
databaseId = databaseId,
covariateSettingJson = covariateSettingsJson,
riskWindowStart = aggregateCovariateSettings$riskWindowStart,
startAnchor = aggregateCovariateSettings$startAnchor,
riskWindowEnd = aggregateCovariateSettings$riskWindowEnd ,
endAnchor = aggregateCovariateSettings$endAnchor
)
runId = runId,
databaseId = databaseId,
covariateSettingJson = covariateSettingsJson,
riskWindowStart = aggregateCovariateSettings$riskWindowStart,
startAnchor = aggregateCovariateSettings$startAnchor,
riskWindowEnd = aggregateCovariateSettings$riskWindowEnd,
endAnchor = aggregateCovariateSettings$endAnchor
)

sql <- SqlRender::loadRenderTranslateSql(
sqlFilename = "DropAggregateCovariate.sql",
Expand All @@ -245,17 +241,15 @@ computeAggregateCovariateAnalyses <- function(


createCohortsOfInterest <- function(
connection,
cdmDatabaseSchema,
dbms,
aggregateCovariateSettings,
targetDatabaseSchema,
targetTable,
outcomeDatabaseSchema,
outcomeTable,
tempEmulationSchema
){

connection,
cdmDatabaseSchema,
dbms,
aggregateCovariateSettings,
targetDatabaseSchema,
targetTable,
outcomeDatabaseSchema,
outcomeTable,
tempEmulationSchema) {
sql <- SqlRender::loadRenderTranslateSql(
sqlFilename = "createTargetOutcomeCombinations.sql",
packageName = "Characterization",
Expand All @@ -266,21 +260,21 @@ createCohortsOfInterest <- function(
target_table = targetTable,
outcome_database_schema = outcomeDatabaseSchema,
outcome_table = outcomeTable,
target_ids = paste(aggregateCovariateSettings$targetIds, collapse = ',', sep = ','),
outcome_ids = paste(aggregateCovariateSettings$outcomeIds, collapse = ',', sep = ','),
target_ids = paste(aggregateCovariateSettings$targetIds, collapse = ",", sep = ","),
outcome_ids = paste(aggregateCovariateSettings$outcomeIds, collapse = ",", sep = ","),
min_prior_observation = aggregateCovariateSettings$minPriorObservation,
tar_start = aggregateCovariateSettings$riskWindowStart,
tar_start_anchor = ifelse(
aggregateCovariateSettings$startAnchor == 'cohort start',
'cohort_start_date',
'cohort_end_date'
),
aggregateCovariateSettings$startAnchor == "cohort start",
"cohort_start_date",
"cohort_end_date"
),
tar_end = aggregateCovariateSettings$riskWindowEnd,
tar_end_anchor = ifelse(
aggregateCovariateSettings$endAnchor == 'cohort start',
'cohort_start_date',
'cohort_end_date'
)
aggregateCovariateSettings$endAnchor == "cohort start",
"cohort_start_date",
"cohort_end_date"
)
)

DatabaseConnector::executeSql(
Expand All @@ -289,5 +283,4 @@ createCohortsOfInterest <- function(
progressBar = FALSE,
reportOverallTime = FALSE
)

}
2 changes: 1 addition & 1 deletion R/Characterization.R
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
# Copyright 2022 Observational Health Data Sciences and Informatics
# Copyright 2024 Observational Health Data Sciences and Informatics
#
# This file is part of Characterization
#
Expand Down
Loading

0 comments on commit 3fb59ec

Please sign in to comment.