MATLAB如何计算三角函数?
主要是利用利用数学函数中的反三角函数。
1、头文件math.h中宏定义的是M_PI
#define M_PI 3.14159265358979323846
2、这是一个在库文件头文件math.h中的定义的宏,实际上就是圆周率π的一个近似值,约等于3.1415
下面是一个求三角函数sin(a)值的一个程序,这里就用到了M_PI这个宏。由于这里的a要求是弧度,所以对于输入的角的度数做了相应的转换。
#include <stdio.h>
#include <math.h>
int main()
{
int degree;
printf("Please input angle degree:
");fflush(NULL);
scanf("%d",°ree);
printf("sin(%d)=%f
",degree,sin(M_PI*degree/180));
return 0;
}
因为:头文件math.h中宏定义的是M_PI
扩展资料:
关于上述提到的M_PI
.M_PI 是一个宏定义,圆周率的定义
#define M_PI 3.14159265358979323846
此宏定义和编译器有关,TC中M_PI宏就定义在<math.h>里面。
但vc的<math.h>中没有了M_PI的宏定义。
常见宏定义:
#include<bits/stdc++.h>
#define _USE_MATH_DEFINES
using namespace std;
int main()
{
cout<<M_PI<<endl;
cout<<M_E<<endl;
return 0;
}
#if defined(_USE_MATH_DEFINES) && !defined(_MATH_DEFINES_DEFINED)
#define _MATH_DEFINES_DEFINED
#define M_E 2.71828182845904523536
#define M_LOG2E 1.44269504088896340736
#define M_LOG10E 0.434294481903251827651
#define M_LN2 0.693147180559945309417
#define M_LN10 2.30258509299404568402
#define M_PI 3.14159265358979323846
#define M_PI_2 1.57079632679489661923
#define M_PI_4 0.785398163397448309616
#define M_1_PI 0.318309886183790671538
#define M_2_PI 0.636619772367581343076
#define M_2_SQRTPI 1.12837916709551257390
#define M_SQRT2 1.41421356237309504880
#define M_SQRT1_2 0.707106781186547524401
#endif /* _USE_MATH_DEFINES */
绛旓細鐢╩atlab瑙d簩鍏冧竴娆涓夎鍑芥暟鏂圭▼鐨勮В鍐虫柟娉曪細syms x y s=solve(A==sin(x)+sin(y),B==cos(x)-cos(y),'x,y');x1=s.x(3);x2=s.x(4);y1=s.y(3);y2=s.y(4); %璇存槑锛寈(1)锛寈(2)鍜寉(1)锛寉(2)涓嶆槸浣犻渶瑕佺殑琛ㄨ揪寮忥紝浣嗕笉鍚岃蒋浠跺彲鑳戒細涓嶄竴鏍 Z=xlsread('Data.xlsx'...
绛旓細鐢╩atlab姹甯涓夎鍑芥暟鐨勪笁鍏冩柟绋嬬粍锛屽彲浠ョ敤fsolve()鍑芥暟姹鍑哄叾杩戜技鍊笺傚叾姹傝В鏂规硶 [x,fval] = fsolve(solve_fun,x0)鍏朵腑锛歴olve_fun鈥斺斾笁鍏冩柟绋嬬粍鑷畾涔夊嚱鏁帮紝x0鈥斺斿垵鍊硷紝x鈥斺斿彉閲忓硷紝fval鈥斺旂瓑寮忓 >> x0=[0.4447 0.6154 0.7919];>> solve_fun=@(x)[x(1)*cos(x(2)*pi...
绛旓細鍙互绠楃殑锛屼綘鐨剆ina瑕佹敼鎴恠in(a)锛matlab鎵嶄細璁ゅ悓锛岀劧鍚庢柊鐨勭増鏈琺atlab涓嶅缓璁綘鐩存帴浣跨敤绗﹀彿鍙橀噺锛岃屾槸瑕佸厛鐢虫槑锛屾墍浠ヤ細鏈変竴浜涜鍛婏紝浣嗘槸鏈璁$畻缁撴灉锛屽涓嬶細[a,t]=solve('2600*sin(a)=9.8*t','1300*1300*sin(2*a)=9.8*111770')缁撴灉W涓猴細a = 1.2182307396525019002681606902101 0....
绛旓細瀵逛簬鍑芥暟璇佹槑鍙互浣跨敤绗﹀彿杩愮畻杩涜锛歴yms x % 瀹氫箟绗﹀彿鍙橀噺 L = tan(x)^2+cot(x)^2; % 宸﹁竟椤 R = 2*(3+cos(4*x))/(1-cos(4*x))锛 % 鍙宠竟椤 F = L-R锛 % 宸﹀彸浣滃樊 flag = simplify(F)锛 % 鍖栫畝锛屽鏋渇lag涓0鍒欏緱鎰忚瘉鏄 ...
绛旓細瀵逛簬姝涓夎鍑芥暟寮忥紝鍙互杩欐牱鏉璁$畻銆>>A=@(x)5*sin(2*x)^2; %瀹氫箟A锛坸锛>>A(10)杩愯缁撴灉 ans = 4.1673
绛旓細MATLAB涓鐨勬寮︾Н鍒嗗嚱鏁帮紝鍙敤sinint(x)鏉璁$畻銆備緥濡傦紝x=25鏃剁殑姝e鸡绉垎鍑芥暟鍊笺>> x=25;sinint(x)ans=1.5315 2. MATLAB鐨鍩烘湰鏁版嵁鍗曚綅鏄煩闃碉紝瀹冪殑鎸囦护琛ㄨ揪寮忎笌鏁板銆佸伐绋嬩腑甯哥敤鐨勫舰寮忓崄鍒嗙浉浼硷紝鏁鐢∕ATLAB鏉ヨВ绠楅棶棰樿姣旂敤C锛孎ORTRAN绛夎瑷瀹屾垚鐩稿悓鐨勪簨鎯呯畝鎹峰緱澶氥3. matlab涓笁瑙掑嚱鏁sin銆乧os銆
绛旓細鎴戠敤solve姹傝В 鍑虹幇x绌哄 浜庢槸鎴戣寰楄繖棰樻牴鏈棤瀹炴暟瑙 浜庢槸鎴戠敤鐢诲浘姹傚 >> syms a h x >> a=10;h=10;x=0:0.1:2*pi;>> y=h*x+h*sin(x)+a*cos(x);>> plot(x,y)鍙互鍙戠幇 鍦╗0,2pi]鑼冨洿鍐 y鐨勭殑鏋佸皬鍊间负10 鏁呭湪鏃犲疄瑙 ...
绛旓細w=solve((-w*w+1+4*w*sin(w)+4*cos(w))*(cos(w)+w*sin(w)+cos(2*w))+(2*w+4*w*cos(w)-4*sin(w))*(w*cos(w)-sin(w)-sin(2*w)),'w')缁撴灉 w = 0.44681413913439468425554021128527e-41-1.8253942094612067195429567400919*i 灏辨槸w=0-1.8254*i 涓夎鍑芥暟鐨勮В骞朵笉鍞竴锛...
绛旓細浣犺瘯涓涓媠in(30*pi/180)鍚э紝matlab閲岀殑涓夎鍑芥暟鍏ㄩ儴鏄敤寮у害鐨勩
绛旓細syms a f = g - 35.62;solve('f==0', 'a');娉細g鏄瓑鍙峰悗闈㈢殑涓澶т覆