$25 GRAYBYTE WORDPRESS FILE MANAGER $62

SERVER : vnpttt-amd7f72-h1.vietnix.vn #1 SMP Fri May 24 12:42:50 UTC 2024
SERVER IP : 103.200.23.149 | ADMIN IP 216.73.216.22
OPTIONS : CRL = ON | WGT = ON | SDO = OFF | PKEX = OFF
DEACTIVATED : NONE

/lib/golang/src/math/

HOME
Current File : /lib/golang/src/math//log_amd64.s
// Copyright 2010 The Go Authors. All rights reserved.
// Use of this source code is governed by a BSD-style
// license that can be found in the LICENSE file.

#include "textflag.h"

#define HSqrt2 7.07106781186547524401e-01 // sqrt(2)/2
#define Ln2Hi  6.93147180369123816490e-01 // 0x3fe62e42fee00000
#define Ln2Lo  1.90821492927058770002e-10 // 0x3dea39ef35793c76
#define L1     6.666666666666735130e-01   // 0x3FE5555555555593
#define L2     3.999999999940941908e-01   // 0x3FD999999997FA04
#define L3     2.857142874366239149e-01   // 0x3FD2492494229359
#define L4     2.222219843214978396e-01   // 0x3FCC71C51D8E78AF
#define L5     1.818357216161805012e-01   // 0x3FC7466496CB03DE
#define L6     1.531383769920937332e-01   // 0x3FC39A09D078C69F
#define L7     1.479819860511658591e-01   // 0x3FC2F112DF3E5244
#define NaN    0x7FF8000000000001
#define NegInf 0xFFF0000000000000
#define PosInf 0x7FF0000000000000

// func Log(x float64) float64
TEXT ·archLog(SB),NOSPLIT,$0
	// test bits for special cases
	MOVQ    x+0(FP), BX
	MOVQ    $~(1<<63), AX // sign bit mask
	ANDQ    BX, AX
	JEQ     isZero
	MOVQ    $0, AX
	CMPQ    AX, BX
	JGT     isNegative
	MOVQ    $PosInf, AX
	CMPQ    AX, BX
	JLE     isInfOrNaN
	// f1, ki := math.Frexp(x); k := float64(ki)
	MOVQ    BX, X0
	MOVQ    $0x000FFFFFFFFFFFFF, AX
	MOVQ    AX, X2
	ANDPD   X0, X2
	MOVSD   $0.5, X0 // 0x3FE0000000000000
	ORPD    X0, X2 // X2= f1
	SHRQ    $52, BX
	ANDL    $0x7FF, BX
	SUBL    $0x3FE, BX
	XORPS   X1, X1 // break dependency for CVTSL2SD
	CVTSL2SD BX, X1 // x1= k, x2= f1
	// if f1 < math.Sqrt2/2 { k -= 1; f1 *= 2 }
	MOVSD   $HSqrt2, X0 // x0= 0.7071, x1= k, x2= f1
	CMPSD   X2, X0, 5 // cmpnlt; x0= 0 or ^0, x1= k, x2 = f1
	MOVSD   $1.0, X3 // x0= 0 or ^0, x1= k, x2 = f1, x3= 1
	ANDPD   X0, X3 // x0= 0 or ^0, x1= k, x2 = f1, x3= 0 or 1
	SUBSD   X3, X1 // x0= 0 or ^0, x1= k, x2 = f1, x3= 0 or 1
	MOVSD   $1.0, X0 // x0= 1, x1= k, x2= f1, x3= 0 or 1
	ADDSD   X0, X3 // x0= 1, x1= k, x2= f1, x3= 1 or 2
	MULSD   X3, X2 // x0= 1, x1= k, x2= f1
	// f := f1 - 1
	SUBSD   X0, X2 // x1= k, x2= f
	// s := f / (2 + f)
	MOVSD   $2.0, X0
	ADDSD   X2, X0
	MOVAPD  X2, X3
	DIVSD   X0, X3 // x1=k, x2= f, x3= s
	// s2 := s * s
	MOVAPD  X3, X4 // x1= k, x2= f, x3= s
	MULSD   X4, X4 // x1= k, x2= f, x3= s, x4= s2
	// s4 := s2 * s2
	MOVAPD  X4, X5 // x1= k, x2= f, x3= s, x4= s2
	MULSD   X5, X5 // x1= k, x2= f, x3= s, x4= s2, x5= s4
	// t1 := s2 * (L1 + s4*(L3+s4*(L5+s4*L7)))
	MOVSD   $L7, X6
	MULSD   X5, X6
	ADDSD   $L5, X6
	MULSD   X5, X6
	ADDSD   $L3, X6
	MULSD   X5, X6
	ADDSD   $L1, X6
	MULSD   X6, X4 // x1= k, x2= f, x3= s, x4= t1, x5= s4
	// t2 := s4 * (L2 + s4*(L4+s4*L6))
	MOVSD   $L6, X6
	MULSD   X5, X6
	ADDSD   $L4, X6
	MULSD   X5, X6
	ADDSD   $L2, X6
	MULSD   X6, X5 // x1= k, x2= f, x3= s, x4= t1, x5= t2
	// R := t1 + t2
	ADDSD   X5, X4 // x1= k, x2= f, x3= s, x4= R
	// hfsq := 0.5 * f * f
	MOVSD   $0.5, X0
	MULSD   X2, X0
	MULSD   X2, X0 // x0= hfsq, x1= k, x2= f, x3= s, x4= R
	// return k*Ln2Hi - ((hfsq - (s*(hfsq+R) + k*Ln2Lo)) - f)
	ADDSD   X0, X4 // x0= hfsq, x1= k, x2= f, x3= s, x4= hfsq+R
	MULSD   X4, X3 // x0= hfsq, x1= k, x2= f, x3= s*(hfsq+R)
	MOVSD   $Ln2Lo, X4
	MULSD   X1, X4 // x4= k*Ln2Lo
	ADDSD   X4, X3 // x0= hfsq, x1= k, x2= f, x3= s*(hfsq+R)+k*Ln2Lo
	SUBSD   X3, X0 // x0= hfsq-(s*(hfsq+R)+k*Ln2Lo), x1= k, x2= f
	SUBSD   X2, X0 // x0= (hfsq-(s*(hfsq+R)+k*Ln2Lo))-f, x1= k
	MULSD   $Ln2Hi, X1 // x0= (hfsq-(s*(hfsq+R)+k*Ln2Lo))-f, x1= k*Ln2Hi
	SUBSD   X0, X1 // x1= k*Ln2Hi-((hfsq-(s*(hfsq+R)+k*Ln2Lo))-f)
	MOVSD   X1, ret+8(FP)
	RET
isInfOrNaN:
	MOVQ    BX, ret+8(FP) // +Inf or NaN, return x
	RET
isNegative:
	MOVQ    $NaN, AX
	MOVQ    AX, ret+8(FP) // return NaN
	RET
isZero:
	MOVQ    $NegInf, AX
	MOVQ    AX, ret+8(FP) // return -Inf
	RET

Current_dir [ NOT WRITEABLE ] Document_root [ WRITEABLE ]


[ Back ]
NAME
SIZE
LAST TOUCH
USER
CAN-I?
FUNCTIONS
..
--
16 Dec 2025 9.30 PM
root / root
0755
big
--
16 Dec 2025 9.34 PM
root / root
0755
bits
--
16 Dec 2025 9.30 PM
root / root
0755
cmplx
--
16 Dec 2025 9.30 PM
root / root
0755
rand
--
16 Dec 2025 9.30 PM
root / root
0755
abs.go
0.357 KB
4 Dec 2025 6.06 PM
root / root
0644
acos_s390x.s
3.69 KB
4 Dec 2025 6.06 PM
root / root
0644
acosh.go
1.708 KB
4 Dec 2025 6.06 PM
root / root
0644
acosh_s390x.s
4.319 KB
4 Dec 2025 6.06 PM
root / root
0644
arith_s390x.go
3.731 KB
4 Dec 2025 6.06 PM
root / root
0644
asin.go
1.089 KB
4 Dec 2025 6.06 PM
root / root
0644
asin_s390x.s
4.118 KB
4 Dec 2025 6.06 PM
root / root
0644
asinh.go
1.921 KB
4 Dec 2025 6.06 PM
root / root
0644
asinh_s390x.s
5.682 KB
4 Dec 2025 6.06 PM
root / root
0644
atan.go
3.026 KB
4 Dec 2025 6.06 PM
root / root
0644
atan2.go
1.523 KB
4 Dec 2025 6.06 PM
root / root
0644
atan2_s390x.s
6.875 KB
4 Dec 2025 6.06 PM
root / root
0644
atan_s390x.s
3.689 KB
4 Dec 2025 6.06 PM
root / root
0644
atanh.go
1.994 KB
4 Dec 2025 6.06 PM
root / root
0644
atanh_s390x.s
5.059 KB
4 Dec 2025 6.06 PM
root / root
0644
bits.go
1.87 KB
4 Dec 2025 6.06 PM
root / root
0644
cbrt.go
2.311 KB
4 Dec 2025 6.06 PM
root / root
0644
cbrt_s390x.s
4.886 KB
4 Dec 2025 6.06 PM
root / root
0644
const.go
2.762 KB
4 Dec 2025 6.06 PM
root / root
0644
copysign.go
0.387 KB
4 Dec 2025 6.06 PM
root / root
0644
cosh_s390x.s
5.594 KB
4 Dec 2025 6.06 PM
root / root
0644
dim.go
1.868 KB
4 Dec 2025 6.06 PM
root / root
0644
dim_amd64.s
1.917 KB
4 Dec 2025 6.06 PM
root / root
0644
dim_arm64.s
0.94 KB
4 Dec 2025 6.06 PM
root / root
0644
dim_asm.go
0.347 KB
4 Dec 2025 6.06 PM
root / root
0644
dim_loong64.s
1.195 KB
4 Dec 2025 6.06 PM
root / root
0644
dim_noasm.go
0.412 KB
4 Dec 2025 6.06 PM
root / root
0644
dim_riscv64.s
1.162 KB
4 Dec 2025 6.06 PM
root / root
0644
dim_s390x.s
1.969 KB
4 Dec 2025 6.06 PM
root / root
0644
erf.go
11.509 KB
4 Dec 2025 6.06 PM
root / root
0644
erf_s390x.s
8.495 KB
4 Dec 2025 6.06 PM
root / root
0644
erfc_s390x.s
14.361 KB
4 Dec 2025 6.06 PM
root / root
0644
erfinv.go
3.369 KB
4 Dec 2025 6.06 PM
root / root
0644
exp.go
5.376 KB
4 Dec 2025 6.06 PM
root / root
0644
exp2_asm.go
0.257 KB
4 Dec 2025 6.06 PM
root / root
0644
exp2_noasm.go
0.289 KB
4 Dec 2025 6.06 PM
root / root
0644
exp_amd64.go
0.255 KB
4 Dec 2025 6.06 PM
root / root
0644
exp_amd64.s
4.242 KB
4 Dec 2025 6.06 PM
root / root
0644
exp_arm64.s
5.356 KB
4 Dec 2025 6.06 PM
root / root
0644
exp_asm.go
0.272 KB
4 Dec 2025 6.06 PM
root / root
0644
exp_loong64.s
5.338 KB
4 Dec 2025 6.06 PM
root / root
0644
exp_noasm.go
0.307 KB
4 Dec 2025 6.06 PM
root / root
0644
exp_s390x.s
4.63 KB
4 Dec 2025 6.06 PM
root / root
0644
expm1.go
7.909 KB
4 Dec 2025 6.06 PM
root / root
0644
expm1_s390x.s
5.201 KB
4 Dec 2025 6.06 PM
root / root
0644
floor.go
3.291 KB
4 Dec 2025 6.06 PM
root / root
0644
floor_386.s
1.474 KB
4 Dec 2025 6.06 PM
root / root
0644
floor_amd64.s
1.999 KB
4 Dec 2025 6.06 PM
root / root
0644
floor_arm64.s
0.56 KB
4 Dec 2025 6.06 PM
root / root
0644
floor_asm.go
0.442 KB
4 Dec 2025 6.06 PM
root / root
0644
floor_loong64.s
1.015 KB
4 Dec 2025 6.06 PM
root / root
0644
floor_noasm.go
0.542 KB
4 Dec 2025 6.06 PM
root / root
0644
floor_ppc64x.s
0.487 KB
4 Dec 2025 6.06 PM
root / root
0644
floor_riscv64.s
1.731 KB
4 Dec 2025 6.06 PM
root / root
0644
floor_s390x.s
0.565 KB
4 Dec 2025 6.06 PM
root / root
0644
floor_wasm.s
0.448 KB
4 Dec 2025 6.06 PM
root / root
0644
fma.go
4.86 KB
4 Dec 2025 6.06 PM
root / root
0644
frexp.go
0.907 KB
4 Dec 2025 6.06 PM
root / root
0644
gamma.go
5.525 KB
4 Dec 2025 6.06 PM
root / root
0644
hypot.go
0.83 KB
4 Dec 2025 6.06 PM
root / root
0644
hypot_386.s
1.813 KB
4 Dec 2025 6.06 PM
root / root
0644
hypot_amd64.s
1.055 KB
4 Dec 2025 6.06 PM
root / root
0644
hypot_asm.go
0.258 KB
4 Dec 2025 6.06 PM
root / root
0644
hypot_noasm.go
0.29 KB
4 Dec 2025 6.06 PM
root / root
0644
j0.go
13.604 KB
4 Dec 2025 6.06 PM
root / root
0644
j1.go
13.304 KB
4 Dec 2025 6.06 PM
root / root
0644
jn.go
7.179 KB
4 Dec 2025 6.06 PM
root / root
0644
ldexp.go
1.052 KB
4 Dec 2025 6.06 PM
root / root
0644
lgamma.go
11.025 KB
4 Dec 2025 6.06 PM
root / root
0644
log.go
3.86 KB
4 Dec 2025 6.06 PM
root / root
0644
log10.go
0.853 KB
4 Dec 2025 6.06 PM
root / root
0644
log10_s390x.s
4.731 KB
4 Dec 2025 6.06 PM
root / root
0644
log1p.go
6.345 KB
4 Dec 2025 6.06 PM
root / root
0644
log1p_s390x.s
5.106 KB
4 Dec 2025 6.06 PM
root / root
0644
log_amd64.s
3.663 KB
4 Dec 2025 6.06 PM
root / root
0644
log_asm.go
0.253 KB
4 Dec 2025 6.06 PM
root / root
0644
log_s390x.s
4.292 KB
4 Dec 2025 6.06 PM
root / root
0644
log_stub.go
0.285 KB
4 Dec 2025 6.06 PM
root / root
0644
logb.go
0.997 KB
4 Dec 2025 6.06 PM
root / root
0644
mod.go
0.882 KB
4 Dec 2025 6.06 PM
root / root
0644
modf.go
0.892 KB
4 Dec 2025 6.06 PM
root / root
0644
modf_arm64.s
0.437 KB
4 Dec 2025 6.06 PM
root / root
0644
modf_asm.go
0.285 KB
4 Dec 2025 6.06 PM
root / root
0644
modf_noasm.go
0.318 KB
4 Dec 2025 6.06 PM
root / root
0644
modf_ppc64x.s
0.406 KB
4 Dec 2025 6.06 PM
root / root
0644
nextafter.go
1.21 KB
4 Dec 2025 6.06 PM
root / root
0644
pow.go
3.646 KB
4 Dec 2025 6.06 PM
root / root
0644
pow10.go
1.239 KB
4 Dec 2025 6.06 PM
root / root
0644
pow_s390x.s
16.216 KB
4 Dec 2025 6.06 PM
root / root
0644
remainder.go
2.043 KB
4 Dec 2025 6.06 PM
root / root
0644
signbit.go
0.295 KB
4 Dec 2025 6.06 PM
root / root
0644
sin.go
6.353 KB
4 Dec 2025 6.06 PM
root / root
0644
sin_s390x.s
8.572 KB
4 Dec 2025 6.06 PM
root / root
0644
sincos.go
1.758 KB
4 Dec 2025 6.06 PM
root / root
0644
sinh.go
1.692 KB
4 Dec 2025 6.06 PM
root / root
0644
sinh_s390x.s
5.978 KB
4 Dec 2025 6.06 PM
root / root
0644
sqrt.go
4.751 KB
4 Dec 2025 6.06 PM
root / root
0644
stubs.go
2.572 KB
4 Dec 2025 6.06 PM
root / root
0644
stubs_s390x.s
12.382 KB
4 Dec 2025 6.06 PM
root / root
0644
tan.go
3.68 KB
4 Dec 2025 6.06 PM
root / root
0644
tan_s390x.s
2.683 KB
4 Dec 2025 6.06 PM
root / root
0644
tanh.go
2.657 KB
4 Dec 2025 6.06 PM
root / root
0644
tanh_s390x.s
4.571 KB
4 Dec 2025 6.06 PM
root / root
0644
trig_reduce.go
3.339 KB
4 Dec 2025 6.06 PM
root / root
0644
unsafe.go
1.596 KB
4 Dec 2025 6.06 PM
root / root
0644

GRAYBYTE WORDPRESS FILE MANAGER @ 2026 CONTACT ME
Static GIF