Path: blob/aarch64-shenandoah-jdk8u272-b10/nashorn/samples/fixed_point.js
32278 views
/*1* Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved.2*3* Redistribution and use in source and binary forms, with or without4* modification, are permitted provided that the following conditions5* are met:6*7* - Redistributions of source code must retain the above copyright8* notice, this list of conditions and the following disclaimer.9*10* - Redistributions in binary form must reproduce the above copyright11* notice, this list of conditions and the following disclaimer in the12* documentation and/or other materials provided with the distribution.13*14* - Neither the name of Oracle nor the names of its15* contributors may be used to endorse or promote products derived16* from this software without specific prior written permission.17*18* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS19* IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO,20* THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR21* PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR22* CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,23* EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,24* PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR25* PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF26* LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING27* NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS28* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.29*/3031// Simple sample demonstrating "fixed point" computation with Streams3233// See also https://mitpress.mit.edu/sicp/chapter1/node21.html#secprocgeneralmethods34var Stream = Java.type("java.util.stream.Stream");3536// generic fixed point procedure37function fixed_point(f, init_guess) {38var tolerance = 0.00001;39function close_enough(v1, v2) Math.abs(v1 - v2) < tolerance;4041var prev;42return Stream.iterate(init_guess, f)43.filter(function(x) {44try {45return prev == undefined? false : close_enough(prev, x);46} finally {47prev = x;48}49})50.findFirst()51.get();52}5354// solution to x = cos(x)55print(fixed_point(Math.cos, 1.0))5657// solution to x = sin(x) + cos(x)58print(fixed_point(function(x) Math.sin(x) + Math.cos(x), 1.0));5960// square root by Newton's method61// http://en.wikipedia.org/wiki/Newton's_method62function sqrt(n)63fixed_point(function(x) (x + n/x) / 2, 2.0);6465print(sqrt(2))66print(sqrt(3))6768697071