xref: /aosp_15_r20/external/bc/scripts/sqrt_int_guess.bc (revision 5a6e848804d15c18a0125914844ee4eb0bda4fcf)
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