یکی از اولین خطاهای همهي تیمهای توسعه نرم افزارهای تحت وب و البته مهلک ترین آنها اشتباه در برآورد پروژه نرم افزار است. نرم افزار برآورد هزینه پروژه، در کلام ساده است اما اگر کار تولید نرمافزار انجام داده باشید ممکن این نیست در دامن این خطا گرفتار نشده باشید.
اگر علاقمند به نرم افزار برآورد پروژه بودید میتوانید ویدئوی ما در کانال یوتیوب همند در همین رابطه را ببینید.
«یه نرمافزار برای ما بزنید، چند در میاد؟» این سوالِ خیلی کلی، زیاد از ما پرسیده میشد و همین باعث شد تا در این مطلب، از نحوه برآورد پروژه نرم افزار و اعلام قیمت در همند، برای شما بنویسیم.
تحلیل اولیه | تخمین پروژه های نرم افزاری
یکی از سادهترین روشهایی که معمولا وجود دارد، برای اینکه یک نفر به ما بگوید که دقیقا چه چیزی نیاز دارد، این است که یک نمونه کپی از محصولی که میخواهد و لینک یا نمونه کاتالوگ آن را برای ما ارسال کند. روش دیگر هم جلسه حضوری و یا مجازی و پرسش و پاسخ است. گاهی هم مشتری در قالب یک پروپوزال یا توضیحات صوتی و یا حتی ویدئویی نیاز یا هدف خود را برای ما شرح میدهد.
بک لاگ یا لیست قابلیتها و امکانات
زمانی که ما متوجه نیازمندیهای پروژه و تفکر کارفرما شدیم، فرایندها را در لایهی اول ترسیم کرده و بسته به ارزش پروژه، جزییات را به فرایندها اضافه میکنیم. امکانات یا فیچرهای نرمافزار را در کارتهایی مینویسیم. بعد از اتمام، کلیه امکانات آنها را از دو بُعد زمان اجرایی (فاز یا اسپرینت) و بخش (فاز تحلیل یا فاز طراحی و …) دستهبندی میکنیم.
فیچرها باید به تسکهای ریز تبدیل شوند و در یک فایل اکسل به شکل زیر قرار گیرند. در این فایل باید میزان نفرساعت هر تسک و نقشی که باید آن را انجام دهد مشخص شود. به طور مثال یک صفحه تماس با ما نیاز به طراحی، برنامهنویس سمت کاربر و برنامهنویس سمت بَکِند دارد. البته کارها از نظر پیچیدگی نیز به سطوح مختلفی از تخصص نیاز دارند.
دستهبندی و زمانبندی و نفرساعت نقشها
این تقسیم کار به نقشهای مختلف، به خاطر هزینههای مختلفیست که به ازای هر تخصص در نظر میگیریم. قطعا هزینه یک مدیر پروژه و یا مدیر فنی با یک برنامهنویس و یا تستِر نرمافزار متفاوت است. در نهایت در یک جدول کلی همه این نفرساعتها جمع بندی میشود.
حجم پروژه و نفر ساعت آن مشخص میکند که حجم کار مدیر پروژه چه اندازه است؟ آیا مدیر فنی مورد نیاز است؟ بخشهای اصلی پروژه برای ما به تحلیل، طراحی، پیادهسازی، تست و امنیت و نصب و راهاندازی تقسیم میشود. این بخشها در هر مرحله یا فاز یا اسپرینت از پروژه میتواند قابل تکرار باشد.
در نهایت در جمع بندی کلی ما به نفرساعتهای مورد نیاز هر نقش میرسیم که با ضرب در هزینه مورد توافق هر نقش، قیمت پروژه مشخص میشود. طبعاً کسورات قانونی و هزینه مالیات بر ارزش افزوده هم به پروژه اضافه میگردد.
برآورد نهایی و تیپ قرارداد | برآورد پروژه نرم افزار
این برآورد ها دو حالت دارد. اول اینکه رقم ثابت قرارداد شود و شرح خدمات عینا مطابق قرارداد پیش رود و حالت دوم اینکه صرفا یک برآورد باشد و در صورت وضعیتهای پروژه، قیمت دقیق هر فاز از پروژه مشخص شود (البته در تعامل با شرکتهای دولتی نمیتواند بیش از ۲۵ درصد از برآورد اولیه انحراف داشته باشد) و پایان پروژه قیمت دقیق پروژه مشخص میشود (این البته منوط به این مورد است که شرح خدمات و جزییات اولیه به صورت کامل در قرار داد اولیه قید شود).
در یک پروژه کارفرما یک نمونه اولیه از ما خواست و همین مشخص نبودن دقیق محدوده پروژه، حجم پروژه آنقدر بالا رفت که به جای دو ماه، هفت ماه به طول انجامید و باعث شد در برنامهریزیهای بعدی آن تیم کلا با مشکل مواجه شویم وضرر قابل توجهی متحمل شویم.
تغییر محدوده پروژه یک امر طبیعیست اما…
در این اقتصاد و شرایط دنیا که کسب و کارها باید دائما تغییر کنند، بدیهیست که نرمافزارها برای هر سازمان یا مجموعه و کسب و کاری که باشند، نیاز به تغییرات و بهبود مستمر دارند. این تغییرات در مورد استارتاپها بسیار بیشتر از حوزههای دیگر است. پس تخمین این بخش باید در روز اول لحاظ شود.
هزینههای جانبی که کارفرما به آنها توجه نمیکند
یکی از کارهایی که ما جزیی از وظایف خود میدانیم آگاه کردن مشتری از لیست هزینههاییست که در زمانی که ایدهی نرمافزار به ذهنش میرسد معمولا نمیبیند.
ما هم مانند هر تیمی علاقمندیم تا در پروژههایی ورود کنیم که موفق باشد و ادامه دار، نه اینکه بعد از مدت کوتاهی متوقف شود. کارفرما در ابتدای کار معمولا به همه جوانب هزینهای توجهی ندارد و ذهنش معطوف به خود حصول نرمافزاریست.
اگر روز اول از آنها مطلع باشد شاید هرگز پروژه را آغاز نکند. درست است که پولی به ما نداده و ما یک پروژه را از دست میدهیم، اما حداقل در یک پروژه شکست خورده ورود نکردهایم. کارفرما هم ممکن است با یک برنامهریزی به پروژه بازگردد و احتمال اینکه با شما کار کند بسیار بیشتر است.
کارفرمای خوب
یکی دیگر از مواردی که به تجربه به آن رسیدیم این بوده که با هر کارفرمایی کار نکنیم، علیالخصوص کارفرمایی که نسبت به حوزه تخصصی ما آگاهی کافی ندارد و یا ارزش واقعی آن را نمیداند. معمولا قبل از تحلیل این نتیجه گیری انجام میشود و هر جایی پیش از شروع پروژه که متوجه این عدم آگاهی بشویم ادامه کار را متوقف میکنیم و علت آن را هم به کارفرما گزارش میکنیم.
جمع بندی | نرم افزار برآورد پروژه
آنچه ما انجام میدهیم حاصل تجربهی ما تا امروز بوده است. ما سعی داریم تا برخلاف آنچه در مورد تیمهای نرمافزاری گفته میشود، تیم منظم و با زمانبندی درستی باشیم.
تعهد و اخلاق در کار برای ما بسیار مهم است. کوشش میکنیم تا با داشتن جلسات اولیهی مشروحتر، کارفرما را از روند دقیق پروژه آگاه کنیم و حدود پروژه و تغییرات را درست تخمین بزنیم تا لطمهای به دیگر پروژهها و زمانبندیهایمان وارد نشود.
قطعا آنچه امروز انجام میدهیم، کاملترین و بهترین نیست و دائما در حال بهبود آن هستیم. خوشحال میشویم که در این بهبود ما را یاری نمایید. در کامنتها برایمان از تجربههایتان بنویسید و اگر در این مورد کمکی از ما برمیآید حتما با ما تماس بگیرید.
در صورتی که این مقاله کاربردی نبود میتوانید از مقالاتی مانند چه کنیم تا در برآورد نرمافزار اشتباه نکنیم کمک بگیرید.