コード例 #1
0
ファイル: Transcription.cs プロジェクト: eiva/Algorithms
 private static uint GetHashCode(NucleotidRna _1, NucleotidRna _2, NucleotidRna _3)
 {
     var a = (uint) _1;
      var b = (uint) _2;
      var c = (uint) _3;
      return (a + 1) | ((b + 1) << 8) | ((c + 1) << 16);
 }
コード例 #2
0
ファイル: Transcription.cs プロジェクト: eiva/Algorithms
 public static AminoAcid Translate(NucleotidRna _1, NucleotidRna _2, NucleotidRna _3)
 {
     var code = GetHashCode(_1, _2, _3);
      AminoAcid res;
      if (!_translationTable.TryGetValue(code, out res))
      {
     throw new ArgumentOutOfRangeException();
      }
      return res;
 }
コード例 #3
0
ファイル: Transcription.cs プロジェクト: eiva/Algorithms
 static void Add(NucleotidRna _1, NucleotidRna _2, NucleotidRna _3, AminoAcid acid)
 {
     var code = GetHashCode(_1, _2, _3);
      _translationTable.Add(code, acid);
 }
コード例 #4
0
ファイル: Convert.cs プロジェクト: eiva/Algorithms
 public static char ToChar(NucleotidRna nucleotid)
 {
     switch (nucleotid)
      {
     case NucleotidRna.A:
        return 'A';
     case NucleotidRna.G:
        return 'G';
     case NucleotidRna.C:
        return 'C';
     case NucleotidRna.U:
        return 'U';
     default:
        throw new ArgumentOutOfRangeException("nucleotid");
      }
 }