| Erfan's Notes | – Telegram
| Erfan's Notes |
192 subscribers
81 photos
10 videos
101 links
Download Telegram
این ویدیو رو توصیه می‌کنم حتما ببینید، یک ویدیو با کیفیت و ارزشمند به تمام معناست، هم به لحاظ محتوایی و هم داستانی و اجرایی واقعا خوبه

موضوع ویدیو هم درباره پورت کردن Dot Net Framework برای ویندوز 95 هست، کاری که خود مایکروسافت از روی تنبلی یا … بیخیالش شد و ساپورت دات نت از ویندوز 98 به بعد شروع شد

https://youtu.be/CTUMNtKQLl8
44
سورس‌کد MS-DOS نسخه های 1.25 و 2.0 و 4.0 توی گیت‌هاب به صورت اوپن‌سورس منتشر شده

اکثریت سورس‌کد با اسمبلی هست و منم چیز زیادی ازش متوجه نشدم، ولی خب تلاش برای خوندن و فهمیدنش می‌تونه تفریح خوبی باشه

https://github.com/microsoft/MS-DOS
11
ظاهرا یک نفر بر بستر بلاکچین بیت‌کوین، برای انتقال 6 دلار، حدود 100 هزار دلار کمیسیون داده، تنها حدسی که می‌شه زد اینه که جای فیلد های Amount و Fee رو اشتباه زده 😅

دفعه بعدی که احساس کردید بدشانس هستید، یاد این بیوفتید که برای انتقال 300 هزار تومن، حدود 6 میلیارد تومن کارمزد انتقال ندادید 😵‍💫

لینک تراکنش
Please open Telegram to view this post
VIEW IN TELEGRAM
8
⭕️ دوره آموزش برنامه‌نویسی ربات تلگرام

💠 در این دوره به آموزش ربات‌نویسی تلگرام می‌پردازیم، از مباحث پایه و عمومی شروع می‌کنیم و مفاهیم رو یاد می‌گیریم، بعد یک ربات کامل رو پیاده‌سازی می‌کنیم.
⭕️ دوره آموزش Spline

💠 دوره آموزش نرم‌افزار طراحی سه‌بعدی اسپلاین (Spline) با محوریت طراحی وبسایت سه‌بعدی
| Erfan's Notes | via @DevelopixBot
⭕️ دوره آموزش Spline 💠 دوره آموزش نرم‌افزار طراحی سه‌بعدی اسپلاین (Spline) با محوریت طراحی وبسایت سه‌بعدی
دوره آموزش اسپلاین (طراحی وب سه‌بعدی) که حدود دو سال پیش ضبط کرده بودم رو منتشر کردم و می‌تونید در کالکشن بالا ببینید
This media is not supported in your browser
VIEW IN TELEGRAM
📱 یک افزونه ایرانی باحال برای VSCode برای ارور های Typenoscript (:

🔹 لینک دانلود و نصب
Please open Telegram to view this post
VIEW IN TELEGRAM
1
من معمولا اکثر زبان‌هایی که به‌صورت روزمره باهاشون سر و کار دارم، مفسری هستند، احتمالا شما هم JS و PHP و Python و زبان های مفسری مشابه کار می‌کنید

همونطور که می‌دونید، من طرفدار شدید پرفورمنس و بهینه‌سازی کد هستم و حتی پست هایی هم درمورد بنچمارک بین فریمورک‌ها و زبان‌ها گذاشتم قبلا که در اون‌ها:

سناریوی فرضی ما برای بنچمارک، یک سایت هست که IO داره و Database داره و Network داره، در واقع اکثر زمانی که تلف می‌کنه سر IO Bound Task ها هست همونطوری که توی این پست هم توضیح دادم

ولی اخیرا برای یک پروژه‌ای به یک تسکی خوردیم که CPU Bound خیلی سنگین بود و Memory Bound هم بود، در واقع نیاز داشتیم که روی دیتاست با حجم 12M شهر/روستا iterate کنیم و نسبت به زبان کشور، از بین 20M اسم که به زبان‌های مختلف برای اون شهر/روستا بود، اسم محلی‌اش رو پیدا کنیم

این رو من با دیتاست کوچک‌تری که فقط برای ایران بود 200K شهر/روستا و 200K هم اسم متناظر، من با PHP نوشتم و نتیجه معقول بود و حدود 10-12 ثانیه طول می‌کشید

ولی برای اینکه IO به صورت Async باشه با JS بازنویسی کردم و به 7-8 ثانیه رسیدم با دیتای 200K x 200K

حالا وقتش بود که با دیتاست 20M x 12M تست کنیم، نهایتا باید 10-15 دقیقه طول می‌کشید، درسته؟ نه! طبق محاسباتی که کردیم، حدود 3-4 روز طول می‌کشید تا بتونه این دیتا رو بخونه و پارس کنه و مپ کنه و فیلتر کنه و اسم متناظر رو پیدا کنه 🤣

اینجا بود که یکی از دوست های Rust کارم به دادم رسید و با زبان کامپایلری Rust، همون کد JS ای که نوشته بودم رو با Rust بازنویسی کرد، نتیجه به نظرتون چی شد؟ از 3-4 روز به 10 ثانیه کاهش پیدا کرد ☺️

البته بازنویسی‌ای که کرد، بسیاری از مفاهیم رو به شکل بهینه‌تری در سطوح پایین هندل کرد و خیلی از بارها و overhead ها رو برداشت، مثلا در نسخه JS مصرف رم حدود 24GB رسیده بود بعد از دوساعت اجرا، ولی نسخه Rust کلا 4GB رم مصرف می‌کرد و کلا 10 ثانیه طول می‌کشید روی دیتاست کامل 🎉

نتیجه ماجرا این هست که حس می‌کنم کم‌کم باید یک زبان کامپایلری هم به چرخه زبان هایی که روزمره باهاشون کار می‌کنیم، اضافه کنیم چون واقعا تفاوت خیلی خیلی زیادی هست در کارهای CPU Bound بین‌شون، تفاوتی مثل ۳-۴ روز و ۱۰ ثانیه 😎
Please open Telegram to view this post
VIEW IN TELEGRAM
Forwarded from TechTube 𝕏 تک توب
گوگل در نسخه 128 مرورگر کروم که در حال حاضر ازمایشی هست، نسخه کوچکی از هوش مصنوعی Gemini رو قرار داده که به صورت افلاین و روی خود دستگاه اجرا میشه و به توسعه دهندگان سایتها امکان استفاده از این مدل رو به صورت مجانی برای کاربردهایی مثل ترجمه، خلاصه سازی و دیگر سوالات به نسبت ساده رو میده.

🔎 mortenjust

📍 @TechTube
🌐 برای مسابقه Tonkeeper یک لندینگ پیج طراحی کردم با SolidJS که از اینجا می‌تونید ببینید و سورس‌کدش هم از اینجا می‌تونید دسترسی داشته باشید و اگر جایی به دردتون خورد استفاده کنید
Please open Telegram to view this post
VIEW IN TELEGRAM
| Erfan's Notes |
🥇 erfa***@gmail.com
🤑🏆
Please open Telegram to view this post
VIEW IN TELEGRAM
مدت زیادی می‌شه که با Lottie سر و کار دارم و خب اگر نمی‌دونید، در واقع Lottie ها یک‌سری انیمیشن‌هایی Vector هستند که به‌صورت JSON هستند و از روی اون JSON می‌شه هر فریم‌شون رو ساخت و انیمیت کرد

در واقع renderer های مختلفی برای Lottie روی پلتفرم‌های مختلف هست، مثلا معقول‌ترین Renderer در وب می‌تونه ترسیم و انیمیت کردن به‌صورت SVG باشه یا حتی می‌شه در تمامی پلتفرم‌ها داخل یک Canvas ترسیم کرد و Image Data هر فریم رو در هر View ای که می‌خواهیم نمایش بدیم

در حالت کلی، تمامی استیکرهای متحرک و ایموجی‌های پریمیومی که در تلگرام می‌بینیم هم همون Lottie هستند که GZip شدند

با وجود تمامی این مزیت‌ها، یک عیب بزرگی که Lottie داره این هست که Renderer هایی که براش وجود دارند معمولا بهینه نیستند و در واقع در بعضی پلتفرم‌ها مثل وب اصلا "نمی‌تونند" هم بهینه باشند

یکی از سریع‌ترین Renderer هایی که برای Lottie وجود داشته و تلگرام هم از اون استفاده می‌کنه، پروژه rlottie هست که توسط سامسونگ توسعه داده شده، چیز جدیدی نیست و حتی در تلگرام وب هم از نسخه WASM اش استفاده شده

حالا می‌خوام بهتون پروژه ThorVG رو معرفی کنم، این پروژه واقعا بی‌نظیر هست و کم‌تر شناخته شده، ولی در واقع یک کیت تمام عیار برای رندر کردن SVG و WebP و Lottie و ... هست و چندین سر و گردن حتی از rlottie هم بالاتره، هم سریع‌تر هست و هم به‌صورت فعال توسعه پیدا می‌کنه و هم باندل سایز بهتری نسبت به rlottie داره برای WASM

در حالت کلی، به‌نظرم هرکسی که از rlottie استفاده می‌کرده باید همین الان بره و با ThorVG جایگزین کنه

اینجا می‌تونید بنچمارک‌های ThorVG برای Lottie رو ببینید
آدرس گیت‌هابتون رو توی این سایت وارد کنید و منتظر باشید که با استفاده از هوش‌مصنوعی OpenAI کاملا Roast تون کنه 😏

🌐 Github Roast
Please open Telegram to view this post
VIEW IN TELEGRAM
ظاهرا گیت‌هاب داون شده و دلیلش هم بخاطر تغییرات سمت دیتابیسی بوده که اعمال کردند، دارند rollback می‌کنند ☕️ نکته جالبی که توی این نیم ساعت داون بودن بهش رسیدم اینه که حداقل ۵-۶ تا سرچ منتهی به گیت‌هاب دارم در هر نیم ساعت
Please open Telegram to view this post
VIEW IN TELEGRAM
Please open Telegram to view this post
VIEW IN TELEGRAM
This media is not supported in your browser
VIEW IN TELEGRAM
جاوا اسکریپت در ترکیب با تایپ اسکریپت واقعا عجیب و در عین حال منطقی هست. ساختار iterator ای که in در JS ارائه می‌ده برای Vue در v-for معمولا به صورت item in Number استفاده می‌شه که در اون item در واقع اسم متغیر هست. حالا اگه از اون متغیر item استفاده نکنیم، تایپ اسکریپت گیر می‌ده که باید استفاده کنی یا حذفش کنی، که وقتی حذف می‌شه با ساختار in Number می‌مونیم که به‌طرز عجیبی مسخره ولی منطقی هست

یا حتی چنین ساختار هایی رو هم داریم:
const [state, setState] = ...

اگر از state استفاده نکنید و صرفا نیاز به setState داشته باشید، مجبورید اینطوری بنویسید:
const [ , setState ] = ...