Clockor2: Inferring global and local strict molecular clocks using root-to-tip regression
Data files
Jan 17, 2024 version files 9.50 KB
-
README.md
3.09 KB
-
simStudyData.RData
6.40 KB
Abstract
Molecular sequence data from rapidly evolving organisms are often sampled at different points in time. Sampling times can then be used for molecular clock calibration. The root-to-tip (RTT) regression is an essential tool to assess the degree to which the data behave in a clock-like fashion. Here, we introduce Clockor2, a client-side web application for conducting RTT regression. Clockor2 uniquely allows users to quickly fit local and global molecular clocks, thus handling the increasing complexity of genomic datasets that sample beyond the assumption homogeneous host populations. Clockor2 is efficient, handling trees of up to the order of 10^4 tips, with significant speed increases compared to other RTT regression applications. Although clockor2 is written as a web application, all data processing happens on the client-side, meaning that data never leaves the user's computer. Clockor2 is freely available at https://clockor2.github.io/
README: Clockor2: Inferring global and local strict molecular clocks using root-to-tip regression
Files in this repo
- simStudy.R - R script to produce the simulation study.
- simStudyData.RData - The compressed data produced by simStudy.R. Load this file if you want to reproduce the analysis, but don't want to regenerate all the data yourself. This is a convenience file.
- testTrees.R - R script to produce the trees used as test cases for the simulation study of the clock search feature
- clockSearchWrapper.ts - TypeScript file that call the clockSearch function from the main Clockor2 repo for use in the simulation study. Further details in lines 1-9 to run. Configuration can be difficult. See https://github.com/LeoFeatherstone/clockor2Paper (opens in new window) further the an example config.ts file.
About
https://doi.org/10.5061/dryad.gxd2547sn (opens in new window)
Welcome to the Clockor2 code base! The Clockor2 app is available at clockor2.github.io (opens in new window).
Clockor2 is a client-side web application for conducting root-to-tip (RTT) regression - the fastest and most widely used method to calibrate strict molecular clocks. See the documentation (opens in new window) for more information.
Clockor2 is open-source and licensed under the GNU General Public License v3.0 (opens in new window). We welcome contributions, feature requests, and bug reports. See below for a guide on developing Clockor2.
Citation
Featherstone, L. A., Rambaut, A., Duchene, S., & Wirth, W. (2023). Inferring global and local strict molecular clocks using root-to-tip regression. bioRxiv. https://doi.org/10.1101/2023.07.13.548947 (opens in new window)
Development
Clockor2 is built with Create React App (opens in new window), using the Redux (opens in new window) and Redux Toolkit (opens in new window) TS template.
To get started clone the repo and install the dependencies.
bash
git clone https://github.com/clockor2/clockor2.git && cd clockor2
npm install
Start the development server for local development.
bash
npm run start
Run test with jest (opens in new window)
bash
npm run test
Some of the tools used by the project include:
- React - https://www.youtube.com/watch?v=s2skans2dP4&ab_channel=DennisIvy (opens in new window)
- Flowbite - https://flowbite-react.com/ (opens in new window)
- Redux - https://react-redux.js.org/tutorials/quick-start (opens in new window)
- Phylocanvas - https://gitlab.com/cgps/phylocanvas/phylocanvas.gl (opens in new window)
- Plotly - https://github.com/plotly/react-plotly.js (opens in new window)
- phylojs - https://github.com/clockor2/phylojs (opens in new window)
The initial design plan:
This is an optional, freeform section for describing any code in your submission and the software used to run it.
Describe any scripts, code, or notebooks (e.g., R, Python, Mathematica, MatLab) as well as the software versions (including loaded packages) that you used to run those files. If your repository contains more than one file whose relationship to other scripts is not obvious, provide information about the workflow that you used to run those scripts and notebooks.