<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0">
    <channel>
        <title>نوشته های حامد فاضل مسائلی</title>
        <link>https://virgool.io/feed/@m_32927681</link>
        <description></description>
        <language>fa</language>
        <pubDate>2026-06-17 06:03:59</pubDate>
        <image>
            <url>https://files.virgool.io/upload/users/1524759/avatar/tHPfqI.jpeg?height=120&amp;width=120</url>
            <title>حامد فاضل مسائلی</title>
            <link>https://virgool.io/@m_32927681</link>
        </image>

                    <item>
                <title>من یک مدل را آموزش دادم. قدم بعدی چیه ؟</title>
                <link>https://virgool.io/Solidity/%D9%85%D9%86-%DB%8C%DA%A9-%D9%85%D8%AF%D9%84-%D8%B1%D8%A7-%D8%A2%D9%85%D9%88%D8%B2%D8%B4-%D8%AF%D8%A7%D8%AF%D9%85-%D9%82%D8%AF%D9%85-%D8%A8%D8%B9%D8%AF%DB%8C-%DA%86%DB%8C%D9%87-wwzq2mcaj7ll</link>
                <description>این پست آموزه های Vladimir Iglovikov یکی از استادبزرگ‌های Kaggle است که آرزو می‌کرد هنگامی که در چالش‌های هوش مصنوعی شرکت می‌کرد کسی  این پیشنهادات را به او می‌داد.پست اصلی را می‌توانید اینجا بخوانید.  Teranus blogمقدمه :من در مسابقات Machine Learning پلتفرم‌های مختلفی شرکت کردم تا مهارت خودم را در ML تقویت کنم. من رتبه ی 19 جهانی و عنوان استادبزرگ Kaggle را کسب کردم.هر چالش ML با یک دانش جدید،کد و مدل به پایان می رسید. من آموختن را دوست داشتم اما از ارزش این روند یادگیری چشم‌پوشی می‌کردم. کد های من در repository (مخزن) خصوصی github باقی می‌ماند و در آخر همه‌ی آن‌ها پاک می‌شد.این وضعیت در همه‌ی پلتفرم‌ها یکسان است. دانش‌آموز مدل را آموزش می‌دهد،مقاله می‌نویسد و بعد از اینکه قبول می‌شود،تمام این کار‌ها را رها می‌کند،این آموزه‌ها پاک می‌شود و دانش آموز سراغ چالش بعدی می‌رود.این بلاگ در مورد قدم‌های کوچکی صحبت می‌کند که بعد از پایان هر چالش می‌توانید انجام دهید.این قدم‌ها باعث می‌شود:اطلاعات فنی شما افزایش یابدبرند شخصی خودتان را بسازیدموقعیت های شغلی شما بهتر شوددنیا به جای بهتری تبدیل شود :))به عنوان مثال،من از این Repository به صورت آزمایشی استفاده می‌کنم تا کار‌هایی که توضیح داده‌ام را آن‌جا نشان دهم.Teranus Repository1.کد را در repository عمومی github پخش کنید. 5+ دقیقهمعمولا کد در repository خصوصی github است. چه چیزی را از دست می‌دهید اگر کدتان را عمومی کنید؟موقعیت‌هایی است که کد‌های خصوصی باید خصوصی بماند اما در پروژه‌ی آموزشی شما،جواب چالش شما یا مقاله‌ی شما ممکن است این طور نباشد.متداول‌ترین مانعی که دیدم این است که مردم فکر می‌کنند باید کد‌های عمومی بدون نقص باشند و گرنه مورد قضاوت قرار می‌گیرند.در واقعیت،هیچ‌کس اهمیت نمی‌دهد،فقط انجامش بدهید و همان‌طور که هست بدون هیچ اصلاحی پخشش کنید. عمومی کردن کد از لحاظ روانی،یک قدم بسیار بزرگ است. پخش کردن کدی که عالی نیست یک عمل جسورانه است.مرحله‌های بعدی بر اساس مثال زیر جلو می‌رود.Teranus Retinaface 2.خوانایی کدتان را افزایش دهید. 20+ دقیقهبا اضافه کردن syntax formatters و checkers می‌توانید خوانایی کدتان را افزایش دهید. اصلا سخت و زمان‌بر نیست. checkers و formatters کد بد را به خوب تغییر نمی‌دهند اما خوانایی آن را افزایش میدهند. به درست‌کردن syntax‌های کد مثل بهداشت فردی فکر کنید مثل مسواک زدن.مرحله‌ی اول: Configuration files (فایل‌های پیکربندی)این فایل‌ها را به ریشه‌ی (root) repository خود اضافه کنید.setup.cfg — configuration for flake8 and mypypyproject.toml — configuration for black.مرحله‌ی دوم: ملزوماتکتاب‌خانه‌های مورد نیاز را نصب کنید.pip install black flake8 mypyمرحله‌ی سوم : Blackراه‌های بسیار زیادی برای Format کردن کد وجود دارد.formatter‌هایی مثل black یا yapf، کد را بر اساس قواعد از پیش تعیین شده تغییر می‌دهند. خواندن کدی که از تعدادی الگو پیروی می‌کند راحت‌تر است وقتی ساعت‌ها روی کد کار می‌کنید و نیاز دارید که زمینه را بین سبک‌های مختلف کدنویسی تغییر دهید، «انرژی اراده» را تخلیه می‌کند؛ نیازی به انجام آن بدون دلیل موجه نیست.اجرا کنیدblack . تمامی فایل‌های پایتون شما را با قواعد black تغییر می‌دهد.مرحله‌ی چهارم: Flake8اجرا کنیدflake8 کد را اصلاح نمی‌کند اما کد را برای مشکلات syntax چک می‌کند و آن‌ها را روی صفحه نشان می‌دهد.درستشان کنید.مرحله ی 5 :mypyپایتون سیستم تایپ ایستا ندارد اما توصیه می‌شود که الگویی به آرگومان‌های تابع و انواع return اضافه کنید.  به عنوان مثال :class MyModel(nn.Module):    ....def forward(x: torch.Tensor) -&gt; torch.Tensor:    ....    return self.final(x)کد خواناتر می‌شود.می‌توانید از mypy package برای بررسی سازگاری آرگومان‌ها و انواع تابع استفاده کنید.بعد از به روز کردن کد، mypy را بر کل repository اجرا کنید.mypy .باید الگوی تایپی به کد اضافه کنید :اگر mypy مشکلی پیدا کرد؛ درستشان کنید.مرحله‌ی ششم :اجرا کردن دستی mypy،black،flake8 آزاردهنده است. ابزاری به اسم pre-commit hook این مشکل را حل می‌کند. برای فعال کردن آن ، این فایل را در repository کپی کنید. pre-commit-config.yamlنیاز دارید که pre-commit package را روی ماشین خود نصب کنید.pip install pre-commit و با این خط کد مقدار اولیه را بدهید.pre-commit install الان همه چیز آمادستاز این به بعد در هر commit مجموعه‌ای از بررسی‌ها را اجرا می‌کند و اگر مشکلی پیش آمد اجازه انتشار commit را نمی دهد.تفاوت اصلی بین اجرای دستی black, flake8, mypy این است که به شما التماس نمی‌کند که مشکلات را برطرف کنید، بلکه شما را مجبور به انجام این کار می کند. از این رو، &quot;انرژی اراده&quot; هدر نمی رود.مرحله‌ی هفتم: اقدام‌های githubشما چک‌ها را به pre-commit hook اضافه کرده اید و آن‌ها را به صورت محلی اجرا می‌کنید. اما شما نیاز به یک خط دفاع دوم دارید. برای اجرای این بررسی‌ها در هر درخواست pull به Github نیاز دارید.راه انجام این کار، اضافه کردن فایل .github/workflows/ci.yaml به repository است.این کد هاست :- name: Install dependencies      run: |        python -m pip install --upgrade pip        pip install -r requirements.txt        pip install black flake8 mypy    - name: Run black      run:        black --check .    - name: Run flake8      run: flake8    - name: Run Mypy      run: mypy retinaface این به github می‌گوید که چه چیزی را چک کند.من همین‌طور پیشنهاد می‌کنم بیخیال push کردن مستقیم کدتان به master branch بشوید.یک شاخه درست کنید ، کدتان را اصلاح کنید، commit کنید،push کنید، درخواست pull ایجاد کنید و بعد با master branch ادغام کنید.این کار‌ها در بازار کار کاملا استاندارد است اما در فضای آموزشی و میان کسانی که در چالش‌ها شرکت می‌کنند غیر‌معمول است.اگر با این ابزار‌ها آشنا نیستید، ممکن است بیش از 20 دقیقه طول بکشد که ابزار‌ها را اضافه کنید و خطا‌ها و هشدار‌ها را درست کنید.یادتان باشد در پروژه بعدی این چک‌ها را در commit اول که هیچ کدی نوشته نشده است اضافه کنید. از آن لحظه، هر commit کوچک بررسی می شود، و شما باید هر بار حداکثر چند خط کد را اصلاح کنید: سربار کوچک، عادت عالی. همچنین خواندن کتاب عادات اتمی را توصیه می کنم. در مورد تغییرات کوچک در رفتار شما صحبت می‌کند که بهره‌وری و کیفیت زندگی شما را بهبود می‌بخشد.3. یک Readme خوب بنویسید.یک Readme خوب دو هدف را دنبال می‌کند:برای خودتان: شما فکر می‌کنید که هرگز قرار نیست از این کد استفاده کنید اما هرگز نگویید هرگز ؛ شما این کار را انجام خواهید داد و یادتان هم نمی‌آید که اینجا چه اتفاقاتی افتاده است. readme به شما کمک خواهد کرد.برای دیگران: readme یک نقطه‌ی فروش است. اگر دیگران نتوانند هدف repository شما را بفهمند و این‌که چه مشکلی را حل می‌کند، از آن استفاده نخواهند کرد و تمام کار‌هایی که شما انجام دادید تاثیر مثبتی بر دیگران نمی‌گذارد.برای machine learning repositories حداقل ها عبارتند از:تصویری که  بگوید task چه بود و چگونه آن را حل کردید. هیچ کلمه ای نباید مورد نیاز باشد. به احتمال زیاد، پس از هفته ها کار روی یک مشکل، کلی عکس دارید. آنها فقط بخشی از Readme نیستند. درستش کنداده ها را کجا اضافه کنند.چگونه آموزش مدل را شروع کنند.چگونه نتیجه‌گیری کنند.اگر شما نیاز به نوشتن 100500 کلمه برای توصیف نحوه اجرای آموزش یا نتیجه‌گیری آن دارید، این یک زنگ خطر است. شما باید کد خود را اصلاح و user friendly کنید. مردم اغلب می پرسند - چگونه می‌توانم برنامه‌نویس بهتری شوم؟ این تمرینی است که کمک می‌کند. شما باید کد خود را بازنویسی کنید. سعی کنید از چشمان شخص دیگری به Readme خود نگاه کنید و به مرور این رفتار باعث ایجاد یک عادت خوب می‌شود که به محصول خودتان از دیدگاه یک کاربر نگاه کنید.4.استفاده از مدل‌تان را راحت‌تر کنید. 20+ دقیقهحدس می‌زنم شما بنویسیدmodel = MyFancyModel()state_dict = torch.load(&lt;path to weights&gt;)model.load_state_dict(state_dict)تا وزن‌های از پیش آموزش دیده روی مدل را بارگذاری کنید.کار می‌کند و مراحل واضح هستند، اما به وزن‌هایی روی دیسک و دانستن اینکه کجا هستند؛ نیاز دارد. راه‌حل زیبا‌تر این است که از تابع torch.utils.model_zoo.load_url در torchvision و مشابه آن در TensorFlow یا Keras استفاده کنید.می‌توانیم انجام دهیم :from retinaface.pre_trained_models import get_modelmodel = get_model(&quot;resnet50_2020-07-20&quot;, max_size=2048)اگر وزن‌ها روی دیسک نباشند، از اینترنت دانلود شده و روی دیسک ذخیره می شوند. مدل مقداردهی اولیه می‌شود و وزن‌ها بارگذاری می شوند.این user friendly است و این همان چیزی است که در کتابخانه‌های Torchvision و timm می‌بینید.مرحله‌ی اول : وزن‌های میزبان مدل از پیش آموزش داده شدهاین بزرگترین مانع برای من بود. اگر نمی خواهید با AWS، GCP سر و کار داشته باشید،پس کجا می‌توانم وزن‌ها را برای مدل قرار دهم؟ظاهراً یک راه‌حل عالی وجود دارد، من می‌گویم یک راه فرار. می‌توانید در GitHub به نسخه‌ها وزن بدهید.محدودیت برای هر فایل 2GB است که برای اکثر مدل‌های Deep learning کافی است.مرحله‌ی دوم : تابعی بنویسید که به مدل مقدار اولیه بدهد و وزن‌ها را بارگذاری کند.در مورد مثال من : Teranusاین قابلیت زمانی که ما نوت‌بوک و برنامه وب Colab را بسازیم، مورد استفاده قرار خواهد گرفت.5.کتابخانه بسازید. 20+ دقیقهدر این مرحله برای استفاده از مدل خود نقطه ورودی را پایین می‌آورید. هدف انجام پیش‌بینی بدون این کد  است.git clone retinaface مرحله‌ی اول : dependency های لازم را به requirement.txt اضافه کنیدمی‌توانید استفاده کنید:pip freeze &gt; requiements.txtیا به صورت دستی به‌روزرسانی کنید.مرحله ی دوم : ساختار فایلی repository را تغییر دهید.یک &quot;main folder&quot; بسازید در مورد من، به نام &quot;retinaface&quot;، مشابه repository ایجاد کنید.تمام کدهای مهم را به آنجا منتقل کنید.تصاویر کمکی، Readme، نوت‌بوک‌ها یا تست‌ها را به آنجا منتقل نکنید.این یک روش معمول برای ساختار کد در repositories است.امیدوارم در آینده از ابتدا این الگو را دنبال کنید. اگر چیزی حتی ساختارمندتر می‌خواهید،  Package Cookie Cutter را بررسی کنید.مرحله‌ی سوم: فایل config اضافه کنید.فایل setup.py را با محتوایی مشابه setup.py به root پوشه اضافه کنید.یک نسخه برای package اضافه کنید. در مورد من، من آن را به فایل init پوشه &quot;main&quot; اضافه کردم.مرحله‌ی چهارم: حساب کاربری در pypi بسازید.اگر در pypi حساب کاربری ندارید؛ وقت آن است که دست به کار شوید.مرحله‌ی پنجم: کتاب‌خانه بسازید و در pypi آپلود کنید.python setup.py sdistpython setup.py sdist uploadتمام شد حالا repository شما یک کتاب‌خانه است و همه می توانند آن را با کد زیر نصب کنند.pip install &lt;your_library_name&gt; اگر صفحه‌ی package را در pypi بررسی کنید، خواهید دید readme که در repository است برای ارائه پروژه استفاده می‌شود.ما از عملکرد این مرحله برای Google Colab و برای یک برنامه وب استفاده خواهیم کرد.6. نوت بوک google colab بسازید. 20+ دقیقهافزودن یک نوت بوک jupyter به repository برای نشان دادن نحوه مقداردهی اولیه مدل و انجام نتیجه‌گیری، تمرین خوبی است. مثالمی‌توانیم بهتر هم انجام دهیم.ما یک مدل اولیه &quot;fancy&quot; و جادوی pip install را در دو مرحله قبل فعال کردیم. بیایید از آن استفاده کنیم.ما می توانیم یک نوت‌بوک Google Colab ایجاد کنیم.حالا تنها چیزی که کسی برای بازی با مدل شما نیاز دارد یک مرورگر است! افراد بیشتری می توانند آن را بررسی کنند. مثالفراموش نکنید که لینکی برای یک نوت‌بوک به readme خود اضافه کنید و نسخه را در PyPi به روز کنید.7.یک برنامه وب ایجاد کنید. 20+ دقیقهبسیاری از دانشمندان داده فرض می‌کنند که ساختن یک برنامه وب روشی پیچیده است که به دانش تخصصی نیاز دارد.این فرض درست است، یک پروژه پیچیده برنامه وب به مهارت‌هایی نیاز دارد که دانشمندان داده ممکن است نداشته باشند.ساختن یک برنامه وب ساده که مدل را نشان می‌دهد آسان است.من یک  github repository جداگانه برای یک برنامه وب ایجاد کردم. با این حال، می‌توانید این کار را در repository خود با مدلتان انجام دهید.مرحله‌ی اول: کد برای برنامه اضافه کنید.کد&quot;&quot;&quot;Streamlit web app&quot;&quot;&quot;import numpy as npimport streamlit as stfrom PIL import Imagefrom retinaface.pre_trained_models import get_modelfrom retinaface.utils import vis_annotationsimport torchst.set_option(&quot;deprecation.showfileUploaderEncoding&quot;, False)@st.cachedef cached_model():    m = get_model(&quot;resnet50_2020-07-20&quot;, max_size=1048, device=&quot;cpu&quot;)    m.eval&#40;&#41;    return mmodel = cached_model()st.title(&quot;Detect faces and key points&quot;)uploaded_file = st.file_uploader(&quot;Choose an image...&quot;, type=&quot;jpg&quot;)if uploaded_file is not None:    image = np.array(Image.open(uploaded_file))    st.image(image, caption=&quot;Before&quot;, use_column_width=True)    st.write(&quot;&quot;)    st.write(&quot;Detecting faces...&quot;)    with torch.no_grad():        annotations = model.predict_jsons(image)    if not annotations[0][&quot;bbox&quot;]:        st.write(&quot;No faces detected&quot;)    else:        visualized_image = vis_annotations(image, annotations)        st.image(visualized_image, caption=&quot;After&quot;, use_column_width=True)کمتر از 40 خطمرحله‌ی دوم: فایل‌های config را اضافه کنید.نیاز دارید که این فایل‌ها را اضافه کنید:شما می‌توانید از این فایل بدون تغییر استفاده کنید.   setup.sh شما باید مسیر فایل را با برنامه تغییر دهید. Procfileمرحله‌ی سوم: requirements.txt را اضافه کنید.مرحله‌ی چهارم: در herokuapp ثبت‌نام کنید.مرحله‌ی پنجم: کد را push کنید.heroku loginheroku creategit push heroku master می‌توانید مثال را در https://retinaface.herokuapp.com/ ببینید.8. یک بلاگ بنویسید. 4+ ساعتبسیاری از مردم کار خود را دست‌کم می‌گیرند. آنها فرض می‌کنند که اگر بدانند چگونه کاری را انجام دهند، همه آن را می‌دانند. اینطور نیست.زباله یک نفر گنج دیگری است.مقاله شما به افراد دیگر کمک می‌کند و فرصت‌های شغلی شما را بهبود می‌بخشد.من در Lyft، در سطح 5 کار می‌کنم و از تکنیک‌های deep learning برای مشکلات ماشین‌های خودران استفاده می‌کنم. قبل از Lyft، من در آژانس جمع‌آوری بدهی TrueAccord کار می‌کردم.یکی از دلایلی که توانستم این تغییر شغلی را انجام دهم این است که دانش خود را در پست‌های وبلاگ و جلسات به اشتراک گذاشتم. این امر توجه استخدام‌کنندگان و مدیران را به خود جلب کرد.برای من که کار کرد پس برای شما هم کار می‌کند.برای machine learning، توصیه می کنم متنی را بنویسید که شامل موارد زیر است:مشکل چه بود؟راه حل شما چه بود؟اگر تا این لحظه بلاگ را مطالعه کردید و مطالب آن برایتان مفید بود پس شما می‌توانید با نوشتن یک مقاله‌ی machine learning در مورد مسئله‌ای که با آن روبه‌رو شدید و چگونگی حل آن؛ از من تشکر کنید.</description>
                <category>حامد فاضل مسائلی</category>
                <author>حامد فاضل مسائلی</author>
                <pubDate>Tue, 01 Mar 2022 23:54:32 +0330</pubDate>
            </item>
            </channel>
</rss>