Błażej Zieliński, Szymon Ściegienny, Hubert Orlicki, Wojciech Książek
{"title":"DetPy (Differential Evolution Tools): A Python toolbox for solving optimization problems using differential evolution","authors":"Błażej Zieliński, Szymon Ściegienny, Hubert Orlicki, Wojciech Książek","doi":"10.1016/j.softx.2024.102014","DOIUrl":null,"url":null,"abstract":"<div><div>The differential evolution algorithm, introduced in 1997, remains one of the most frequently used methods for solving complex optimization problems. The basic version of the algorithm is widely available and implemented in many popular programming languages. However, the algorithm has continued to evolve, with newer, improved variants often achieving superior results over the original. Unfortunately, many of these modifications are not readily accessible as prebuilt programming solutions, creating a need for a comprehensive programming library that includes the most popular and effective variants of the base algorithm. The library we designed, DetPy (Differential Evolution Tools), provides implementations of the standard differential evolution algorithm along with 15 distinct variants. This tool allows researchers working on optimization problems to compare multiple algorithmic approaches, making it easier to select the most effective solution for their specific challenges.</div></div>","PeriodicalId":21905,"journal":{"name":"SoftwareX","volume":"29 ","pages":"Article 102014"},"PeriodicalIF":2.4000,"publicationDate":"2025-02-01","publicationTypes":"Journal Article","fieldsOfStudy":null,"isOpenAccess":false,"openAccessPdf":"","citationCount":"0","resultStr":null,"platform":"Semanticscholar","paperid":null,"PeriodicalName":"SoftwareX","FirstCategoryId":"94","ListUrlMain":"https://www.sciencedirect.com/science/article/pii/S2352711024003844","RegionNum":4,"RegionCategory":"计算机科学","ArticlePicture":[],"TitleCN":null,"AbstractTextCN":null,"PMCID":null,"EPubDate":"","PubModel":"","JCR":"Q2","JCRName":"COMPUTER SCIENCE, SOFTWARE ENGINEERING","Score":null,"Total":0}
引用次数: 0
Abstract
The differential evolution algorithm, introduced in 1997, remains one of the most frequently used methods for solving complex optimization problems. The basic version of the algorithm is widely available and implemented in many popular programming languages. However, the algorithm has continued to evolve, with newer, improved variants often achieving superior results over the original. Unfortunately, many of these modifications are not readily accessible as prebuilt programming solutions, creating a need for a comprehensive programming library that includes the most popular and effective variants of the base algorithm. The library we designed, DetPy (Differential Evolution Tools), provides implementations of the standard differential evolution algorithm along with 15 distinct variants. This tool allows researchers working on optimization problems to compare multiple algorithmic approaches, making it easier to select the most effective solution for their specific challenges.
期刊介绍:
SoftwareX aims to acknowledge the impact of software on today''s research practice, and on new scientific discoveries in almost all research domains. SoftwareX also aims to stress the importance of the software developers who are, in part, responsible for this impact. To this end, SoftwareX aims to support publication of research software in such a way that: The software is given a stamp of scientific relevance, and provided with a peer-reviewed recognition of scientific impact; The software developers are given the credits they deserve; The software is citable, allowing traditional metrics of scientific excellence to apply; The academic career paths of software developers are supported rather than hindered; The software is publicly available for inspection, validation, and re-use. Above all, SoftwareX aims to inform researchers about software applications, tools and libraries with a (proven) potential to impact the process of scientific discovery in various domains. The journal is multidisciplinary and accepts submissions from within and across subject domains such as those represented within the broad thematic areas below: Mathematical and Physical Sciences; Environmental Sciences; Medical and Biological Sciences; Humanities, Arts and Social Sciences. Originating from these broad thematic areas, the journal also welcomes submissions of software that works in cross cutting thematic areas, such as citizen science, cybersecurity, digital economy, energy, global resource stewardship, health and wellbeing, etcetera. SoftwareX specifically aims to accept submissions representing domain-independent software that may impact more than one research domain.