/*
* AncestralStatesComponentOptions.java
*
* Copyright (c) 2002-2015 Alexei Drummond, Andrew Rambaut and Marc Suchard
*
* This file is part of BEAST.
* See the NOTICE file distributed with this work for additional
* information regarding copyright ownership and licensing.
*
* BEAST is free software; you can redistribute it and/or modify
* it under the terms of the GNU Lesser General Public License as
* published by the Free Software Foundation; either version 2
* of the License, or (at your option) any later version.
*
* BEAST is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with BEAST; if not, write to the
* Free Software Foundation, Inc., 51 Franklin St, Fifth Floor,
* Boston, MA 02110-1301 USA
*/
package dr.app.beauti.components.ancestralstates;
import dr.app.beauti.options.*;
import java.io.Serializable;
import java.util.*;
/**
* @author Andrew Rambaut
* @version $Id$
*/
public class AncestralStatesComponentOptions implements ComponentOptions {
public AncestralStatesComponentOptions() {
}
public void createParameters(final ModelOptions modelOptions) {
}
public void selectParameters(final ModelOptions modelOptions, final List<Parameter> params) {
}
public void selectStatistics(final ModelOptions modelOptions, final List<Parameter> stats) {
// no statistics required
}
public void selectOperators(final ModelOptions modelOptions, final List<Operator> ops) {
}
private AncestralStateOptions getOptions(final AbstractPartitionData partition) {
AncestralStateOptions options = ancestralStateOptionsMap.get(partition);
if (options == null) {
options = new AncestralStateOptions();
ancestralStateOptionsMap.put(partition, options);
}
return options;
}
public boolean usingAncestralStates(final AbstractPartitionData partition) {
return reconstructAtNodes(partition) || reconstructAtMRCA(partition) || isCountingStates(partition) || dNdSRobustCounting(partition);
}
public boolean reconstructAtNodes(final AbstractPartitionData partition) {
return getOptions(partition).reconstructAtNodes;
}
public void setReconstructAtNodes(final AbstractPartitionData partition, boolean reconstructAtNodes) {
getOptions(partition).reconstructAtNodes = reconstructAtNodes;
}
public boolean reconstructAtMRCA(final AbstractPartitionData partition) {
return getOptions(partition).reconstructAtMRCA;
}
public void setReconstructAtMRCA(final AbstractPartitionData partition, boolean reconstructAtMRCA) {
getOptions(partition).reconstructAtMRCA = reconstructAtMRCA;
}
public String getMRCATaxonSet(final AbstractPartitionData partition) {
AncestralStateOptions options = ancestralStateOptionsMap.get(partition);
return options.mrcaTaxonSetName;
}
public void setMRCATaxonSet(final AbstractPartitionData partition, String taxonSetName) {
getOptions(partition).mrcaTaxonSetName = taxonSetName;
}
public boolean isCountingStates(final AbstractPartitionData partition) {
return getOptions(partition).countingStates;
}
public void setCountingStates(final AbstractPartitionData partition, boolean isCountingStates) {
getOptions(partition).countingStates = isCountingStates;
}
public boolean isCompleteHistoryLogging(final AbstractPartitionData partition) {
return getOptions(partition).isCompleteHistoryLogging;
}
public void setCompleteHistoryLogging(final AbstractPartitionData partition, boolean isCompleteHistoryLogging) {
getOptions(partition).isCompleteHistoryLogging = isCompleteHistoryLogging;
}
public boolean dNdSRobustCounting(final AbstractPartitionData partition) {
return getOptions(partition).dNdSRobustCounting;
}
public void setDNdSRobustCounting(final AbstractPartitionData partition, boolean dNdSRobustCounting) {
if (dNdSRobustCounting && partition.getPartitionSubstitutionModel().getCodonPartitionCount() != 3) {
throw new IllegalArgumentException("dNdS Robust Counting can only be used with 3 codon partition models.");
}
if (dNdSRobustCounting && (partition.getPartitionSubstitutionModel().isGammaHetero() ||
partition.getPartitionSubstitutionModel().isInvarHetero())) {
throw new IllegalArgumentException("dNdS Robust Counting can only be when site-specific rate heterogeneity is off.");
}
getOptions(partition).dNdSRobustCounting = dNdSRobustCounting;
}
public boolean dNdSRobustCountingAvailable(final AbstractPartitionData partition) {
// todo - are there other constraints of the use of this model?
return partition.getPartitionSubstitutionModel().getCodonPartitionCount() == 3 &&
!partition.getPartitionSubstitutionModel().isGammaHetero() &&
!partition.getPartitionSubstitutionModel().isInvarHetero();
}
class AncestralStateOptions implements Serializable {
boolean reconstructAtNodes = false;
boolean reconstructAtMRCA = false;
String mrcaTaxonSetName = null;
boolean countingStates = false;
boolean isCompleteHistoryLogging = false;
boolean dNdSRobustCounting = false;
};
private final Map<AbstractPartitionData, AncestralStateOptions> ancestralStateOptionsMap = new HashMap<AbstractPartitionData, AncestralStateOptions>();
}