Bryan’s first software ships

opgen_logo.jpgJune 5: Bryan’s been working extra-hard the last several weeks as he has been completing the first release of the software that he has been designing.  He started at OpGen last September, and he’s really been enjoying it.  You can see his blog post about completing the software here.  He also wrote three posts describing what his company does on his blog, which I have posted below.

Here comes the science, Part 1

I’ve been wanting for some time to make a post or two to try and explain the basics of the science that is the core of our company. The techniques described here are in the public domain so there’s nothing secret here. I’ve been working here long enough that I now feel pretty confident that I understand the process at a fairly high level.. just the right amount to be able to describe it to someone else that might find it interesting. For part 1 here, I will just describe the basic premise and will cover more actual detail in later posts. I’ve really enjoyed learning this stuff and I hope that other people find it interesting too.

The “Op” stands for Optical
The company’s name, OpGen, is based on the fact that the core scientific process behind the business is called “optical mapping” which is, in short, a technique for taking physical samples of DNA and creating a visual representation of it such that unique organisms can be easily differentiated from each other and similarities between other organisms can be easily spotted. The whole concept is that you can break up DNA into many fragments and then put those fragments together in a line and you get what we call a “map”. What’s useful about this is that similar organisms will consistently and repeatedly break up in the same way such that their maps are very similar. As you’ll see later, these maps almost look like barcodes and you can actually think of them as such, or as a “fingerprint” which uniquely identifies an organism. Here’s an example of what one might look like:


What’s it for?
The most interesting applications for optical mapping that I am aware of are in the area of what we call “comparative genomics” (other people might call it something else). Basically, it’s the practice of looking at a number of similar or related organisms and analyzing what’s different about them. For instance, say you have maps of two isolates of the same species of bacteria that cause infections in humans.
Furthermore, say that one of those isolates is known to be extremely nasty and hard to treat, while the other is easily killed off with a round of antibiotics. By comparing the maps of these two bugs, you can actually see where the two are genetically different. Those parts that are different most likely indicate where the nastiness of the bacteria is regulated and can point the way for researchers to know where to look when trying to figure out how to combat that strain.

Coming soon…
In future posts I’ll tell you more detail about how we actually create those maps and talk about the software I’m working on and how it pertains to these maps.

Here comes the science, Part 2

This time around I’m going to dive down into a little more detail about what actually goes on in the process of making this optical maps of DNA samples. At a theoretical level, the process is fairly straight forward and sounds pretty basic. However, as I’m learning while working here, real life does not think very highly of our nice, simple, straight-forward theories. So the process has to be very robust, especially on the software side, which makes me very glad that I work with a lot of really smart people.

Making DNA lay down straight
The whole linchpin of this process is being able to measure the length of the strands of DNA (more accurately, the lengths of DNA fragments but we’ll get to that shortly). In order for length to have any meaning, we need to have the subjects we’re measuring be as close to a straight line as possible. In order to do that we use a glass surface (you remember those microscope slides you used in high school) and a cover slip that has microscopically small channels carved into it. The DNA is placed, in solution, onto this surface and, using a magical process I know nothing about, the DNA is stretched out along those channels which serve as guides for straightening out the molecules.

Cutting it up into fragments
In order to create meaningful maps that can be used to identify and compare organisms we need to break up the DNA molecules into fragments.
It’s these fragments that we measure to create that nice-looking barcode map. In order to create those maps you use what is called a “restriction enzyme”, which are enzymes that actually cut DNA. A particular restriction enzyme always cuts in the same place, at a particular occurrence of base pairs in the DNA strand. For example, the enzyme BamHI cuts at restriction sites of GGATCC. As an aside, most restriction enzymes cut at sites that are palindromic.. there’s no obvious reason that I know of why that is, but it sure is a neat coincidence. Due to the genetic makeup of different organisms, different enzymes will cut different numbers of fragments for each organism. Part of our process is picking an enzyme that will cut the “right number” of fragments, that is, enough to make a meaningful map.
Too few fragments or too many fragments often make the maps indistinguishable from each other.

Measuring those fragments
As part of the preparation of the DNA, a stain is applied that will cause the fragments to light up or “fluoresce” when exposed to a laser. The glass slip containing the DNA solution is placed on a fluorescent microscope that has a camera attached to it and an automated software system moves the camera up and down the length of those channels and takes pictures through the microscope. Here’s an example of what it looks like. Remember this is one tiny fraction of a single image from the microscope. You can see several broken strands of DNA. The colored one is one that has been picked out by the software as clean enough to be measured and recorded.


Hundreds of such images are acquired and finally fed through some image processing software that finds the nicest looking DNA molecules and it finds the fragments and measures their length in some unit of measure that is smaller than anything I can image. Finally those fragment lengths are recorded in order and they can be visually represented by that barcode-like display I showed last time. Here’s an artists interpretation of how that looks:


Assembling the pieces
Here’s where the real world comes in and whacks you in the head. DNA will almost never stay fully in tact throughout the process I just described. And even if it did, there are usually a lot of molecules and they tend to overlap each other or they don’t straighten out exactly right (or sometimes at all). So what you end up with is lots and lots of small maps that represent just a chunk of the entire strand of DNA.
And here is where some intense computing power is brought to bear on the problem as we take all of those smaller maps and try and determine how and where the overlap each other. It’s kind of analogous to trying to put a piece of paper back together after it has been through a shredder. When this process is finally done (and everything worked out okay) you end up with a “consensus map”, which is the amalgamation of
all of those smaller map chunks.


Once you’ve got that consensus map, then the doors open to a wide range of things you can do with it and that’s where the software that I’m working on comes into play. But I’ll save that stuff for the third and final installment of this series. Thanks for reading!

Here comes the science, Part 3

Before I went on hiatus it was just about time to talk about the software that I’ve been working on and how it pertains to the process of working with optical genome maps and actually doing something interesting with them.

Building a database
As I mentioned in previous posts the most interesting thing you can do with an optical map is to compare it to other maps of similar genomes for the purposes of looking at similarities and differences. But in order to do that you need a repository of maps and way of categorizing and searching that repository to find what you’re looking for. We didn’t have anything like that at the time I started so it was the first thing I worked on and we now have a nicely categorized, searchable database of over 40,000 genome maps.

Making maps in software
Creating optical maps is currently a time-consuming process and we’d need a lot of people to make 40,000 maps by hand. The vast majority of those maps that we have in the database are what are called “in-silico” maps, which is a cutesy way of saying that they were made in software. When you think about what mapping is, you’re taking little bits and pieces of DNA and cutting it up with an enzyme and then measuring the fragments that get created. We don’t necessarily know what the actual DNA sequence of that genome is and it’s actually irrelevant for the purposes of creating optical maps (which can be very helpful, which I’ll describe later). However there are plenty of people out there who are working hard at sequencing the genomes of all sorts of organisms.
We can take those sequences (the literal nucleotide sequence, e.g. ATCGGACT) and simulate the process of applying a restriction enzyme to cut that sequence into fragments to create in-silico maps. Luckily someone out there already wrote libraries for doing these sorts of things so it was pretty easy to use that code to populate our database.

Comparing maps
Really the critical functionality of the software I’m working on is the ability to compare maps to each other. In a nutshell we compare maps by looking at the series of fragments in each map and use some complicated math that I’ll likely never understand to figure out whether or not they’re “close enough” to each other to confidently say that they probably represent the same underlying DNA structure. While it’s very likely that the actual DNA sequences are different in some respects, those differences are small enough that they don’t show up at the map level. And we can reasonably assume that these are regions of similarity between the genomes. Using maps these similarities and differences are very easy to visualize.. here’s an example of a couple of similar strains of P.aeruginosa:


The purple parts are regions of similarity while the white parts represent regions that do not appear to be similar at all. It’s immediately obvious where these particular strains differ and where they appear to have common structure.

Extracting meaning
All of these leads up to my final point which is how you can use this software for comparing maps to extract meaning. As we know, the DNA structure of organisms dictates what they look like and what they are capable of in the physical world. In our particular realm we’re mainly looking at bacteria.. specifically bacteria that make people sick.
There are a lot of species of bacteria that make people sick and, within those species, there are several sub-species or strains that act differently. Some are particularly nasty, some are immune to certain antibiotic medications, and some are just run-of-the-mill . Since these strains are all of the same species they (frequently, but not always) end up sharing a lot of similar DNA. So by comparing maps of the different strains you can fairly easily see places where the DNA structure differs and that can really help you isolate the region of the genome that is cause a particular strain to be especially nasty.

I guess that’s about it for now .. this is getting pretty long. I may revisit this topic a little later as more code gets written and I start in on more new things. Right now I’m kind of in the middle of a round of bug-fixing and polish and that’ s just not that interesting!! Bye for now.