package dr.evomodel.ibd; import dr.evomodel.substmodel.FrequencyModel; import dr.evomodel.substmodel.HKY; import dr.inference.model.Parameter; /** * Package: dr.evomodel.ibd * Description: * <p/> * <p/> * Created by * avaleks (alexander.alekseyenko@gmail.com) * Date: 05-Aug-2008 * Time: 09:32:35 */ public class HKYRates extends HKY { /** * Constructor */ public HKYRates(Parameter kappaParameter, FrequencyModel freqModel) { super(kappaParameter, freqModel); } public double[] getRelativeRates(double[] rateMatrix) { double kappa = getKappa(); double[] freq = getFrequencyModel().getFrequencies(); // A - C - G - T rateMatrix[0] = -(freq[1] + freq[3]) - freq[2] * kappa; rateMatrix[1] = freq[1]; rateMatrix[2] = freq[2] * kappa; rateMatrix[3] = freq[3]; rateMatrix[4] = freq[0]; rateMatrix[5] = -(freq[0] + freq[2]) - freq[3] * kappa; rateMatrix[6] = freq[2]; rateMatrix[7] = freq[3] * kappa; rateMatrix[8] = freq[0] * kappa; rateMatrix[9] = freq[1]; rateMatrix[10] = -(freq[1] + freq[3]) - freq[0] * kappa; rateMatrix[11] = freq[3]; rateMatrix[12] = freq[0]; rateMatrix[13] = freq[1] * kappa; rateMatrix[14] = freq[2]; rateMatrix[15] = -(freq[0] + freq[1]) - freq[1] * kappa; return rateMatrix; } }