نیازمندیهای چابک

شما در این سایت با مفاهیم نیازمندیهای نرم افزار چابک آشنا می شوید

تصویر کلانِ نیازمندی های چابک

تصویر کلان سازمان چابک

(تصویر کلان سازمان چابک)

پیاده سازی موثر مجموعه ای از اصول و تجارب نیازمندی های چابک و ناب در سطوح تیم، برنامه و یا سازمان با وجود ادبیات و زبان متفاوت در آن ها، شاهکار کوچکی نیست (داستان های کاربر، اسپرینت ها، امتیاز داستان، اپیک ها، بک لاگ؟). به علاوه، در ناب کردن سازمان ها اغلب نیازمند حذف یا کاهش مشخصات نیازمندی ها، مشخصات طراحی و مدل های مرحله-دروازه (که در آن نیازمندهای نرم افزار باید بازبینی شوند)، تایید سلسله مراتب سازمان (که باعث ایجاد تاخیر می شود)، پیاده سازی محدویت های کار در جریان (که ممکن است از دیدگاه افرادی که بهره وری را اندازه گیری می کنند تاثیر عکس داشته باشد) و ... هستیم. بنابراین، برای چابک و ناب کردن سازمان ها چالش های فراوانی وجود خواهد داشت.

حتی برای معرفی و پیاده سازی تجارب ابتدایی در سازمان، مدت زمانی در حدود شش ماه تا یک سال نیاز است. به طوری که برای بدست آوردن چندین نتیجه موفقیت آمیز که باعث ایجاد رضایت مشتریان، کسب درآمد و سهم بیشتری از بازار می گردد، به زمانی بیش از یک سال نیاز است. برای دستیابی به این مزایا، باید چیزهای زیادی از قبیل تجربه های مدیریت نیازمندی های قبلی تغییر کنند. هر چند، بسیاری از دستاوردهای الزامی موجود، نقاط عطف و ... به عنوان محافظی برای اجتناب از بروز انواع مسائلی که اغلب پروژه  های نرم افزاری تجربه می کنند، مورد استفاده قرار می گیرد. بنابراین ما با معمای دشواری روبرو هستیم (چگونه بر روی این بند«بندی که بندباز در سیرک بر روی آن راه می رود» بدون داشتن تور ایمن حرکت کنیم و آن را تجربه نمایم، به طوری که خود این تور ایمن بخش اعظمی از مساله است؟)

خوشبختانه، در نقطه ای قرار داریم که تعدادی از سازمان ها این گذار را قبل از ما طی کرده اند و در این راستا چندین الگوی رایج برای موفقیت فرایند نرم افزار چابک و ناب ایجاد شده است. به دلیل بحث هایی که با تیم ها، مدیران و هیئت رئیسه در طول این گذار داریم، تلاش کردیم یک زبان مشترک که شامل مجموعه ای از مفاهیم انتزاعی و تصاویر گرافیکی مناسب است پیدا کنیم تا قادر به توصیف سریع موضوع «سازمان شما پس از تحول چابک شبیه چه چیزی می شود و چگونه کار می کند» باشیم. برای انجام این کار، نیازمند توصیف مکانیزم های جدیدی برای توسعه نرم افزار و فرایند تحویل، تیم های جدید، واحد های سازمانی و نقش هایی که افراد مهم در الگوی چابک جدید بازی می کنند، هستیم. نهایتا و با راهنمایی دیگران به چیزی رسیدم که در دستیابی به اهدافش به طرز معقولی خوب عمل می کند. ما آن را «تصویر کلان سازمان چابک» می نامیم. همان طوری که در شکل بالا قابل مشاهده است.

۰ نظر
علیرضا قاقالو

محتویات خانه ناب: اصول جریان توسعه محصول

در مرکز خانه نرم افزار ناب اصول و تجربه هایی قرار دارند که توسط تیم برای توسعه و تحویل نرم افزار به کاربران پایانی استفاده می شوند. برای انجام این کار تنها یک روش درست وجود ندارد بلکه کتاب هایی هستند که دیدگاه های مختلفی را فراهم می‌کنند. در کتاب «اصول جریان توسعه محصول» هشت تم مهم مطرح شده است که هر کدام توسط تعدادی اصول کمکی پشتیبانی می شوند. این تم ها به همراه اصول مربوطه راهنمای جامعی برای ناب فراهم می‌کنند. از دیدگاه من، این بهترین و معمول‌ترین رویکر برای توصیف اصول ناب است که بر روی توسعه محصول اعمال می‌شود. همچنین، این اصول راهنمای عالی و با اهمیتی برای تیم توسعه نرم افزار است. این هشت تم شامل موارد ذیل هستند: 

  • دید اقتصادی داشته باشید 
  • به طور فعال صف ها را مدیریت نمایید 
  • تغییرپذیری را درک نمایید و از آن بهره‌برداری کنید 
  • اندازه  بسته ها را کاهش دهید 
  • محدودیت های کار در جریان را اعمال کنید 
  • جریان تحت عدم قطعیت را کنترل کنید(ریتم و همگام سازی) 
  • بازخورد را تا حد ممکن سریع دریافت کنید 
  • کنترل را نامتمرکز کنید
۰ نظر
علیرضا قاقالو

شالوده خانه ناب: حمایتِ مدیریت

حمایتِ مدیریت شالوده تفکر ناب است. در حقیقت، «حمایت» واژه مناسبی نیست تا به وسیله آن نقش اصلی و فعال مدیریت در پیاده سازی و هدایت ناب توصیف گردد. واژه «رهبری» ممکن است انتخاب بهتری باشد. در ناب، مدیریت با به کارگیری تجربه ها و ابزارهای تفکر ناب و بهبود مداوم، اعمال همیشگی آن ها و تعلیم به کارمندان، آموزش می بیند.

در این مورد، ناب از بیشتر تجربه های ما در توسعه چابک فاصله می گیرد. براساس تجربه‌ای که داریم، چابک اغلب به صورت فرایند تیم محور ترویج پیدا کرده است و در بدیرین حالت تمایل به کنار گذاشتن مدیریت از فرایند و تجربه های اصلی را دارد. البته، کنار گذاشتن مدیریت از مشارکت و حل مسئله رویکرد مناسبی نیست. موارد ذیل تفاوت های میان چابک و ناب را بیان میکنند:

  • در چابک، انتظار داریم مدیریت ما را حمایت کند و در برطرف کردن موانع کمک نماید. 
  • در ناب، انتظار می رود که مدیریت ما را رهبری کند و نقش فعالی را در انجام بهبود مداوم بازی نماید.

این اصل مهم برای ناب هدایت کننده ای با اهمیت در سازمان نرم افزاری است. مدیران و هیئت رئیسه به جای پیگیری، رهبری می کنند و برای پیشبرد مداوم تجربه ها جواب گو هستند.

۰ نظر
علیرضا قاقالو

ستون دوم خانه ناب: بهبود مداوم

بهبود مداوم یا «کایزن» ستون دوم ناب است. با کایزن، از طریق بازبینی و بهبود مداوم به سوی یک سازمان یادگیرنده هدایت می شویم. 

  • منشاء مسئله را کشف نماید و برای حل آن و بهبود فرایند شخصاً داده‌ها را مشاهده و بررسی کنید. 
  • تصمیم گیری ها را تدریجی و با توافق انجام دهید و همه گزینه ها را در نظر بگیرید. سپس تصمیم ها را به سرعت پیاده سازی کنید. 
  • برای تشخیص علت اصلی ناکارآمدی، بهبود مداوم را به کار بگیرید و اقدامات متقابل موثر را اعمال کنید. 
  • از طریق پرورش پرسنل با ثبات، ارتقاء تدریجی و سیستم های جانشینی دقیق از پایگاه دانش سازمانی محافظت کنید. 
  • در نقاط عطف اصلی تفکر کنید و پس از پایان پروژه به طور آشکار کاستی های پروژه را شناسایی نمایید
۰ نظر
علیرضا قاقالو

ستون اول خانه ناب: به افراد احترام بگذارید

با وجود اینکه تمرکز بر نیازمندی ها موضوع مهمی است، اما همیشه باید آگاه باشیم که در حقیقت تمام کارهای با ارزش افزوده را افراد انجام می دهند و احترام به آن ها موجب آرامش و راحتی شان می‌شود. علاوه بر این، احترام به افراد از اصول پایه ای ناب و چابک نیز است(اصل چابکی متناظر: پروژه ها را حول اشخاص با انگیزه بسازید. برای آن ها محیط و پشتیبانی لازم را محیا کنید و به آن ها اعتماد کنید تا کار را انجام دهند.). همچنین، افراد در ناب توانایی رشد تجربیات و بهبود خود را نیز پیدا می‌کنند.

۰ نظر
علیرضا قاقالو

سقف خانه ناب: پایداری به تحویل ارزش سرعت می بخشد

هدف ناب قابل مذاکره نیست: در کوتاه ترین زمان ممکن باید بتوانیم ارزش تحویلی به مشتری را حداکثر کنیم.

در ادامه، نحوی نگرش دیگران در این مورد بیان می‌شود:

 تایچی اوهنو: از زمانی که مشتری سفارشی را به ما می دهد تا زمانی که هزینه آن را دریافت کنیم، آنچه که انجام می دهیم این است که به محور زمان نگاه می‌کنیم تا آن را با کنار گذاشتن کارهای بدون ارزش افزوده کاهش دهیم.

 پوپن دیک: روشی برای تحویل بسیار سریع نرم افزار نیاز داریم تا مشتریان زمان کافی برای تغییر طرز فکر خود نداشته باشند.

لارمن و وود: بر روی چوب دستی متمرکز شوید نه بر روی دونده ها. «به جای اینکه به مشغول بودن افراد یا بهینه محلی فکر کنید بر روی جریان ارزش و نرخ ارزش/ اتلاف متمرکز شوید»

بنابراین، به نکات ذیل در مورد نیازمندی ها توجه می کنیم:

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

 از دیدگاه نیازمندی های نرم افزار می توانیم «زنجیره ارزش» تحویل نرم فزار سازمان را همانند شکل ذیل نمایش دهیم.

زنجیره ارزش

برای بهینه کردن زمان تحویل و بازگشت سرمایه باید گام های موجود در زنجیره ارزش را بهینه کنیم. همچنین برای افزایش واقعی سرعت باید تمام تاخیرهای موجود در زنجیره ارزش را به حداقل برسانیم.
۰ نظر
علیرضا قاقالو

خانه نرم افزار ناب

اصول و تجربه هایی که بر تولید ناب، توسعه محصول ناب، خدمات ناب و تفکر ناب اعمال می شوند معمولا عمیق و گسترده هستند. اگرچه بدنه عمومی کار بزرگ است، اما لارمن و وود چارچوبی را برای تفکر نرم افزار ناب توصیف کرده اند که به موجب آن بسیاری از اصول و تجربه های اصلی را به متن نرم افزار قابل مدیریت ترجمه می کند. آن ها برای انجام این کار، تصویر «خانه تفکر ناب» را مجددا ارائه می کنند، به طوری که از خانه های ناب قبلی همانند تویوتا و ... الهام گرفته شده است. خانه نرم افزار ناب در شکل ذیل قابل مشاهده است.

خانه نرم افزار ناب شامل پنج جزء ذیل است:

  • سقف، هدف: پایداری به تحویل ارزش سرعت می بخشد 
  • ستون اول: به افراد احترام بگذارید 
  • ستون دوم: بهبود مداوم 
  • شالوده: حمایتِ مدیریت 
  • محتویات: جریان توسعه محصول
خانه نرم افزار ناب
(خانه نرم افزار ناب) 
۰ نظر
علیرضا قاقالو

معرفی نرم افزار ناب

ریشه های اصلی جنبش نرم افزار ناب از موفقیت های تویوتا و سیستم تولید تویوتا ناشی شد. این سیستم شامل مجموعه ای از دانش های تولید اقتصادی، اصول و تجربه های ناب است که باعث شد تویوتا در سال ۲۰۰۷ تولید کننده پیشتاز ماشین در جهان باشد. در حقیقت، سیستم تولید تویوتا باعث رشد جنبش نرم افزار ناب شد که توسط تفکر نویسندگانی در کتاب های مختلفی رواج پیدا کرد. تفکر ناب دارای زمینه گسترده تر و عمیق تری از متدهای چابک خاص مثل اسکرام و ایکس پی است. همچنین تاثیر تفکر ناب در طول زمان بیشتر از تاثیر متد های چابک خواهد بود. در حقیقت، به سادگی می توانیم اسکرام، ایکس پی و دیگر متدهای چابک را نمونه های از نرم افزار ناب مشاهده کنیم. همچنین متدهای ناب یک چارچوب وسیع تری برای بهبود اقتصاد توسعه محصول جدید در سازمان های وابسته به نرم افزار فراهم می کنند.


۰ نظر
علیرضا قاقالو

فرایندهای تطبیقی در مقیاس سازمان

طبیعت قانع کننده داده های مربوط به بازگشت سرمایه در کنار افزایش بهره وری، افزایش کیفیت و روحیه ای که توسط تیم های چابک کسب شده است، باعث شده تا سازمان های بزرگ نرم افزاری برای استفاده از روشهای چابک  تحریک شوند. اگر چه روش های چابکی که تا اینجا توصیف شده اند، در متن تیم های کوچک تر توسعه داده شده بودند. اما امروزه به طور فعال در سازمان های بزرگ اعمال شده و گسترش پیدا می کنند. کتاب هایی همانند Scaling Software Agility و Scaling Lean and Agile Development توان بسیاری را به وسیله رهنمودهای عملی در مورد موضوعات سازمانی از قبیل معماری خط تولید، معماری سیستم ها، حاکمیت و مدیریت سبد محصول به این جنبش افزوده اند.


۰ نظر
علیرضا قاقالو

چابک بازگشت سرمایه را بهینه می کند

چابک مبتنی بر یک اصل اقتصادی ساده است: ما ویژگی ها را زودتر تحویل می دهیم و مشتریان پول را زودتر پرداخت می کنند. این موضوع بازگشت سرمایه را برای هزینه توسعه بهبود می بخشد. همان طوری که در شکل ذیل قابل مشاهده است.

تحویل ارزش و بازگشت سرمایه در آبشاری در مقایسه با چابک

(تحویل ارزش و بازگشت سرمایه در آبشاری و چابک)


در مدل آبشاری (شکل سمت چپ)، سرمایه گذاری (هزینه) فورا شروع می شود و تا زمان تحویل ادامه پیدا می کند. هیچ بازگشت سرمایه ای تا زمان تحویل نیازمندی های تعهد شده یا آخرین مهلت زمانی تعیین شده ممکن نیست. در چابک (شکل سمت راست)، تحویل ارزش با اولین بخش قابل عرضه شروع می گردد. با فرض سرمایه گذاری ثابت، معادله ذیل برقرار است:
معادله بهبود بازگشت سرمایه
۰ نظر
علیرضا قاقالو