NAME

Bio::GeneDesign::RestrictionEnzyme

VERSION

Version 5.56

DESCRIPTION

GeneDesign object that represents a type II restriction enzyme

AUTHOR

Sarah Richardson <SMRichardson@lbl.gov>

CONSTRUCTOR METHODS

new

You can create a new enzyme or clone an existing enzyme to create a new instance of an abstract enzyme definition. To do this, provide the -enzyme flag; the constructor will ignore every other argument except for -start.

Required arguments:

EITHER

    -enzyme : a Bio::GeneDesign::RestrictionEnzyme object to clone

OR
    -id     : The name of the enzyme (i.e., BamHI)
    -cutseq : The string describing the enzyme's recognition and cleavage
              site

Optional arguments:

-temp     : The incubation temperature for the enzyme
-tempin   : The heat inactivation temperature for the enzyme
-score    : A float score, usually the price of the enzyme in dollars
-methdam  : Sensitivity to dam methylation; can take the values
              b or blocked,
              i or inhibited,
              u or unknown,
            if undefined, will take the value indifferent.
-methdcm  : Sensitivity to dcm methylation; can take the values
              b or blocked,
              i or inhibited,
              u or unknown,
            if undefined, will take the value indifferent.
-methcpg  : Sensitivity to cpg methylation; can take the values
              b or blocked,
              i or inhibited,
              u or unknown,
            if undefined, will take the value indifferent.
-vendors  : a string of single letter codes that represent vendor
            availability - no spaces.  see vendor() for a list of the
            codes.
-staract  : Whether or not the enzyme exhibits star activity - 1 or 0.
-buffers  : a hash reference; keys are buffer names and values are the
            enzyme activity in that buffer. For example:
            NEB1 => 50, NEB2 => 100, etc.
-start    : An integer representing an offset; usually used only in
            cloned instances, as opposed to abstract instances.
-exclude  : An arrayref full of ids for enzymes that should be
            considered mutually exclusive to this enzyme - see exclude()

FUNCTIONAL METHODS

clone

By default in GeneDesign code, RestrictionEnzyme objects are meant to stand as abstracts - that is, they stand for BamHI in general, and not for a particular instance of a BamHI recognition site. If you want to use the objects in the latter sense, you will need to clone the abstract object instantiated when the definition file is read in, thus generating an arbitrary number of BamHI instances that can then be differentiated by their start attributes.

positions

Generates a hash describing the positions of the enzyme's recognition sites in a nucleotide sequence. Keys are offset in nucleotides, and values are the recognition site found at said offset as a string.

overhang

Given a nucleotide sequence context, what overhang does this enzyme leave, and how far away from the cutsite is it?

Arguments:

display

Generates a tab delimited display string that can be used to print enzyme information out in a tabular format.

common_buffers

Returns an array reference listing the buffers, if any, in which two enzymes both have 100% activity. in boolean mode returns the number of buffers

acceptable_buffer

Returns a buffer in which both enzymes will have at least a thresholded amount of activity.

units

Returns the number of units needed to cleave some sequence

FILTERING METHODS

filter_by_sequence

Arguments: an arrayref of string nucleotide sequences (may be ambiguous)
           a flag indicating whether or not the sequences in the array are
            required (1 means they must NOT match; default 0 means they must
            match)

Returns : 1 if the enzyme passes;
          0 if the enzyme fails.

filter_by_score

Arguments : a float

Returns   : 1 if the enzyme's score is less than or equal to the argument,
            0 if the enzyme's score is higher.

filter_by_vendor

Arguments : an arrayref of vendor abbreviations; see vendor().

Returns   : 1 if the enzyme is supplied by any of the vendors queried,
            0 else.

filter_by_buffer_activity

Arguments : a hashref of buffer thresholds; the key is the buffer name, the
              value is an activity threshold.

Returns   : 1 if the enzyme meets all the buffer requirements,
            0 else.

filter_by_dcm_sensitivity

Arguments : an arrayref of sensitivity values; the key is the sensitivity
              blocked, inhibited, or indifferent

Returns   : 1 if the enzyme meets the dcm sensitivity requirements,
            0 else.

filter_by_dam_sensitivity

Arguments : an arrayref of sensitivity values; the key is the sensitivity
              blocked, inhibited, or indifferent

Returns   : 1 if the enzyme meets the dam sensitivity requirements,
            0 else.

filter_by_cpg_sensitivity

Arguments : an arrayref of sensitivity values; the key is the sensitivity
              blocked, inhibited, or indifferent

Returns   : 1 if the enzyme meets the cpg sensitivity requirements,
            0 else.

filter_by_star_activity

Arguments : 1 if star activity required, 0 else

Returns   : 1 if the enzyme meets the star activity requirements,
            0 else.

filter_by_incubation_temperature

Arguments : an arrayref of acceptable integer incubation temperatures

Returns   : 1 if the enzyme meets the incubation temperature requirements,
            0 else.

filter_by_inactivation_temperature

Arguments : an acceptable integer inactivation temperature maximum

Returns   : 1 if the enzyme meets the inactivation temperature requirement,
            0 else.

filter_by_base_ambiguity

Arguments : "nonNonly" if any non N bases are allowed; "ATCGonly" if only
              A, T, C, or G are allowed

Returns   : 1 if the enzyme meets the ambiguous nucleotide requirement,
            0 else.

filter_by_length

Arguments : an arrayref of acceptable recognition site lengths

Returns   : 1 if the enzyme meets the recognition site length requirements,
            0 else.

filter_by_overhang_palindromy

Arguments : an arrayref of acceptable overhang palindromys, from the list
              pal (palindromic),
              nonpal (nonpalindromic),
              pnon (potentially nonpalindromic)

Returns   : 1 if the enzyme meets the palindromy requirements,
            0 else.

filter_by_stickiness

Arguments : an arrayref of acceptable overhang orientations, from the list
              1 (single basepair overhang),
              5 (five prime overhang),
              3 (three prime overhang),
              b (blunt ended)

Returns   : 1 if the enzyme meets the overhang requirements,
            0 else.

ACCESSOR METHODS

Methods for setting and accessing enzyme attributes

id

The name of the enzyme.

display_name

The name of the enzyme.

score

This attribute initially holds the price in dollars per unit of the enzyme (2009 US Dollars) but can be used to hold any score or cost value.

aggress

Aggressiveness is the number of recognition sites in a template piece of DNA (usually lambda, but sometimes adeno2, pBR322, pUC19, pXba, etc) over the total length of that template piece of DNA. This number tells the manufacturer how much enzyme to sell as a "unit" - the amount of enzyme required to fully digest one microgram of template DNA under reaction conditions in an hour.

len

The length in bases of the recognition sequence (recseq).

methcpg

The effect of CpG methylation on the enzyme's efficacy.

methdcm

The effect of Dcm methylation on the enzyme's efficacy.

methdam

The effect of Dam methylation on the enzyme's efficacy.

buffers

A hash reference where the keys are buffer names and the values are the activity level of the enzyme in that Buffer. Since most of the enzymes in the default GeneDesign list are NEB enzymes, this is usually full of NEB buffers.

vendors

A hash reference where the keys are abbreviations for and the values are names of vendors that stock the enzyme. These are read in from the enzyme file.

B = Invitrogen
C = Minotech
E = Stratagene
F = Thermo Scientific Fermentas
I = SibEnzyme
J = Nippon Gene Co.
K = Takara
M = Roche Applied Science
N = New England Biolabs
O = Toyobo Technologies
Q = Molecular Biology Resources
R = Promega
S = Sigma Aldrich
U = Bangalore Genei
V = Vivantis
X = EURx
Y = CinnaGen

tempin

The temperature in degrees Celsius that deactivates the enzyme.

timein

The time required at inactivation temperature to deactivate the enzyme.

temp

Incubation temperature for the best enzyme activity, in degrees Celsius.

recseq

This attribute is the "clean" description of the enzyme's recognition sequence - that is, no information about cleavage site can be gained from this attribute. This is determined automatically from the cleavage string (cutseq) at instantiation.

seq

Synonym for recseq

cutseq

This attribute is the string description of the enzyme's recognition sequence. It includes information about both the recognition and cleavage sites. See http://rebase.neb.com/rebase/rebrec.html for help interpreting this field.

regex

This attribute stores a set of regular expressions as an array reference to speed the search for recognition sites in sequence. The first entry in the arrayref is the regular expression representing the forward orientation of the recognition sequence; the second entry represents the reverse orientation and is only defined if the recognition site is nonpalindromic.

This attribute is defined at instantiation.

class

Class describes the cutting behavior of an enzyme. The classes used by GeneDesign uses a generalized subset of the classes as described at Rebase - for the purposes of enzyme editing, three classes have so far proven to be enough. See http://rebase.neb.com/cgi-bin/sublist for the full description of enzyme classes.

IIP : This enzyme has a symmetric target and a symmetric cleavage site; this
      usually means that the enzyme cleaves inside its own recognition site.
      This is not the same as overhang palindromy!

IIA : This enzyme has an asymmetric recognition site and usually cleaves
      outside of it.

IIB : This enzyme has one recognition site and two cleavage sites, one on
      either side of the recognition site, and thus cuts itself out of
      sequence.

classex

class_regexes

Short cut to accessing class regular expressions

type

Type describes the kind of overhang left by an enzyme. This is probably not a good use of the word type.

Type may be 5', for a five prime overhang; 3', for a three prime overhang; or b for blunt ends.

onebpoverhang

One basepair overhangs can be harder to ligate than blunt ends. This attribute returns 1 if an enzyme leaves a 1bp overhang and 0 else.

exclude

Some enzymes share overlapping recognition sites. If you are trying to ensure the absence or uniqueness of a recognition site, you will want to be sure to exclude isoschizomers and neoschizomers from consideration elsewhere. The exclude attribute stores an array reference that lists the ids of neo- and isoschizomers - or any arbitrary enzyme that is incompatible with this enzyme - for easy lookup.

palindromy

Information about the overhang the enzyme leaves.

pal     = palindromic
nonpal  = nonpalindromic
pnon    = potentially nonpalindromic, or sometimes palindromic and sometimes
          nonpalindromic
unknown = unknown

staract

1 if the enzyme exhibits star activity, 0 else

start

The offset in nucleotides of the enzymes recognition site in an ORF

outside_cut

inside_cut

COPYRIGHT AND LICENSE

Copyright (c) 2015, Sarah Richardson 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.

* The names of Johns Hopkins, the Joint Genome Institute, the Lawrence Berkeley National Laboratory, the Department of Energy, and the GeneDesign developers may not be used to endorse or promote products derived from this software without specific prior written permission.

THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "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 THE DEVELOPERS 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.