ShoneSharp语言(S#)的设计和使用介绍
系列(5)— 数值Double
作者:Shone
声明:原创文章欢迎转载,但请注明出处,https://www.cnblogs.com/ShoneSharp。
摘要: S#语言的最基本类型——数值(对应C#的Double),可用于表示整数或实数值,如10、25.32等。S#只有一种数值类型,可避免类型转换和运算陷阱。本文详细列出数值类型专用的常量、函数、属性以及方法,包括语法格式、成员说明、输入示例以及求值结果。
软件: S#语言编辑解析运行器,运行环境.NET 4.0,绿色软件,单个EXE直接运行,无副作用。网盘下载链接为https://pan.baidu.com/s/1dF4e08p
今天详细解释一下S#语言的最基本类型——数值(对应C#的双精度浮点数类型double),可用于表示整数或实数值,如10、25.32等。
注意C#中还有int, float, byte, short, long等多种数值类型,为什么S#只有一种数值类型?
S#这样设计就是为了简化常规数据输入,避免进行类型转换,同时也避免部分符号的运算陷阱。比如:在C#中5/2等于2,而5/2.0则等于2.5,这对于用户大量输入数据公式时很容易犯下错误,而且不容易察觉。因此S#这样设计可以确保5/2等于2.5。
S#语言为数值类型专门提供了大量的常量、函数、属性以及方法,具体语法格式、成员说明、输入示例以及求值结果都在下面详细列出,可供参考。
其实还有些适用于数值类型的算符、函数、属性以及方法,如10+20、cos(30)、5.2.ToStr等,没有在本节列出而是放在其基类型——任意对象(对应C#的object)中介绍,因为这些符号功能更加强大,不但支持数值,还支持数组、列表和数据表的计算。比如[10,15]+20、cos({30,40,50})、{5.2,[1,2],6}.ToStr。
(1) 常量
Double BaseE
说明:自然对数底e
输入:BaseE
求值:2.7182818284590451
Double DecFactor
说明:角度系数
输入:DecFactor
求值:57.295779513082323
Double DoubleE
说明:2e
输入:DoubleE
求值:5.43656365691809
Double DoubleEpsilon
说明:2ε
输入:DoubleEpsilon
求值:2E-06
Double DoublePI
说明:2π
输入:DoublePI
求值:6.2831853071795862
Double Epsilon
说明:误差因子ε
输入:Epsilon
求值:1E-06
Double HalfE
说明:e/2
输入:HalfE
求值:1.3591409142295225
Double HalfEpsilon
说明:ε/2
输入:HalfEpsilon
求值:5E-07
Double HalfND
说明:-0.5的标准正态分布概率值
输入:HalfND
求值:0.3085
Double HalfPI
说明:π/2
输入:HalfPI
求值:1.5707963267948966
Double MaxValue
说明:最大数值 1.7976931348623157E+308
输入:MaxValue
求值:1.7976931348623157E+308
Double MinValue
说明:最小数值 -1.7976931348623157E+308
输入:MinValue
求值:-1.7976931348623157E+308
Double NaN
说明:非数字0/0、∞/∞、sqrt(负数)、ln(负数)等
输入:NaN
Double NEpsilon
说明:-ε
输入:NEpsilon
求值:-1E-06
Double NInfinity
说明:负无穷大-∞
输入:NInfinity
求值:-∞
Double OneEpsilon
说明:1+ε
输入:OneEpsilon
求值:1.000001
Double OneHalfND
说明:-1.5的标准正态分布概率值
输入:OneHalfND
求值:0.0668
Double OneND
说明:-1的标准正态分布概率值
输入:OneND
求值:0.1587
Double OneNEpsilon
说明:1-ε
输入:OneNEpsilon
求值:0.999999
Double OneSigma
说明:1σ区间概率累计值
输入:OneSigma
求值:0.6826
Double PI
说明:圆周率π
输入:PI
求值:3.1415926535897931
Double PInfinity
说明:正无穷大∞
输入:PInfinity
求值:∞
Double Precision
说明:小数点精度位数
输入:Precision
求值:6
Double RadFactor
说明:弧度系数
输入:RadFactor
求值:0.017453292519943295
Double SqrdE
说明:e平方
输入:SqrdE
求值:7.3890560989306495
Double SqrdEpsilon
说明:ε平方
输入:SqrdEpsilon
求值:1E-12
Double SqrdPI
说明:π平方
输入:SqrdPI
求值:9.869604401089358
Double SqrtE
说明:e平方根
输入:SqrtE
求值:1.6487212707001282
Double SqrtEpsilon
说明:ε平方根
输入:SqrtEpsilon
求值:0.001
Double SqrtPI
说明:π平方根
输入:SqrtPI
求值:1.7724538509055159
Double ThreeHD
说明:-3的标准正态分布概率值
输入:ThreeHD
求值:0.0013
Double ThreeSigma
说明:3σ区间概率累计值
输入:ThreeSigma
求值:0.9974
Double TwoHalfND
说明:-2.5的标准正态分布概率值
输入:TwoHalfND
求值:0.0062
Double TwoND
说明:-2的标准正态分布概率值
输入:TwoND
求值:0.0228
Double TwoSigma
说明:2σ区间概率累计值
输入:TwoSigma
求值:0.9544
(2) 函数
Double ang(Double x, Double y)
说明:求点坐标(x,y)逆时针方向角度值
输入:ang(10,10)
求值:45
Double area(Double a, Double b, Double c)
说明:求边长为a,b,c三角形的面积
输入:area(10,10,10)
求值:43.301270189221931
Double avd(Double m, Double L, Double d)
说明:求长度L间距d的等分距,m为等距模式:-1最小间距,0近似间距,1最大间距
输入:avd(0,100,30)
求值:33.333333333333336
Double avn(Double m, Double L, Double d)
说明:求长度L间距d的等分数,m为等距模式:-1最小间距,0近似间距,1最大间距
输入:avn(0,100,30)
求值:3
Double cmb(Double n, Double r)
说明:求(n,r)组合值
输入:cmb(10,2)
求值:45
Double dist(Double x1, Double y1, Double x2, Double y2)
说明:求点(x1,y1)到点(x2,y2)的距离平方
输入:dist(0,0,10,10)
求值:14.142135623730951
Double distsqrd(Double x1, Double y1, Double x2, Double y2)
说明:求点(x1,y1)到点(x2,y2)的距离平方
输入:distsqrd(0,0,10,10)
求值:200
Double dx(Double r, Double a)
说明:求极坐标(r,a)在X轴投影值
输入:dx(100,30)
求值:86.602540378443877
Double dy(Double r, Double a)
说明:求极坐标(r,a)在Y轴投影值
输入:dy(100,30)
求值:50
Double gauss(Double x)
说明:高斯标准正态分布函数
输入:gauss(0.5)
求值:0.35206532676429952
Double gauss(Double x, Double u, Double e)
说明:高斯正态分布函数
输入:gauss(0.5,0,1)
求值:0.35206532676429952
Double gcd(Double a, Double b)
说明:计算两个整数的最大公约数
输入:gcd(20,12)
求值:4
Vect gcdeq(Double a, Double b, Double c)
说明:求解不定整数方程ax+by=c
输入:gcdeq(20,12,8)
求值:<-2,4>
Vect gcdex(Double a, Double b)
说明:计算整数对x,y,使得gcd(a,b)=ax+by
输入:gcdex(20,12)
求值:<-1,2>
Double lcm(Double a, Double b)
说明:计算两个整数的最小公倍数
输入:lcm(20,12)
求值:60
Double max(Double val1, Double val2)
说明:求最大值
输入:max(1,10)
求值:10
Double mid(Double d1, Double d2)
说明:求[d1,d2]区间的中值
输入:mid(0,10)
求值:5
Double min(Double val1, Double val2)
说明:求最小值
输入:min(1,10)
求值:1
Double norm(Double a)
说明:求[0,360]区间规格化角度值
输入:norm(390)
求值:30
Double pbl2(Double x)
说明:二次过渡函数(抛物线)
输入:pbl2(0.5)
求值:0.25
Double pbl3(Double x)
说明:三次过渡函数(抛物线)
输入:pbl3(0.5)
求值:0.5
Double pbl4(Double x)
说明:四次过渡函数(抛物线)
输入:pbl4(0.5)
求值:0.3125
Double pbla(Double x)
说明:圆弧过渡函数
输入:pbla(0.5)
求值:0.2632316107465042
Double pblaa(Double x)
说明:双圆弧过渡函数
输入:pblaa(0.5)
求值:0.5
Double pbls(Double x)
说明:正弦线过渡函数
输入:pbls(0.5)
求值:0.29289321881345254
Double pblss(Double x)
说明:双正弦线过渡函数
输入:pblss(0.5)
求值:0.5
Double pmt(Double n)
说明:求排列值
输入:pmt(10)
求值:3628800
Double pmt(Double n, Double r)
说明:求(n,r)排列值
输入:pmt(10,2)
求值:90
Double rang(Double x, Double y)
说明:求点坐标(x,y)逆时针方向弧度值
输入:rang(10,10)
求值:0.78539816339744828
Double rnorm(Double a)
说明:求[0,2π]区间规格化弧度值
输入:rnorm(10)
求值:3.7168146928204138
Double root(func(…) fx, Double a, Double b)
说明:用二分法求[a,b]区间指定函数的根,注意必须单调函数且必有根
输入:root(x=>2*x-1,-1,1)
求值:0.5
Double[] roots(func(…) fx, Double a, Double b)
说明:返回指定区间[a,b]内指定函数的根数组(最多5个)
输入:roots(x=>x*x-0.5,-1,1)
求值:[-0.70710678100585933, 0.70710678100585933]
Double spl(Double L, Double d, Double w)
说明:求长度L间距d等宽的螺旋钢筋总长
输入:spl(50,5,30)
求值:945.74462665601391
Double spl(Double L, Double d, Double w1, Double w2)
说明:求长度L间距d变宽w1~w2的螺旋钢筋总长
输入:spl(50,5,15,30)
求值:525.51295716469406
(3) 属性
Bool Double.ApproxZero
说明:判断数值是否近似于0(误差ε)
输入:x.ApproxZero
String Double.CharStr
说明:转换为单个字符串,如"A"
输入:x.CharStr
Bool Double.EqualZero
说明:判断数值是否约等于0(误差ε平方)
输入:x.EqualZero
Double Double.Factor
说明:获取数值整数部分的分解因子
输入:x.Factor
Double[] Double.Factors
说明:获取数值整数部分的分解因子数组
输入:x.Factors
Bool Double.IsEven
说明:判断数值整数部分是否为偶数
输入:x.IsEven
Bool Double.IsInvalid
说明:判断数值是否无效(无穷大或非数字)
输入:x.IsInvalid
Bool Double.IsOdd
说明:判断数值整数部分是否为奇数
输入:x.IsOdd
Bool Double.IsPrime
说明:判断数值整数部分是否为质素
输入:x.IsPrime
Bool Double.IsValid
说明:判断数值是否有效
输入:x.IsValid
String Double.LevelStr
说明:转换为3位小数点标高串,如4.250
输入:x.LevelStr
Bool Double.NearZero
说明:判断数值是否靠近于0(误差ε平方根)
输入:x.NearZero
Double Double.Odd
说明:返回整数部分0/1
输入:x.Odd
String Double.ScaleStr
说明:转换为比例格式标高串,如1:4
输入:x.ScaleStr
(4) 方法
Bool Double.Approxes(Double d2)
说明:判断数值是否近似(误差ε)
输入:x.Approxes(10)
Bool Double.Betweens(Double a, Double b)
说明:判断数值是否∈[a,b]
输入:x.Betweens(0,10)
Bool Double.Betweins(Double a, Double b)
说明:判断数值是否∈[a,b)
输入:x.Betweins(0,10)
Bool Double.Betwiens(Double a, Double b)
说明:判断数值是否∈(a,b]
输入:x.Betwiens(0,10)
Bool Double.Betwiins(Double a, Double b)
说明:判断数值是否∈(a,b)
输入:x.Betwiins(0,10)
Bool Double.Equals(Double d2)
说明:判断数值是否约等(误差ε平方)
输入:x.Equals(10)
Double Double.Interplate(Double d2, Double t)
说明:计算线性插值
输入:x.Interplate(10,0.5)
Double Double.Interplate(Double d2, ILambada func, Double t)
说明:计算自定义函数插值
输入:x.Interplate(10,x=>2*x*x-x,0.5)
Double Double.Interplate(Double d2, Object mode, Double t)
说明:按模式进行插值(mode=0/1线性,=10/11三次抛物线,=20/21四次抛物线,=30/31二次抛物线,=40/41圆弧,=50/51双圆弧,=60/61正弦线,=70/71双正弦线,=80/81常量线)
输入:x.Interplate(10,0,0.5)
Bool Double.Nears(Double d2)
说明:判断数值是否靠近(误差ε平方根)
输入:x.Nears(10)
Bool Double.Nears(Double d2, Double nearness)
说明:判断数值是否靠近(指定误差)
输入:x.Nears(10,0.001)
String Double.ToShortStr(Double delta)
说明:转换为短字符串,保持指定精度
输入:x.ToShortStr(0.001)
String Double.ToStr(String format)
说明:转换为指定格式字符串
输入:x.ToStr('f1')
声明:原创文章欢迎转载,但请注明出处,https://www.cnblogs.com/ShoneSharp。
软件: S#语言编辑解析运行器,运行环境.NET 4.0,绿色软件,单个EXE直接运行,无副作用。网盘下载链接为https://pan.baidu.com/s/1dF4e08p