![سامانه مدیریت نشریات علمی دانشگاه امام حسین (ع)](./data/logo.png)
تعداد نشریات | 36 |
تعداد شمارهها | 1,192 |
تعداد مقالات | 8,579 |
تعداد مشاهده مقاله | 6,988,708 |
تعداد دریافت فایل اصل مقاله | 4,032,557 |
ارائه روشی برای پیشبینی کدهای نابسامان سامانههای نرمافزاری با استفاده از شبکه عصبی | ||
پدافند الکترونیکی و سایبری | ||
مقاله 7، دوره 11، شماره 3 - شماره پیاپی 43، آبان 1402، صفحه 67-76 اصل مقاله (578.98 K) | ||
نوع مقاله: مقاله پژوهشی | ||
نویسندگان | ||
علی کریمی1؛ فرهاد کریمی* 2 | ||
1مهندسی کامپیوتر، دانشکده رایانه، دانشگاه جامع امام حسین (ع)، تهران، ایران | ||
2گروه آموزشی کامپیوتر، دانشکده کامپیوتر، دانشگاه جامع امام حسین(ع)، تهران، ایران | ||
تاریخ دریافت: 03 اسفند 1401، تاریخ بازنگری: 21 تیر 1402، تاریخ پذیرش: 09 مرداد 1402 | ||
چکیده | ||
مهندسان نرمافزار همواره به دنبال کاهش هزینههای تولید و افزایش کیفیت نرمافزار هستند. روشهای مختلفی برای افزایش کیفیت نرمافزار وجود دارد که بازسازی کد یکی از این روشها است. بازسازی و بازآرایی کد روشی برای تمیز کردن کدهای نرمافزار و یکی از روالهای بسیار مهم در حفظ کیفیت نرمافزار است. یکی از چالشهای اصلی در توسعه و تولید کدهای تمیز در نرمافزار وجود کدهای نابسامان یا بوهای کد است. بوی کد یک نشانه سطحی در کد است که احتمالاً نشاندهندهی یک مشکل عمیقتر در نرمافزار میباشد. وجود بوی کد ممکن است باعث کند شدن پردازش، افزایش خطر خرابی و همچنین خطاهای نرمافزار شود. از اینرو، توسعهدهندگان نرمافزار درصدد هستند که با شناسایی کدهای نابسامان، ضمن بازآرایی کد نرمافزار، توسعهپذیری و نگهداشتپذیری آن را در آینده تسهیل کنند. با این حال، شناسایی دستی و غیرخودکار بوهای کد چالشبرانگیز و خستهکننده است. بنابراین، روشهایی برای شناسایی این نوع کدها بهصورت خودکار و نیمهخودکار ارایه شده است. نکته حائز اهمیت در روشهای غیرخودکار آن است که پیشبینی کدهای نابسامان، نیاز به دانش فردی افراد است که هم زمانبر است و هم امکان خطا را افزایش میدهد. ازاینرو، استفاده از روشهای خودکار برای پیشبینی کدهای نابسامان، ارجحیت بیشتری دارد. تاکنون تحقیقات زیادی در حوزه پیشبینی و شناسایی کدهای نابسامان بهصورت خودکار انجام شده است. درصد زیادی از این تحقیقات بر روی پیشبینی چهار نوع بوی کد شامل؛ متد طولانی، خصیصه حسادت، کلاس خدا و کلاس داده تمرکز کردهاند. تمرکز ما نیز در این مقاله بر روی بهبود دقت استخراج این نوع از کدهای نابسامان است. یکی از روشهای رایج برای پیشبینی این نوع کدها، استفاده از روشهای مبتنی بر یادگیری ماشین است. شبکههای عصبی مصنوعی نوع خاصی از الگوریتمهای یادگیری ماشین است که مطابق با روش عملکرد مغز انسان مدل شدهاند. به این معنی که این شبکهها قادر هستند از دادههای ورودی یاد بگیرند و پاسخ را در قالب پیشبینیها و طبقهبندیها ارائه دهند. در این مقاله، برای پیشبینی کدهای نابسامان نرمافزار از شبکه عصبی چند لایه و همچنین از یک روش انتخاب ویژگی جدید بهمنظور افزایش دقت پیشبینی استفاده شده است. | ||
کلیدواژهها | ||
کد نابسامان؛ بوی کد؛ انتخاب ویژگی؛ طبقهبندی؛ یادگیری ماشین؛ شبکه عصبی | ||
عنوان مقاله [English] | ||
A method to prediction of software system’s code smells using neural network | ||
نویسندگان [English] | ||
Ali Karimi1؛ farhad karimi2 | ||
1Computer Engineering, Faculty of Computer Science, Imam Hossein University, Tehran, Iran | ||
2Department of Computer Education, Computer Faculty, Imam Hossein University, Tehran, Iran | ||
چکیده [English] | ||
Software engineers are always looking to reduce production costs and increase software quality. There are various methods to improve software quality, and code refactoring is one of these methods. Code refactoring and reorganization is a method for cleaning up software code and is one of the crucial processes in maintaining software quality. One of the main challenges in developing and producing clean code in software is the existence of inconsistent or bad-smelling code. Code smell is a superficial sign in the code that may indicate a deeper problem in the software. The existence of code smells may slow down processing, increase the risk of failure, as well as software errors. Therefore, software developers attempt to identify inconsistent code and facilitate its maintainability and scalability by refactoring software code. However, manual and automatic identification of code smells is challenging and tiring. As a result, methods for identifying such codes automatically and semi-automatically have been proposed. An important note in non-automatic methods is that predicting inconsistent code requires individual knowledge that is both time-consuming and increases the possibility of error. Therefore, automated methods have a greater advantage in predicting inconsistent code. So far, extensive research has been conducted on automatic prediction and identification of inconsistent code. A high percentage of these studies have focused on predicting four types of code smells: long method, feature envy, god class, and data class. In this article, our focus is on improving the accuracy of extracting such inconsistent codes. One of the common methods for predicting this type of code is using machine learning-based methods. Artificial neural networks are a specific type of machine learning algorithm that is modeled according to the human brain's performance method. This means that these networks can learn from input data and provide responses in the form of predictions and classifications. In this article, a multi-layer neural network was used to predict software inconsistent code, as well as a new feature selection method to increase prediction accuracy. | ||
کلیدواژهها [English] | ||
code smell, feature selection, classification, machine learning, neural network | ||
مراجع | ||
| ||
آمار تعداد مشاهده مقاله: 63 تعداد دریافت فایل اصل مقاله: 111 |