DnaDesign
DnaDesign is a Go project creating tools for automated genetic design, spanning from the lowest levels of DNA sequence manipulation to higher level functionality.
-
Practical: DnaDesign tooling is meant to be used by practitioners of synthetic biology.
-
Modern: DnaDesign is at the bleeding edge of technology. We are happy to adopt the newest advancements in synthetic biology, wasm, LLMs, and more to get our tools in the hands of people who need it.
-
Ambitious: DnaDesign's goal is to be the most complete, open, and well used collection of computational synthetic biology tools ever assembled. If you like our dream and want to support us please star this repo, request a feature, or open a pull request.
Documentation
Repo organization
On the highest level:
lib
contains core functionality as a go library.
external
contains functions to work with external bioinformatics command-line interfaces.
py
contains code to use the dnadesign library in python using a C shared library.
Detailed repo organization
- lib contains the core DnaDesign library, with nearly all functionality, all in idiomatic Go with nearly no dependencies.
- lib/bio contains biological parsers for file formats including genbank, fasta, uniprot, fastq, slow5, sam, and pileup files.
- lib/align contains Needleman-Wunsch and Smith-Waterman alignment functions, as well as the mash similarity algorithm.
- lib/clone contains functions for simulating DNA cloning, including restriction digestion, ligation, and GoldenGate assembly.
- lib/fold contains DNA and RNA folding simulation software, including the Zuker and LinearFold folding algorithms.
- lib/primers contains DNA primer design functions.
- lib/seqhash contains the Seqhash algorithm to create universal identifiers for DNA/RNA/protein.
- lib/synthesis contains various functions for designing synthetic DNA.
- lib/transform contains basic utility functions for transforming DNA, like reverse complementation.
- external contains integrations with external bioinformatics software, usually operating on the command line.
Python
We have python package, dnadesign
, which allows python users to use dnadesign. This is a work-in-progress: more documentation coming soon!
Contributing
Write good, useful code. Open a pull request, and we'll see if it fits!
License
Sources
There are a few pieces of "complete" software that we have directly integrated into the source tree (with their associated licenses). These projects don't receive updates anymore (or just bug fixes with years between). In particular, lib
has most of these, since we intend to have as few dependencies as possible in lib
. The integrated projects include the following.
Other
DnaDesign is a fork of Poly at commit f76bf05 with a different mission focus.
Changelog
All notable changes to this project will be documented here.
The format is based on Keep a Changelog,
and this project adheres to Semantic Versioning.
[Unreleased]
- Fixes RecursiveFragment to not add flanks to the initial input #102
- Fixes add flank bug, releases new version of python lib #101
- Adds feature for adding flanks to RecursiveFragment. #100
- Adds cloning and recursion functions to python. #96
- Adds recursive fragmentation. #92
- Updated megamash documentation to be more specific. #91
- Adds automatic python documentation generation. #88
- Adds genbank parsing to python package. Release version 0.1.5 of dnadesign python. #87
- Adds fastq parsing to python package. Releases version 0.1.4 of dnadesign python. #86
- Integrated errgroup into source tree #84
- Added kmer detection for ligation events in cloning and removed enzyme manager #83
- Added option for linear ligations #82
- Added minimal python packaging #81
- Greatly simplified the Ligate function #77
- Updated barcoding functions to handle edge case of hanging-edge barcodes #74
- Updated megamash to use int instead of uint for minimal Kmer counts (so you can use -1) #73
- Added bcftools to external #72
- Fixed bug in PCR where certain matching primers wouldn't create any amplicons #71
- Updated seqhash2 to use base58 rather than base64 #69
- Updated dual barcodes primer sets to be created without csv files #67
- Added workers to bio as a way to process data #62
- Improved megamash efficiency and added []Match JSON conversion #61
- Added barcoding functionality for sequencing reads #59
- Added the megamash algorithm #50
- Changed parsers to return values instead of pointers. Added some sequencing utils #49
- Added minimap2 and samtools(pileup) integrations in external #46
- Added sam parser #5
- Added the LinearFold folding algorithms #38
- Added Get function to uniprot for getting a single uniprot xml from online #37
- Removed murmur3 in favor of crc32 for mash #33
- Patch start codon problems #32
- Added tests for OpenBSD #31
- Removed a large number of unneeded dependencies #28
- Added full rebase text database into tree 27b41fb
- Updated uniprot to be a standardized parser #22
- Purged unsupported gff parser #23
- Moved library to lib directory #21
- Fixed issue with JSON codon tables #4
- Added Seqhash v2 #3
- Added lowercase methylation options during cloning #2
- Standardized parsers with generics #1