matlab基础功能实践
一、matlab在高等数学中的应用(《数学建模算法与应用》P453)
1、求极限
syms x
b=limit((sqrt(1+x^2)-1)/(1-cos(x)))
syms x a
b=limit((1+a/x)^2,x,inf)
2、求导数
syms x
dy=diff(log((x+2)/(1-x)),3)
dy=simplify(dy) %对符号函数进行化简
pretty(dy) %分数线居中显示,这部一般不需要
差分:
a=[0,0.5,2,4];
da=diff(a)
3、求极值
syms x
y=x^3+6*x^2+8*x-1;
dy=diff(y);
dy_zero=solve(dy) %表达式类型
dy_zero_num=double(dy_zero) %变成数值类型
ezplot(y)
syms x
y=x^3+6*x^2+8*x-1;
dy=diff(y);
dy_zero=solve(dy) %表达式类型
dy_zero_num=double(dy_zero) %变成数值类型
ezplot(y) %符号曲线画图
4、求积分
不定积分:
syms x
I=int(1/(1+sqrt(1-x^2)))
pretty(I)
定积分 (符号解、数值解):
符号解:
syms x
I=int(cos(x)*cos(2*x),-pi/2,pi/2)
数值解:
I=quadl(@(t)(t-3*t.^2+2*t.^3).^(-1/3),eps,0.5)
(积分上下限不能为inf,可以不变换而直接设一个很大的数
syms t %不加也可以
I=quadl('(t-3*t.^2+2*t.^3).^(-1/3)',eps,0.5) %后面两项分别为积分上下限,eps认为是0
二重数值积分:
I=dblquad(@(x,y)sqrt(1-x.^2-y.^2).*(x.^2+y.^2<=x),0,1,-0.5,0.5)
(matlab中的log就是ln
三重数值积分:
fun3=@(x,y,z)z.^2*log(x.^2+y.^2+z.^2+1)./(x.^2+y.^2+z.^2+1).*(z>=0&...
z<=sqrt(1-x.^2-y.^2)); %...是续航符
I=triplequad(fun3,-1,1,-1,1,0,1)
注意把范围不等式点乘一下,最后的上下限只能为数字
5、级数求和
级数的上下限可以带inf
syms n
f1=(2*n-1)/2^n;
s1=symsum(f1,n,1,inf)
syms n
f2=1/n^2
s2=symsum(f2,n,1,inf)
二、matlab绘图命令(《数学建模算法与应用P449》)
1、二维绘图命令
title('my title')
xlabel('x-axis label')
ylabel('y-scid label')
text(x,y,'text for annotation')
gtext('text for annotation')
grid %网格的打开与关闭
subplot(r,c,p)
plot(t,[x1,x2,x3])
plot(t1,x1,t2,x2,t3,x3)
plot(x,y,'r-*')
2、显函数、符号函数或隐函数的绘图
function y=Afun1(x);
if x<1
y=x+1;
else
y=1+1/x;
end fplot('Afun1',[-3,3])
匿名函数:
Afun2=@(x)(x+1)*(x<1)+(1+1/x)*(x>=1);
fplot(Afun2,[-3,3]);
符号函数:
ezplot('tan(x)')
ezplot('x^2+y^2/4=1')
ezplot可以用来绘制隐函数
3、三维图形
三维曲线图:plot3
三维网格图:mesh
三维表面图:surf
1)三维曲线:
t=0:pi/50:10*pi
plot3(sin(t),cos(t),t);
xlabel('sin(t)'),ylabel('cos(t)'),zlabel('t')
2)网格图
clc,clear
x=-3:0.1:3;y=-5:0.1:5;
[x,y]=meshgrid(x,y); %生成网格数据,自变量
z=(sin(x.*y)+eps)./(x.*y+eps); %为避免0/0,分子分母都加eps
mesh(x,y,z);
3)表面图
[x,y]=meshgrid([-3:0.2:3]);
z=(sin(x.*y)+eps)./(x.*y+eps);
surf(x,y,z);
4)旋转曲面(绕x轴旋转一周所得的图像
x=0:10:600;
[X,Y,Z]=cylinder(30*exp(-x/400).*sin((x+25*pi)/100)+130);
surf(X,Y,Z)
r为母线,n为沿周长的格数
alpha=[0:0.1:2*pi]';
beta=0:0.1:2*pi;
x=4*cos(alpha)*ones(size(beta));
y=(5+4*sin(alpha))*cos(beta);
z=(5+4*sin(alpha))*sin(beta);
surf(x,y,z)
emmm,上面这段代码不太理解。。。
下面这段是参数方程的常用画图方法,用函数句柄以及ezsurf完成
x=@(alpha,beta)4*cos(alpha);
y=@(alpha,beta)(5+4*sin(alpha)).*cos(beta);
z=@(alpha,beta)(5+4*sin(alpha)).*sin(beta);
ezsurf(x,y,z)
5、其他二次曲面
(1)旋转单叶双曲面
x=@(s,t)3*sec(s).*cos(t);
y=@(s,t)3*sec(s).*sin(t);
z=@(s,t)2*tan(s);
ezmesh(x,y,z);
(2)旋转双叶双曲面
x=@(s,t)3*sec(s);
y=@(s,t)3*tan(s).*cos(t);
z=@(s,t)2*tan(s).*cos(t);
ezmesh(x,y,z);
(3)抛物柱面
ezsurf(@(y,z)y.^2,50);
(4)椭圆锥面
x=@(s,t)3*tan(s).*cos(t);
y=@(s,t)2*tan(s).*sin(t);
z=@(s,t)tan(s);
ezsurf(x,y,z);
(5)椭球面
ellipsoid(0,0,0,3,2,sqrt(6));
使用matlab内置的绘制椭球的函数 ellipsoid(xc,yc,zc,xr,yr,zr,n),其中:
xc,yc,zc分别表示椭球中心的x,y,z坐标。
xr,yr,zr分别表示椭球x,y,z半轴的长度。
n表示绘图时,沿着经度和纬度方向划分的曲面片数量,n越大则数据越密集,曲面越光滑。
(6)马鞍面
ezsurf(@(x,y)x.*y);
(7)椭圆柱面
x=@(s,t)3*cos(s);
y=@(s,t)2*sin(s);
z=@(s,t)t;
ezmesh(x,y,z)
4、3-D可视化图形
[x,y,z,v]=flow;
isosurface(x,y,z,v);
x=1:20;y=1:10;z=-10:10;
[x,y,z]=meshgrid(x,y,z);
v=x.^2.*y.*(z+1);
isosurface(x,y,z,v);
isosurface与ezplot对应,可以绘制三维隐函数图像。ezmesh与ezsurf必须显函数或转化为参数方程。isosurface默认值不确定。
isosurface与ezmesh、ezsurf的作用相同,但是表达式不同。
matlab基础功能实践的更多相关文章
- Matlab - 基础知识
Matlab R2016a完全自学一本通 记在前面: (1)函数中:dim=1 按列:dim=2 按行 (2)这本书很垃圾,不建议买. (3)在数据库连接中,用两个单引号表示字符串,千万不能用双引号 ...
- MSF基础攻击实践报告
MSF基础攻击实践 MSF的六个模块:exploit,encoder,payload,aux,post,nops exploit——渗透攻击模块 测试者利用它来攻击一个系统,程序,或服务,以获得开发者 ...
- 数字图像处理学习笔记之一 DIP绪论与MATLAB基础
写在前面的话 数字图像处理系列的学习笔记是作者结合上海大学计算机学院<数字图像处理>课程的学习所做的笔记,使用参考书籍为<冈萨雷斯数字图像处理(第二版)(MATLAB版)>,同 ...
- Matlab--从入门到精通(chapter2 matlab 基础知识)
Chapter2 Matlab 基础知识 1.基本数学运算符号 注:矩阵的右除是一般意义的除法,但是左除具有对称意义,即A./B=B.\A 2. 命令行中的常用标点 3.常见的操作命令 4.输出数据显 ...
- Matlab高级教程_第一篇:Matlab基础知识提炼_02
第三节:变量 正如其他编程软件一样. 都是通过变量来传递和交换数据的,这是基础.按照<MATLAB基础知识提炼>这篇文章先介绍变量比较合适.编程语言不外乎包括两部分:数据和结构.应该先把数 ...
- Matlab高级教程_第一篇:Matlab基础知识提炼_01
第一篇:Matlab基础知识提炼: 这一篇主要用系统和提炼性的语言对Matlab基础知识进行总结,主要适用于有语言基础的学习者.尽量不讲废话. 第一部分:Matlab是什么? 1 Matlab是Mat ...
- 信号与系统实验序章0——MATLAB基础命令入门
本次开启新的系列,关于用Matlab实现常见信号和函数的生成和变换. 同时如果没有MATLAB基础,那么可以跟着本文一步一步学习Matlab的相关操作,本文旨在记录在信号与系统课程中MATLAB的学习 ...
- 【matlab 基础篇 02】基础知识一键扫盲,看完即可无障碍编程(超详细+图文并茂)
博主快速入门matlab,系统地整理一遍,如何你和我一样是一个新手,那么此文很适合你: 本人能力有限,文中难免有错误和纰漏之处,请大佬们不吝赐教 创作不易,如果本文帮到了您: 请帮忙点个赞
- machine learning基础与实践系列
由于研究工作的需要,最近在看机器学习的一些基本的算法.选用的书是周志华的西瓜书--(<机器学习>周志华著)和<机器学习实战>,视频的话在看Coursera上Andrew Ng的 ...
随机推荐
- WPF中如何在文本外面加虚线外框
WPF中如何在文本外面加虚线外框 昨天突然被问到如何在wpf里面给一段文本加个虚线外框,由于有一段时间没玩wpf了,一时还真没想出来,虽然大概有个思路,但是也不保证正确.今天回到家,闲着没事情也就随便 ...
- ipconfig | find /i "ipv4"
C:\Users\Bob>ipconfig|find /i "IPv" 本地链接 IPv6 地址. . . . . . . . : fe80::d495:6e3:6368 ...
- The RK3066/RK30SDK Android 4.2 audio codec has a bug!
在文件kernel/sound/soc/soc-core.c中,函数soc_bind_dai_link引入了一个新定义的宏CODEC_NAME_CMP,这个新玩意导致了后面的strcpy(p_code ...
- Mysql ERROR 145 (HY000)
问题:今天Mysql数据库异常关闭,起来之后感觉可以了. 但是运行业务数据的时间就类似如下的错误 ERROR 145 (HY000) at line 34: Table './database_nam ...
- vs 2005/2008/2010 ATL ActiveX控件显示XP风格
vs 2005/2008/2010 ATL ActiveX控件在IE浏览器中控件显示的是原始的风格,要显示XP风格只要进行以下操作 一.在Stdafx.h中增加下以内容 #if defined _M_ ...
- LeetCode OJ:Delete Node in a Linked List(链表节点删除)
Write a function to delete a node (except the tail) in a singly linked list, given only access to th ...
- Git学习--创建版本库
什么是版本库呢?版本库又名仓库,英文名repository,你可以简单理解成一个目录,这个目录里面的所有文件都可以被Git管理起来,每个文件的修改.删除,Git都能跟踪,以便任何时刻都可以追踪历史,或 ...
- 2.mysql优化---增删改优化
整理自互联网 补充知识点:操作数据语句优化的认识 通常情况下,当访问某张表的时候,读取者首先必须获取该表的锁,如果有写入操作到达,那么写入者一直等待读取者完成操作(查询开始之后就不能中断,因此允许读取 ...
- THUWC2017
100+20+20=140 还是很菜... T1 在美妙的数学王国中畅游 一棵树每个点有一个函数(sin,exp,一次函数),支持加边,删边,单点修改,查询一条路径在 $x$ 处的点值和 sol: 题 ...
- 转载:关于消息队列的使用----ActiveMQ,RabbitMQ,ZeroMQ,Kafka,MetaMQ,RocketMQ
转载: http://blog.csdn.net/konglongaa/article/details/52208273