TWaver - 專注UI技術

          http://twaver.servasoft.com/
          posts - 171, comments - 191, trackbacks - 0, articles - 2
            BlogJava :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理

          DNA分子結構3D模型

          Posted on 2014-08-21 15:07 TWaver 閱讀(633) 評論(0)  編輯  收藏

          生物信息資源更新越來越快,使用可視化的方法來分析DNA序列已成為生物信息學的一個研究熱點,用圖形表示DNA序列的方法也越來越成熟。2011年,著名雜志《Science》發表一篇引起轟動的文章:《Presenting the Human Genome:Now is 3D!》,這篇文章完全給我們描述了人類基因組測序未來的藍圖,可見3D技術在很多領域都是發展方向。
          使用mono可以快速的創建DNA分子結構立體模型,效果如下:



          當然簡單的呈現DNA分子結構,僅僅是一部分功能,如果將mono和專業的DNA分析儀結合,不僅可以發現病癥,更重要的是預測病癥的發生,治病于未發,這將是人類的福音。除了研究人類基因之外,我們還可以對農作物的進行DNA3D模型化,并加以分析,對農業的發展和糧食安全方面都會有積極的意義。
          使用mono創建3D模型最大的特點就是快,代碼不過幾十行,使用Editor更是不需要代碼量。本文的效果圖通過代碼實現,核心代碼如下:

          1function createDNA(box, x, y, z, colors){
          2    var count=20+Math.random()*50;
          3    var dist=50;
          4    var parent=createNode(box, 100,0,0,'red');
          5    for(var i=0;i<count;i++){               
          6            var angle=Math.PI*2/360*15*i;
          7        var radius = (i % 2==0) ? 10 7;
          8        var color = colors[i%2]
          9        var node1=createPairNode(box, dist, radius, i, angle, color);
          10        var node2=createPairNode(box, dist*0.3, radius, i, angle, color);
          11        node1.setParent(parent);
          12        node2.setParent(parent);
          13 
          14        if(i % 2==0){
          15        var link=createLink(box, node1, node2, dist, angle, 'gray');
          16        var node3=createPairNode(box, dist*0.58, radius*0.4, i, angle,'cyan');
          17        var node4=createPairNode(box, dist*0.72, radius*0.4, i, angle,'cyan');
          18        link.setParent(parent);
          19        node3.setParent(parent);
          20        node4.setParent(parent);
          21        }
          22    }
          23    parent.setPosition(x,y,z);
          24        parent.setStyle('m.visible',false);
          25        return parent;
          26}
          1function createPairNode(box, size, radius, index, angle, color){
          2    var x=size*Math.sin(angle);
          3    var z=size*Math.cos(angle);
          4    var y=index * 10;                      
          5    var node = createNode(box, radius, x, y, z, color);
          6    return node;
          7}

          只有注冊用戶登錄后才能發表評論。


          網站導航:
           
          主站蜘蛛池模板: 潞西市| 新郑市| 肇源县| 文安县| 二连浩特市| 杭锦旗| 延长县| 娱乐| 延寿县| 卫辉市| 叶城县| 石嘴山市| 奈曼旗| 清流县| 卢湾区| 军事| 康乐县| 罗江县| 菏泽市| 商都县| 泾源县| 陆丰市| 南陵县| 元朗区| 瓮安县| 南汇区| 福贡县| 屏南县| 观塘区| 兰溪市| 拉萨市| 岳西县| 渝北区| 太谷县| 岚皋县| 香河县| 潜山县| 谷城县| 吉隆县| 得荣县| 陕西省|