EEDB::Experiment - EEDB::Experiment documentation


EdgeExpressDB documentation Contained in the EdgeExpressDB distribution.

Index


Code Index:

NAME - EEDB::Experiment

Top

SYNOPSIS

Top

DESCRIPTION

Top

CONTACT

Top

Jessica Severin <severin@gsc.riken.jp>

LICENSE

Top

 * Software License Agreement (BSD License)
 * EdgeExpressDB [eeDB] system
 * copyright (c) 2007-2009 Jessica Severin RIKEN OSC
 * All rights reserved.
 * Redistribution and use in source and binary forms, with or without
 * modification, are permitted provided that the following conditions are met:
 *     * Redistributions of source code must retain the above copyright
 *       notice, this list of conditions and the following disclaimer.
 *     * Redistributions in binary form must reproduce the above copyright
 *       notice, this list of conditions and the following disclaimer in the
 *       documentation and/or other materials provided with the distribution.
 *     * Neither the name of Jessica Severin RIKEN OSC nor the
 *       names of its contributors may be used to endorse or promote products
 *       derived from this software without specific prior written permission.
 *
 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS ''AS IS'' AND ANY
 * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
 * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
 * DISCLAIMED. IN NO EVENT SHALL COPYRIGHT HOLDERS BE LIABLE FOR ANY
 * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
 * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
 * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
 * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
 * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.

APPENDIX

Top

The rest of the documentation details each of the object methods. Internal methods are usually preceded with a _


EdgeExpressDB documentation Contained in the EdgeExpressDB distribution.

my $__riken_EEDB_experiment_global_should_cache = 1;
my $__riken_EEDB_experiment_global_id_cache = {};
my $__riken_EEDB_experiment_global_name_cache = {};

$VERSION = 0.953;

package EEDB::Experiment;

use strict;
use Time::HiRes qw(time gettimeofday tv_interval);

use MQdb::MappedQuery;
our @ISA = qw(MQdb::MappedQuery);

#################################################
# Class methods
#################################################

sub class { return "Experiment"; }

sub set_cache_behaviour {
  my $class = shift;
  my $mode = shift;

  $__riken_EEDB_experiment_global_should_cache = $mode;

  if(defined($mode) and ($mode eq '0')) {
    #if turning off caching, then flush the caches
    $__riken_EEDB_experiment_global_id_cache = {};
    $__riken_EEDB_experiment_global_name_cache = {};
  }
}



#################################################
# Instance methods
#################################################

sub init {
  my $self = shift;
  $self->SUPER::init;
  
  $self->{'series_name'} = undef;
  $self->{'exp_accession'} = undef;
  $self->{'series_point'} = undef;
  
  return $self;
}


##########################
#
# getter/setter methods of data which is stored in database
#
##########################

sub exp_accession {
  my $self = shift;
  return $self->{'exp_accession'} = shift if(@_);
  return $self->{'exp_accession'};
}

sub display_name {
  my $self = shift;
  return $self->{'display_name'} = shift if(@_);
  if(!defined($self->{'display_name'}) and defined($self->{'exp_accession'})) {
    return $self->{'exp_accession'};
  } else {
    return $self->{'display_name'};
  }
}

sub platform {
  my $self = shift;
  return $self->{'platform'} = shift if(@_);
  $self->{'platform'}='' unless(defined($self->{'platform'}));
  return $self->{'platform'};
}

sub series_name {
  my $self = shift;
  return $self->{'series_name'} = shift if(@_);
  $self->{'series_name'}='' unless(defined($self->{'series_name'}));
  return $self->{'series_name'};
}

sub series_point {
  my $self = shift;
  return $self->{'series_point'} = shift if(@_);
  $self->{'series_point'}=0 unless(defined($self->{'series_point'}));
  return $self->{'series_point'};
}

sub is_active {
  my $self = shift;
  return $self->{'is_active'} = shift if(@_);
  $self->{'is_active'}='' unless(defined($self->{'is_active'}));
  return $self->{'is_active'};
}

sub metadataset {
  my $self = shift;
  
  if(!defined($self->{'metadataset'})) {
    $self->{'metadataset'} = new EEDB::MetadataSet;

    if($self->database) {
      my $symbols = EEDB::Symbol->fetch_all_by_experiment_id($self->database, $self->id);
      $self->{'metadataset'}->add_metadata(@$symbols);

      my $mdata = EEDB::Metadata->fetch_all_by_experiment_id($self->database, $self->id);
      $self->{'metadataset'}->add_metadata(@$mdata);
    }
  }
  return $self->{'metadataset'};
}

####################################

sub display_desc
{
  my $self = shift;
  my $str = sprintf("Experiment(%s) [%s] %s : (%s, %s) : %s", 
    $self->id,
    $self->platform,
    $self->display_name,
    $self->series_name,
    $self->series_point,
    $self->exp_accession);
  return $str;
}

sub display_contents {
  my $self = shift;
  my $str = $self->display_desc;
  $str .= "\n". $self->metadataset->display_contents;   
  return $str;
}

####################################

sub xml_start {
  my $self = shift;
  my $str = sprintf("<experiment id=\"%d\" platform=\"%s\" name=\"%s\" exp_acc=\"%s\" ",
           $self->id,
           $self->platform,
           $self->display_name,
           $self->exp_accession);
  $str .= sprintf("series_name=\"%s\" ", $self->series_name) if($self->series_name);
  $str .= sprintf("series_point=\"%s\" ", $self->series_point) if(defined($self->series_point));
  $str .= ">\n";
  return $str;
}

sub xml_end {
  my $self = shift;
  return "</experiment>\n"; 
}

sub xml {
  my $self = shift;
  
  my $str = $self->xml_start;

  $str .= $self->metadataset->xml;
           
  $str .= $self->xml_end;
  return $str;
}


#################################################
#
# DBObject override methods
#
#################################################

sub store {
  my $self = shift;
  my $db   = shift;
  
  if($db) { $self->database($db); }
  my $dbh = $self->database->get_connection;  
  my $sql = "INSERT ignore INTO experiment ".
             "(exp_accession, display_name, platform, series_name, series_point, is_active) ".
             "VALUES(?,?,?,?,?,?)";
  my $sth = $dbh->prepare($sql);
  $sth->execute($self->exp_accession,
                $self->display_name,
                $self->platform,
                $self->series_name,
                $self->series_point,
                $self->is_active
                );

  my $dbID = $sth->{'mysql_insertid'};
  $sth->finish;
  unless($dbID) {
    $sql = "select experiment_id from experiment where exp_accession=?";
    $dbID = $self->fetch_col_value($self->database, $sql, $self->exp_accession);
  }
  $self->primary_id($dbID);
  
  #now do the symbols and metadata  
  $self->store_metadata;

  return $self;
}

sub store_metadata {
  my $self = shift;
  die("error no database to store metadata\n") unless($self->database);

  my $mdata_list = $self->metadataset->metadata_list;
  foreach my $mdata (@$mdata_list) {
    if(!defined($mdata->primary_id)) { 
      $mdata->store($self->database);
      $mdata->store_link_to_experiment($self);
    }
  }
}

sub update {
  my $self = shift;

  die("error no database set\n") unless($self->database);
  dies("Experiment with undef id") unless(defined($self->primary_id));
  
  my $dbc = $self->database->get_connection;  
  my $sql = "UPDATE experiment SET display_name=? WHERE experiment_id=?";
  my $sth = $dbc->prepare($sql);
  $sth->execute($self->display_name,
                $self->id);
  $sth->finish;
}



##### DBObject instance override methods #####

sub mapRow {
  my $self = shift;
  my $rowHash = shift;
  my $dbh = shift;

  my $dbID = $rowHash->{'experiment_id'};
  if(($__riken_EEDB_experiment_global_should_cache != 0) and ($self->database())) {
    my $cached_self = $__riken_EEDB_experiment_global_id_cache->{$self->database() . $dbID};
    if(defined($cached_self)) { 
      return $cached_self; 
    }
  }

  $self->primary_id($rowHash->{'experiment_id'});
  $self->series_name($rowHash->{'series_name'});
  $self->exp_accession($rowHash->{'exp_accession'});
  $self->display_name($rowHash->{'display_name'});
  $self->platform($rowHash->{'platform'});
  $self->series_point($rowHash->{'series_point'});
  $self->is_active($rowHash->{'is_active'});
   
  if($__riken_EEDB_experiment_global_should_cache != 0) {
    $__riken_EEDB_experiment_global_id_cache->{$self->database() . $self->id} = $self;
    $__riken_EEDB_experiment_global_name_cache->{$self->database() . $self->exp_accession} = $self;
  }

  return $self;
}


##### public class methods for fetching by utilizing DBObject framework methods #####

sub fetch_by_id {
  my $class = shift;
  my $db = shift;
  my $id = shift;

  if($__riken_EEDB_experiment_global_should_cache != 0) {
    my $feature = $__riken_EEDB_experiment_global_id_cache->{$db . $id};
    if(defined($feature)) { return $feature; }
  }

  my $sql = "SELECT * FROM experiment WHERE experiment_id=?";
  return $class->fetch_single($db, $sql, $id);
}

sub fetch_all {
  my $class = shift;
  my $db = shift;

  my $sql = "SELECT * FROM experiment ORDER BY platform, series_name, series_point, exp_accession";
  return $class->fetch_multiple($db, $sql);
}

sub fetch_all_by_platform {
  my $class = shift;
  my $db = shift;
  my $platform = shift;

  my $sql = "SELECT * FROM experiment WHERE platform=? ORDER BY platform, series_name, series_point, exp_accession";
  return $class->fetch_multiple($db, $sql, $platform);
}

sub fetch_by_exp_accession {
  my $class = shift;
  my $db = shift;
  my $exp_accession = shift;

  if($__riken_EEDB_experiment_global_should_cache != 0) {
    my $feature = $__riken_EEDB_experiment_global_name_cache->{$db . $exp_accession};
    if(defined($feature)) { return $feature; }
  }

  my $sql = "SELECT * FROM experiment WHERE exp_accession=?";
  return $class->fetch_single($db, $sql, $exp_accession);
}


sub fetch_all_by_filter_search {
  my $class = shift;
  my $db = shift;
  my $filter = shift; 
  my $response_limit = shift; #optional
  
  my $filter_sql = "(SELECT distinct t1.experiment_id FROM \n";

  my @clauses = split (/and/, $filter);
  my $and_count=0;
  foreach my $and_clause (@clauses) {
    my $or_sql = "(SELECT distinct experiment_id FROM experiment_2_symbol join symbol using(symbol_id) WHERE "; 
    #sym_value like "RIKEN1%" or sym_value like 'RIKEN3%' or sym_value like 'CAGE%')t1
    #printf("or block :: %s\n", $and_clause);
    my @toks = split (/or/, $and_clause);
    my $or_count=0;
    foreach my $tok (@toks)  {
      $or_count++;
      $tok =~ s/^\s+//g;
      $tok =~ s/\s+$//g;
      $tok =~ s/_/\\_/g;
      $tok =~ s/\"/\\\"/g; 
      $tok =~ s/\'/\\\'/g;  #'
      if($or_count>1) { $or_sql .= " or "; }
      $or_sql .= sprintf(" sym_value like \"%s%%\" ", $tok);
      
    }
    $and_count++;
    $or_sql .= sprintf(") t%d", $and_count);
    if($and_count>1) { $filter_sql .= ",\n"; }
    $filter_sql .= "  ". $or_sql;
  }
  if($and_count > 1) {
    $filter_sql .= "\nWHERE ";
    my $x=1;
    while($x < $and_count) {
      if($x>1) { $filter_sql .= " AND "; }
      $filter_sql .= sprintf(" t%d.experiment_id = t%d.experiment_id ", $x, $x+1);
      $x++;
    }
  }

  $filter_sql .= ")";
    
  my $sql = sprintf("SELECT e.* FROM experiment e join %s filter where e.experiment_id = filter.experiment_id", $filter_sql);
  $sql .= sprintf(" LIMIT %d", $response_limit) if($response_limit);

  #print($sql, "\n", );
  return $class->fetch_multiple($db, $sql);
  #return [];
}


1;