package dr.evomodelxml.sitemodel;
import dr.evomodel.sitemodel.SampleStateAndCategoryModel;
import dr.evomodel.substmodel.SubstitutionModel;
import dr.inference.model.Parameter;
import dr.xml.*;
import java.util.Vector;
/**
*
*/
public class SampleStateAndCategoryModelParser extends AbstractXMLObjectParser {
public static final String SAMPLE_STATE_AND_CATEGORY_MODEL = "sampleStateAndCategoryModel";
public static final String MUTATION_RATE = "mutationRate";
public static final String CATEGORY_PARAMETER = "categoriesParameter";
public String getParserName() {
return SAMPLE_STATE_AND_CATEGORY_MODEL;
}
public Object parseXMLObject(XMLObject xo) throws XMLParseException {
XMLObject cxo = xo.getChild(MUTATION_RATE);
Parameter muParam = (Parameter) cxo.getChild(Parameter.class);
cxo = xo.getChild(CATEGORY_PARAMETER);
Parameter catParam = (Parameter) cxo.getChild(Parameter.class);
Vector subModels = new Vector();
for (int i = 0; i < xo.getChildCount(); i++) {
if (xo.getChild(i) instanceof SubstitutionModel) {
subModels.addElement(xo.getChild(i));
}
}
return new SampleStateAndCategoryModel(muParam, catParam, subModels);
}
//************************************************************************
// AbstractXMLObjectParser implementation
//************************************************************************
public String getParserDescription() {
return "A SiteModel that has a discrete distribution of substitution models over sites, " +
"designed for sampling of rate categories and internal states.";
}
public Class getReturnType() {
return SampleStateAndCategoryModel.class;
}
public XMLSyntaxRule[] getSyntaxRules() {
return rules;
}
private final XMLSyntaxRule[] rules = {
new ElementRule(MUTATION_RATE,
new XMLSyntaxRule[]{new ElementRule(Parameter.class)}),
new ElementRule(CATEGORY_PARAMETER,
new XMLSyntaxRule[]{new ElementRule(Parameter.class)}),
new ElementRule(SubstitutionModel.class, 1, Integer.MAX_VALUE)
};
}