MMO: Meta Multi-Objectivization for Software Configuration Tuning
This repository contains the data and code for the following paper that is currently submitting for publication:
Tao Chen and Miqing Li. MMO: Meta Multi-Objectivization for Software Configuration Tuning.
Introduction
In software configuration tuning, different optimizers have been designed to optimize a single performance objective (e.g.,minimizing latency), yet there is still little success in preventing (or mitigating) the search from being trapped in local optima — a hard nut to crack due to the complex configuration landscape and expensive measurement. To tackle this challenge, in this paper, we take a different perspective. Instead of focusing on improving the optimizer, we work on the level of optimization model and propose a meta multi-objectivization (MMO) model that considers an auxiliary performance objective (e.g., throughput in addition to latency). What makes this model unique is that we do not optimize the auxiliary performance objective, but rather use it to make similarly-performing while different configurations less comparable (i.e. Pareto nondominated to each other), thus preventing the search from being trapped in local optima. Importantly, we show how to effectively use the MMO model without worrying about its weight — the only yet highly sensitive parameter that can determine its effectiveness. This is achieved by designing a new normalization method that allows an optimizer to adaptively find the right objective bounds when guiding the tuning. Experiments on 22 cases from 11 real-world software systems/environments confirm that our MMO model with the new normalization performs better than its state-of-the-art single-objective counterparts on 18 out of 22 cases while achieving up to 2.09x speedup. For 15 cases, the new normalization also enables the MMO model to outperform the instance when using it with the normalization proposed in our prior FSE work under pre-tuned best weights, saving a great amount of resources which would be otherwise necessary to find a good weight. We also demonstrate that the MMO model with the new normalization can consolidate FLASH, a recent model-based tuning tool, on 15 out of 22 cases with 1.22x speedup in general.
Data Result
The dataset of this work can be accessed via the Zenodo link here. In particular, the zip file contains all the raw data as reported in the paper; most of the structures are self-explained but we wish to highlight the following:
-  The data under the folder 1.0-0.0and0.0-1.0are for the single-objective optimizers. The former uses O1 as the target performance objective while the latter uses O2 as the target. The data under other folders named by the subject systems are for the MMO and PMO. The result under the weight folder1.0are for MMO while all other folders represent different weight values, containing the data for MMO-FSE.
-  For those data of MMO, MMO-FSE, and PMO, the folder 0and1denote using uses O1 and O2 as the target performance objective, respectively.
-  In the lowest-level folder where the data is stored (i.e., the sasfolder),SolutionSet.rtfcontains the results over all repeated runs;SolutionSetWithMeasurement.rtfrecords the results over different numbers of measurements.
Souce Code
The code folder contains all the information about the source code, as well as an executable jar file in the executable folder .
Running the Experiments
To run the experiments, one can download the mmo-experiments.jar from the aforementioned repository (under the executable folder). Since the artifacts were written in Java, we assume that the JDK/JRE has already been installed. Next, one can run the code using java -jar mmo-experiments.jar [subject] [runs], where [subject] and [runs] denote the subject software system and the number of repeated run (this is an integer and 50 is the default if it is not specified), respectively. The keyword for the systems/environments used in the paper are:
- trimesh
- x264
- storm-wc
- storm-rs
- dnn-sa
- dnn-adiac
- mariadb
- vp9
- mongodb
- lrzip
- llvm
For example, running java -jar mmo-experiments.jar trimesh would execute experiments on the trimesh software for 50 repeated runs.
For each software system, the experiment consists of the runs for MMO, MMO-FSE with all weight values, PMO and the four state-of-the-art single-objective optimizers, as well as the FLASH and FLASH_MMO. All the outputs would be stored in the results folder at the same directory as the executable jar file.
All the measurement data of the subject configurable systems have been placed inside the mmo-experiments.jar.