Team:DTU-Denmark/HelloWorld
From 2013.igem.org
(→Fluorescent microscope images) |
Pdworzynski (Talk | contribs) (→Model of "Hello World" construct) |
||
Line 61: | Line 61: | ||
===Model of "Hello World" construct=== | ===Model of "Hello World" construct=== | ||
+ | <html> | ||
+ | |||
+ | <form> | ||
+ | <label for="inner_cell_prop_slider">Slider:</label> | ||
+ | <input type="range" name="inner_cell_prop_slider" id="inner_cell_prop_slider" min="0" max="1" step=".01" value="0.5"> | ||
+ | <label for="red_vs_green_slider">Slider red vs green:</label> | ||
+ | <input type="range" name="inner_cell_prop_slider" id="red_vs_green_slider" min="0" max="1" step=".01" value="0.5"> | ||
+ | </form> | ||
+ | |||
+ | <div id="visualization"> | ||
+ | |||
+ | </div> | ||
+ | <div id="cell_image"> | ||
+ | |||
+ | </div> | ||
+ | |||
+ | <script src="http://cdnjs.cloudflare.com/ajax/libs/d3/3.2.2/d3.v3.min.js" charset="utf-8"></script> | ||
+ | <script src="http://code.jquery.com/jquery-1.9.1.min.js"></script> | ||
+ | <script src="http://code.jquery.com/mobile/1.3.2/jquery.mobile-1.3.2.min.js"></script> | ||
+ | |||
+ | |||
+ | var pi = 3.14; | ||
+ | |||
+ | var width = 800, | ||
+ | height = 600, | ||
+ | margin = 50; | ||
+ | |||
+ | var cell_radius = 200, | ||
+ | relative_concentration_red_vs_green = 1, | ||
+ | inner_cell_proportion = 0.5; | ||
+ | |||
+ | |||
+ | var outer_data = [], | ||
+ | relative_data = [], | ||
+ | inner_data = []; | ||
+ | |||
+ | var svg = d3.select('#visualization').append('svg') | ||
+ | .attr('width', width + margin*2) | ||
+ | .attr('height', height + margin*2) | ||
+ | .append('g') | ||
+ | .attr('transform', 'translate(' + margin + ',' + margin + ')'); | ||
+ | |||
+ | |||
+ | var scaleX = d3.scale.linear() | ||
+ | .range([width/2 - cell_radius, width/2+cell_radius]) | ||
+ | .domain([-1, 1]); | ||
+ | |||
+ | function x(d, i) { return scaleX(i); } | ||
+ | |||
+ | var scaleY = d3.scale.linear() | ||
+ | .range([3*cell_radius, 2*cell_radius]) | ||
+ | .domain([0,1]); | ||
+ | |||
+ | function y(d, i) { return scaleY(d); } | ||
+ | |||
+ | var xAxis = d3.svg.axis() | ||
+ | .scale(scaleX) | ||
+ | .orient('bottom'); | ||
+ | |||
+ | svg.append('g') | ||
+ | .attr('class', 'axis') | ||
+ | .attr('transform', 'translate(0,' + height + ')') | ||
+ | .call(xAxis); | ||
+ | |||
+ | var yAxis = d3.svg.axis() | ||
+ | .scale(scaleY) | ||
+ | .orient('left'); | ||
+ | |||
+ | svg.append('g') | ||
+ | .attr('class', 'axis') | ||
+ | .call(yAxis); | ||
+ | |||
+ | var line = d3.svg.line() | ||
+ | .interpolate('basis') | ||
+ | .x(function(d) {return scaleX(d.x)}) | ||
+ | .y(function(d) {return scaleY(d.y)}); | ||
+ | |||
+ | |||
+ | var outer_cell = svg.append("circle").attr({ | ||
+ | fill: '#f00', | ||
+ | cx: width/2, | ||
+ | cy: margin + cell_radius/2, | ||
+ | r: cell_radius | ||
+ | }); | ||
+ | |||
+ | var inner_cell = svg.append("circle").attr({ | ||
+ | fill: '#0f0', | ||
+ | // fill: "url(#temperature-gradient)", | ||
+ | cx: width/2, | ||
+ | cy: margin + cell_radius/2, | ||
+ | r: cell_radius * inner_cell_proportion | ||
+ | }); | ||
+ | |||
+ | var canvas = d3.select("#cell_image").append("canvas") | ||
+ | .attr("width", width + margin*2) | ||
+ | .attr("height", height + margin*2) | ||
+ | .style("width", width + margin*2 + "px") | ||
+ | .style("height", height + margin*2 + "px"); | ||
+ | // .call(drawImage); | ||
+ | |||
+ | function get_intesity(x){ | ||
+ | |||
+ | var amount_of_red = -1; | ||
+ | if((x < inner_cell_proportion) && (x > (-1 * inner_cell_proportion))){ | ||
+ | amount_of_red = 2* Math.sin(Math.acos(x)) - 2 * inner_cell_proportion * Math.sin( Math.acos( x / inner_cell_proportion)); | ||
+ | } else if((x > -1) && (x < 1)) { | ||
+ | amount_of_red = 2 * Math.sin(Math.acos(x)); | ||
+ | } else { | ||
+ | amount_of_red = 0; | ||
+ | } | ||
+ | |||
+ | var amount_of_green = -1; | ||
+ | if((x < inner_cell_proportion) && (x > (-1 * inner_cell_proportion))){ | ||
+ | amount_of_green = 2 * inner_cell_proportion * Math.sin(Math.acos(x/inner_cell_proportion)); | ||
+ | } else { | ||
+ | amount_of_green = 0; | ||
+ | } | ||
+ | |||
+ | var red_intensity = -1; | ||
+ | var green_intensity = -1; | ||
+ | |||
+ | if(relative_concentration_red_vs_green > 1){ | ||
+ | red_intensity = 1; | ||
+ | green_intensity = 1 / relative_concentration_red_vs_green; | ||
+ | } else { | ||
+ | red_intensity = 1 / relative_concentration_red_vs_green; | ||
+ | green_intensity = 1 ; | ||
+ | } | ||
+ | |||
+ | return { | ||
+ | red: amount_of_red * red_intensity, | ||
+ | green: amount_of_green * green_intensity | ||
+ | } | ||
+ | } | ||
+ | |||
+ | function drawImage(canvas) { | ||
+ | var context = canvas.node().getContext("2d"), | ||
+ | image = context.createImageData(cell_radius*2, cell_radius*2); | ||
+ | |||
+ | var p = 0; | ||
+ | for(var x_pix=0; x_pix < cell_radius*2; x_pix++){ | ||
+ | for(var y_pix=0; y_pix < cell_radius*2; y_pix++){ | ||
+ | |||
+ | var x = Math.sqrt(Math.pow(Math.abs(x_pix - cell_radius),2) + Math.pow(Math.abs(y_pix - cell_radius),2)); | ||
+ | |||
+ | x /= cell_radius; | ||
+ | |||
+ | |||
+ | var intensity = get_intesity(x); | ||
+ | |||
+ | var transparency = 255; | ||
+ | |||
+ | var red_intensity = 255; | ||
+ | var green_intensity = 255; | ||
+ | |||
+ | |||
+ | intensity.red /= 2; | ||
+ | intensity.red *= red_intensity; | ||
+ | |||
+ | intensity.green /= 2; | ||
+ | intensity.green *= green_intensity; | ||
+ | |||
+ | image.data[p++] = intensity.red; | ||
+ | image.data[p++] = intensity.green; | ||
+ | image.data[p++] = 0; | ||
+ | image.data[p++] = transparency; | ||
+ | } | ||
+ | } | ||
+ | |||
+ | context.putImageData(image, width/2 - cell_radius + margin, 0); | ||
+ | } | ||
+ | |||
+ | var outer_path = svg.append('path') | ||
+ | .attr({ | ||
+ | 'fill': 'none', | ||
+ | 'stroke-width': 2, | ||
+ | stroke: '#f00', | ||
+ | d: line(outer_data) | ||
+ | }); | ||
+ | |||
+ | var inner_path = svg.append('path') | ||
+ | .attr({ | ||
+ | 'fill': 'none', | ||
+ | 'stroke-width': 2, | ||
+ | stroke: '#0f0', | ||
+ | d: line(inner_data) | ||
+ | }); | ||
+ | |||
+ | var relative_path = svg.append('path') | ||
+ | .attr({ | ||
+ | 'fill': 'none', | ||
+ | 'stroke-width': 2, | ||
+ | stroke: '#00f', | ||
+ | d: line(relative_data) | ||
+ | }); | ||
+ | |||
+ | |||
+ | function update() { | ||
+ | |||
+ | var outer_vol = 4/3 * pi * Math.pow(cell_radius,3); | ||
+ | var inner_vol = 4/3 * pi * Math.pow(inner_cell_proportion * cell_radius,3); | ||
+ | var vol_proportion_red_vs_green = outer_vol/inner_vol; | ||
+ | relative_concentration_red_vs_green = vol_proportion_red_vs_green; | ||
+ | |||
+ | inner_cell.transition().attr({ | ||
+ | // fill: '#0f0', | ||
+ | cx: width/2, | ||
+ | cy: margin + cell_radius/2, | ||
+ | r: cell_radius * inner_cell_proportion | ||
+ | }); | ||
+ | |||
+ | outer_data = []; | ||
+ | inner_data = []; | ||
+ | relative_data = []; | ||
+ | for (var k = -100; k < 101; k++) { | ||
+ | var step = 0.01; | ||
+ | |||
+ | var x = step * k; | ||
+ | |||
+ | |||
+ | var intensity = get_intesity(x); | ||
+ | |||
+ | |||
+ | inner_data.push({x: x, y: 0.5 * intensity.green}); | ||
+ | outer_data.push({x: x, y: 0.5 * intensity.red}); | ||
+ | // relative_data.push({x: x, y: y_outside - y_inside}); | ||
+ | } | ||
+ | |||
+ | outer_path.transition() | ||
+ | .attr({ | ||
+ | 'fill': 'none', | ||
+ | 'stroke-width': 2, | ||
+ | stroke: '#f00', | ||
+ | d: line(outer_data) | ||
+ | }); | ||
+ | |||
+ | inner_path.transition() | ||
+ | .attr({ | ||
+ | 'fill': 'none', | ||
+ | 'stroke-width': 2, | ||
+ | stroke: '#0f0', | ||
+ | d: line(inner_data) | ||
+ | }); | ||
+ | |||
+ | drawImage(canvas); | ||
+ | // relative_path.transition() | ||
+ | // .attr({ | ||
+ | // 'fill': 'none', | ||
+ | // 'stroke-width': 2, | ||
+ | // stroke: '#f00', | ||
+ | // d: line(relative_data) | ||
+ | // }); | ||
+ | } | ||
+ | |||
+ | update(); | ||
+ | |||
+ | |||
+ | </html> | ||
== Conclusions == | == Conclusions == |
Revision as of 15:33, 3 October 2013
Hello World Pilot Project
Contents |
Introduction
‘Hello World!’ are the first words a programmer prints when learning a new programming language. In analogy to this our team decided to do a ‘Hello World’ project in order to familiarize ourselves with lab techniques that we used later on to construct plasmids. Specifically we were performing PCR with uracil-containing primers, purifying PCR products and ligating them by means of USER cloning (Nour-Eldin, H. H.).
Since we are working with many periplasmic proteins, we wanted to try to target proteins to the periplasm. To do this, we used periplasmic signal peptides from the TAT and Sec pathways, and with a translational fusion of the signal peptide to GFP, we expressed GFP in the periplasm. Simultaneously, we expressed RFP in the cytoplasm as a background color, inspired by Skoog, Karl, et al.
Methods
Construction
The overal goal was to test the twin arginine pathway (TAT) and whether this signal peptide could transport GFP SF into the periplasm. The reason why we choose to use GFP superfolder (SF) was that this variant has been shown to fold faster than the E. coli transport system is at translocation, (Fisher, Adam C., and Matthew P. DeLisa.). This assures that the GFP will form its fluorophore before translocation to the more reductive periplasmic space. Thus it will not be inactivated by the inhibition of fluorophore formation as seen in other oxidative compartments like ER (Aronson, Deborah E., Lindsey M. Costantini, and Erik L. Snapp.).
Construction of the plasmids was done with USER-cloning and assembly of 3 fragments. The starting point was a plasmid construct with RFP and GFP SF respectively. The RFP and GFP SF were amplified out with their associated RBS (the same in both cases).
The TAT signal peptide was bought as a gBlock from IDT. All fragments were assembled into an expression vector specially designed to have a tight on/off mechanism ([http://parts.igem.org/Part:BBa_K1067007 BBa_K1067007]). Primers were design by the program [http://www.cbs.dtu.dk/services/PHUSER-2.0/web/ PHUSER] (Olsen, Lars Rønn, et al.) so that we got a seamless assembly.
Visualization
To visualize that GFP SF actually is exported we constructed a procedure for growing the cells and tracing the GFP SF to the periplasm (Skoog, Karl, et al.). It turns out that if you just grow cells in LB and induce the GFP SF/RFP expression there will be too much GFP SF in the cytoplasm to get a good resolution between cytoplasm and periplasm. That is why it’s important to devise a procedure for stopping the production for GFP SP and thereafter tracing it from the cytoplasm into the periplasm. This underlines the importance of having a non-leaky inducible expression system; when expression is stopped by removing the inducer it would spoil the procedure if the system kept leaking out GFP SF into the cytoplasm.
After optimizing the procedure we made a final version which can be found in the methods page. This also includes how to use background subtraction to get a better resolution.
Modeling
To assess the ability to distinguish the periplasmic from the cytoplasmic space we made a model which is based on a perfect spherical cell with and even layer between inner and outer membrane.
To get a value of the RFP and GFP signal we used a cross section of the spherical cell and measured the length of RFP and GFP going across this section; see the measurement bars at the figure. The make a graph of this we set the middle of the cell to be 0 on the x-axis. On the y-axis we let two lines show the value of GFP and RFP in the cross section.
The first graph can be seen below:
Results
We used different methods for testing that our construct actually did work and also for verifying the model we did before the test.
Periplasmic vs. cytoplasmic fraction
The first test we did was to purify the periplasmic fraction of the cells and then comparing with the cytoplasmic (link to notebook). We did this with the cold osmotic shock method and viewed the fraction under UV-light.
Fluorescent microscope images
Next test was the "real thing". We wanted bulletproof evidences that GFP SF was actually exported; and what better way to do this than getting pictures of it? After following the our procedure for chasing GFP SF to the periplasm the could see these images after background subtraction. Following is an image with no zoom:
Next to test our model we picked a cell this good resolution and zoomed in on this:
For this cell a line profile was made that shows both the GFP- and RFP signal across the cell:
This was staggeringly close to our model seen in next section.
Model of "Hello World" construct
Conclusions
Biobrick BBa_K1067009 successfully directs GFP SF to the periplasm of E. coli. This experiment is a proof of concept that proteins can be exported to the periplasm. There have in previous iGEM project been a confusing whether or not it was possible to export GFP to the periplasm; this experiment verifies just that and gives a procedure on how to reproduce this.
References
- Skoog, Karl, et al. "Sequential Closure of the Cytoplasm and Then the Periplasm during Cell Division in Escherichia coli." Journal of bacteriology 194.3 (2012): 584-586.
- Nour-Eldin, H. H., Geu-Flores, F., & Halkier, B. A. (2010). USER cloning and USER fusion: the ideal cloning techniques for small and big laboratories. In Plant Secondary Metabolism Engineering (pp. 185-200). Humana Press.
- Olsen, Lars Rønn, et al. "PHUSER (Primer Help for USER): a novel tool for USER fusion primer design." Nucleic acids research 39.suppl 2 (2011): W61-W67.
- Fisher, Adam C., and Matthew P. DeLisa. "Laboratory evolution of fast-folding green fluorescent protein using secretory pathway quality control." PLoS One 3.6 (2008): e2351.
- Aronson, Deborah E., Lindsey M. Costantini, and Erik L. Snapp. "Superfolder GFP is fluorescent in oxidizing environments when targeted via the Sec translocon." Traffic 12.5 (2011): 543-548.