দাবিত্যাগ : এই নিবন্ধটির লক্ষ্য হল স্পষ্ট করা যে প্রদত্ত কোডটি গাণিতিক মডেলিংয়ের সমস্ত দিকগুলির জন্য সর্বজনীন সমাধান নয়। পরিবর্তে, এটি একটি শিক্ষামূলক সরঞ্জাম হিসাবে কাজ করে, গাণিতিক মডেলিং প্রক্রিয়ার একটি নির্দিষ্ট ধাপকে হাইলাইট করে এবং এই ক্ষেত্রে সচেতনতা বাড়ানোর প্রাথমিক লক্ষ্য সহ উদাহরণমূলক উদ্দেশ্যে পাইথনকে নিয়োগ করে।
এটি মনে রাখাও গুরুত্বপূর্ণ যে একটি গাণিতিক মডেল প্রকল্প জমা দেওয়ার/প্রস্তাব করার সময় আপনাকে অবশ্যই নির্দিষ্ট ব্যবস্থা নিতে হবে, যেমন জৈব গণিতের ক্ষেত্রের সাথে সম্পর্কিত।
এই পদক্ষেপগুলির মধ্যে রয়েছে, তবে সীমাবদ্ধ নয়: সমস্যাটি সংজ্ঞায়িত করা, একটি মডেল পদ্ধতি নির্বাচন করা (দুটি মডেল এই নিবন্ধে আলোচনা করা হবে), সমীকরণ প্রণয়ন, পরামিতি অনুমান—প্রায়শই ঐতিহাসিক ডেটার উপর ভিত্তি করে, বিশ্লেষণাত্মক সমীকরণগুলি সমাধান করে সংখ্যাসূচক সিমুলেশনগুলি প্রয়োগ করা বা পাইথন এবং ম্যাটল্যাব, বৈধতা এবং সংবেদনশীলতা বিশ্লেষণ, দৃশ্যকল্প পরীক্ষা, ফলাফল ব্যাখ্যা ইত্যাদির মতো গণনামূলক সরঞ্জামগুলি ব্যবহার করে।
যেমনটি আমি আগে বলেছি, এটি শুধুমাত্র গাণিতিক মডেলিং প্রক্রিয়ার একটি নির্দিষ্ট পদক্ষেপ এবং চিত্রিত উদ্দেশ্যে পাইথন নিয়োগ করে।
জনসাধারণের স্বাস্থ্য বজায় রাখার জন্য কীভাবে সংক্রামক রোগ ছড়িয়ে পড়ে তা বোঝা অপরিহার্য কারণ মানব ইতিহাসে সেগুলি বহু শতাব্দী ধরে বিদ্যমান। রোগ বিস্তারের গতিশীলতা অনুকরণ এবং বোঝার জন্য একটি শক্তিশালী হাতিয়ার হল গাণিতিক মডেল। পাইথন ব্যবহার করে কীভাবে তাদের অনুকরণ করা যায় তার সাথে এই নিবন্ধে SIR (সংবেদনশীল-সংক্রামক-পুনরুদ্ধার) এবং SEIR (সংবেদনশীল-প্রকাশিত-সংক্রামক-পুনরুদ্ধার) মডেলগুলি নিয়ে আলোচনা করা হবে।
জনস্বাস্থ্য পেশাদার এবং এপিডেমিওলজিস্টদের জন্য, সিমুলেশন একটি ক্রিস্টাল বলের মতো। এটি আমাদের বিভিন্ন পরিস্থিতিতে এবং চিকিত্সার বিকল্পগুলির অধীনে রোগের সম্ভাব্য বিস্তারের পূর্বাভাস দিতে সক্ষম করে। এই মডেলগুলি সিদ্ধান্ত গ্রহণ, কার্যকর সংস্থান বরাদ্দ এবং বিভিন্ন কৌশলগুলির সম্ভাব্য প্রভাবগুলি বোঝার ক্ষেত্রে সহায়তা করে। আসুন দুটি মৌলিক মডেল পরীক্ষা করা যাক; SIR মডেল, এবং SEIR মডেল।
সংবেদনশীল, সংক্রামক এবং পুনরুদ্ধার (SIR) মডেল একটি জনসংখ্যাকে এই তিনটি বিভাগে আলাদা করে। ট্রান্সমিশন রেট ( β ) এবং রিকভারি রেট ( γ ) এর মত ভেরিয়েবলের উপর ভিত্তি করে, এটি অনুকরণ করে কিভাবে এই কম্পার্টমেন্টগুলি সময়ের সাথে পরিবর্তিত হয়।
পাইথন ব্যবহার করে একটি সিমুলেশনের উদাহরণ দেওয়ার আগে, গাণিতিক মডেলগুলিতে কাজ করার সময় "মডেল অনুমান" তৈরি করা প্রয়োজন।
আমাদের অনুমানে আমরা LaTeX ফর্মুলার বা কোড ব্যবহার করে মডেল তৈরি করব:
\begin{align*} \frac{dS}{dt} &= -\beta \cdot S \cdot I \\ \frac{dI}{dt} &= \beta \cdot S \cdot I - \gamma \cdot I \\ \frac{dR}{dt} &= \gamma \cdot I \end{align*}
দ্রষ্টব্য: আপনি পাইথন ব্যবহার করে এই ফর্মুলারটি latexify করতে পারেন। একটি উদাহরণ https://github.com/google/latexify_py/blob/main/examples/examples.ipynb- এ পাওয়া যাবে।
এই নিবন্ধটি লেটেক্সকে একটি সঠিক গাণিতিক স্বরলিপি/সমীকরণে রূপান্তর করতে পাইথন কোডটি লিখতে বিরক্ত করবে না, তবে আমি অনলাইন সম্পাদক যেমন https://latexeditor.lagrida.com/ ব্যবহার করেছি যাতে আপনি নীচের সূত্র/সমীকরণ অনুমানগুলি স্পষ্টভাবে দেখতে পারেন :
কোথায় :
পরামিতি β এবং γ যথাক্রমে সংক্রমণ এবং পুনরুদ্ধারের হার নিয়ন্ত্রণ করে। নেতিবাচক চিহ্ন (অর্থাৎ −β) নির্দেশ করে যে সংবেদনশীল ব্যক্তির সংখ্যা (S) সময়ের সাথে হ্রাস পায়। ডট নোটেশন "গুণ" নির্দেশ করে।
সংক্ষেপে, এই সমীকরণগুলি এসআইআর মডেলের গতিশীলতাকে বর্ণনা করে, যেখানে সংবেদনশীল লোকের সংখ্যা হ্রাস পায় যখন তারা রোগে আক্রান্ত হয় (যেমন dS/dt), সংক্রামক মানুষের সংখ্যা নতুন সংক্রমণের ফলে বৃদ্ধি পায় এবং পুনরুদ্ধারের সাথে সাথে হ্রাস পায় ( যেমন dI/dt), এবং রোগের চিকিৎসার সাথে সাথে পুনরুদ্ধারের সংখ্যা বৃদ্ধি পায় (যেমন dR/dt)। যেহেতু প্রতিটি বগির পরিবর্তন প্রাসঙ্গিক উপাদানগুলির গুণনের উপর নির্ভর করে, বিন্দুগুলি (.) গুণ বোঝাতে ব্যবহৃত হয়।
যেহেতু সমস্ত অনুমান সেট করা আছে, আমরা তখন SIR মডেলের জন্য পাইথন ব্যবহার করে একটি সিমুলেশন চালাতে পারি এবং তারপর গতিবিদ্যাকে কল্পনা করতে পারি:
import numpy as np from scipy.integrate import odeint import matplotlib.pyplot as plt # SIR model equations def SIR_model(y, t, beta, gamma): S, I, R = y dSdt = -beta * S * I dIdt = beta * S * I - gamma * I dRdt = gamma * I return [dSdt, dIdt, dRdt] """ Initial conditions (such as S0, I0, and R0) are not to be random but I hardcoded them with specific values. These choices are typically made based on the characteristics of the disease being modeled and the context of the simulation. Initial condition are set such that S0 = 99%, which indicates the proportion of susceptible individuals when the simulation starts. I0 is set to 1%, which indicates proportion of infected individuals to be 1% when the simulation starts. R0 is set to 0% which is expected that there are are no recovered individuals when the simulations start. """ S0 = 0.99 I0 = 0.01 R0 = 0.00 y0 = [S0, I0, R0] # Parameters # β (beta) is transmission rate and I chose 30%. γ (gamma) is set to 1% beta = 0.3 gamma = 0.1 # Time vector t = np.linspace(0, 200, 200) # Simulate for 200 days # Solve the SIR model equations using odeint() solution = odeint(SIR_model, y0, t, args=(beta, gamma)) # Extract results S, I, R = solution.T # Plot the results plt.figure(figsize=(10, 6)) plt.plot(t, S, label='Susceptible') plt.plot(t, I, label='Infected') plt.plot(t, R, label='Recovered') plt.xlabel('Time (days)') plt.ylabel('Proportion of Population') plt.title('SIR Model Simulation') plt.legend() plt.grid(True) plt.show()
scipy.integrate.ode
এবং scipy.integrate.odeint
এর মধ্যে পার্থক্যের জন্য, আমি আপনাকে odeint এবং ode- এ নির্দেশ করতে চাই যাতে আপনি এটি আরও বুঝতে পারেন।
পাইথনে SIR মডেল চালানো আপনাকে অনুমতি দেয়:
রোগের বিস্তার বুঝুন : মহামারী বক্ররেখা পর্যবেক্ষণ করুন এবং একটি সম্প্রদায়ের মাধ্যমে কীভাবে একটি রোগ ছড়ায় তা কল্পনা করুন। উপরের পাইথন এসআইআর মডেলটি চলমান, আপনি নীচের গ্রাফে ফলাফল/ফলাফল দেখতে পারেন:
হস্তক্ষেপের মূল্যায়ন করুন: পরামিতি পরিবর্তন করে, আপনি হস্তক্ষেপের পরিণতি অনুকরণ করতে পারেন যেমন
সামাজিক বিচ্ছিন্নতা বা টিকাদান।
একটি "উন্মুক্ত" বগি যোগ করার মাধ্যমে, SEIR মডেল SIR মডেলের উপর প্রসারিত হয়। এটি ইনকিউবেশনের সময়কালকে বিবেচনা করে যে সময়ে লোকেরা সংক্রমিত হয়েছে কিন্তু এখনও সংক্রামক নয়। পাইথনে এটি কীভাবে অনুকরণ করা যায় তা এখানে দেখানো হয়েছে।
import numpy as np from scipy.integrate import odeint import matplotlib.pyplot as plt # SEIR model equations def SEIR_model(y, t, beta, sigma, gamma): S, E, I, R = y dSdt = -beta * S * I dEdt = beta * S * I - sigma * E dIdt = sigma * E - gamma * I dRdt = gamma * I return [dSdt, dEdt, dIdt, dRdt] # Initial conditions S0 = 0.99 E0 = 0.01 I0 = 0.00 R0 = 0.00 y0 = [S0, E0, I0, R0] # Parameters beta = 0.3 sigma = 0.1 gamma = 0.05 # Time vector t = np.linspace(0, 200, 200) # Solve the SEIR model equations solution = odeint(SEIR_model, y0, t, args=(beta, sigma, gamma)) # Extract results S, E, I, R = solution.T # Plot the results plt.figure(figsize=(10, 6)) plt.plot(t, S, label='Susceptible') plt.plot(t, E, label='Exposed') plt.plot(t, I, label='Infected') plt.plot(t, R, label='Recovered') plt.xlabel('Time (days)') plt.ylabel('Proportion of Population') plt.title('SEIR Model Simulation') plt.legend() plt.grid(True) plt.show()
এই ক্ষেত্রে একমাত্র পার্থক্য হল বিভিন্ন পরিস্থিতিতে অন্বেষণ করতে এবং একটি "উন্মুক্ত" সময়ের সাথে সংক্রামক রোগের গতিশীলতা বোঝার জন্য latent period rate (σ)
এর প্রবর্তন। এটি ব্যক্তিদের সংক্রামক হওয়ার আগে এটি কীভাবে ইনকিউবেশন পিরিয়ডের জন্য দায়ী তা প্রদর্শন করে।
যখন আপনি SEIR মডেল চালানোর জন্য Python ব্যবহার করেন, আপনি করতে পারেন:
মডেল সুপ্ত সময়কাল
অবিলম্বে সংক্রামক অসুস্থতা এবং ইনকিউবেশন পিরিয়ডের সাথে রোগের আচরণের মধ্যে পার্থক্যগুলি চিনুন।
প্রারম্ভিক হস্তক্ষেপ মূল্যায়ন
বিচ্ছিন্নতা এবং প্রাথমিক সনাক্তকরণ কৌশলগুলির প্রভাব বিশ্লেষণ করুন।
অধ্যয়ন জটিল প্রাদুর্ভাব
COVID-19-এর মতো অসুস্থতার জন্য যেখানে উন্মুক্ত ব্যক্তিরা সংক্রমণের একটি প্রধান কারণ, SEIR ব্যবহার করুন।
পাইথনের সরলতা এবং শক্তিশালী লাইব্রেরি, যেমন SciPy, এটিকে মডেলিং রোগের জন্য নিখুঁত ভাষা করে তোলে। এবং এটির সাথে এই সিমুলেশনগুলি সম্পাদন করে, আপনি সংক্রামক রোগের গতিশীলতা সম্পর্কে আরও শিখছেন। এটি আপনাকে রায় এবং দক্ষতার সাথে সজ্জিত করতে পারে যা সঠিকভাবে অবহিত সিদ্ধান্ত নিতে সাহায্য করতে পারে এবং বাস্তব বিশ্বে মহামারীগুলি মূল্যায়ন করার জন্য আপনার নিজস্ব ক্ষমতা উন্নত করতে পারে।
SIR এবং SEIR মডেলের পরে আরও অনেক কিছু আসতে হবে। অন্যান্য জটিল মডেল রয়েছে যেমন SEIRS (Susceptible-Exposed-Infectious-Removed-Susceptible) মডেল, স্থানিক মডেল, নেটওয়ার্ক মডেল, ইত্যাদি। জটিল মডেলগুলি তদন্ত করে, সেইসাথে বাস্তব বিশ্বের ডেটা, যেমন ভূ-স্থানিক ডেটা, মহামারী সংক্রান্ত ডেটা, আচরণগত ডেটা। , ইত্যাদি, এবং সাবধানে হস্তক্ষেপের প্রভাবগুলি পরীক্ষা করে, যেমন টিকা কৌশল, চিকিত্সার প্রাপ্যতা, সামাজিক দূরত্বের ব্যবস্থা, আপনি আপনার মডেলিং ক্ষমতা আরও বিকাশ করবেন।
এই মডেলিং সরঞ্জামগুলির সম্পর্কে আপনার জ্ঞান ভবিষ্যতে জনস্বাস্থ্য রক্ষায় উল্লেখযোগ্যভাবে প্রভাবিত করতে পারে যেখানে সংক্রামক রোগ সংক্রমণ বোঝা অত্যাবশ্যক।
এটি ইতিমধ্যেই অনেক দীর্ঘ, কিন্তু আমি আশা করি আমি আপনাকে দেখাতে সক্ষম হয়েছি কিভাবে পাইথন ব্যবহার করে গাণিতিক মডেলে SIR এবং SEIR মডেলগুলি অনুকরণ করা যায়।