samples/logisticmap.js

changeset 0
b1a7da25b547
child 962
ac62e33a99b0
     1.1 --- /dev/null	Thu Jan 01 00:00:00 1970 +0000
     1.2 +++ b/samples/logisticmap.js	Wed Apr 27 01:36:41 2016 +0800
     1.3 @@ -0,0 +1,82 @@
     1.4 +#// Usage: jjs -fx -scripting logisticmap.js -- <initial_x> <R>
     1.5 +
     1.6 +/*
     1.7 + * Copyright (c) 2014, Oracle and/or its affiliates. All rights reserved.
     1.8 + * 
     1.9 + * Redistribution and use in source and binary forms, with or without
    1.10 + * modification, are permitted provided that the following conditions
    1.11 + * are met:
    1.12 + * 
    1.13 + *   - Redistributions of source code must retain the above copyright
    1.14 + *     notice, this list of conditions and the following disclaimer.
    1.15 + * 
    1.16 + *   - Redistributions in binary form must reproduce the above copyright
    1.17 + *     notice, this list of conditions and the following disclaimer in the
    1.18 + *     documentation and/or other materials provided with the distribution.
    1.19 + * 
    1.20 + *   - Neither the name of Oracle nor the names of its
    1.21 + *     contributors may be used to endorse or promote products derived
    1.22 + *     from this software without specific prior written permission.
    1.23 + * 
    1.24 + * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS
    1.25 + * IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO,
    1.26 + * THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
    1.27 + * PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE COPYRIGHT OWNER OR
    1.28 + * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
    1.29 + * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
    1.30 + * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
    1.31 + * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
    1.32 + * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
    1.33 + * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
    1.34 + * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
    1.35 + */
    1.36 +
    1.37 +// Logistic map viewer using Java8 Streams and JavaFX
    1.38 +// See also http://en.wikipedia.org/wiki/Logistic_map
    1.39 +
    1.40 +if (!$OPTIONS._fx || arguments.length < 2) {
    1.41 +    print("Usage: jjs -fx -scripting logisticmap.js -- <initial_x> <R>");
    1.42 +    exit(1);
    1.43 +}
    1.44 +
    1.45 +// parameters for the logistic map
    1.46 +var x = parseFloat(arguments[0]);
    1.47 +var R = parseFloat(arguments[1]);
    1.48 +var NUM_POINTS = arguments.length > 2? parseFloat(arguments[2]) : 20;
    1.49 +
    1.50 +// Java classes used
    1.51 +var DoubleStream = Java.type('java.util.stream.DoubleStream');
    1.52 +var LineChart = Java.type("javafx.scene.chart.LineChart");
    1.53 +var NumberAxis = Java.type("javafx.scene.chart.NumberAxis");
    1.54 +var Scene = Java.type("javafx.scene.Scene");
    1.55 +var Stage = Java.type("javafx.stage.Stage");
    1.56 +var XYChart = Java.type("javafx.scene.chart.XYChart");
    1.57 +
    1.58 +function start(stage) {
    1.59 +    stage.title = "Logistic Map: initial x = ${x}, R = ${R}";
    1.60 +    // make chart
    1.61 +    var xAxis = new NumberAxis();
    1.62 +    var yAxis = new NumberAxis();
    1.63 +    var lineChart = new LineChart(xAxis, yAxis);
    1.64 +    xAxis.setLabel("iteration");
    1.65 +    yAxis.setLabel("x");
    1.66 +    // make chart data series
    1.67 +    var series = new XYChart.Series();
    1.68 +    var data = series.data;
    1.69 +    // populate data using logistic iteration
    1.70 +    var i = 0;
    1.71 +    DoubleStream
    1.72 +        .generate(function() x = R*x*(1-x))
    1.73 +        .limit(NUM_POINTS)
    1.74 +        .forEach(
    1.75 +            function(value) {
    1.76 +                data.add(new XYChart.Data(i, value));
    1.77 +                i++;
    1.78 +            }
    1.79 +         );
    1.80 +    // add to stage
    1.81 +    var scene = new Scene(lineChart, 800, 600);
    1.82 +    lineChart.data.add(series);
    1.83 +    stage.scene = scene;
    1.84 +    stage.show();
    1.85 +}

mercurial