Source of file AminoAcidComposition.php
Size: 2,498 Bytes - Last Modified: 2019-05-10T12:24:09+01:00
src/Core/AminoAcidComposition.php
12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879
Covered by 3 test(s):
8081
Covered by 3 test(s):
82
Covered by 1 test(s):
838485
Covered by 2 test(s):
86
Covered by 1 test(s):
878889
Covered by 1 test(s):
90919293949596979899100101102
Covered by 3 test(s):
103104
Covered by 3 test(s):
105106107
| <?php /** * Copyright 2016 University of Liverpool * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ namespace pgb_liv\php_ms\Core; /** * Get molecular formula for common amino acids. * * @author Andrew Collins */ class AminoAcidComposition { const A = 'C3H7NO2'; const C = 'C3H7NO2S'; const D = 'C4H7NO4'; const E = 'C5H9NO4'; const F = 'C9H11NO2'; const G = 'C2H5NO2'; const H = 'C6H9N3O2'; const I = 'C6H13NO2'; const K = 'C6H14N2O2'; const L = 'C6H13NO2'; const M = 'C5H11NO2S'; const N = 'C4H8N2O3'; const P = 'C5H9NO2'; const Q = 'C5H10N2O3'; const R = 'C6H14N4O2'; const S = 'C3H7NO3'; const T = 'C4H9NO3'; const U = 'C3H7NO2Se'; const V = 'C5H11NO2'; const W = 'C11H12N2O2'; const Y = 'C9H11NO3'; /** * Gets the molecular formula for the provided amino acid. * * @param string $acid * Amino acid * @throws \InvalidArgumentException If acid is not a single character or valid amino acid * @return string Molecular formula */ public static function getFormula($acid) { $formula = @constant('pgb_liv\php_ms\Core\AminoAcidComposition::' . $acid); if (! is_null($formula)) { return $formula; } if (strlen($acid) > 1) { throw new \InvalidArgumentException('Value must be a single amino acid. Input was ' . $acid); } throw new \InvalidArgumentException('Value must be a valid amino acid. Input was ' . $acid); } /** * Gets the molecular formula for the provided amino acid. * * @param string $acid * Amino acid * @throws \InvalidArgumentException If acid is not a single character or valid amino acid * @return string Molecular formula */ public static function getFormulaInsensitive($acid) { $acidUp = strtoupper($acid); return self::getFormula($acidUp); } } |