Steiner Tree 4+

Reinhard MAENNER

Progettata per iPad

    • Gratis

Screenshot

Descrizione

This app computes Steiner trees using an evolutionary algorithm. You can place, drag, and delete points of your tree. The optimal number and position of Steiner points is computed.

A minimal spanning tree (MST) connects a given set of points in a plane so that the sum of all edges is minimal. Often this sum of all edges can be reduced, if additional points are added. These points are called Steiner points, and the corresponding minimal spanning tree Steiner tree. If more than 3 points are given, it is a hard optimization problem to compute the optimal number and position of Steiner points.

This app uses a simple evolutionary algorithm for demonstration purposes. It uses a population of individuals. Each individual represents a MST containing some Steiner points. The population develops towards the optimal Steiner tree in an evolutionary loop: Initially, each individual sets random Steiner points, and constructs the corresponding Steiner tree. The minimal length of the Steiner tree in the population is stored. Each individual has now a fitness value, which is the higher, the closer its Steiner tree length is to the minimal length in the population. Fitter individuals have more descendants by reproduction, and less fit individuals die out. In order to explore better solutions, reproduction does not create descendants that are identical to the parent individual, i.e. do not have their Steiner points at the same position. Rather these positions are shifted randomly by mutation, using a Gaussian distribution. How far they are shifted on average is determined also by their fitness: Good individuals shift their Steiner points less than worse individuals.
How fast a good solution is found, depends thus on the population size, and the mutation strength.

Novità

Versione 4.3

Minor internal update for newer iOS versions

Privacy dell’app

Lo sviluppatore, Reinhard MAENNER, ha indicato che le procedure per la tutela della privacy dell’app potrebbero includere il trattamento dei dati descritto di seguito. Per scoprire di più, consulta l’informativa sulla privacy dello sviluppatore.

Dati non raccolti

Lo sviluppatore non raccoglie alcun dato da quest’app.

Le procedure per la tutela della privacy possono variare, per esempio, in base alle funzioni che usi o alla tua età. Scopri di più

Altre app di questo sviluppatore

Ti potrebbe piacere

RealMandelRender
Istruzione
LineAlgebrArt
Istruzione
Quarked! Baryon Blaster
Istruzione
neural networks for XOR
Istruzione
Base to Base Converter
Istruzione
Drawing with Math
Istruzione