1*5a6e8488SAndroid Build Coastguard Worker#! /usr/bin/bc -l 2*5a6e8488SAndroid Build Coastguard Worker# 3*5a6e8488SAndroid Build Coastguard Worker# SPDX-License-Identifier: BSD-2-Clause 4*5a6e8488SAndroid Build Coastguard Worker# 5*5a6e8488SAndroid Build Coastguard Worker# Copyright (c) 2018-2024 Gavin D. Howard and contributors. 6*5a6e8488SAndroid Build Coastguard Worker# 7*5a6e8488SAndroid Build Coastguard Worker# Redistribution and use in source and binary forms, with or without 8*5a6e8488SAndroid Build Coastguard Worker# modification, are permitted provided that the following conditions are met: 9*5a6e8488SAndroid Build Coastguard Worker# 10*5a6e8488SAndroid Build Coastguard Worker# * Redistributions of source code must retain the above copyright notice, this 11*5a6e8488SAndroid Build Coastguard Worker# list of conditions and the following disclaimer. 12*5a6e8488SAndroid Build Coastguard Worker# 13*5a6e8488SAndroid Build Coastguard Worker# * Redistributions in binary form must reproduce the above copyright notice, 14*5a6e8488SAndroid Build Coastguard Worker# this list of conditions and the following disclaimer in the documentation 15*5a6e8488SAndroid Build Coastguard Worker# and/or other materials provided with the distribution. 16*5a6e8488SAndroid Build Coastguard Worker# 17*5a6e8488SAndroid Build Coastguard Worker# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" 18*5a6e8488SAndroid Build Coastguard Worker# AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 19*5a6e8488SAndroid Build Coastguard Worker# IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 20*5a6e8488SAndroid Build Coastguard Worker# ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE 21*5a6e8488SAndroid Build Coastguard Worker# LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR 22*5a6e8488SAndroid Build Coastguard Worker# CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF 23*5a6e8488SAndroid Build Coastguard Worker# SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS 24*5a6e8488SAndroid Build Coastguard Worker# INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN 25*5a6e8488SAndroid Build Coastguard Worker# CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) 26*5a6e8488SAndroid Build Coastguard Worker# ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 27*5a6e8488SAndroid Build Coastguard Worker# POSSIBILITY OF SUCH DAMAGE. 28*5a6e8488SAndroid Build Coastguard Worker# 29*5a6e8488SAndroid Build Coastguard Worker 30*5a6e8488SAndroid Build Coastguard Worker# Adjust this number to try ranges above different powers of 10. 31*5a6e8488SAndroid Build Coastguard Workermax = 0 32*5a6e8488SAndroid Build Coastguard Worker 33*5a6e8488SAndroid Build Coastguard Workern = (1 << max) 34*5a6e8488SAndroid Build Coastguard Worker 35*5a6e8488SAndroid Build Coastguard Worker# Uncomment this to test the high part of the ranges. 36*5a6e8488SAndroid Build Coastguard Worker#n += (1 - (1 >> 10)) 37*5a6e8488SAndroid Build Coastguard Worker 38*5a6e8488SAndroid Build Coastguard Workern 39*5a6e8488SAndroid Build Coastguard Worker 40*5a6e8488SAndroid Build Coastguard Worker# Loop from the start number to the next power of 10. 41*5a6e8488SAndroid Build Coastguard Workerfor (i = n; i < (n$ << 1); i += 1) 42*5a6e8488SAndroid Build Coastguard Worker{ 43*5a6e8488SAndroid Build Coastguard Worker # This is the lower limit. 44*5a6e8488SAndroid Build Coastguard Worker t1 = sqrt(1/(3*i)) 45*5a6e8488SAndroid Build Coastguard Worker 46*5a6e8488SAndroid Build Coastguard Worker l = length(i$)/2 47*5a6e8488SAndroid Build Coastguard Worker 48*5a6e8488SAndroid Build Coastguard Worker print "i: ", i, "\n" 49*5a6e8488SAndroid Build Coastguard Worker #print "l: ", l, "\n" 50*5a6e8488SAndroid Build Coastguard Worker 51*5a6e8488SAndroid Build Coastguard Worker if (l$ != l) 52*5a6e8488SAndroid Build Coastguard Worker { 53*5a6e8488SAndroid Build Coastguard Worker # Limit between 2.4 and 3. 54*5a6e8488SAndroid Build Coastguard Worker limit = 2.7 << (l$ * 2) 55*5a6e8488SAndroid Build Coastguard Worker #print "limit: ", limit, "\n" 56*5a6e8488SAndroid Build Coastguard Worker 57*5a6e8488SAndroid Build Coastguard Worker if (i >= limit) 58*5a6e8488SAndroid Build Coastguard Worker { 59*5a6e8488SAndroid Build Coastguard Worker t2 = 1/(i >> (l$)) * 2 60*5a6e8488SAndroid Build Coastguard Worker } 61*5a6e8488SAndroid Build Coastguard Worker else 62*5a6e8488SAndroid Build Coastguard Worker { 63*5a6e8488SAndroid Build Coastguard Worker t2 = 1/(i >> (l$)) 64*5a6e8488SAndroid Build Coastguard Worker } 65*5a6e8488SAndroid Build Coastguard Worker } 66*5a6e8488SAndroid Build Coastguard Worker else 67*5a6e8488SAndroid Build Coastguard Worker { 68*5a6e8488SAndroid Build Coastguard Worker # Limit between 3.8-ish and 4.8 69*5a6e8488SAndroid Build Coastguard Worker limit = 4.3 << (l$ * 2 - 1) 70*5a6e8488SAndroid Build Coastguard Worker #print "limit: ", limit, "\n" 71*5a6e8488SAndroid Build Coastguard Worker 72*5a6e8488SAndroid Build Coastguard Worker if (i >= limit) 73*5a6e8488SAndroid Build Coastguard Worker { 74*5a6e8488SAndroid Build Coastguard Worker t2 = 1/(i >> (l$ - 1)) * 8 75*5a6e8488SAndroid Build Coastguard Worker } 76*5a6e8488SAndroid Build Coastguard Worker else 77*5a6e8488SAndroid Build Coastguard Worker { 78*5a6e8488SAndroid Build Coastguard Worker t2 = 1/(i >> (l$ - 1)) * 4 79*5a6e8488SAndroid Build Coastguard Worker } 80*5a6e8488SAndroid Build Coastguard Worker } 81*5a6e8488SAndroid Build Coastguard Worker 82*5a6e8488SAndroid Build Coastguard Worker # This is the upper limit. 83*5a6e8488SAndroid Build Coastguard Worker t3 = sqrt(5/(3*i)) 84*5a6e8488SAndroid Build Coastguard Worker 85*5a6e8488SAndroid Build Coastguard Worker # This is true when the guess is in between the limits. 86*5a6e8488SAndroid Build Coastguard Worker good = (t1 < t2 && t2 < t3) 87*5a6e8488SAndroid Build Coastguard Worker 88*5a6e8488SAndroid Build Coastguard Worker print t1, " < ", t2, " < ", t3, ": ", good, "\n" 89*5a6e8488SAndroid Build Coastguard Worker 90*5a6e8488SAndroid Build Coastguard Worker # Error if we have a problem. 91*5a6e8488SAndroid Build Coastguard Worker if (!good) sqrt(-1) 92*5a6e8488SAndroid Build Coastguard Worker} 93*5a6e8488SAndroid Build Coastguard Worker 94*5a6e8488SAndroid Build Coastguard Workerhalt 95