R/biochem.db.r

Defines functions biochem.db

# Biochem data analysis  .. focus on bottom oxygen for now

  biochem.db = function(DS="", p=NULL, ss=NULL, tbl=NULL ) {

    biochem.dir = project.datadirectory("aegisa", "biochem")
    biochem.data.dir = file.path( biochem.dir, "data" )
    biochem.datadump.dir = file.path( biochem.dir, "data", "datadump" )

    # to list table names
    # ROracle::dbGetQuery(con, "select tablespace_name, table_name from all_tables;" )

    bctables = c("bcmissions", "bcevents", "bcactivities", "bcdiscretehedrs",
                 "bcdiscretedtails", "bcdiscretereplicates", "bcgears", "bcdatatypes", "bcunits",
                 "bccollectionmethods", "bcerrorcodes", "bcerrors"
                 )


    if ( DS=="rawdata.datadump" ){

      dir.create( biochem.datadump.dir, recursive=TRUE, showWarnings=FALSE )
      con = ROracle::dbConnect( DBI::dbDriver("Oracle"), dbname=oracle.biochem.server, username=oracle.biochem.user, password=oracle.biochem.password, believeNRows=F)

      for ( o in 1:length(bctables) ) {
        tblname =  bctables[o]
        tblname2 =  paste( "biochem", tblname, sep="." )
        fn = file.path( biochem.datadump.dir, paste( tblname2, "rdata", sep="."))

        query = paste( "select * from ", tblname2 )
        res = NULL

        res = ROracle::dbGetQuery(con, query )
        if (is.null(res)) next()

        names( res) = tolower( names( res) )
        # assign( o, res)
        # save( list=o, file=fn, compress=TRUE )
        save( res, file=fn, compress=TRUE )
      }

      ROracle::dbDisconnect(con)
    }

    if ( DS=="rawdata" ) {
      res = NULL
      fn = file.path( biochem.datadump.dir, paste( "biochem", tbl, "rdata", sep=".") )
      if (file.exists( fn) ) {
        load(fn)
      }
      return(res)
    }

    if ( DS %in% c("discrete_simple", "discrete_simple.redo")) {

      fn = file.path( biochem.datadump.dir, paste( "biochem","discrete_simple", "rdata", sep=".") )

      if (DS=="discrete_simple" ) {
        x = NULL
        if (file.exists( fn) ) {
        load(fn)
        return(x)
      }

      # load all data and flatten in memory

      bcmissions  = biochem.db( DS="rawdata", tbl="bcmissions" )
      bcevents  = biochem.db( DS="rawdata", tbl="bcevents" )
      bcactivities = biochem.db( DS="rawdata", tbl="bcactivities" )
      bcdiscretehedrs  = biochem.db( DS="rawdata", tbl="bcdiscretehedrs" )
      bcgears  = biochem.db( DS="rawdata", tbl="bcgears" )
      bcdiscretedtails = biochem.db( DS="rawdata", tbl="bcdiscretedtails" )

      bccollectionmethods = biochem.db( DS="rawdata", tbl="bccollectionmethods" )
      bcqualcodes  = biochem.db( DS="rawdata", tbl="bcqualcodes" )

      bcdatatypes = biochem.db( DS="rawdata", tbl="bcdatatypes" )
      bcunits = biochem.db( DS="rawdata", tbl="bcunits" )


      x = merge( bcevents, bcmissions, by="mission_seq", suffixes=c("", "_bcmissions") )
      x = merge( bcactivities, x, by="event_seq", suffixes=c("_bcactivities", "") )
      x = merge( bcdiscretehedrs, x, by="activity_seq", suffixes=c("_bcdiscretehdrs", "") )
      x = merge( x, bcgears, by="gear_seq", suffixes=c("", "_bcgears") )
      x = merge( bcdiscretedtails, x, by="discrete_seq", suffixes=c("_bcdiscretedetails", "") )
      x = merge( x, bcqualcodes, by.x="data_qc_code", by.y="qc_code", suffixes=c("", "_bcqualcodes") )
      x = merge( x, bcdatatypes, by="data_type_seq", suffixes=c("", "_bcdatatypes") )
      x = merge( x, bcunits, by="unit_seq", suffixes=c("", "_bcunits") )

      save( x, file=fn, compress=TRUE)

      return(x)

    }


    if (DS %in% c("scotian.shelf.redo", "scotian.shelf") ){

      fn = file.path( biochem.data.dir, "ss.rdata" )

      if (DS=="scotian.shelf") {
        load( fn)
        return(ss)
      }

      if (DS=="scotian.shelf.redo") {
        print( "Data needs to be downloaded manually from the server:")
        print( "  http://www.meds-sdmm.dfo-mpo.gc.ca/biochemQuery/authenticate.do?errors=yes ")
        print( "TODO: make this automatic ..." )

        ess = read.table(file= file.path(biochem.data.dir, "archive", "initial", "ess.dat"), sep=",",header=T)
        ess$region = "4VW"
        wss = read.table(file= file.path(biochem.data.dir,  "archive", "initial", "wss.dat"), sep=",",header=T)
        wss$region = "4X"

        ss = rbind(ess, wss)
        rm(ess, wss)

        names(ss) =  tolower( names(ss) )
        namelist = data.frame( matrix( c(
          "collector_station_name", "station",
          "data_center_code",       "source",
          "start_lat",              "lat",
          "start_lon",              "lon",
          "start_date",              "date"
          ), ncol=2, byrow=T) )
        namelistnames = names(namelist) = c("old", "new")
        namelist = factor2character( namelist, namelistnames)

        for (i in 1:nrow(namelist)) names(ss)[which(names(ss)==namelist$old[i])] = namelist$new[i]

        ss$Z = rowMeans(ss[,c("start_depth","end_depth")], na.rm=T)

        ss$timestamp = lubridate::dmy( as.character(ss$date) )

        ss$id = paste( ss$lon, ss$lat, as.character(ss$timestamp), sep="~" )
        ss$id2 = paste( ss$lon, ss$lat, as.character(ss$timestamp), ss$Z, sep="~" )
        ss = ss[ !duplicated(ss$id2) , ]

        tokeep = c(
          "id", "region", "lon", "lat", "Z", "gear_model", "salinity", "salinity_datatype",
          "temperature", "temperature_datatype", "o2", "o2_datatype", "sigma_t",
          "oxygen_saturation", "timestamp" )
        ss = ss[, tokeep ]

        save(ss, file=fn, compress=T)
        return ( fn )
      }
    }


    if (DS %in% c("sse.bottom", "sse.bottom.redo" ) ) {

      fn = file.path(  biochem.dir, "ss.bottom.rdata" )

      if (DS=="sse.bottom") {
        load( fn)
        return(ss)
      }

      if (DS == "sse.bottom.redo" ) {

        ss = biochem.db( DS="scotian.shelf" )

        ids = sort( unique( ss$id ) )
        s = NULL
        t = which( is.finite(ss$Z) )
        for (i in ids) {
          q = intersect( which( ss$id==i ), t )
          r = which.max( ss$Z[q] )
          s = c(s, q[-r])
        }
        ss = ss[-s,]
        ss$julian = lubridate::yday( ss$timestamp)
        ss$yr =  lubridate::year( ss$timestamp)

        # select shelf data:
        # ss = ss[ which(ss$Z < 600 & ss$Z > 75) , ]
        # ss = ss[ which(ss$yr >= 1960), ]

        save(ss, file=fn, compress=T)
        return (fn )
      }

    }


    if ( DS=="visual.check.of spatial.spead.of data") {
      # visual check of the spatial spread of the data
      if (is.null(ss)) ss = biochem.db( DS="scotian.shelf" )
      plot.new()
      yrs = sort( unique( ss$yr) )
      for (y in yrs) {
        ii = which( ss$yr==y & is.finite(ss$oxygen_saturation ))
        plot( ss$lon, ss$lat, type="n", main=y)
        points(ss$lon[ii], ss$lat[ii])
        print(y)
        pause(5)
      }

      # results:
      # good overall spatial coverage in 1970, 1999-2005
      # good only for 4x : 33 60 66 68 71 73
        good.4vw = c(1970, 1999:2005)
        good.4x  = c(1933, 1960, 1966, 1968, 1970, 1971, 1973, 1999:2005)

    }



    if (DS=="oxygen.annual.old") {
      if (is.null(ss)) ss = biochem.db( DS="scotian.shelf" )
      oxy = stats.by.factors(ss$oxygen_saturation ,  list(yr=ss$yr, region=ss$region) )
      oxy$yr = as.numeric( as.character (oxy$yr) )
      oxy = oxy[ order(oxy$region, oxy$yr) ,]
      return (oxy)
    }

    if (DS=="oxygen.annual") {
      if (is.null(ss)) ss = biochem.db( DS="scotian.shelf" )
      oxy = NULL
      yrs = sort( unique( ss$yr) )
      regions = c("4VW", "4X")
      for (r in regions) {
      for (y in yrs) {
        tt = which( ss$yr==y & ss$region==r)

        if (y==1970) { # selectively remove one area that was heavily sampled relative the rest of the shelf
          tt = intersect( tt, which(ss$lat < 45.4) )
        }

        if (length( tt) < 10) next
        mean = mean( ss$oxygen_saturation [ tt ], na.rm=T, trim=0.1 )
        sd = sd(  ss$oxygen_saturation [ tt ], na.rm=T )
        n = length( which( is.finite(   ss$oxygen_saturation [ tt ] ) ) )
        se = sd / sqrt(n-1)
        ub = mean + 4*se
        lb = mean - 4*se

        rob = intersect( tt, which( ss$oxygen_saturation <=ub & ss$oxygen_saturation >= lb) )
        if (length( rob) < 10) next
        rmean = mean( ss$oxygen_saturation [ rob ], na.rm=T, trim=0.1 )
        rsd = sd( ss$oxygen_saturation [ rob ], na.rm=T )
        rn = length( which( is.finite( ss$oxygen_saturation [ rob ] ) ) )
        rse = rsd / sqrt(rn - 1)

        oxy = rbind( oxy, data.frame(region=r, yr=y, mean=rmean, se=rse, n=rn ) )

      }}
      return (oxy )
    }

    if ( DS == "ess" ) {
      good.4vw = c(1970, 1999:2005)
      oxy = biochem.db( DS="oxygen.annual", ss=biochem.db( DS="sse.bottom" ) )
      ess = which(oxy$region=="4VW" & oxy$yr %in% good.4vw )
      plot.new()
      xval = oxy$yr[ess]
      yval = oxy$mean[ess]
      weight = oxy$n[ess]
      plot(xval, yval)
      lss = predict( loess( yval ~ xval, span=0.5, degree=1), weight=weight, data.frame(xval=xval), se=T )
      lines( xval, lss$fit, col="gray", lty="solid", lwd=4 )
      return (ess)
    }


    if ( DS == "wss" ) {
      oxy = biochem.db( DS="oxygen.annual", ss=biochem.db( DS="sse.bottom" ) )
      good.4x  = c(1933, 1960, 1966, 1968, 1970, 1971, 1973, 1999:2005)
      wss = which(oxy$region=="4X" & oxy$yr %in% good.4x)
      plot.new()
      xval = oxy$yr[wss]
      yval = oxy$mean[wss]
      weight = oxy$n[wss]
      plot(xval, yval)
      lss = predict( loess( yval ~ xval, span=0.5, degree=1), weight=weight, data.frame(xval=xval), se=T )
      lines( xval, lss$fit, col="gray", lty="solid", lwd=4 )
      return (ess)
    }


  }

}
jae0/emaf documentation built on May 28, 2019, 9:57 p.m.