Optimal product line design: Genetic algorithm approach to mitigate cannibalization

G. E. Fruchter, A. Fligler, R. S. Winer

Research output: Contribution to journalArticlepeer-review

37 Scopus citations


In this marketing-oriented era where manufacturers maximize profits through customer satisfaction, there is an increasing need to design a product line rather than a single product. By offering a product line, the manufacturer can customize his or her products to the needs of a variety of segments in order to maximize profits by satisfying more customers than a single product would. When the amount of data on customer preferences or possible product configurations is large and no analytical relations can be established, the problem of an optimal product line design becomes very difficult and there are no traditional methods to solve it. In this paper, we show that the usage of genetic algorithms, a mathematical heuristics mimicking the process of biological evolution, can solve efficiently the problem. Special domain operators were developed to help the genetic algorithm mitigate cannibalization and enhance the algorithm's local search abilities. Using manufacturer's profits as the criteria for fitness in evaluating chromosomes, the usage of domain specific operators was found to be highly beneficial with better final results. Also, we have hybridized the genetic algorithm with a linear programming postprocessing step to fine tune the prices of products in the product line. Attacking the core difficulty of cannibalization in the algorithm, the operators introduced in this work are unique.

Original languageEnglish
Pages (from-to)227-244
Number of pages18
JournalJournal of Optimization Theory and Applications
Issue number2
StatePublished - Nov 2006


  • Cannibalization
  • Genetic algorithms
  • Heuristics
  • Marketing
  • Pricing
  • Product line design


Dive into the research topics of 'Optimal product line design: Genetic algorithm approach to mitigate cannibalization'. Together they form a unique fingerprint.

Cite this