定制 jcbontemps/phylogenetictree 二次开发

按需修改功能、优化性能、对接业务系统,提供一站式技术支持

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

jcbontemps/phylogenetictree

最新稳定版本:1.0.2

Composer 安装命令:

composer require jcbontemps/phylogenetictree

包简介

Compute phylogenetic trees from distance matrix using BioNJ algorithm. It produce Newick file and Weighted newick if needed. There is also a render using Equal-angle algorithm and SVG output for testing. It's recommended to use a JS render like 'phylotree.js' (demo of phylotree.js here http://phylot

README 文档

README

Description

Compute phylogenetic trees from distance matrix using BioNJ algorithm.
It will produce Newick file and Weighted newick if needed.

There is also a render using Equal-angle algorithm and SVG output for testing.
It's preferred to use a JS render like 'phylotree.js' (demo of phylotree.js here http://phylotree.hyphy.org/).

Installation

composer require jcbontemps/phylogenetictree

How to use

We have this image representing locations:

We compute the pixel distance between each point:

abcdef
a0184222177216231
b184045123128200
c222450129121203
d17712312904683
e21612812146083
f23120020383830

This file is saved in ./tests/distance_matrix_pixels.csv in CSV format with ; as separator.

We can use this code to print newicks:

$distance_matrix = BioNJ::distanceCsvToArray('./test/distance_matrix_pixels.csv');
$distance_matrix = BioNJ::normalizeMatrix($distance_matrix, 'auto');
$tree = BioNJ::BioNJ($distance_matrix);
$Newick = $tree->Newick;
echo "Newick generated:"."\n";
echo $Newick."\n";
$NewickW = $tree->newickWeight();
echo "Weighted newick generated:"."\n";
echo $NewickW."\n";

We can use the test render to print this SVG tree:

$render = new EqualAngle();
$svg = $render->compute($tree, 1024, 768, 100, 100, 24, []);
file_put_contents('./test/distance_matrix_pixels.svg', $svg);

It will produce this image:

The other produced image from US Cities:

You can see the complete example in ./tests/testBioNJ.php

License

Copyright (C) 2024  jcbontemps

This program is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.

This program 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 General Public License for more details.

You should have received a copy of the GNU General Public License
along with this program.  If not, see <https://www.gnu.org/licenses/>.

统计信息

  • 总下载量: 39
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 0
  • 点击次数: 2
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 0
  • Watchers: 0
  • Forks: 0
  • 开发语言: PHP

其他信息

  • 授权协议: GPL-3.0-or-later
  • 更新时间: 2024-11-06

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固