Dastur xaritasi - Software map

A dasturiy ta'minot xaritasi ning statik, dinamik va evolyutsion ma'lumotlarini ifodalaydi dasturiy ta'minot tizimlari va ularning dasturiy ta'minotni ishlab chiqish jarayonlari 2D yoki 3D xaritaga yo'naltirilgan yordamida axborotni vizualizatsiya qilish. Bu asosiy tushuncha va vositani tashkil etadi dasturiy ta'minotni vizualizatsiya qilish, dasturiy ta'minotni tahlil qilish va dasturiy ta'minot diagnostikasi. Uning asosiy dasturlari xavflarni tahlil qilish va monitoringini o'z ichiga oladi kod sifati, jamoaviy faoliyat yoki dasturiy ta'minotni ishlab chiqish jarayoni [1] va umuman olganda, dastur davomida barcha tegishli artefaktlar, jarayonlar va manfaatdor tomonlarga nisbatan dasturiy ta'minotning samaradorligini oshirish dasturiy ta'minot jarayoni va dasturiy ta'minotga xizmat ko'rsatish.

Motivatsiya va tushunchalar

Dastur xaritalari kontekstida qo'llaniladi dasturiy ta'minot: Murakkab, uzoq muddatli dasturiy ta'minotni ishlab chiqish loyihalar odatda turli xil qiyinchiliklarga duch keladi, masalan, tizim xususiyatlarini to'ldirish o'rtasidagi ishqalanish va shu bilan birga yuqori darajaga erishish kod sifati va dasturiy ta'minot sifati ta'minlash uchun dasturiy ta'minotga xizmat ko'rsatish kelajakda tizimning. Xususan, "Murakkab dasturiy ta'minot tizimlarini saqlab qolish qimmatga tushmoqda, chunki ishlab chiquvchilar tizimning tuzilishi va xatti-harakatlarini tushunishga harakat qilish bilan vaqtlarining katta qismini sarflaydilar."[2] Dasturiy xaritalarning asosiy g'oyasi - bu dasturiy ta'minotni ishlab chiqish loyihalari doirasida turli xil manfaatdor tomonlar va axborot sohalari o'rtasidagi aloqa bo'shliqni bartaraf etish uchun samarali aloqa vositalarini taqdim etish va ushbu ma'noda tushuncha olish orqali ushbu muammo va optimallashtirish muammolarini engishdir. axborotni vizualizatsiya qilish.

Dastur xaritalari aniq belgilangan kartografik imkoniyatlardan foydalanadi xarita virtualdan foydalanadigan usullar 3D shahar modeli metafora[3] asosiy murakkab, mavhum axborot makonini ifodalash. Metafora "dasturiy ta'minotning jismoniy shakli bo'lmaganligi sababli, dasturiy ta'minotni ikki o'lchovli bo'shliqqa tabiiy xaritasi yo'qligi sababli" talab qilinadi.[4] Dastur xaritalari fazoviy emas xaritalar ular ierarxiya ma'lumotlarini va uning xususiyatlarini fazoviy vakolatxonaga aylantirishi kerak.

Ilovalar

Dasturiy ta'minot xaritalari odatda dasturiy ta'minotni ishlab chiqish loyihalari xavfi va xarajatlari, menejment va ishlab chiqarish guruhlari kabi turli manfaatdor tomonlarga tushunarli va samarali ravishda xabar berishga imkon beradi. Ular bir vaqtning o'zida loyiha rahbarlari va menejmentiga hozirda ishlab chiqilayotgan yoki qo'shimcha ravishda ishlab chiqilgan dasturlar va tizimlarning holatini etkazishadi. "Ushbu qarorni qabul qilishning asosiy jihati shundaki, dasturiy xaritalar ushbu ishlash ko'rsatkichlarini to'g'ri talqin qilish uchun zarur bo'lgan tarkibiy kontekstni taqdim etadi".[5] Aloqa vositasi sifatida dasturiy xaritalar ochiq, shaffof axborot maydonlari vazifasini bajaradi, bu kodlar sifatining ustuvor yo'nalishlari va yangi funktsiyalarni yaratishda bir-biriga mutanosib bo'lishiga hamda qarorlarni qabul qilish va takomillashtirish bo'yicha zarur choralarni ko'rishga imkon beradi. dasturiy ta'minotni ishlab chiqish jarayoni.

Masalan, ular kodni sifatni oshirish qaerda hozirgi rivojlanish faoliyatini tezlashtirish uchun va kelajakda parvarishlash muammolari xavfini kamaytirish uchun foydali bo'lishi to'g'risida qaror qabul qilishda yordam beradi.

Xaritalar yuqori darajadagi ekspresivligi (masalan, axborot zichligi) va bir lahzada, avtomatlashtirilgan tarzda yaratilishi tufayli qo'shimcha ravishda tizim va rivojlanish jarayonlarining hozirgi holatini aks ettiradi, menejment va ishlab chiqarish guruhlari o'rtasida muhim axborot bo'shliqlarini yo'q qiladi, odamlar to'g'risida xabardorlikni yaxshilaydi. holati va xavfni erta aniqlash vositasi bo'lib xizmat qiladi.

Mundarija

Dasturiy xaritalar ob'ektiv ma'lumotlarga asoslanadi KPI tomonidan boshqariladigan kodlarni tahlil qilish shuningdek, import qilingan ma'lumotlar bo'yicha dasturiy ta'minot ombori tizimlari, ma'lumotlari manba kodlari, yoki dasturiy ta'minotni ishlab chiqish vositalari va dasturlash vositalari. Xususan, dasturiy xaritalar aniq bir narsaga bog'liq emas dasturlash tili, modellashtirish tili, yoki dasturiy ta'minotni ishlab chiqish jarayoni model.

Dastur xaritalari kabi dasturiy ta'minot artefaktlarining ierarxiyasidan foydalanadi manba kodi yaratish uchun asos sifatida fayllar daraxtlarni xaritalash, ya'ni butun ierarxiyani aks ettiruvchi to'rtburchaklar soha, maydonni to'rtburchaklar pastki maydonlarga ajratish. Dasturiy xarita, norasmiy ravishda, virtualga o'xshaydi 3D shahar modeli, bu orqali dasturiy ta'minot tizimining artefaktlari dasturiy ta'minotni amalga oshirish ierarxiyasidagi mavqeiga ko'ra joylashtirilgan virtual, to'rtburchaklar shaklidagi 3D binolar yoki minoralar kabi ko'rinadi.

Dasturiy ta'minot xaritalari dasturiy ta'minotni ishlab chiqish, dasturiy ta'minot sifati va tizim dinamikasi haqidagi ma'lumotlarni ifodalaydi va birlashtirishi mumkin.[6] Oyoq izlari o'lchami, bo'yi, rangi yoki tuzilishi kabi daraxt xaritasi elementlari. Ular muntazam ravishda belgilanishi, avtomatik ravishda yaratilishi va shablonlar bo'yicha tartibga solinishi mumkin.

Xaritalash dasturiy ta'minot tizimining misoli

Dasturiy xaritalar "dasturiy ta'minotni ishlab chiqish jarayonlari (evolyutsiyasi), dasturiy ta'minot sifati, tuzilishi va dinamikasi haqidagi tematik ma'lumotlarni birlashtiradi va ushbu ma'lumotlarni kartografik tarzda namoyish etadi".[7] Masalan:

  • Virtual binoning balandligi kod birligining murakkabligi bilan mutanosib bo'lishi mumkin (masalan, bitta yoki birlashtirilgan) dasturiy ta'minot ko'rsatkichlari ).
  • Virtual 3D binoning er maydoni moduldagi kod satrlari soniga mutanosib bo'lishi mumkin yoki (masalan, sharh bo'lmagan NCLOC kod satrlari).
  • Rang hozirgi rivojlanish holatini, ya'ni qancha ishlab chiqaruvchilar kod birligini o'zgartirayotganini / tahrir qilayotganligini ifoda etishi mumkin.

Ushbu namunali konfiguratsiya bilan dasturiy ta'minot xaritasi dasturiy ta'minotni ishlab chiqish jarayonining jihatlariga bog'liq bo'lgan manba kodidagi muhim nuqtalarni ko'rsatadi. Masalan, nimani o'zgartirish kerakligi bir qarashda ayon bo'ladi:

  • o'zgarishlarni tezda amalga oshirish;
  • bir joyda o'zgarishlarning boshqa joylarda funksionallikka ta'sirini tezda baholash;
  • dasturdagi nazoratsiz jarayonlarga olib keladigan chalkashliklarni kamaytirish;
  • xatolarni tezroq topish;
  • yomon dasturlash uslubini toping va yo'q qiling.

Dasturiy xaritalar avtomatlashtirilgan dasturiy ta'minot diagnostikasi doirasidagi asosiy vositalarni aks ettiradi dasturiy ta'minot diagnostikasi.

Biznes-razvedka vositalari va tavsiyalar tizimlari sifatida

Dasturiy xaritalardan, xususan, tahlil qilish va taqdimot vositasi sifatida foydalanish mumkin biznes razvedkasi dasturiy ta'minot bilan bog'liq ma'lumotlarni tahlil qilishga ixtisoslashgan tizimlar. Bundan tashqari, dasturiy xaritalar "dasturiy injiniring uchun tavsiya tizimlari sifatida xizmat qiladi".[7]

Dasturiy ta'minot xaritalari dasturiy ta'minot bilan bog'liq ma'lumotlar bilan chegaralanmaydi: ular har qanday ierarxik tizim ma'lumotlarini, masalan, murakkab texnik artefaktlar haqida texnik ma'lumotlarni o'z ichiga olishi mumkin.

Vizualizatsiya texnikasi

Dastur xaritalari domenida tekshiriladi dasturiy ta'minotni vizualizatsiya qilish. Dasturiy xaritalarning vizualizatsiyasi odatda asoslanadi daraxtlarni xaritalash, "ierarxik axborot tuzilmalarini vizualizatsiya qilish uchun bo'sh joyni to'ldirish yondashuvi"[8] yoki boshqa ierarxik xaritalash yondashuvlari.

Joylashtirish algoritmlari

Dasturiy xaritalarni yaratish uchun tarkibiy qismlarning asosiy fazoviy xaritasini yaratish uchun turli xil joylashuv yondashuvlari qo'llaniladi:

  • Dastlab dasturiy ta'minot iyerarxiyasini rekursiv joylashtirilgan to'rtburchaklar maydonga tushiradigan daraxt-xarita algoritmlari.
  • Dastlab dasturiy ta'minot ierarxiyasini a hosil qilib xaritalaydigan Voronoi-map algoritmlari Voronoi xarita

Joylashuv barqarorligi

Daraxtlar xaritalarida aniqlangan tartiblar bo'yicha hisoblangan fazoviy tartib qat'iyan ierarxiyaga bog'liq. Rivojlanayotgan yoki o'zgaruvchan tizim uchun dasturiy xaritalarni tez-tez yaratish kerak bo'lsa, dasturiy ta'minot xaritalaridan foydalanishga barqaror bo'lmagan maketlar ta'sir qiladi, ya'ni ierarxiyadagi kichik o'zgarishlar maketda sezilarli o'zgarishlarga olib kelishi mumkin.

Deterministik joylashishni ta'minlamaydigan muntazam Voronoi treemap algoritmlaridan farqli o'laroq, Voronoi treemaplarini joylashtirish algoritmini har xil ierarxiyalar uchun yuqori darajadagi o'xshashlikni ta'minlash uchun kengaytirish mumkin.[9] Shunga o'xshash yondashuvlar daraxt xaritasiga asoslangan holda mavjud.

Tarix

Dasturiy xaritalarning usullari va uslublari ilmiy yo'nalishga tegishli Dasturiy ta'minotni vizualizatsiya qilish va axborotni vizualizatsiya qilish. Sohalarida asosiy tushuncha va texnikani shakllantiradi dasturiy ta'minot diagnostikasi. Ularning dasturlari ham mavjud dasturiy ta'minotni qazib olish va dasturiy ta'minotni tahlil qilish. Dasturiy xaritalar keng ishlab chiqilgan va o'rganilgan, masalan, at Xasso Plattner instituti IT tizimlari muhandisligi uchun, xususan, keng ko'lamli, murakkab IT tizimlari va ilovalari uchun.

Adabiyotlar

  1. ^ Bonnet, J .; Döllner, J. (2011). "Dastur xaritalari bo'yicha kod sifati va ishlab chiqish faoliyatini monitoring qilish". IEEE ACM ICSE Texnik qarzlarni boshqarish bo'yicha seminarining materiallari. Hisoblash texnikasi assotsiatsiyasi. 9-16 betlar. doi:10.1145/1985362.1985365. ISBN  9781450305860.
  2. ^ Bohnet, J. (2010). Ijro izlarini vizualizatsiya qilish va uni dasturiy ta'minotga tatbiq etish (PhD). Potsdam universiteti, Xasso-Plattner-instituti.
  3. ^ Vettel, R .; Lanza, M. (2007). "Shahar sifatida dasturiy ta'minot tizimlarini vizualizatsiya qilish". VISSOFT 2007 materiallari (IEEE dasturlarini tushunish va tahlil qilish uchun vizualizatsiya qilish bo'yicha 4-Xalqaro seminar). IEEE Computer Society Press. 92–99 betlar. CiteSeerX  10.1.1.135.1979. doi:10.1109 / VISSOF.2007.4290706. ISBN  978-1-4244-0599-2.
  4. ^ Kann, A .; Loretan, P .; Nierstrasz, O. (2008). "Tematik dasturiy ta'minot xaritalari uchun izchil joylashish". 2008 yil teskari muhandislik bo'yicha 15-ishchi konferentsiya. 209-218 betlar. arXiv:1209.5490. doi:10.1109 / WCRE.2008.45. ISBN  978-0-7695-3429-9.
  5. ^ Limberger, D .; Wasty, B .; Trümper, J .; Döllner, J. (2013). "Veb-manba kodlarini tahlil qilish uchun interaktiv dasturiy xaritalar". 3D veb-texnologiyalar bo'yicha 18-xalqaro konferentsiya materiallari. 91-98 betlar. doi:10.1145/2466533.2466550. ISBN  9781450321334.
  6. ^ Karpendeyl, M.S.T. "Vizual o'zgaruvchilarni axborotni vizuallashtirish asosi sifatida ko'rib chiqish" (PDF).
  7. ^ a b Trümper, Jonas; Döllner, Yurgen (2012). "Dastur xaritalari bilan tavsiya tizimlarini kengaytirish". Dasturiy injiniring bo'yicha tavsiyalar tizimlari bo'yicha uchinchi xalqaro ICSE seminarining materiallari (RSSE). IEEE Kompyuter Jamiyati. 92-96 betlar. doi:10.1109 / RSSE.2012.6233420. ISBN  978-1-4673-1758-0.
  8. ^ Jonson, B.; Shnayderman, B. (1991). "Daraxt xaritalari: ierarxik axborot tuzilmalarini vizuallashtirish uchun bo'shliqni to'ldirish usuli" (PDF). Vizualizatsiya davom etmoqda '91. 284-291 betlar. doi:10.1109 / VISUAL.1991.175815. ISBN  0-8186-2245-8.
  9. ^ Xann, S .; Trümper, J .; Morits, D .; Döllner, J. (2014). "Turli xil ierarxiyalarni voronoi treemaplarining barqaror joylashuvi bo'yicha ingl.". Axborotni vizualizatsiya nazariyasi va qo'llanilishi bo'yicha 2014 yilgi xalqaro konferentsiya (IVAPP). 50-58 betlar. ISBN  978-9-8975-8132-8.

Tashqi havolalar