前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >matlab画心形曲线_笛卡尔心形曲线方程

matlab画心形曲线_笛卡尔心形曲线方程

作者头像
全栈程序员站长
发布2022-11-02 09:58:22
1K0
发布2022-11-02 09:58:22
举报
文章被收录于专栏:全栈程序员必看

MATLAB 心形曲线


基本知识

clc;指令可以清除屏幕,所以你可以通过clc指令来清理屏幕

代码语言:javascript
复制
clc

hold on;指令可以将画的图连起来

代码语言:javascript
复制
hold on

clear;清除之前所留的定义

代码语言:javascript
复制
clear

笛卡尔爱心曲线

代码语言:javascript
复制
ezpolar('1-sin(t)')
matlab画心形曲线_笛卡尔心形曲线方程
matlab画心形曲线_笛卡尔心形曲线方程
代码语言:javascript
复制
a=1;
theta = 0 : 0.01 : 2 * pi;
r = a*(1 - sin(theta));
polar(theta, r, '-r');
matlab画心形曲线_笛卡尔心形曲线方程
matlab画心形曲线_笛卡尔心形曲线方程

特别定制


第一种实现方式

代码语言:javascript
复制
clear
t=-pi:pi/100:pi;

r=abs(t);
x=r.*sin(t);
y=r.*cos(t);
plot(x,y)
title('I love you.')
axis equal
matlab画心形曲线_笛卡尔心形曲线方程
matlab画心形曲线_笛卡尔心形曲线方程

方法二:grid on可以加上网格,可以通过删除下面代码中的grid on删除表格

代码语言:javascript
复制
clear
x=-2:0.01:2;
y=sqrt(2*sqrt(x.^2)-x.^2);
z=asin(abs(x)-1)-pi./2;plot(x,y);
grid on;
hold on;
plot(x,z);
axis equal;
matlab画心形曲线_笛卡尔心形曲线方程
matlab画心形曲线_笛卡尔心形曲线方程

fill语句填色

代码语言:javascript
复制
clear
x=-2:0.01:2;
y=sqrt(2*sqrt(x.^2)-x.^2);
z=asin(abs(x)-1)-pi./2;plot(x,y);
grid on;
hold on;
plot(x,z);
axis equal;
fill(x,y,'r')
fill(x,z,'r')
matlab画心形曲线_笛卡尔心形曲线方程
matlab画心形曲线_笛卡尔心形曲线方程

方案3

代码语言:javascript
复制
t=0:0.1:2*pi;
x=16*sin(t).^3;
y=13*cos(t)-5*cos(2*t)-2*cos(3*t)-cos(4*t);
figure;
axis([-10,10,-10,10]);
plot(x,y)
matlab画心形曲线_笛卡尔心形曲线方程
matlab画心形曲线_笛卡尔心形曲线方程

axis off 可以关闭坐标轴,进行动态绘图

代码语言:javascript
复制
clear
t=0:0.1:2*pi;
x=16*sin(t).^3;
y=13*cos(t)-5*cos(2*t)-2*cos(3*t)-cos(4*t);
figure;
h = plot(x(1),y(1),'r');
axis([-20,20,-20,20]);
axis off

for idx = 2:length(t)
    h.XData(idx) = x(idx);
    h.YData(idx) = y(idx);
    drawnow
end

如果你需要保存到本地的话,你需要进一步添加imwrite保存到本地,delayTime延时画图

matlab画心形曲线_笛卡尔心形曲线方程
matlab画心形曲线_笛卡尔心形曲线方程
代码语言:javascript
复制
clear
t=0:0.1:2*pi;
x=16*sin(t).^3;
y=13*cos(t)-5*cos(2*t)-2*cos(3*t)-cos(4*t);
figure;
h = plot(x(1),y(1),'r');
axis([-20,20,-20,20]);
axis off
[A,map] = rgb2ind(frame2im(getframe),256);
imwrite(A,map,'love.gif','LoopCount',inf,'DelayTime',0.1);
for idx = 2:length(t)
    h.XData(idx) = x(idx);
    h.YData(idx) = y(idx);
    drawnow
%这两句话是为了在本地保存的图片也能显示出来,保存地址默认
    [A,map] = rgb2ind(frame2im(getframe),256);
    imwrite(A,map,'love.gif','WriteMode','append','DelayTime',0.1);  
end
matlab画心形曲线_笛卡尔心形曲线方程
matlab画心形曲线_笛卡尔心形曲线方程

最终实现版本


进一步动态实现 (借用movie函数)再进行本地保存改进

https://blog.csdn.net/lpsl1882/article/details/50806694?depth_1-utm_source=distribute.pc_relevant.none-task&utm_source=distribute.pc_relevant.none-task

首先添加函数保存

代码语言:javascript
复制
function ratio=HeartRate(i,heartSpeed)
i=mod(i,heartSpeed);
if i < heartSpeed / 2
    ratio=sin( i/heartSpeed*pi);
elseif i >= heartSpeed / 2 && i < heartSpeed * 3/4
    ratio=2*cos(i/heartSpeed*2/3*pi);
else
    ratio = 0;
end
matlab画心形曲线_笛卡尔心形曲线方程
matlab画心形曲线_笛卡尔心形曲线方程
matlab画心形曲线_笛卡尔心形曲线方程
matlab画心形曲线_笛卡尔心形曲线方程

通过Movie函数进行跳动Heartbeats

代码语言:javascript
复制
clear
gcp=figure;
M=moviein(100,gcp);
heartSpeed=15;
radiusRate=3;

for i = 1:100
    
    axis([-20 20 -20 20]);
axis off
[A,map] = rgb2ind(frame2im(getframe),256);
imwrite(A,map,'1.gif','LoopCount',inf,'DelayTime',0.1);
    cla(gcp);
    x=[];
    y=[];
    
    for t = 0:0.01:2*pi
        r=(sin(t)*sqrt(abs(cos(t))))/(sin(t)+7/5)-2*sin(t)+2;
        r = radiusRate * r;
        x=[x,r*cos(t)*(0.5+0.5*HeartRate(i,heartSpeed))];
        y=[y,r*sin(t)*(0.5+0.5*HeartRate(i,heartSpeed))];
    end
    hold on;
    fill(x,y,'r');
    
    M(:,i)=getframe;
    [A,map] = rgb2ind(frame2im(getframe),256);
    imwrite(A,map,'1.gif','WriteMode','append','DelayTime',0.1);  
end
movie(M,1);
matlab画心形曲线_笛卡尔心形曲线方程
matlab画心形曲线_笛卡尔心形曲线方程

后记


既然提到heartbeats天使的跳动,自然是我们的天使(不是天降之物啦,可怕想什么呢)

matlab画心形曲线_笛卡尔心形曲线方程
matlab画心形曲线_笛卡尔心形曲线方程

这个才是正确的✔

matlab画心形曲线_笛卡尔心形曲线方程
matlab画心形曲线_笛卡尔心形曲线方程

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/181065.html原文链接:https://javaforall.cn

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022年10月17日,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • MATLAB 心形曲线
    • 基本知识
      • 笛卡尔爱心曲线
    • 特别定制
      • 第一种实现方式
      • 方法二:grid on可以加上网格,可以通过删除下面代码中的grid on删除表格
      • fill语句填色
      • 方案3
      • axis off 可以关闭坐标轴,进行动态绘图
      • 如果你需要保存到本地的话,你需要进一步添加imwrite保存到本地,delayTime延时画图
    • 最终实现版本
      • 进一步动态实现 (借用movie函数)再进行本地保存改进
    • 后记
      • 这个才是正确的✔
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档