整理记录matlab令人迷惑(或有用)的操作 不定期更新

2024-01-08 13:58

本文主要是介绍整理记录matlab令人迷惑(或有用)的操作 不定期更新,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!


2.if转switch

巧用逻辑运算

score=68
switch 1case 90<=score&&score<=100,disp('优秀');case 70<=score&&score<90,disp('良好');case 60<=score&&score<70,disp('一般');case score<60,disp('不及格');
end

3.生成随机初级扫雷矩阵
rand_mat=rand(9,9);
[~,order]=sort(rand_mat(:));
mine=zeros(9,9);
mine(order(1:10))=1;

4.删除矩阵中含有元素0的行
A=[2 3 4 0;3 6 2 6;1 2 0 4;3 4 9 1];
A(sum(A(:,:)==0,2)~=0,:)=[]
%同理删除含有元素0的列:
%A(:,sum(A(:,:)==0,1)~=0)=[]

5.当timer和while做的小动画未进行完要优雅的从右上角关闭
set(gcf,'tag','co','CloseRequestFcn',@clo);function clo(~,~)stop(game)delete(findobj('tag','co'));clfcloseend 
%注:其中的stop(game)中的game是timer函数构造的实例名称。

6.删除图像
delete(findobj('type','line'))%删除类似于plot的线性图像
deletd(findobj('type','patch'))%删除类似于fill的填充图像%当你只想删除部分图像时,不妨给他们加个'tag'
%例如plot(x,y,'tag','plotline')
%   delete(findobj('tag','plotline'));

7.matlab拟合函数后转换成匿名函数
x=[2 2.5 3 3.5 4 4.5 5 5.5 6];
y=[41 38 34 32 29 28 25 22 20];
p=polyfit(x,y,3)
f=matlabFunction(poly2sym(p))

8.隐藏图像边框
set(gca,'xtick',[],'ytick',[],'xcolor','w','ycolor','w')

9.获取鼠标在figure上位置
set(gcf,'WindowButtonMotionFcn',@getpos)
function getpos(~,~)xy=get(gca,'CurrentPoint');x=xy(1,1);y=xy(1,2);end

10.黑白子轮流下棋?
turn=0
while 条件turn=mod(turn+1,2);switch turncase: 1,下黑子;case: 0,下白子;end
end

11.获取矩阵各行或各列最大值
A=[1 2 4;4 5 6;7 8 9];
max_A_rows=max(A,[],2)
max_A_cols=max(A,[],1)

12.构造0xn大小的矩阵,用于初始化矩阵
mat=ones(1,n);
mat(1,:)=[];
%这样的初始化矩阵可以直接往后面并上新的元素

13. 删除矩阵中不存在元素或无限大元素
mat1=[nan,4,5];
mat1(isnan(mat1))=[];mat2=[inf,6,7];
mat2(isinf(mat2))=[];

14.设置默认值
function example(arg1,arg2,arg3)if nargin<2arg2='';endif nargin<3arg3='';end
end

15.利用严密逻辑在matlab内无法关闭的图像(可用任务进程管理器关掉
function bug
set(gcf,'tag','co','CloseRequestFcn',@draw)function draw(~,~)spyend
draw()
end

16.能看懂就怪了的万年历(a,b,c分别为年月日)
function y=wannianli(a,b,c)
yue=[1 0 0;2 31 31;3 59 60;4 90 91;5 120 121;6 151 152;7 181 182;8 212 213;9 243 244;10 273 274;11 304 305;12 334 335];
y=mod(((a-1)*365+floor((a-1)/4)-floor((a-1)/100)+floor((a-1)/400)+yue(yue(:,1)==b,3-((~mod(a,4)==0)||((mod(a,100)==0)&&(~mod(a,400)==0))))+c+7),7);
end

17.复数矩阵转置
a=a(:).'
%来源:https://www.cnblogs.com/hgyzm/p/10298100.html

18.已知邻接矩阵求可达矩阵
function P=dgraf(A)
n=size(A,1);
P=A;
for i=2:nP=P+A^i;
end
P(P~=0)=1;
end
%来源:《图论算法及matlab实现》
%      北京航空航天大学出版社

19.没啥用的程序
function nothing=nothing(nothing),end

20.确定点击图像的序号

如果图像是用image创建,则可以为其设置’ButtonDownFcn’,并设置一个回调,如:@clickOnPic

PicHdl(i)=image([xMin xMax],[yMin yMax],picName,'tag',num2str(i),'ButtonDownFcn',@clickOnPic);

然后为clickOnPic第一个输入命名为object并获得其Tag值

function clickOnPic(object,~)picId=object.Tag;
end

详细使用可见我写的连连看程序或植物大战僵尸程序。


21.神奇的图像

超超超级短,超超超神奇,好久之前知乎上看到的,出处有些难找

mat=eye(40);
plot(fft(mat)); axis equal

在这里插入图片描述


22.RGB颜色与十六进制色相互转换

RGB颜色–>十六进制色

function string=ten2sixteen(num)%the num should be a 1x3 Integer mat limited in [0 255]exchange_list={'0','1','2','3','4','5','6','7','8','9','A','B','C','D','E','F'};string='#';for ii=1:3temp_num=num(ii);string(1+ii*2-1)=exchange_list{(temp_num-mod(temp_num,16))/16+1};string(1+ii*2)=exchange_list{mod(temp_num,16)+1};endend

十六进制色–>RGB颜色

function num=sixteen2ten(string)exchange_list='0123456789ABCDEF#';ismember(string,exchange_list)num=zeros(1,3);if all(ismember(string,exchange_list))for ii=1:3tempCoe1=find(ismember(exchange_list,string(ii*2))==1)-1;tempCoe2=find(ismember(exchange_list,string(ii*2+1))==1)-1;num(ii)=16*tempCoe1+tempCoe2;endelsenum=nan;endend 

这篇关于整理记录matlab令人迷惑(或有用)的操作 不定期更新的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/583686

相关文章

poj3468(线段树成段更新模板题)

题意:包括两个操作:1、将[a.b]上的数字加上v;2、查询区间[a,b]上的和 下面的介绍是下解题思路: 首先介绍  lazy-tag思想:用一个变量记录每一个线段树节点的变化值,当这部分线段的一致性被破坏我们就将这个变化值传递给子区间,大大增加了线段树的效率。 比如现在需要对[a,b]区间值进行加c操作,那么就从根节点[1,n]开始调用update函数进行操作,如果刚好执行到一个子节点,

hdu1394(线段树点更新的应用)

题意:求一个序列经过一定的操作得到的序列的最小逆序数 这题会用到逆序数的一个性质,在0到n-1这些数字组成的乱序排列,将第一个数字A移到最后一位,得到的逆序数为res-a+(n-a-1) 知道上面的知识点后,可以用暴力来解 代码如下: #include<iostream>#include<algorithm>#include<cstring>#include<stack>#in

hdu1689(线段树成段更新)

两种操作:1、set区间[a,b]上数字为v;2、查询[ 1 , n ]上的sum 代码如下: #include<iostream>#include<algorithm>#include<cstring>#include<stack>#include<queue>#include<set>#include<map>#include<stdio.h>#include<stdl

hdu 1754 I Hate It(线段树,单点更新,区间最值)

题意是求一个线段中的最大数。 线段树的模板题,试用了一下交大的模板。效率有点略低。 代码: #include <stdio.h>#include <string.h>#define TREE_SIZE (1 << (20))//const int TREE_SIZE = 200000 + 10;int max(int a, int b){return a > b ? a :

数论入门整理(updating)

一、gcd lcm 基础中的基础,一般用来处理计算第一步什么的,分数化简之类。 LL gcd(LL a, LL b) { return b ? gcd(b, a % b) : a; } <pre name="code" class="cpp">LL lcm(LL a, LL b){LL c = gcd(a, b);return a / c * b;} 例题:

AI行业应用(不定期更新)

ChatPDF 可以让你上传一个 PDF 文件,然后针对这个 PDF 进行小结和提问。你可以把各种各样你要研究的分析报告交给它,快速获取到想要知道的信息。https://www.chatpdf.com/

GIS图形库更新2024.8.4-9.9

更多精彩内容请访问 dt.sim3d.cn ,关注公众号【sky的数孪技术】,技术交流、源码下载请添加微信:digital_twin123 Cesium 本期发布了1.121 版本。重大新闻,Cesium被Bentley收购。 ✨ 功能和改进 默认启用 MSAA,采样 4 次。若要关闭 MSAA,则可以设置scene.msaaSamples = 1。但是通过比较,发现并没有多大改善。

Node.js学习记录(二)

目录 一、express 1、初识express 2、安装express 3、创建并启动web服务器 4、监听 GET&POST 请求、响应内容给客户端 5、获取URL中携带的查询参数 6、获取URL中动态参数 7、静态资源托管 二、工具nodemon 三、express路由 1、express中路由 2、路由的匹配 3、路由模块化 4、路由模块添加前缀 四、中间件

JavaFX应用更新检测功能(在线自动更新方案)

JavaFX开发的桌面应用属于C端,一般来说需要版本检测和自动更新功能,这里记录一下一种版本检测和自动更新的方法。 1. 整体方案 JavaFX.应用版本检测、自动更新主要涉及一下步骤: 读取本地应用版本拉取远程版本并比较两个版本如果需要升级,那么拉取更新历史弹出升级控制窗口用户选择升级时,拉取升级包解压,重启应用用户选择忽略时,本地版本标志为忽略版本用户选择取消时,隐藏升级控制窗口 2.

记录每次更新到仓库 —— Git 学习笔记 10

记录每次更新到仓库 文章目录 文件的状态三个区域检查当前文件状态跟踪新文件取消跟踪(un-tracking)文件重新跟踪(re-tracking)文件暂存已修改文件忽略某些文件查看已暂存和未暂存的修改提交更新跳过暂存区删除文件移动文件参考资料 咱们接着很多天以前的 取得Git仓库 这篇文章继续说。 文件的状态 不管是通过哪种方法,现在我们已经有了一个仓库,并从这个仓