آموزش ریزآرایه فنوتیپ در برنامه نویسی بایوپایتون
آموزش ریزآرایه فنوتیپ در برنامه نویسی بایوپایتون
در این درس از آموزش های برنامه نویسی سایت سورس باران، ما در مورد آموزش ریزآرایه فنوتیپ در برنامه نویسی بایوپایتون بحث خواهیم کرد.
پیشنهاد ویژه : پکیج آموزش پایتون مختص بازار کار
فنوتیپ به عنوان یک کاراکتر یا صفت قابل مشاهده که توسط ارگانیسم در برابر یک ماده شیمیایی یا محیط خاص به نمایش گذاشته می شود، تعریف می شود. ریزآرایه فنوتیپ همزمان واکنش یک ارگانیسم را در برابر تعداد بیشتری از مواد شیمیایی و محیط اندازه گیری می کند و داده ها را برای درک جهش ژنی، کاراکتر های ژنی و غیره تجزیه و تحلیل می کند
بایوپایتون یک ماژول عالی، Bio.Phenotype برای تجزیه و تحلیل داده های فنوتیپی فراهم می کند. بیایید یاد بگیریم که چگونه داده های ریزآرایه فنوتیپ را تجزیه، درون یابی، استخراج و تحلیل کنیم.
تجزیه ریزآرایه فنوتیپ
داده های ریزآرایه فنوتیپ می توانند در دو قالب CSV و JSON باشند. بایوپایتون از هر دو قالب پشتیبانی می کند. تجزیه کننده بایوپایتون داده ریزآرایه فنوتیپ را تجزیه می کند و به عنوان مجموعه ای از اشیا Pla PlateRecord برمی گردد. هر شی PlateRecord شامل مجموعه ای از اشیا Well WellRecord است. هر شی WellRecord داده ها را در قالب 8 ردیف و 12 ستون نگهداری می کند. هشت ردیف با A تا H و 12 ستون با 01 تا 12 نشان داده می شوند. به عنوان مثال، سطر 4 و ستون 6 با D06 نشان داده می شوند.
اجازه دهید قالب و مفهوم تجزیه را با مثال زیر درک کنیم:
مرحله 1 – دانلود فایل Plates.csv ارائه شده توسط تیم بایوپایتون – https://raw.githubusercontent.com/biopython/biopython/master/Doc/examples/Plates.csv
مرحله 2 – ماژول phenotpe را به صورت زیر بار کنید:
1 |
>>> from Bio import phenotype |
مرحله 3 – متد phenotype.parse را فراخوانی کنید تا از فایل داده و گزینه قالب (“pm-csv”) استفاده شود. PlateRecord قابل تکرار را به صورت زیر برمی گرداند:
1 2 3 4 5 6 7 |
>>> plates = list(phenotype.parse('Plates.csv', "pm-csv")) >>> plates [PlateRecord('WellRecord['A01'], WellRecord['A02'], WellRecord['A03'], ..., WellRecord['H12']'), PlateRecord('WellRecord['A01'], WellRecord['A02'], WellRecord['A03'], ..., WellRecord['H12']'), PlateRecord('WellRecord['A01'], WellRecord['A02'], WellRecord['A03'], ..., WellRecord['H12']'), PlateRecord('WellRecord['A01'], WellRecord['A02'],WellRecord['A03'], ..., WellRecord['H12']')] >>> |
مرحله 4 – به صفحه اول لیست زیر به صورتی که در پایین نمایش داده شده است، دسترسی پیدا کنید:
1 2 3 4 5 |
>>> plate = plates[0] >>> plate PlateRecord('WellRecord['A01'], WellRecord['A02'], WellRecord['A03'], ..., WellRecord['H12']') >>> |
مرحله 5 – همانطور که قبلاً بحث شد، یک صفحه شامل 8 ردیف است که هر کدام دارای 12 مورد هستند. WellRecord به دو متد قابل دسترسی است که در زیر مشخص شده است:
1 2 3 4 5 |
>>> well = plate["A04"] >>> well = plate[0, 4] >>> well WellRecord('(0.0, 0.0), (0.25, 0.0), (0.5, 0.0), (0.75, 0.0), (1.0, 0.0), ..., (71.75, 388.0)') >>> |
مرحله 6 – هر WellRecord دارای یک سری اندازه گیری در نقاط مختلف زمانی است و می توان با استفاده از حلقه به شرح زیر دسترسی پیدا کرد:
1 2 3 4 5 6 7 8 9 10 11 12 13 |
>>> for v1, v2 in well: ... print(v1, v2) ... 0.0 0.0 0.25 0.0 0.5 0.0 0.75 0.0 1.0 0.0 ... 71.25 388.0 71.5 388.0 71.75 388.0 >>> |
درون یابی
درون یابی بینش و اطلاعات بیشتری به داده ها می دهد. بایوپایتون روش هایی را برای استفاده از داده های WellRecord برای به دست آوردن اطلاعات برای زمان های میانی ارائه می دهد. نحو مشابه فهرست بندی فهرست است و بنابراین یادگیری آن آسان است.
برای بدست آوردن داده ها در ساعت 20.1 ، کافی است مقادیر شاخص را در زیر مشخص کنید:
1 2 3 |
>>> well[20.10] 69.40000000000003 >>> |
ما می توانیم از نقطه زمان شروع و زمان پایان و همچنین در زیر مشخص کنیم:
1 2 3 |
>>> well[20:30] [67.0, 84.0, 102.0, 119.0, 135.0, 147.0, 158.0, 168.0, 179.0, 186.0] >>> |
دستور فوق داده ها را از 20 ساعت تا 30 ساعت با فاصله 1 ساعت درون یابی می کند. به طور پیش فرض، این فاصله 1 ساعت است و می توانیم آن را به هر مقداری تغییر دهیم. به عنوان مثال اجازه دهید 15 دقیقه (0.25 ساعت) فاصله را به شرح زیر ارائه دهیم:
1 2 3 |
>>> well[20:21:0.25] [67.0, 73.0, 75.0, 81.0] >>> |
تجزیه و تحلیل و استخراج
بایوپایتون یک متد مناسب برای تجزیه و تحلیل داده های WellRecord با استفاده از توابع سیگموئید Gompertz ،Logistic و Richards فراهم می کند. به طور پیش فرض، متد fit از تابع Gompertz استفاده می کند. برای انجام وظیفه باید متد fit شی object WellRecord را فراخوانی کنیم. که به شرح زیر است:
1 2 3 4 5 6 7 8 9 10 |
>>> well.fit() Traceback (most recent call last): ... Bio.MissingPythonDependencyError: Install scipy to extract curve parameters. >>> well.model >>> getattr(well, 'min') 0.0 >>> getattr(well, 'max') 388.0 >>> getattr(well, 'average_height') 205.42708333333334 >>> |
بایوپایتون برای انجام تجزیه و تحلیل پیشرفته به ماژول Scipy نیاز دارد. این جزئیات حداقل، حداکثر و متوسط_ارتفاع را بدون استفاده از ماژول scipy محاسبه می کند.
لیست جلسات قبل آموزش برنامه نویسی بایوپایتون
- آموزش برنامه نویسی بایوپایتون (Biopython)
- معرفی برنامه نویسی بایوپایتون
- آموزش نصب بایوپایتون
- ایجاد یک برنامه ساده در برنامه نویسی بایوپایتون
- آموزش دنباله در برنامه نویسی بایوپایتون
- عملیات توالی پیشرفته در برنامه نویسی بایوپایتون
- آموزش توالی ورودی/خروجی در برنامه نویسی بایوپایتون
- آموزش همترازسازی توالی در برنامه نویسی بایوپایتون
- بررسی اجمالی BLAST در برنامه نویسی بایوپایتون
- بررسی پایگاه داده Entrez در برنامه نویسی بایوپایتون
- آموزش ماژول PDB در برنامه نویسی بایوپایتون
- آموزش اشیا موتیف در برنامه نویسی بایوپایتون
- آموزش ماژول BioSQL در برنامه نویسی بایوپایتون
- آموزش ژنتیک جمعیت در برنامه نویسی بایوپایتون
- آموزش آنالیز ژنوم در برنامه نویسی بایوپایتون
دیدگاه شما