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. import orange
  7. data = orange.ExampleTable("genestrain")
  8. data2= orange.ExampleTable("genesblind")
  9. classifier = orange.BayesLearner(data)
  10. i = 0
  11. for item in data2:
  12. c = classifier(item)
  13. print "%d: %s " % (i, c)
  14. i = i + 1

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

最终输出结果如下:

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

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

利用Python【Orange】结合DNA序列进行人种预测的更多相关文章

  1. 利用Needleman–Wunsch算法进行DNA序列全局比对

    生物信息学原理作业第二弹:利用Needleman–Wunsch算法进行DNA序列全局比对. 具体原理:https://en.wikipedia.org/wiki/Needleman%E2%80%93W ...

  2. 利用python实现二分法和斐波那契序列

    利用python实现二分法:我的实现思路如下 1.判断要查找的值是否大于最大值,如果大于则直接返回False 2.判断要查找的值是否小于最小值,如果小于则直接返回False 3.如果要查找的值在最大值 ...

  3. python实现DNA序列字符串转换,互补链,反向链,反向互补链

    在生物信息学分析中,经常对DNA序列进行一系列操作,包括子序列截取,互补序列获取,反向序列获取,反向互补序列获取.在python语言中,可编写如下函数完成这些简单功能. 子序列截取 python中对序 ...

  4. 简单DNA序列组装(非循环子图)

    生物信息学原理作业第四弹:DNA序列组装(非循环子图) 原理:生物信息学(孙啸) 大致思想: 1. 这个算法理解细节理解比较困难,建议看孙啸的生物信息学相关章节. 2. 算法要求所有序列覆盖整个目标D ...

  5. DNA序列局部比对(Smith–Waterman algorithm)

    生物信息原理作业第三弹:DNA序列局部比对,利用Smith–Waterman算法,python3.6代码实现. 实例以及原理均来自https://en.wikipedia.org/wiki/Smith ...

  6. 利用Python进行数据分析(4) NumPy基础: ndarray简单介绍

    一.NumPy 是什么 NumPy 是 Python 科学计算的基础包,它专为进行严格的数字处理而产生.在之前的随笔里已有更加详细的介绍,这里不再赘述. 利用 Python 进行数据分析(一)简单介绍 ...

  7. [LeetCode] Repeated DNA Sequences 求重复的DNA序列

    All DNA is composed of a series of nucleotides abbreviated as A, C, G, and T, for example: "ACG ...

  8. 环状DNA序列

    大意: 一个DNA序列是环状的,这意味着有N个碱基的序列有N种表示方法(假设无重复).而这N个序列有一种最小的表示,这个最小表示的意思是这个序列的字典序最小(字典序的意思是在字典中的大小 比如ABC& ...

  9. 利用Python完成一个小游戏:随机挑选一个单词,并对其进行乱序,玩家要猜出原始单词

    一 Python的概述以及游戏的内容 Python是一种功能强大且易于使用的编程语言,更接近人类语言,以至于人们都说它是“以思考的速度编程”:Python具备现代编程语言所应具备的一切功能:Pytho ...

随机推荐

  1. 0027 Java学习笔记-面向对象-(非静态、静态、局部、匿名)内部类

    内部类 内部类就是把一个类写在另一个类的内部 用途: 如果一个类只希望它被某一个类访问,那么可以把它定义在另一个类的内部,并用private修饰 内部类可以访问它所在外部类的private成员:但所在 ...

  2. css3【语法要点】

    语法要点 display: -webkit-box; /* 老版本语法: Safari, iOS, Android browser, older WebKit browsers. */ display ...

  3. WEB开发中的字符集和编码

    html,body,div,span,applet,object,iframe,h1,h2,h3,h4,h5,h6,p,blockquote,pre,a,abbr,acronym,address,bi ...

  4. 【转】SpringMVC中DispatcherServlet配置中url-pattern 配置/*和/的区别

    原文地址:http://m.blog.csdn.net/blog/liuxiao723846/43733287 在使用springmvc时,都会在web.xml中配置一个dispatchservlet ...

  5. Android Studio failed to open by giving error “Files Locked” 解决方案

    windows 7 下的解决方案 导航至 android-studio 安装目录. (默认为C:\Program Files (x86)\Android\android-studio). 往上一层文件 ...

  6. 博客代码美化(SyntaxHighlighter)

    这篇博文主要讲解自己使用SyntaxHighlighter对代码进行美工中遇见的问题以及如何使用SyntaxHighlighter? 首先来看看SyntaxHighlighter对代码美工的效果吧! ...

  7. 帆软报表FineReport SQLServer数据库连接失败常见解决方案

    1. 问题描述 帆软报表FineReport客户端连接SQLServer(2000.2005等),常常会出现如下错误:com.microsoft.sqlserver.jdbc.SQLServerExc ...

  8. h3c防火墙的设置过程

    公司采购了一款h3c的防火墙,型号为F100-E-G,以前也设置过H3C的防火墙,不过这次还是设置还是有各种问题,所以把设置过程记录下来,方便以后查阅. 一.防火墙一般在0口都设置一个默认的IP地址1 ...

  9. SpringMVC注入Spring的bean

    一.Spring和SpringMVC两个IOC容器有什么关系呢? Spring的IOC容器包含了SpringMVC的IOC,即SpringMVC配置的bean可以调用Spring配置好的bean,反之 ...

  10. 嵌入式Linux驱动学习之路(二十三)NAND FLASH驱动程序

    NAND FLASH是一个存储芯片. 在芯片上的DATA0-DATA7上既能传输数据也能传输地址. 当ALE为高电平时传输的是地址. 当CLE为高电平时传输的是命令. 当ALE和CLE都为低电平时传输 ...