بیوفارماسی در پایتون | بخش ۱: سیستم یک بخشی عروقی

۷۹۱ بازدید
آخرین به‌روزرسانی: ۹ خرداد ۱۴۰۲
زمان مطالعه: ۶ دقیقه
دانلود PDF مقاله
بیوفارماسی در پایتون | بخش ۱: سیستم یک بخشی عروقیبیوفارماسی در پایتون | بخش ۱: سیستم یک بخشی عروقی

در این مطلب یکی از مدل‌های ساده و پرکاربرد برای توزیع داروهای تزریقی در خون را بررسی می‌کنیم که به آن سیستم یک‌بخشی عروقی گفته می‌شود.

997696

مدل ریاضی توزیع دارو در خون

در شرایطی که دارو به صورت مستقیم وارد خون می‌شود و به صورت درجه یک از خون حذف می‌شود، به صورت زیر خواهیم داشت:

dCdt=K×C{dC \over dt} = -K \times C

که در این رابطه، CC نشان‌دهنده‌ غلظت پلاسمایی دارو tt نشان‌دهنده‌ زمان و عدد KK نیز برابر با ثابت سرعت حذف دارو است.

با اندکی تغییر رابطه‌ بالا به فرم زیر می‌رسیم:

dCC=Kdt{dC \over C} = -K \cdot dt

حال می‌توانیم از طرفین انتگرال بگیریم:

1CdC= Kdt\int {1 \over C} \cdot dC = \space - \int K \cdot dt

ln C= ln C0Kt{\ln \space C} = {\space \ln \space C_0} {-} {Kt}

حال می‌توان مقدار CC را به شکل زیر به دست آورد:

ln Cln C0=Kt{\ln \space C} - {\ln \space C_0} = {- Kt}

ln(CC0)=Kt{\ln} {\large(} { {C} \over C_0} {\large) = -Kt}

CC0=eKt\frac{C}{C_{0}}=e^{-K t}

C=C0eKtC=C_{0} \cdot e^{-K t}

به این شکل مدل نهایی به دست آمد. حال می‌خواهیم یک مدل‌سازی روی داده‌های واقعی انجام دهیم.

مدل‌سازی با داده‌های واقعی در پایتون

فرض کنید 50 میلی‌گرم دارو به صورت تک‌دوز به بیماری تجویز شده است و غلظت پلاسمایی دارو در زمان‌های مختلف در جدول زیر آورده شده است. با مدل‌سازی مناسب، ثابت سرعت حذف، سطح زیر نمودار تا بی‌نهایت، نیمه‌عمر و کلیرانس را محاسبه کنید.

Concentration (mg/L)Time (h)
1٫84۰
1٫56۰٫۵
1٫52۱
1٫17۲
0٫68۴
0٫48۶
0٫24۸
0٫18۱۰

ابتدا وارد محیط برنامه‌نویسی شده و کتابخانه‌های مورد نیاز را فراخوانی می‌کنیم:

این کتابخانه‌ها به ترتیب برای موارد زیر استفاده خواهند شد:

  1. محاسبات ریاضی
  2. کار با آرایه و محاسبات برداری
  3. بهینه‌سازی مدل
  4. رسم نمودار

حال تولید اعداد تصادفی را ثابت کرده و Style نمودارها را تنظیم می‌کنیم:

سطر اول باعث می‌شود در صورت استفاده از اعداد تصادفی در برنامه، در دفعات متفاوت از اجرای کد، نتایج یکسانی بگیریم و نتایج قابل بازتولید باشند. در سطر دوم نیز Style معروف ggplot استفاده شده است. حال داده‌ها را به صورت آرایه تعریف می‌کنیم:

قبل از شروع، داده‌ها را مصورسازی می‌کنیم. برای این کار می‌توانیم از Plot استفاده کنیم:

بنابراین، در خروجی شکل زیر را داریم.

شکل خروجی داده‌ها

مشاهده می‌کنیم که نمودار حاصل، به نمودار تابع نمایی نزدیک است، بنابراین سیستم یک‌بخشی عروقی می‌تواند مورد استفاده قرار گیرد.

اکنون باید مدل را به صورت یک تابع تعریف کنیم. از آن‌جا که محاسبات برای مجموعه‌ای از زمان‌ها انجام می‌شود، باید تابع را متناسب با این نیاز بسازیم. این تابع در ورودی مقدار KK، C0C_0 و زمان‌های مورد نظر را خواهد گرفت و در خروجی غلظت در تک تک زمان‌های ورودی را خواهد داد. بنابراین، خواهیم داشت:

توجه داشته باشید که دو ورودی اول تابع اعدادی اعشاری هستند، ولی ورودی سوم یک بردار از نوع numpy.ndarray است. به دلیل اینکه در TT به جای یک عدد، با مجموعه‌ای از اعداد کار می‌کنیم، باید از تابع numpy.exp به جای math.exp استفاده کنیم. خروجی این تابع نیز یک بردار از نوع numpy.ndarray است.

حالا می‌توانیم با دادن KK و C0C_0 مناسب به تابع Model مقدار غلظت دارو در پلاسما را پیش‌بینی کنیم. ولی مقدار مناسب KK و C0C_0 معلوم نیست و باید آن را تعیین کنیم. برای این کار یک تابع خطا باید تعریف کنیم و آن را بهینه کنیم.

تابع خطا با گرفتن داده‌های اصلی، KK و C0C_0 خواهد توانست خطای حاصل را برگرداند که یک عدد است. بنابراین داریم:

نکته‌ای که باید به آن توجه کرد این است که KK و C0C_0 پارامترهای مدل هستند و باید به صورت یک آرایه با هم به تابع وارد شوند. بنابراین به صورت قراردادی، عضو اول Parameters را برابر با KK و عضو دوم آن را برابر با C0C_0 در نظر می‌گیریم.

در این تابع به ترتیب عملیات زیر را انجام می‌دهیم:

  1. مقدار KK را استخراج می‌کنیم.
  2. مقدار C0C_0 را استخراج می‌کنیم.
  3. با استفاده از تابع Model پیش‌بینی را انجام می‌دهیم.
  4. میانگین قدرمطلق خطاها را محاسبه می‌کنیم.
    • به این خطا به اختصار RMSE گفته می‌شود که کوتاه‌شده عبارت Root Mean Squared Error است.
    • توجه داشته باشید که چون YY و Prediction آرایه‌ای از اعداد هستند، باید از تابع numpy.power به جای pow استفاده کنیم.
  5. مقدار خطا را خروجی می‌گیریم.

به این صورت تابع خطا نیز تعریف می‌شود.

اکنون باید یک حدس اولیه از پارامترها داشته باشیم. با توجه به اینکه غلظت ثبت شده در زمان T=0T=0 برابر با 1.841.84‌است، احتمالاً همین عدد برای غلظت اولیه مناسب خواهد بود. برای ثابت سرعت حذف نیز می‌توان عدد 0.30.3 را محل شروع در نظر گرفت.

حال می‌توانیم بهینه‌سازی را انجام دهیم:

این خط کد، تابع Error را با تغییر پارامترها بهینه می‌کند. با توجه به اینکه تابع خطا به جز پارامترها، دو آرایه‌ دیگر مربوط به زمان و غلظت پلاسمایی را نیز در ورودی می‌گیرد، این دو مورد را در بخش args به صورت یک tuple تعریف می‌کنیم. خروجی این بخش کد یک دیکشنری با اسم Result خواهد بود که کمترین مقدار تابع، بهترین جواب، نتیجه‌ بهینه‌سازی را در خود جای داده است.

از بین این موارد باید بهترین جواب را استخراج کنیم که با کلید 'x' در دسترس است. بنابراین می‌توان نوشت:

حال از روی Parameters می‌توانیم مقدار KK و C0C_0 را استخراج کنیم:

برای مشاهده‌ مقادیر پارامترها نیز، اعداد را تا 4 رقم اعشار در خروجی نمایش می‌دهیم:

پس از اجرا، نتایج زیر در خروجی ظاهر می‌شود.

K: 0.2352 1/h
C0: 1.8359 mg/L

همان‌طور که انتظار داشتیم، مقدار C0C_ 0 عددی نزدیک به 1.841.84 ظاهر شد.

حال می‌توانیم کمترین مقدار خطا را نیز از Result استخراج کرده و نمایش دهیم:

پس از اجرا خواهیم داشت:

RMSE: 0.0426 mg/L

به این صورت مشاهده می‌کنیم که به خطای مناسبی دست یافته‌ایم. توجه داشته باشید که واحد خطای RMSE برابر با داده‌های اصلی یعنی mg/L است.

حال می‌توانیم سایر مقادیر خواسته شده را محاسبه کنیم:

سطح زیر نمودار تا بینهایت

برای به دست آوردن این مقدار، باید از رابطه‌ اصلی به دست آمده انتگرال بگیریم:

0Cdt=0C0eKtdt=C00eKtdt=C0(eKe0K)=C0(0K1K)=C0K\begin{aligned} \int_{0}^{\infty} C \cdot d t=& \int_{0}^{\infty} C_{0} \cdot e^{-K t} \cdot d t=C_{0} \int_{0}^{\infty} e^{-K t} \cdot d t=C_{0}\left(\frac{e^{-\infty}}{-K}-\frac{e^{0}}{-K}\right) \\ &=C_{0}\left(\frac{0}{-K}-\frac{1}{-K}\right)=\frac{C_{0}}{K} \end{aligned}

حال، با وارد کردن رابطه در برنامه داریم:

که پس از اجرا به نتیجه‌ زیر می‌رسیم:

AUC: 7.8035 mg.h/L

نیمه عمر

بر اساس تعریف، نیمه عمر برابر است با مدت زمانی که طول می‌کشد تا غلظت دارو نصف شود. بنابراین داریم:

12C0=C0eKthl21=eKthl2=eKthlln2=Kthlthl=ln2K\begin{align*} \frac{1}{2} C_{0} & =C_{0} \cdot e^{-K t_{h l}} \\ \Rightarrow 2^{-1}&=e^{-K t_{h l}} \\ \Rightarrow 2 &=e^{K t_{h l}} \\ \Rightarrow \ln 2 &=K t_{h l} \\ \Rightarrow t_{h l} &=\frac{\ln 2}{K} \end{align*}

حال خواهیم داشت:

که در خروجی به این حالت داریم:

HL: 2.9482 h

این عدد با داده‌های واقعی نیز سازگار است و می‌توانیم روی نمودار به صورت تقریبی این نقطه را مشاهده کنیم.

کلیرانس

با توانایی بدن در پاک‌سازی حجم توزیع از دارو متناسب است و می‌توان از فرمول زیر مقدار آن را به دست آورد:

Cl=DAUCC l=\frac{D}{A U C}

توجه داشته باشید که در این فرمول، DD مقدار داروی تزریقی است، پس خواهیم داشت:

و در خروجی نیز نتیجه به این صورت خواهد بود:

Cl: 6.4074 L/h

حال می‌توانیم نمودار حاصل از مدل‌سازی را با داده‌های اصلی مقایسه کنیم. برای این کار ابتدا با استفاده از پارامترهای به دست آمده، پیش‌بینی انجام می‌دهیم:

اکنون می‌توانیم دو نمودار را در کنار هم رسم کنیم:

و در خروجی شکل زیر را داشته باشیم.

نمودار کلیرانس

مشاهده می‌کنیم که مدل دقت خوبی از خود نشان داده است.

می‌توان خطای مدل و رابطه‌ نهایی را نیز وارد نمودار کرد و به این صورت نوشت:

تا در خروجی شکل زیر را داشته باشیم.

نمودار خطا

به این صورت می‌توانیم نتیجه‌ کار را به صورت جامع و کامل در یک نمودار نشان دهیم.

بهتر است در این‌گونه مسائل، کمترین و بیشترین درصد خطا نیز آورده شود. برای این منظور، می‌توانیم درصد قدرمطلق خطا (APE یا Absolute Percentage Error) را با استفاده از فرمول زیر محاسبه کنیم:

APE=100×yy^yA P E=100 \times\left|\frac{y-\hat{y}}{y}\right|

درون کد می‌توانیم با استفاده از numpy این بخش را پیاده‌سازی کنیم:

و در نهایت کمترین، بیشترین و میانگین درصد قدرمطلق خطاها را بیابیم و در خروجی نمایش دهیم:

که خواهیم داشت:

Minimum APE: 0.2894 %
Mean APE: 5.3739 %
Maximum APE: 16.5446 %

جمع‌بندی

در این مطلب یاد گرفتیم که مدل یک‌بخشی عروقی را روی داده‌های واقعی برازش (Fit) کنیم، پارامترهای مورد نیاز را محاسبه و مدل را ارزیابی کنیم.

نتایج را به صورت نمودار مشاهده کنیم. مدل ارائه‌شده حالت ساده‌ای از سیستم و ارتباط موجود بین دارو و بدن است. در مطالب بعدی به مدل‌های برای مدل‌سازی شرایط پیچیده‌تر خواهیم پرداخت.

بر اساس رای ۱۶ نفر
آیا این مطلب برای شما مفید بود؟
اگر بازخوردی درباره این مطلب دارید یا پرسشی دارید که بدون پاسخ مانده است، آن را از طریق بخش نظرات مطرح کنید.
منابع:
مجله فرادرس
دانلود PDF مقاله
نظر شما چیست؟

نشانی ایمیل شما منتشر نخواهد شد. بخش‌های موردنیاز علامت‌گذاری شده‌اند *