當前位置: 首頁>>代碼示例>>Java>>正文


Java MutableTree類代碼示例

本文整理匯總了Java中dr.evolution.tree.MutableTree的典型用法代碼示例。如果您正苦於以下問題:Java MutableTree類的具體用法?Java MutableTree怎麽用?Java MutableTree使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


MutableTree類屬於dr.evolution.tree包,在下文中一共展示了MutableTree類的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: fillInternalGaps

import dr.evolution.tree.MutableTree; //導入依賴的package包/類
private Object fillInternalGaps(Tree tree, NodeRef node) {

        if (!tree.isExternal(node)) {
            Object left = fillInternalGaps(tree, tree.getChild(node, 0));
            Object right = fillInternalGaps(tree, tree.getChild(node, 1));

            if (tree.getNodeAttribute(node, POP) == null) {

                if (left == null && right == null) {
                    throw new RuntimeException("left and right are both null for node " + node.getNumber());
                }

                if (left == null) left = right;
                if (right == null) right = left;

                if (left.equals(right)) {
                    ((MutableTree) tree).setNodeAttribute(node, POP, left);
                    //System.out.println("Setting pop to " + left + " in node " + node.getNumber());
                } else {
                    throw new RuntimeException(left + "!=" + right + " in children of node " + node.getNumber());
                }
            }
        }
        return tree.getNodeAttribute(node, POP);
    }
 
開發者ID:beast-dev,項目名稱:beast-mcmc,代碼行數:26,代碼來源:MigrateTreeImporter.java

示例2: fillExternalGaps

import dr.evolution.tree.MutableTree; //導入依賴的package包/類
private void fillExternalGaps(Tree tree) {

        for (int i = 0; i < tree.getExternalNodeCount(); i++) {
            NodeRef node = tree.getExternalNode(i);
            if (tree.getNodeAttribute(node, POP) == null) {
                ((MutableTree) tree).setNodeAttribute(node, POP,
                        tree.getNodeAttribute(tree.getParent(node), POP));
            }
        }
    }
 
開發者ID:beast-dev,項目名稱:beast-mcmc,代碼行數:11,代碼來源:MigrateTreeImporter.java

示例3: adjustInternalHeights

import dr.evolution.tree.MutableTree; //導入依賴的package包/類
private static void adjustInternalHeights(MutableTree tree, NodeRef node) {

        if (!tree.isExternal(node)) {
            // pre-order recursion
            for (int i = 0; i < tree.getChildCount(node); i++) {
                adjustInternalHeights(tree, tree.getChild(node, i));
            }
        }

        NodeRef parent = tree.getParent(node);

        if (parent != null) {

            if (tree.getNodeHeight(parent) < tree.getNodeHeight(node)) {
                tree.setNodeHeight(parent, tree.getNodeHeight(node));
            }
        }
    }
 
開發者ID:beast-dev,項目名稱:beast-mcmc,代碼行數:19,代碼來源:TreeUtils.java

示例4: rescaleTree

import dr.evolution.tree.MutableTree; //導入依賴的package包/類
private void rescaleTree(Tree tree, double scale) {
    if (tree instanceof MutableTree) {
        MutableTree mutableTree = (MutableTree) tree;

        for (int i = 0; i < tree.getNodeCount(); i++) {
            NodeRef node = tree.getNode(i);
            if (node != tree.getRoot()) {
                double length = tree.getBranchLength(node);
                mutableTree.setBranchLength(node, length * scale);
            }
        }
    } else {
        throw new IllegalArgumentException("Tree not mutable");
    }
}
 
開發者ID:beast-dev,項目名稱:beast-mcmc,代碼行數:16,代碼來源:LogCombiner.java

示例5: setTree

import dr.evolution.tree.MutableTree; //導入依賴的package包/類
/**
 * Set the tree.
 */
public void setTree(Tree tree) {
	this.tree = tree;

	if (tree != null) {
		if (tree instanceof MutableTree) {
			((MutableTree)tree).addMutableTreeListener(this);
		}

		if (tree instanceof MutableTaxonList) {
			((MutableTaxonList)tree).addMutableTaxonListListener(this);
		}
	}

	repaint();
}
 
開發者ID:beast-dev,項目名稱:beast-mcmc,代碼行數:19,代碼來源:JTreeDisplay.java

示例6: makeCompatible

import dr.evolution.tree.MutableTree; //導入依賴的package包/類
public void makeCompatible(double rootHeight) {
    for( GeneTreeInfo t : getGeneTrees() ) {

        MutableTree tree = t.tree;

        for (int i = 0; i < tree.getExternalNodeCount(); i++) {
            final NodeRef node = tree.getExternalNode(i);
            final NodeRef p = tree.getParent(node);
            tree.setNodeHeight(p, rootHeight + tree.getNodeHeight(p));
        }
        MutableTree.Utils.correctHeightsForTips(tree);
         // (todo) ugly re-init - can I do something better?
        t.wasChanged();
        t.getCoalInfo();
        t.wasBacked = false;
        //t.wasChanged();
   }
}
 
開發者ID:beast-dev,項目名稱:beast-mcmc,代碼行數:19,代碼來源:MulSpeciesBindings.java

示例7: doOperation

import dr.evolution.tree.MutableTree; //導入依賴的package包/類
public double doOperation() {
    if( tree.getInternalNodeCount() < 2 ) {
        throw new RuntimeException("no node found");
    }

    tree.beginTreeEdit();

    switch( nodesToMove ) {
        case 2: move2(); break;
        case 3: move3(); break;
    }

    tree.endTreeEdit();

    // AR not sure whether this check is needed...
    try {
        tree.checkTreeIsValid();
    } catch( MutableTree.InvalidTreeException ite ) {
        throw new RuntimeException(ite.toString());
    }

    return 0;
}
 
開發者ID:beast-dev,項目名稱:beast-mcmc,代碼行數:24,代碼來源:TreeUniform.java

示例8: parseXMLObject

import dr.evolution.tree.MutableTree; //導入依賴的package包/類
@Override
public Object parseXMLObject(XMLObject xo) throws XMLParseException {

    MutableTree model = (MutableTree) xo.getChild(MutableTree.class);
    final CompoundParameter allTraits = (CompoundParameter) xo.getChild(CompoundParameter.class);

    String taxonString = (String) xo.getAttribute(TreeModelParser.TAXON);
    final int leafIndex = model.getTaxonIndex(taxonString);
    if (leafIndex == -1) {
        throw new XMLParseException("Unable to find taxon '" + taxonString + "' in trees.");
    }
    final Parameter leafTrait = allTraits.getParameter(leafIndex);

    boolean setBounds = xo.getAttribute(SET_BOUNDS, true);
    if (setBounds) {

        Parameter.DefaultBounds bound = new Parameter.DefaultBounds(Double.MAX_VALUE, -Double.MAX_VALUE,
                leafTrait.getDimension());
        leafTrait.addBounds(bound);
    }

    return leafTrait;
}
 
開發者ID:beast-dev,項目名稱:beast-mcmc,代碼行數:24,代碼來源:LeafTraitExtractorParser.java

示例9: addNewClades

import dr.evolution.tree.MutableTree; //導入依賴的package包/類
private BitSet addNewClades(final MutableTree tree, final NodeRef node) {

		final BitSet bitSet = new BitSet(tree.getTaxonCount());
		if (tree.isExternal(node)) {
			bitSet.set(hostTaxonList.getTaxonIndex(tree.getNodeTaxon(node).getId()));
		} else {
			for (int i = 0; i < tree.getChildCount(node); ++i) {
				bitSet.or(addNewClades(tree, tree.getChild(node, i)));
			}
		}
		
		if (!clades.containsKey(bitSet))
			clades.put(bitSet, clades.size());

		final int id = clades.get(bitSet);
		ids[(Integer) tree.getNodeAttribute(node, NODE_REF)] = id;
		tree.setNodeAttribute(node, NODE_REF, id);

		return bitSet;
	}
 
開發者ID:armanbilge,項目名稱:BECKY,代碼行數:21,代碼來源:PreAnnotator.java

示例10: annotateModeAttribute

import dr.evolution.tree.MutableTree; //導入依賴的package包/類
private void annotateModeAttribute(MutableTree tree, NodeRef node, String label, HashMap<Object, Integer> values) {
    Object mode = null;
    int maxCount = 0;
    int totalCount = 0;
    int countInMode = 1;

    for (Object key : values.keySet()) {
        int thisCount = values.get(key);
        if (thisCount == maxCount) {
            // I hope this is the intention
            mode = mode.toString().concat("+" + key);
            countInMode++;
        } else if (thisCount > maxCount) {
            mode = key;
            maxCount = thisCount;
            countInMode = 1;
        }
        totalCount += thisCount;
    }
    double freq = (double) maxCount / (double) totalCount * countInMode;
    tree.setNodeAttribute(node, label, mode);
    tree.setNodeAttribute(node, label + ".prob", freq);
}
 
開發者ID:whdc,項目名稱:ieo-beast,代碼行數:24,代碼來源:TreeAnnotator.java

示例11: annotateFrequencyAttribute

import dr.evolution.tree.MutableTree; //導入依賴的package包/類
private void annotateFrequencyAttribute(MutableTree tree, NodeRef node, String label, HashMap<Object, Integer> values) {
    double totalCount = 0;
    Set keySet = values.keySet();
    int length = keySet.size();
    String[] name = new String[length];
    Double[] freq = new Double[length];
    int index = 0;
    for (Object key : values.keySet()) {
        name[index] = key.toString();
        freq[index] = new Double(values.get(key));
        totalCount += freq[index];
        index++;
    }
    for (int i = 0; i < length; i++)
        freq[i] /= totalCount;

    tree.setNodeAttribute(node, label + ".set", name);
    tree.setNodeAttribute(node, label + ".set.prob", freq);
}
 
開發者ID:whdc,項目名稱:ieo-beast,代碼行數:20,代碼來源:TreeAnnotator.java

示例12: annotateHPDAttribute

import dr.evolution.tree.MutableTree; //導入依賴的package包/類
private void annotateHPDAttribute(MutableTree tree, NodeRef node, String label, double hpd, double[] values) {
    int[] indices = new int[values.length];
    HeapSort.sort(values, indices);

    double minRange = Double.MAX_VALUE;
    int hpdIndex = 0;

    int diff = (int) Math.round(hpd * (double) values.length);
    for (int i = 0; i <= (values.length - diff); i++) {
        double minValue = values[indices[i]];
        double maxValue = values[indices[i + diff - 1]];
        double range = Math.abs(maxValue - minValue);
        if (range < minRange) {
            minRange = range;
            hpdIndex = i;
        }
    }
    double lower = values[indices[hpdIndex]];
    double upper = values[indices[hpdIndex + diff - 1]];
    tree.setNodeAttribute(node, label, new Object[]{lower, upper});
}
 
開發者ID:whdc,項目名稱:ieo-beast,代碼行數:22,代碼來源:TreeAnnotator.java

示例13: doOperation

import dr.evolution.tree.MutableTree; //導入依賴的package包/類
public double doOperation() throws OperatorFailedException {
    if( tree.getInternalNodeCount() < 2 ) {
        throw new OperatorFailedException("no node found");
    }

    tree.beginTreeEdit();

    switch( nodesToMove ) {
        case 2: move2(); break;
        case 3: move3(); break;
    }

    tree.endTreeEdit();

    // AR not sure whether this check is needed...
    try {
        tree.checkTreeIsValid();
    } catch( MutableTree.InvalidTreeException ite ) {
        throw new OperatorFailedException(ite.toString());
    }

    return 0;
}
 
開發者ID:whdc,項目名稱:ieo-beast,代碼行數:24,代碼來源:TreeUniform.java

示例14: simulate

import dr.evolution.tree.MutableTree; //導入依賴的package包/類
/**
 * simulates a trait ona tree.
 * @param clone if true, use copy of the tree, otherwise use given tree
 * @return the simulated tree.
 */
public Tree simulate(Tree tree, double value, boolean clone) {
	
	Tree binaryTree = null;
	
	if (clone) {
		binaryTree = new FlexibleTree(tree);
		((FlexibleTree)binaryTree).resolveTree();
	} else {
		binaryTree = tree;	
	}
	simulate((MutableTree)binaryTree, binaryTree.getRoot(), value);
	
	return binaryTree;
}
 
開發者ID:beast-dev,項目名稱:beast-mcmc,代碼行數:20,代碼來源:SimulateTrait.java

示例15: getSyntaxRules

import dr.evolution.tree.MutableTree; //導入依賴的package包/類
@Override
public XMLSyntaxRule[] getSyntaxRules() {
    return new XMLSyntaxRule[]{
            AttributeRule.newStringRule(TreeModelParser.TAXON),
            AttributeRule.newBooleanRule(SET_BOUNDS, true),
            new ElementRule(MutableTree.class),
            new ElementRule(CompoundParameter.class),
    };
}
 
開發者ID:beast-dev,項目名稱:beast-mcmc,代碼行數:10,代碼來源:LeafTraitExtractorParser.java


注:本文中的dr.evolution.tree.MutableTree類示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。