phylotree
Version:
A JavaScript library for developing applications and interactive visualizations involving [phylogenetic trees](https://en.wikipedia.org/wiki/Phylogenetic_tree), written as an extension of the [D3](http://d3js.org) [hierarchy layout](https://github.com/d3/
51 lines (36 loc) • 1.53 kB
JavaScript
const fs = require("fs"),
phylotree = require("../dist/phylotree.js"),
commander = require("commander"),
_ = require("underscore");
commander
.arguments("<newick>", "Input newick file")
.requiredOption("-s --source <node>", "Source Node")
.requiredOption("-t --target <node>", "Target Node")
.option("-i --include-source-length", "Include source node's length as part of distance")
.usage("./test/data/CD2-relax.new -s Cow -t Cat")
.on("--help", function() {
console.log("\nComputes the distance from the source tip to target tip. Does *not* include the length of the source tip by default.");
})
.parse(process.argv);
fs.readFile(commander.args[0], (err, newick_data) => {
const tree = new phylotree.phylotree(newick_data.toString());
phylotree.pairwise_distances(tree);
// GET SOURCE NODE
const sourceNode = tree.getNodeByName(commander.source)
if(_.isUndefined(sourceNode)) {
throw new Error('Could not find source node with name ' + commander.source)
}
// GET LEAF INDEX OF TARGET
const targetNode = tree.getNodeByName(commander.target);
if(_.isUndefined(targetNode)) {
throw new Error('Could not find target node with name ' + commander.target)
}
const targetIndex = targetNode['cot_leaf_index'];
let distance = sourceNode['cot_path_to_leaves_above'][targetIndex];
// if include source tip length, add it
if(commander.includeSourceLength) {
distance+=parseFloat(sourceNode.data.attribute);
}
console.log(distance);
});