Skip to content

Koeng101/dnadesign

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

DnaDesign

GitHub license Tests Test Coverage

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

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