利用PythonOrange结合DNA序列进行人种预测

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了利用PythonOrange结合DNA序列进行人种预测相关的知识,希望对你有一定的参考价值。

 

 

http://blog.csdn.net/jj12345jj198999/article/details/8951120

coursera上 web intelligence and big data 终于布置了HW7,这一次的要求是对一系列DNA序列进行预测,具体说明如下:

Data Analytics Assignment (for HW7)

Predict the Ethnicity of Individuals from their Genes  
============================================

It is now possible to get the DNA sequence of an individual at a reasonable cost.  An individual‘s genetic make-up determines a number
of charactersistics - eye colour, propensity for certain diseases, response to treatment and so on.  In this problem, you are given a subset of genetic information for several individuals. For some of the individuals you are also told their ethinicity.  Your task is to figure out the ethnicity of the other individuals.

The information provided is as follows:

1. For each individual the presence (1) or absence (0) of a  genetic variation at a particular position on chromosome 6 is provided.  In some cases, information for an individual at a particular position is not available and this represented as ? (missing).

2. Information is provided for approximately 204000 positions. These are   your features.

3. The training set has data for 139 individuals along with their ethnicity.

4. The test (prediction) set has data for 11 individuals.  You have to predict the ethnicity for these individuals and enter your answers via HW7.

Data Sets 
----------- 

The training set is available here: genestrain.tab.zip (6.2 Mb)

The test set is available here: genesblind.tab.zip (1.2 Mb)


File Format
----------- 

(Note: Data sets are .tab files in the tab-separated format that can be read into Orange): 

Both the training and test data files have a header line which is a tab-separated line of column/feature names: For example ‘6_10000005‘ indicates that the column describes the presence or absence of variations at position 10000005 on chromosome #6.

Entries in the second header line indicate the type of column (in this case all features are ‘discrete‘). 

Entries in the third header line indicate the nature of each column: 
A ‘ ‘ for most columns that contain a feature, and ‘class‘ for the first column as it contains the actual class labels (i.e., ethnicities of the individuals in each row). 

These header lines are followed by lines containing feature values (0, 1, or ?) for each genetic feature of an individual. 

In the training set file the first column, which denotes the class label, is a three-letter code with one of the following values:

o CEU is Northern and Western European
o GIH is Gujarati Indian from Houston 
o JPT is Japanese in Tokyo
o ASW is Americans of African Ancestry
o YRI is Yoruba in Ibadan, Nigera

In the test file the ethnicity column also exists but is blank. 

=========================

For the purposes of your HW answer alone, each three letter code is to be marked with a NUMERIC VALUE  as indicated in the table below:

o CEU is Northern and Western European - 0
o GIH is Gujarati Indian from Houston - 1
o JPT is Japanese in Tokyo - 2
o ASW is Americans of African Ancestry - 3
o YRI is Yoruba in Ibadan, Nigera - 4

YOU MUST USE THE ABOVE NUMERIC VALUES TO ENCODE YOUR ANSWER. Note: This numeric value has no presence in the test or training data.

Task: For each of the individuals in the test file, predict their ethnicity as CEU, GIH, JPT, ASW or YRI and enter your answers in HW7 in exactly the order that the 11 individuals appear in the test file. So, for example, if your prediction is CEU, GIH, JPT, ASW, YRI CEU, GIH, JPT, ASW, YRI, CEU, you should enter your answer as 0 1 2 3 4 0 1 2 3 4 0 (i.e. numbers separated by a space - no commas, tabs or anything else, just as space between single digit numbers).


不过很多人在discussion form里面反映着印度老师在描述的时候没有把问题讲明白(主要是没告诉他们该怎么做),也没在video里面给个指导视频啥的。好在把数据下下来以后,发现其中有一个训练集,一个预测集,估计也只能是先训练,再预测而已。

训练集是一个tab文件,格式如下:

技术分享

横坐标class代表人种(这里有139行,代表139个训练数据),纵坐标代表DNA片段(约有20万个,后面n列未列出)

预测集如下:

技术分享

这里第一列加 问号 的就是要预测的,总共为11个人种信息。

了解完数据的情况后,下一步就是看如何来训练和预测了,discussion form中有人提出了用Orange这个库,基友Python,使用起来很方便,地址是 http://orange.biolab.si/doc/ofb/c_basics.htm ,更详细的可以看 http://orange.biolab.si/docs/latest/tutorial/rst/classification/ 

针对这个问题,贝叶斯分类器就能搞定了,代码很短如下:

  1. # Description: Read data, build naive Bayesian classifier and classify first few instances  
  2. # Category:    modelling  
  3. # Uses:        genestrain.tab  
  4. # Predict:     genesblind.tab  
  5. # Referenced:  c_basics.htm  
  6.   
  7. import orange  
  8. data = orange.ExampleTable("genestrain")  
  9. data2= orange.ExampleTable("genesblind")  
  10. classifier = orange.BayesLearner(data)  
  11. i = 0  
  12. for item in data2:  
  13.     c = classifier(item)  
  14.     print "%d: %s " % (i, c)  
  15.     i = i + 1  

可以看到这里先用训练数据进行训练,得到分类器,然后用分类器对预测数据的每一行进行预测,输出结果,思想还是比较清晰的,不过唯一的缺点是在数据量稍大一点时,运行速度和消耗资源很大,针对这题要使用1G内存,运行10分钟:

技术分享


最终输出结果如下:

技术分享

这样就得到了有待预测的11个人种,填写答案搞定。

技术分享



估计这是这门课最后一次编程作业了,还剩一个在线的final exam,赶紧结课吧。





























































以上是关于利用PythonOrange结合DNA序列进行人种预测的主要内容,如果未能解决你的问题,请参考以下文章

利用BioPerl将DNA序列翻译成蛋白序列

利用python求一段DNA序列的互补序列

MEGA 构建进化树步骤

什么是转录因子?

目标序列捕获测序常见问题集锦

有一段长度约为1000bp的DNA序列,如何证明其中的PRD区(大约第60-100bp)表达的蛋白与特定蛋白有作用?