網路城邦
上一篇 回創作列表 下一篇   字體:
MetaPost語言﹣宏練習(二)
2013/07/16 07:29:58瀏覽303|回應0|推薦1

%這次練習字串運算,設計宏來進行字串的運算與轉換。DNA主要是由四種氮基結構的配對組成,A、T、C、G四種,而雙股DNA則是A和T配對,C和G配對。而現在就設計宏把單股DNA序列轉成它的配對序列,並且配對成雙股DNA序列。

def antiString (expr t) =

begingroup

save s, antiString; string s[], antiString;

antiString=""

for i=0 upto length t:

hide(

s[i]=substring(i,i+1) of t;

if s[i]="A": s[i]:="T";

elseif s[i]="T": s[i]="A";

elseif s[i]="C": s[i]="G";

elseif s[i]="G": s[i]="C";

fi

)

&s[i]

endfor

;

antiString

endgroup

enddef;

%字串的相加是用&。&前後都要有字串,如果沒有字串,那用空字串""就可以。hide的內容在前面的文章介紹過,它是一個不會為真的判斷式。但判斷式的內容會運算過一遍,而運算結果就直接可以使用。所以antiString="" for i=0 utpo length t: hide( .......) &s[i] endfor ; 的運算結果就是 antiString = "" &s0&s1&s2&s3...; s[i]的內容在hide()內已算過一遍了,所以不會影響字串的相加運算。最後運算結果就是antiString的值。

%接下來畫出雙股DNA:

def draw_dsDNA(expr t)=

begingroup

save ssDNA, asDNA; string ssDNA[], asDNA[];

if length t > 5:%檢查字串長度

for i=0 upto floor (length t -1)/5:%分別截取長度為5的字串

ssDNA[i]=substring(5*i, 5*i+5) of t;

asDNA[i]=antiString(ssDNA[i]);

label.rt(ssDNA[i],(0,-i*cm));

labe.rt(asDNA[i],(0,(-i-0.3)*cm));

endfor

else:

ssDNA0=t;

asDNA0=antiString(t);

label.rt(ssDNA0,(0,0));

label.rt(asDNA0,(0,-0.3cm));

fi

endgroup

enddef;

%draw_dsDNA也很簡單,主要就是把二個字串用label指令畫出來。因為考慮到DNA序列很長,所以在5個DNA氮基長度就把它切斷。這個字串要表示多長則可以視需要改變其中判斷式的內容。

%接下來就是實際上畫出來:

beginfig(1);

string a; a="TAACCAAGCATG"

draw_dsDNA(a);

endfig;

%其他的運算,如檢查EcoR1的位置,可以用

pair position[];

def position_Ecor1_check(expr t) = 

begingroup

save check;

check:=0;

for i=0 upto length t:

if substring (i, i+6) of t = "GAATTC":

position[check]=(i,i+6);

check:=check+1;

fi

endfor

if check=0:

show "No EcoR1 site!";

fi

endgroup;

enddef;

%position[]的內容就是EcoR1在DNA字串中的位置,然後再視需要再做出運算。DNA的序列很長,可以用readfom "fileName" 取得檔案內一行字串內容。

( 興趣嗜好電腦3C )
回應 推薦文章 列印 加入我的文摘
上一篇 回創作列表 下一篇

引用
引用網址:https://classic-blog.udn.com/article/trackback.jsp?uid=paraquat&aid=7943752