Difference between revisions of "Team:William and Mary/Outreach Search"

(Undo revision 76693 by Tgibney (talk))
 
(39 intermediate revisions by 2 users not shown)
Line 8: Line 8:
  
 
<head>
 
<head>
<meta charset="UTF-8">
+
<meta charset="UTF-8">
<title>Fullproof example: Animals species database</title>
+
<script type='text/javascript' src='https://2017.igem.org/Team:William_and_Mary/papaparse?action=raw&ctype=text/javascript'></script>
<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.8.0/jquery.min.js"></script>
+
<script type='text/javascript' src='https://cdnjs.cloudflare.com/ajax/libs/fuse.js/3.0.4/fuse.min.js'></script>
 +
<script type='text/javascript'>
 +
function generateTable(data) {
 +
var html = '';
  
<script type='text/javascript' src='http://reyesr.github.io/fullproof/js/fullproof-all.js'></script>
+
if(typeof(data[0]) === 'undefined') {
</script>
+
return null;
 +
}
  
 +
if(data[0].constructor === String) {
 +
html += '<tr>\r\n';
 +
for(var item in data) {
 +
html += '<td>' + data[item] + '</td>\r\n';
 +
}
 +
html += '</tr>\r\n';
 +
}
  
<style TYPE="text/css">
+
if(data[0].constructor === Array) {
 +
for(var row in data) {
 +
html += '<tr>\r\n';
 +
for(var item in data[row]) {
 +
html += '<td>' + data[row][item] + '</td>\r\n';
 +
}
 +
html += '</tr>\r\n';
 +
}
 +
}
  
div.floatbox {
+
if(data[0].constructor === Object) {
float:left; width: 300px;
+
for(var row in data) {
}
+
html += '<tr>\r\n';
div.resultbox {
+
for(var item in data[row]) {
border: 1px solid black; margin:0.5em;
+
html += '<td>' + item + ':' + data[row][item] + '</td>\r\n';
color: black; background-color: #EEEEEE;
+
}
overflow: hidden;
+
html += '</tr>\r\n';
}
+
}
textarea.typebox {
+
}
float: left;
+
width: 300px; height: 200px; margin:1em;"
+
color: black; background-color: white;
+
}
+
</style>
+
</head>
+
<body>
+
<h1>Animal Database</h1>
+
  
<div>
+
return html;
This application provides an example of fulltext search in the species database from
+
}</script>
the <a href="http://gapanalysis.usgs.gov/data/species-data/">U.S. Geological Survey Gap Analysis Program</a>
+
</head>
</div>
+
<body>
<div style="margin-top: 1em;">
+
<h1>Outreach Database</h1>
It uses a BooleanEngine, which only displays documents (here animals) that match all the searched terms.  
+
<input type="text" id="searchTextbox" placeholder="Search here">
It works by creating sets of results for each terms, and intersecting all the results. The BooleanEngine is
+
<button type="button" id="searchButton">Search</button>
fine when your users only want the documents that exactly match their terms. If you need to display
+
<div id='resultTable'>
results that contain any of the words typed by the user, it's better to use the ScoringEngine, which
+
Application DIV
provides scores and result sorting.
+
</div>
</div>
+
<script src='https://cdnjs.cloudflare.com/ajax/libs/jquery-csv/0.71/jquery.csv-0.71.min.js' type='text/javascript'></script>
  
<div style="display: none; margin-top: 1em" id="application">
+
<script type="text/javascript">
Type an animal name here:
+
var myFuse;
<div>
+
var showResult = function(resultObj){
<input type="text" id="typehere" class="typebox">
+
$('#resultTable').html(generateTable(resultObj));
<button id="search">Search</button>
+
}
<button id="reload">Reload database</button>
+
var prepareSearch = function(parsedObj){
</div>
+
var fuseOptions = {
<div style="clear:both" id="results">
+
shouldSort: true,
</div>
+
threshold: 0.6,
</div>
+
location: 0,
<div id="loading" style="margin: 1em; display: none;">
+
distance: 100,
<div>The first time the application is displayed, fullproof initializes its search indexes. This is done only once,
+
maxPatternLength: 32,
subsequent loading will use the index locally stored.</div>
+
minMatchCharLength: 1,
<div>Note that this can be done in the background while the application works normally for the user.</div>
+
keys: Object.keys(parsedObj[0])
<div>Application is loading: <span id="progress"></span>%</div>
+
};
</div>
+
console.log(fuseOptions)
 +
myFuse = new Fuse(parsedObj, fuseOptions);
 +
$('#searchButton').click(function(){
 +
showResult(
 +
myFuse.search(
 +
$('#searchTextbox').val()
 +
)
 +
)
 +
});
 +
}
 +
$(document).ready(function() {
 +
$.ajax({
  
<script type="text/javascript">
+
url: 'https://2017.igem.org/Team:William_and_Mary/Outreach_DB?action=raw&ctype=text/csv',
$(document).ready(function() {
+
type: 'GET',
 +
/*success: function(csvText) { $('#resultTable').html(Papa.parse(csvText)); },*/
 +
success: function(csvText) {
 +
parsedObj = Papa.parse(csvText, {header:true})['data'];
 +
showResult(parsedObj);
 +
prepareSearch(parsedObj)
 +
},
 +
error: function() { $('#resultTable').text('CSV data load failed!'); },
 +
});
  
       
+
});
$.ajax({
+
  
    url: 'https://2017.igem.org/Team:William_and_Mary/Outreach_DB?action=raw&ctype=text/csv',
 
    type: 'GET',
 
    crossDomain: true,
 
    dataType: 'jsonp',
 
    success: function() { $('#application').text("Success"); },
 
    error: function() { $('#application').text('Failed!'); },
 
});
 
  
</script>
 
  
</html>
+
</script>
  
 +
</html>
  
{{Team:William_and_Mary/JS_SOURCE}}
+
 
{{Team:William_and_Mary/FOOTER_SMALL}}
+
{{Team:William_and_Mary/JS_SOURCE}}
 +
{{Team:William_and_Mary/FOOTER_SMALL}}

Latest revision as of 21:08, 3 August 2017

NOISE - W&M iGEM

NOISE

Characterization of promoter-driven transcriptional noise in E. coli

Parts

In deciding which parts to submit to the iGEM Registry we focused on three main aspects.

First: ensuring our project is as reproducible and extensible as possible. To that end we have submitted all of new composite fluorescent protein parts that we constructed during the project.
Second: Making genome integration as straightforward as possible for iGEM teams. In order to accomplish this goal we designed, tested, and validated a new integrator cassette that allows simple genome integration using 3A or Gibson Assembly.
Third: Increasing the number of tools available for promoter-mediated regulation in synthetic biology. We created and validated an E. coli codon optimized dCas9 variant and a suite of gRNAs to target the most commonly used promoters in iGEM.

Measurement & Modeling

We measured noise in fluorescence data for dual-integrated sets of CFP and YFP under three promoters: BBa_R0010, BBa_R0011, and BBa_R0051. We also developed an analytic model of the impact of plasmid copy number fluctuations on transcriptional noise, which revealed that intrinsic noise cannot be accurately measured from reporters on the pSB1X3 plasmid series.

Human practices

Our Human Practices effort was a multi-faceted outreach approach to science literacy, focusing specifically on spreading a basic understanding of synthetic biology to the general public. We collaborated with numerous organizations to host nine educational Synthetic Biology workshops for the public (from first graders to adults!) and to implement our educational 24-activity Synthetic Biology booklet into schools worldwide, to further sustain our efforts for years to come.

Collaboration

W&M iGEM met and exceeded iGEM's collaboration requirements by collaborating with other researchers in four main ways: creating a pen pal program to connect teams with similar projects, participating in the interlab measurement study, interviewing the general public to provide data to future teams about how to communicate synthetic biology, and collaborating on individual research projects with iGEM teams from University of Georgia, University of Maryland, and Cambridge.

2015 Jamboree Results

Undergraduate Grand Prize Winner

Best in Track: Measurement

Best Education & Public Engagement

Best Presentation

Nominee: Best Mathematical Model

Outreach Database

Application DIV