正剧开始:
星历2016年04月15日 15:32:35, 银河系厄尔斯星球中华帝国江南行省。
[工程师阿伟]正在和[机器小伟]一起研究[三角初等变换]。
if (1) {
var mathText = new MathText();
var s = [
'和角、差角公式',
'sin(A+B) = sinAcosB+sinBcosA',
'sin(A-B) = sinAcosB-sinBcosA',
' ',
'cos(A+B) = cosAcosB-sinAsinB',
'cos(A-B) = cosAcosB+sinAsinB',
' ',
'tan(A+B) = (tanA+tanB)/(1-tanA*tanB)',
'tan(A-B) = (tanA-tanB)/(1+tanA*tanB)',
];
var x =40, y=40;
var r1 = 40;
var len = s.length;
for (var i = 0; i < len; i++) {
if (s[i] == '') {
if (x < 100) {
x += 300;
y-=r1*3;
}
else {
x = 20;
y += r1;
}
}
else {
mathText.print(s[i], x, y);
y+=r1;
}
}
}
var s = [
'倍角公式',
'sin2a = 2sinacosa',
'cos2a = cos^[2]a-sin^[2]a',
'tan2a = 2tana/(1-tan^[2]a)',
' ',
'cos2a = 2cos^[2]a-1',
'cos2a = 1-2sin^[2]a',
];
var s = [
'半角公式',
'sin(a/2) = ±((1-cosa)/2)^[0.5]',
'cos(a/2) = ±((1+cosa)/2)^[0.5]',
'tan(a/2) = ±((1-cosa)/(1+cosa))^[0.5] ',
'= sina/(1+cosa) ',
'= (1-cosa)/sina',
];
以前这种公式还有很多,都是前人的经验和智囊的结晶,
可是时过境迁哪,现在不管怎么算,哪比得上先求出角度,
再直接算来得准和快呢。所以[人叫板老师]也觉得这些公式
点到为止就行了。
当然,小伟还是做了一个工具,一般来说应该够用了:
>>>
sin45° = 0.707
cos45° = 0.707
tan45° = 1.0
sin30° = 0.5
cos30° = 0.866
tan30° = 0.577
sin75° = 0.966
cos75° = 0.259
tan75° = 3.732
sin15° = 0.259
cos15° = 0.966
tan15° = 0.268
sin90° = 1.0
cos90° = 0.0
tan90° = 1.633123935319537e+16
sin135° = 0.707
cos135° = -0.707
tan135° = -1.0
sin22.5° = 0.383
cos22.5° = 0.924
tan22.5° = 0.414
#三角恒等式
def tmp(angle1, angle2 = 0):
task = [
#第一个角的三角函数值
['sin', angle1],
['cos', angle1],
['tan', angle1],
#第二个角的三角函数值
['sin', angle2],
['cos', angle2],
['tan', angle2],
#和角公式
['sin', angle1+angle2],
['cos', angle1+angle2],
['tan', angle1+angle2],
#差角公式
['sin', angle1-angle2],
['cos', angle1-angle2],
['tan', angle1-angle2],
#二倍角
['sin', angle1*2],
['cos', angle1*2],
['tan', angle1*2],
#三倍角
['sin', angle1*3],
['cos', angle1*3],
['tan', angle1*3],
#半角
['sin', angle1/2],
['cos', angle1/2],
['tan', angle1/2]
];
triFun(task);
if __name__ == '__main__':
tmp(45, 30);
>>>
5400
[0.0002908882045634, 0.00058178, 0.00087266, 0.00116355, 0.00145444, 0.00174533, 0.00203622, 0.0023271, 0.00261799, 0.00290888, 0.00319976, 0.00349065, 0.00378154, 0.00407242, 0.00436331, 0.00465419, 0.00494508, 0.00523596, 0.00552685, 0.00581773, 0.00610861, 0.0063995, 0.00669038, 0.00698126, 0.00727214, 0.00756302, 0.0078539, 0.00814478, 0.00843566, 0.00872654, 0.00901741, 0.00930829, 0.00959916, 0.00989004, 0.01018091, 0.01047178, 0.01076266, 0.01105353, 0.0113444, 0.01163527, 0.01192613, 0.012217, 0.01250787, 0.01279873, 0.0130896, 0.01338046, 0.01367132, 0.01396218, 0.01425304, 0.0145439, 0.01483475, 0.01512561, 0.01541646, 0.01570732, 0.01599817, 0.01628902, 0.01657987, 0.01687072, 0.01716156, 0.01745241, 0.01774325, 0.01803409, 0.01832493, 0.01861577, 0.01890661, 0.01919744, 0.01948828, 0.01977911, 0.02006994, 0.02036077, 0.02065159, 0.02094242, 0.02123324, 0.02152407, 0.02181489, 0.0221057, 0.02239652, 0.02268733, 0.02297815, 0.02326896, 0.02355976, 0.02385057, 0.02414138, 0.02443218, 0.02472298, 0.02501378, 0.02530457, 0.02559537, 0.02588616, 0.02617695, 0.02646774, 0.02675852, 0.0270493, 0.02734008, 0.02763086, 0.02792164, 0.02821241, 0.02850318, 0.02879395, 0.02908472]
#[0, 90]度角范围内正弦三角函数表
def triTable():
import math;
#1'角的三角函数值
sin1 = 0.0002908882045634;
cos1 = math.sqrt(1-sin1*sin1);
#90度内
sin = sin1;
cos = cos1;
#存放值
array = [];
array.append(sin);
while (sin < 1):
sin = sin1*cos+cos1*sin;
cos = math.sqrt(1-sin*sin);
array.append(round(sin, 8));
#每次1'角递增,array数组应有元素90*60=5400个
print(len(array));
#看看前100个元素
print(array[:100]);
###
# @usage 三角函数调用封装
# @author mw
# @date 2016年04月05日 星期二 09:36:50
# @param
# @return
#
###
def triFun(task, prec = 3):
#需要计算的任务
#输入量为角度制,依次为度,分,秒
#可输出显示度、分、秒的表达式
#用于计算锐角三角函数
#对于角度变换,还没有经过测试
#以后可扩展添加其它多种数学函数
size = len(task);
result = [];
import math;
precision = max(prec, 3);
for i in range(size):
if task[i][0] == 'sin' or task[i][0] == 'cos' or task[i][0] == 'tan' \
or task[i][0] == 'cot':
taskNew = task[i];
part1 = angleTransfer(taskNew[1:]);
len1 = len(part1);
taskNew = [taskNew[0]];
for n in range(len1):
taskNew.append(part1[n]);
size_1 = len(task[i]);
angle = 0;
if size_1 == 2:
angle = taskNew[1];
elif size_1 == 3:
angle = taskNew[1]+taskNew[2]/60;
elif size_1 == 4:
angle = taskNew[1]+taskNew[2]/60+taskNew[3]/3600;
angle = angle/180*math.pi;
if task[i][0] == 'sin':
s = '';
if size_1 == 2:
s = task[i][0]+str(task[i][1])+'°';
elif size_1 == 3:
s = task[i][0]+str(task[i][1])+'°'+str(task[i][2])+'\'';
elif size_1 == 4:
s = task[i][0]+str(task[i][1])+'°'+str(task[i][2])+'\''+str(task[i][3])+'″';
s += ' = ';
s += str(round(math.sin(angle), precision));
s += '\n';
result.append(s);
elif task[i][0] == 'cos':
s = '';
if size_1 == 2:
s = task[i][0]+str(task[i][1])+'°';
elif size_1 == 3:
s = task[i][0]+str(task[i][1])+'°'+str(task[i][2])+'\'';
elif size_1 == 4:
s = task[i][0]+str(task[i][1])+'°'+str(task[i][2])+'\''+str(task[i][3])+'″';
s += ' = ';
s += str(round(math.cos(angle), precision));
s += '\n';
result.append(s);
elif task[i][0] == 'tan':
s = '';
if size_1 == 2:
s = task[i][0]+str(task[i][1])+'°';
elif size_1 == 3:
s = task[i][0]+str(task[i][1])+'°'+str(task[i][2])+'\'';
elif size_1 == 4:
s = task[i][0]+str(task[i][1])+'°'+str(task[i][2])+'\''+str(task[i][3])+'″';
s += ' = ';
s += str(round(math.tan(angle), precision));
s += '\n';
result.append(s);
elif task[i][0] == 'cot':
s = '';
if size_1 == 2:
s = task[i][0]+str(task[i][1])+'°';
elif size_1 == 3:
s = task[i][0]+str(task[i][1])+'°'+str(task[i][2])+'\'';
elif size_1 == 4:
s = task[i][0]+str(task[i][1])+'°'+str(task[i][2])+'\''+str(task[i][3])+'″';
s += ' = ';
s += str(round(1/math.tan(angle), precision));
s += '\n';
result.append(s);
else:
if task[i][0] == 'asin':
s = '';
s = task[i][0]+str(task[i][1])+' = ';
res = math.asin(task[i][1])/math.pi*180;
if res < 0:
s += '-';
absres = abs(res);
s += str(math.floor(absres))+'°'+str(math.floor(absres*60)%60)+'\''+str(round(absres*3600)%60)+'″';
s += '\n';
result.append(s);
elif task[i][0] == 'acos':
s = '';
s = task[i][0]+str(task[i][1])+' = ';
res = math.acos(task[i][1])/math.pi*180;
if res < 0:
s += '-';
absres = abs(res);
s += str(math.floor(absres))+'°'+str(math.floor(absres*60)%60)+'\''+str(round(absres*3600)%60)+'″';
s += '\n';
result.append(s);
elif task[i][0] == 'atan':
s = '';
s = task[i][0]+str(task[i][1])+' = ';
res = math.atan(task[i][1])/math.pi*180;
if res < 0:
s += '-';
absres = abs(res);
s += str(math.floor(absres))+'°'+str(math.floor(absres*60)%60)+'\''+str(round(absres*3600)%60)+'″';
s += '\n';
result.append(s);
elif task[i][0] == 'acot':
s = '';
s = task[i][0]+str(task[i][1])+' = ';
res = 90-math.atan(task[i][1])/math.pi*180;
if res < 0:
s += '-';
absres = abs(res);
s += str(math.floor(absres))+'°'+str(math.floor(absres*60)%60)+'\''+str(round(absres*3600)%60)+'″';
s += '\n';
result.append(s);
else:
pass;
size = len(result);
for i in range(size):
print(result[i]);
return result;
#把任意角转化成[0, 360]度范围内的角度。
#传入[度, 分,秒]
#传出[度, 分,秒]
def angleTransfer(a):
#传入的角度可以只有度,也可也有分,也可以有秒
#这样会造成数组的大小变动
accuracy = len(a);
if (a[0] < 0):
if accuracy == 2:
if (a[1] != 0):
a[0]-=1;
a[1] = 60-a[1];
elif accuracy == 3:
if (a[1] != 0 or a[2] != 0):
a[0] -=1;
if (a[2] != 0):
a[1] = 59-a[1];
a[2] = 60-a[2];
else:
a[1] = 60-a[1];
while a[0] < 0:
a[0]+=360;
elif (a[0] >= 360):
while a[0] >= 360:
a[0]-=360;
return a;