電子產(chǎn)業(yè)一站式賦能平臺(tái)

PCB聯(lián)盟網(wǎng)

搜索
查看: 10|回復(fù): 0
收起左側(cè)

【高級(jí)繪圖】Matlab繪制陰影誤差圖

[復(fù)制鏈接]

238

主題

238

帖子

1400

積分

三級(jí)會(huì)員

Rank: 3Rank: 3

積分
1400
跳轉(zhuǎn)到指定樓層
樓主
發(fā)表于 2021-10-24 00:15:00 | 只看該作者 |只看大圖 回帖獎(jiǎng)勵(lì) |倒序?yàn)g覽 |閱讀模式
點(diǎn)擊上方藍(lán)字和“好玩的matlab”一起快樂的玩耍吧
- ?$ E# {7 b( z; O4 S9 |$ w ; M& X; W9 P" f7 b9 ^& v3 l
好玩的matlab% }2 Y( m/ D/ n$ n& J& T( _" K
帶你喜歡上MATLAB! W* H6 `- C% L8 o' X8 g7 i
* o- W2 B7 x$ O4 |! T
科研繪圖中遇見的問題:怎么樣去繪制好看精致的誤差圖?今天小編教大家畫圖的方法。繪圖效果
; @3 o( g  [6 m0 r
1
" ~1 f9 h2 ^$ C! k& V1 T9 \

6 K: R: I6 ]6 v$ ?5 W: M1 Q $ \0 j& j3 H0 r' B: V2 @# f; T' \

9 T8 N  J8 {: h1 g
2 I7 _; _1 D) }8 Q. P
源碼2
  • clear,clc;x = 0:10:500; y_true =  30*sind(x) + x/10; sigma = 3; y_measured = y_true + sigma*randn(size(x)); plot(x,y_true,'k','linewidth',2)hold onplot(x,y_measured,'color',[0.0118 0.2078 0])ylabel( 'Y軸');xlabel('X軸');% 繪制不確定性陰影區(qū)間errorshade(x,y_measured,sigma,[0 1 0.7]) legend('真實(shí)值','測(cè)量值 \pm\sigma = 3 mV ','location','northwest')legend box off axis tight title('好看的陰影誤差圖')grid minor?errorshade 函數(shù):+ D( r" \3 `) _- u% Q6 s( I6 b7 T
  • function h = errorshade(x,y,sigma,color,varargin)%errorshade繪制陰影區(qū)域以指示高斯不確定性。%通過生成指定顏色的RGB圖像并設(shè)置透明度來作圖%% 語法規(guī)則%  errorshade(x,y,sigma,color)%  errorshade(...,'resolution',res)%  errorshade(...,'average',N)%  h = errorshade(...)%%% 簡(jiǎn)介%% %errorshade(x,y,sigma ,color)以高斯陰影區(qū)域?yàn)橹行睦L制% x,y:為數(shù)據(jù)行。%sigma:表示陰影的一個(gè)標(biāo)準(zhǔn)偏差% color:為rgb值的三元素向量。* m6 o# \3 g/ c. G
    %% 舉例%數(shù)據(jù)% x = 0:10:500;% y_true =  30*sind(x) + x/10;% sigma = 3;% y_measured = y_true + sigma*randn(size(x));% plot(x,y_true,'k','linewidth',2)% hold on% plot(x,y_measured,'color',[0.0118 0.2078 0])% ylabel 'some values in mV'%% % 繪制不確定性陰影區(qū)間% errorshade(x,y_measured,sigma,[0.0824 0.6902 0.1020])% legend('true value','measured value \pm\sigma = 3 mV uncertainty','location','northwest')% legend boxoff% axis tight%% Error checks:narginchk(4,inf)assert(numel(color)==3,'輸入錯(cuò)誤: 顏色必須是三元素向量.')assert(numel(x)==numel(y),'輸入錯(cuò)誤::x 和 y 維度必須相等')assert(isscalar(sigma)==1,'輸入錯(cuò)誤: sigma必須是標(biāo)量.')
    ; L/ T) h" [" }; Q( T. H8 n5 U%% Input parsing8 X2 a7 G( c! W; g/ {4 J
    tmp = strncmpi(varargin,'resolution',3);if any(tmp)    res = varargin{find(tmp)+1};    if isscalar(res)        res = [res res];    else        assert(numel(res)==2,'輸入錯(cuò)誤: 分辨率必須是標(biāo)量或二元素向量.')    endelse    res = 2500*[1 1];endtmp = strncmpi(varargin,'average',2);if any(tmp)    avg = varargin{find(tmp)+1};    assert(isscalar(avg)==1,'輸入錯(cuò)誤: 移動(dòng)平均距離必須為標(biāo)量.')    y = imfilter(y(:),fspecial('average',[avg 1]),'replicate');endbuffer = 3*sigma; % This is the padding to add around all measurements in the vertical dimension.%% 限制范圍:% 制作一個(gè)與數(shù)據(jù)緩沖區(qū)的尺寸相對(duì)應(yīng)的網(wǎng)格:[X,Y] = meshgrid(linspace(min(x),max(x),res(1)),linspace(min(y)-buffer,max(y)+buffer,res(2)));% Find y locations along all x points of the gridyi = interp1(x,y,linspace(min(x),max(x),res(1)));% 正態(tài)分布:P = (1/sqrt(2*pi*sigma^2)) * exp(-(bsxfun(@minus,Y,yi)).^2/(2*sigma^2));%每個(gè)點(diǎn)到y(tǒng)i的距離將用作透明度的量度:Z = P-min(P(:));Z = Z/max(Z(:));%創(chuàng)建指定顏色的RGB圖像:RGB = cat(3,color(1)*ones(size(Z)),color(2)*ones(size(Z)),color(3)*ones(size(Z)));% 繪制顏色的RGB圖像:h = image(RGB,'xdata',X(1,:),'ydata',Y(:,1));axis xy% 設(shè)置透明度:set(h,'alphadata',Z)% 將渲染器設(shè)置為OpenGL,因?yàn)橥该鞫葍H適用于OpenGL:set(gcf,'renderer','OpenGL');% 底部:uistack(h,'bottom')%% 清除:if nargout==0    clear hendend
    4 g& B; L( r5 ]% F: Y2 G( F' A參考文獻(xiàn):
    + |8 `  L& i$ i) }好玩的matlab:https://idmatlab.blog.csdn.net/article/details/113733467
    + U$ r& Z5 L1 b+ P. r& l. n+ k& D# S7 }* d
    ; X" B' {7 i5 _3 F

    / Q3 V7 P$ c- @! T4 }6 Y1 h" }好玩的matlab 1分鐘前. ~; f* i% Z/ C
    誰給你的權(quán)利,一天啥正事不干就想著玩手機(jī),還不快去測(cè)試代碼。
    ) O7 {7 ~: M6 F  @4 D3 b8 w& h) a/ K' v) P* b0 t
    往期精彩回顧  A2 N3 ]- P+ f6 R, P2 `& N

    6 h  }4 ?. d+ ]7 S- l5 \" e推薦 | 【好玩的源碼】MATLAB 繪制動(dòng)態(tài)正弦函數(shù)推薦 | 【高級(jí)繪圖】MATLAB怎么將圖形局部放大推薦 | 【源碼分享】* {- q# G/ o7 V3 `$ d0 F
    ( @! U1 g( h" S7 K! u" h

    " o0 }+ t1 H! c' v* A0 T) r( `3 \; f6 b+ i
    / D* J1 }/ t1 D% K  B- ]) M! H& z
    9 g. G7 }( X) c7 Z8 @, q

    5 L& L* f- C: T8 _+ |& d/ D" t% X: o/ ?2 L8 ?
    ↓↓↓ 點(diǎn)擊"閱讀原文" 【查看更多信息】
  • 發(fā)表回復(fù)

    本版積分規(guī)則


    聯(lián)系客服 關(guān)注微信 下載APP 返回頂部 返回列表