zoukankan      html  css  js  c++  java
  • 利用Python【Orange】结合DNA序列进行人种预测

     python机器学习-乳腺癌细胞挖掘(博主亲自录制视频)

    https://study.163.com/course/introduction.htm?courseId=1005269003&utm_campaign=commission&utm_source=cp-400000000398149&utm_medium=share

    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,赶紧结课吧。

     https://study.163.com/provider/400000000398149/index.htm?share=2&shareId=400000000398149( 欢迎关注博主主页,学习python视频资源,还有大量免费python经典文章)


     
  • 相关阅读:
    hdu4675 GCD of Sequence 莫比乌斯+组合数学
    hdu4746 Mophues 莫比乌斯
    BZOJ2820 YY的GCD 莫比乌斯+系数前缀和
    bzoj2005 能量采集 莫比乌斯或者普通容斥
    GCD 莫比乌斯反演 给定整数N,求1<=x,y<=N且Gcd(x,y)为素数的 数对(x,y)有多少对.
    spoj7001 Visible Lattice Points 莫比乌斯反演+三维空间互质对数
    hdu1695 GCD 莫比乌斯反演做法+枚举除法的取值 (5,7),(7,5)看做同一对
    bzoj2440 完全平方数 莫比乌斯值+容斥+二分
    Problem b 莫比乌斯反演+枚举除法的取值
    Codeforces839D Winter is here 容斥
  • 原文地址:https://www.cnblogs.com/webRobot/p/6101999.html
Copyright © 2011-2022 走看看