电子产业一站式赋能平台

PCB联盟网

搜索
查看: 238|回复: 0
收起左侧

MATLAB|科研绘图|山脊图

[复制链接]

260

主题

260

帖子

1833

积分

三级会员

Rank: 3Rank: 3

积分
1833
发表于 2023-11-14 13:09:00 | 显示全部楼层 |阅读模式
点击上方蓝字和“好玩的MATLAB”一起快乐玩耍吧!
# M( r' H, p4 ^! |; l2 M/ Z

qp244ctpmz464015159434.jpg

qp244ctpmz464015159434.jpg
5 S* E- V9 G8 F6 u% H5 P$ y
好玩的matlab
+ ~$ m# x+ D8 l, P* R带你解锁不一样的matlab新玩法& ^+ U- U6 C. U7 D, F

9 I# z$ Y" c4 B0 G9 F今天介绍一下山脊图,喜欢此推文的小伙伴们记得点赞+关注+分享!【尊重作者劳动成果,转载请注明推文链接和公众号名】上周去逛了一下商店看见一个笔架7 d: i' u/ g  y' {' d. Y/ ^

ioawjtavs3r64015159535.png

ioawjtavs3r64015159535.png

- d! G) d  M, I这突然让我想起,这个不就像科研绘图的山脊图嘛,于是我打算用 MATLAB 复刻一个。
! o  w3 {2 c4 N

kd5bi0xe1qv64015159635.png

kd5bi0xe1qv64015159635.png

) k  ^7 R9 M- d5 Q6 p+ C
9 L+ y' s. T6 j0 I效果图7 c1 k$ c0 B; Q" W$ G

5nrbv4yimym64015159735.png

5nrbv4yimym64015159735.png

% ~, u' `+ m- x9 n# s9 q9 I1 B, r
5 E: e4 ^! X7 D" {! y

iahbxjtz0hs64015159835.gif

iahbxjtz0hs64015159835.gif
* B2 |, c% s1 @) U& R/ ]
山脊图介绍山脊图(Ridge Plot),也被称为Joy Plot,是一种用于可视化数据分布的图表,特别是用于显示多个组的分布情况。在这种图表中,每个组的数据分布都通过平滑的密度曲线来表示,这些曲线沿着垂直轴堆叠,形成类似山脊的视觉效果。山脊图是核密度估计(KDE)的一个应用,它提供了比传统的条形图或直方图更平滑的数据分布视图。
$ J6 }7 Q/ f1 t$ ^* z' r8 Q! c0 D用途:山脊图主要用于展示和比较不同组或类别内数据的分布情况。它特别适合于以下情境:
" }& z1 b* }# u/ }比较多个分布:当需要展示和比较多组数据的分布形状时,山脊图能够直观地展示出分布之间的差异。
- F) u4 A$ L* x/ b" x6 [展现趋势变化:在时间序列数据中,山脊图可以用来展示数据随时间的变化趋势。( y5 I% m. W/ I9 \( C
优化空间利用:通过堆叠的方式,山脊图能在有限的空间内展示大量的分布信息。
: N6 y# L' |6 A3 }5 G" P! @缺点:
# B6 g9 ~9 A- u( a3 T; {可读性:对于不熟悉这种图表的观众来说,山脊图可能难以理解和解读。
8 R8 c% g2 S/ C% X叠加问题:当曲线重叠较多时,可能会导致图表的某些部分难以区分。4 S" n8 \: S) u! ?
数据量限制:对于数据量非常大的数据集,山脊图可能不那么有效,因为过多的曲线会使图表变得杂乱。
3 J  [! j# K1 G, E9 C应用场景  I3 l1 _3 s0 `# W4 q+ I( z1 y2 z; J
时间序列分析:在金融、经济、气象等领域,用于展示某个变量随时间的变化趋势。
- S' P9 K' a/ R/ v- V( ~社会科学:比如在选举数据分析中,展示不同候选人或党派在不同地区或人群中的支持率分布。8 G# c4 @! L+ |  w% K, E" H& o
生物医学:用于展示不同实验组或治疗方法下的生物统计数据分布。6 k/ w0 D+ W' z6 B
绘图教程线条山脊图
  • data = randn(100,12)+[ 20 22 24 26 28 31 30 28 26 24 22 20];lgLable= {'January', 'February', 'March', 'April', 'May', 'June','July', 'August', 'September', 'October', 'November', 'December'};colors=makeColorMap([0,0,0;1,1,1],12);figure('Position',[476 246 511 620])p=0.15;yTick=(1:size(data, 2))*p;for i = 1:size(data, 2)    [f, x] = ksdensity(data(:, i));    f=f+i*p;    pHandle=plot(x, f, 'LineWidth', 1.5,'color',colors(i,:));    hold on;    yline(yTick(i),'-.','LineWidth',1,'Color',pHandle.Color,'HandleVisibility','off')endgrid off;box off;legend(lgLable,'box','on','Color',[1,1,1]*0.95,'EdgeColor','none');set(gca, 'YTick',yTick , 'YTickLabel',lgLable,'LineWidth', 1.5, 'XMinorTick', 'on', 'TickDir', 'out', ...    'fontname','Times new Roman','color',[1,1,1]*0.9);xlabel('XXXX-Value');ylabel('YYYY-Value');title('Ridge Plot');hold off;. B% n" f( `# m" _# T

    j5w2ko2hvck64015159936.png

    j5w2ko2hvck64015159936.png
    : n  [% [9 C9 g7 c6 y% ]
    填充山脊图
  • data = randn(100,12)+[ 20 22 24 26 28 31 30 28 26 24 22 20];lgLable= {'January', 'February', 'March', 'April', 'May', 'June','July', 'August', 'September', 'October', 'November', 'December'};% colors=makeColorMap(winter,size(data, 2));colors=makeColorMap(jet,size(data, 2));figure('Position',[476 246 511 620])p =0.2;hold on;for i = size(data, 2):-1:1    [f, x] = ksdensity(data(:, i));    fShifted = f + i * p;    pHandle = plot(x, fShifted,'color',colors(i,:),'LineWidth', 1.5,'HandleVisibility', 'off');    yline(i * p, '-.', 'LineWidth', 1, 'Color', colors(i,:),'HandleVisibility', 'off')    Xfill = [x, fliplr(x)];    Yfill = [fShifted, ones(1, length(x)) * i * p];    fill(Xfill, Yfill, pHandle.Color, 'EdgeColor', 'none', 'FaceAlpha', 0.3);endyTick = (1:size(data, 2)) * p;set(gca, 'YTick', yTick, ...    'YTickLabel', lgLable, ...    'LineWidth', 1.5, 'XMinorTick', 'on', 'TickDir', 'out', ...    'fontname','Times new Roman');xlabel('XXXX-Value');ylabel('YYYY-Value');title('Ridge Plot');ax = gca;hold off;?
    " K6 J; S  r2 w9 h7 i& a

    3zrmybd2fqs64015160036.png

    3zrmybd2fqs64015160036.png
    6 M- p' T3 z: h
    3D填充山脊图
  • data = randn(100,12)+[ 20 22 24 26 28 31 30 28 26 24 22 20];lgLabel= {'January', 'February', 'March', 'April', 'May', 'June','July', 'August', 'September', 'October', 'November', 'December'};p = 0.2;xTick=(1:size(data, 2))*p;figure('Position',[476 246 511 620])hold on;colors=makeColorMap(hsv,size(data, 2));legendHandles = zeros(size(data, 2), 1);for i = 1:size(data, 2)    [f, y] = ksdensity(data(:, i));    xShifted = i * p;    plot3(xShifted * ones(size(f)), y, f, 'LineWidth', 1.5, 'Color', colors(i,:), 'HandleVisibility', 'off');    Yfill = [y, fliplr(y)];    Xfill = [xShifted * ones(1, length(y)), xShifted * ones(1, length(y))];    Zfill = [f, zeros(size(f))];    legendHandles(i)  = fill3(Xfill, Yfill, Zfill, colors(i,:), 'EdgeColor', 'none', 'FaceAlpha', 0.3); endgrid off;box on;legend(lgLabel,'box','on','Color',[1,1,1]*0.95,'EdgeColor','none','FontName','Times New Roman','location','best');set(gca, 'XTick',xTick, 'XTickLabel',lgLabel,'FontName','Times New Roman','linewidth',1)xlabel('XXXX-Value');ylabel('YYYY-Value');zlabel('ZZZ-Value');title('Ridge Plot');view([-83.4000   71.6830])hold off;
    " f! K2 D" ?$ |6 _/ f8 {3 `5 i

    kzqrrnocwvx64015160136.png

    kzqrrnocwvx64015160136.png
    . u) E8 R/ v$ k& z
    不同核山脊图、添加边际散点密度
  • data = randn(100,3)+[ 20  24 28];colors=makeColorMap(jet,size(data, 2));figure('Position',[476 246 511 620])p=0;hold on;yTick=(1:size(data, 2))*p;lineLength = 0.02; % 竖线的长度for i = size(data, 2):-1:1    [f, x] = ksdensity(data(:, i));    fShifted = f + i * p;    pHandle = plot(x, fShifted, 'color', colors(i,:), 'LineWidth', 1.5, 'HandleVisibility', 'off');    yline(i * p, '-.', 'LineWidth', 1, 'Color', colors(i,:), 'HandleVisibility', 'off');    Xfill = [x, fliplr(x)];    Yfill = [fShifted, ones(1, length(x)) * i * p];    fill(Xfill, Yfill, pHandle.Color, 'EdgeColor', 'none', 'FaceAlpha', 0.3);    for j = 1:length(data(:, i))        line([data(j, i), data(j, i)], [i * p, i * p + lineLength], 'Color', pHandle.Color, 'LineWidth', 1);    endendgrid off;box off;ax=gca;set(ax,'LineWidth', 1.5, 'XMinorTick', 'on', 'TickDir', 'out', ...    'fontname','Times new Roman','color',[1,1,1]*0.9);ax.YLim=[0,1];ax.XLim=[15,32];xlabel('XXXX-Value');ylabel('YYYY-Value');title('Ridge Plot');hold off;. J) `8 s) H- C

    pi3g4mzgufe64015160236.png

    pi3g4mzgufe64015160236.png

    / y2 R4 u3 O* T9 A* L' h横坐标方向、全局渐变的散点图' C1 ~$ ]" r& _9 S8 c/ |* E7 I
  • data = randn(100,12)+[ 20 22 24 26 28 31 30 28 26 24 22 20];lgLabel={'January', 'February', 'March', 'April', 'May', 'June',    'July', 'August', 'September', 'October', 'November', 'December'};p = 0.2;numColors = 256;% 创建一个从紫色到红色再到黄色的颜色映射colorMap =makeColorMap([0.1490    0.0353    0.5608;0.7305    0.2500    0.4922;0.9569    0.9490    0.1765],numColors);% 计算全局的x轴范围xMin = min(data, [], 'all');xMax = max(data, [], 'all');figure('Position',[476 246 511 620])hold on;for i = size(data, 2):-1:1    [f(i,:), x] = ksdensity(data(:, i), 'Kernel', 'triangle');    fShifted = f(i,:) + i * p; % 偏移每个分布    plot(x, fShifted, 'LineWidth', 1.5, 'color', 'k', 'HandleVisibility', 'off');    yline(i * p, '-.', 'LineWidth', 1, 'HandleVisibility', 'off');    for j = 1:length(x)-1        Xfill = [x(j), x(j+1), x(j+1), x(j)];        Yfill = [i * p, i * p, fShifted(j+1), fShifted(j)];        % 计算当前点的颜色比例        colorRatio = (x(j) - xMin) / (xMax - xMin);        colorIdx = min(numColors, max(1, round(colorRatio * (numColors - 1)) + 1));        fill(Xfill, Yfill, colorMap(colorIdx, :), 'EdgeColor', 'none', 'FaceAlpha', 0.9);    endend% 设置轴标签和标题yTick = (1:size(data, 2)) * p;set(gca, 'YTick', yTick, ...    'YTickLabel', lgLabel, ...    'LineWidth', 1.5, 'XMinorTick', 'on', 'TickDir', 'out', ...    'fontname','Times new Roman');xlabel('XXXX-Value');ylabel('YYYY-Value');title('Ridge Plot');% 设置颜色条colormap(colorMap);cBar = colorbar;cBar.TickDirection = 'out';cBar.LineWidth = 1;cBar.TickLength = 0.02;cBar.FontName = 'Times new Roman';caxis([xMin,xMax]);hold off;
    & O" w1 X+ k& I5 P0 e

    ieeezantuxb64015160336.png

    ieeezantuxb64015160336.png
    " I! X, U1 ~7 p! k6 J
    横坐标方向、单核渐变图
  • data = randn(100,12) + [20 22 24 26 28 31 30 28 26 24 22 20];lgLabel = {'January', 'February', 'March', 'April', 'May', 'June', 'July', 'August', 'September', 'October', 'November', 'December'};numColors = 256; % 颜色数量colors = jet(numColors); % 使用jet颜色映射figure('Position',[476 246 511 620])p = 0.2;hold on;for i = size(data, 2):-1:1    [f, x] = ksdensity(data(:, i));    fShifted = f + i * p;    plot(x, fShifted, 'LineWidth', 1.5, 'HandleVisibility', 'off');    yline(i * p, '-.', 'LineWidth', 1, 'HandleVisibility', 'off');    colorGradient = linspace(1, numColors, length(x));    for j = 1:length(x)-1        Xfill = [x(j), x(j+1), x(j+1), x(j)];        Yfill = [i * p, i * p, fShifted(j+1), fShifted(j)];        fill(Xfill, Yfill, colors(round(colorGradient(j)), :), 'EdgeColor', 'none', 'FaceAlpha', 0.7);    endendyTick = (1:size(data, 2)) * p;set(gca, 'YTick', yTick, 'YTickLabel', lgLabel, ...    'LineWidth', 1.5, 'XMinorTick', 'on', 'TickDir', 'out', ...    'fontname', 'Times new Roman');xlabel('XXXX-Value');ylabel('YYYY-Value');title('Ridge Plot');colormap(colors);cBar = colorbar;cBar.TickDirection = 'out';cBar.LineWidth = 1;cBar.TickLength = 0.02;cBar.FontName = 'Times new Roman';hold off;
    4 D5 ?4 r% q* F, A6 H0 o

    mee114g1pfn64015160436.png

    mee114g1pfn64015160436.png

    , |7 x( J4 p6 |4 x" m- C% a: A" ^' ^每个山脊图设置不同颜色,且添加边际散点图
  • data = randn(100,12)+[ 20 22 24 26 28 31 30 28 26 24 22 20];lgLable = {'January', 'February', 'March', 'April', 'May', 'June', 'July', 'August', 'September', 'October', 'November', 'December'};figure('Position', [476 246 511 620])p = 0.3;lineLength = 0.04; % 竖线的长度colors=makeColorMap(hsv,size(data, 2));hold on;for i = size(data, 2):-1:1    [f, x] = ksdensity(data(:, i));    fShifted = f + i * p;    pHandle = plot(x, fShifted, 'color', colors(i,:), 'LineWidth', 1.5, 'HandleVisibility', 'off');    yline(i * p, '-.', 'LineWidth', 1, 'Color', colors(i,:), 'HandleVisibility', 'off');    Xfill = [x, fliplr(x)];    Yfill = [fShifted, ones(1, length(x)) * i * p];    fill(Xfill, Yfill, pHandle.Color, 'EdgeColor', 'none', 'FaceAlpha', 0.3);    for j = 1:length(data(:, i))        line([data(j, i), data(j, i)], [i * p, i * p + lineLength], 'Color', 'k', 'LineWidth', 1);    endendyTick = (1:size(data, 2)) * p;set(gca, 'YTick', yTick, ...    'YTickLabel', lgLable, ...    'LineWidth', 1.5, 'XMinorTick', 'on', 'TickDir', 'out', ...    'fontname', 'Times new Roman');xlabel('XXXX-Value');ylabel('YYYY-Value');title('Ridge Plot');1 b4 ?; r/ L- F3 G

    lzbd4n1tcao64015160537.png

    lzbd4n1tcao64015160537.png

    . }" K; N. K5 _8 j& J3 V每个山脊图设置不同颜色单核横向颜色渐变
  • data = randn(100,12)+[ 20 22 24 26 28 31 30 28 26 24 22 20];lgLabel = {'January', 'February', 'March', 'April', 'May', 'June', ...    'July', 'August', 'September', 'October', 'November', 'December'};p = 0.2;numColors = 256;% 创建12个不同的颜色映射,每个月一个colorMaps = cell(1, 12);colorList={parula,turbo,hsv,hot,cool,spring,summer,autumn,winter,gray,bone,copper,pink,jet,lines,colorcube,prism,flag};for i = 1:12    colorMaps{i} = makeColorMap(colorList{i}, numColors);end% 计算全局的x轴范围xMin = min(data, [], 'all');xMax = max(data, [], 'all');figure('Position', [476 246 511 620])hold on;for i = size(data, 2):-1:1    [f(i,:), x] = ksdensity(data(:, i), 'Kernel', 'triangle');    fShifted = f(i,:) + i * p; % 偏移每个分布    plot(x, fShifted, 'LineWidth', 1.5, 'color', 'k', 'HandleVisibility', 'off');    yline(i * p, '-.', 'LineWidth', 1, 'HandleVisibility', 'off');    currentColorMap = colorMaps{i};    for j = 1:length(x)-1        Xfill = [x(j), x(j+1), x(j+1), x(j)];        Yfill = [i * p, i * p, fShifted(j+1), fShifted(j)];        colorRatio = (x(j) - xMin) / (xMax - xMin);        colorIdx = min(numColors, max(1, round(colorRatio * (numColors - 1)) + 1));        fill(Xfill, Yfill, currentColorMap(colorIdx, :), 'EdgeColor', 'none', 'FaceAlpha', 0.9);    endendyTick = (1:size(data, 2)) * p;set(gca, 'YTick', yTick, ...    'YTickLabel', lgLabel, ...    'LineWidth', 1.5, 'XMinorTick', 'on', 'TickDir', 'out', ...    'fontname', 'Times new Roman');xlabel('XXXX-Value');ylabel('YYYY-Value');title('Ridge Plot');hold off;
    ) ^$ y/ }% I' d+ A( z* V! `

    nlx55ni4bvi64015160637.png

    nlx55ni4bvi64015160637.png
    2 H7 k" Q1 D; D! }
    山脊图的 Y值映射颜色变化% X3 z2 k8 {8 P9 T/ ~- ?, n
  • data = randn(100,12) + [20 22 24 26 28 31 30 28 26 24 22 20];lgLabel = {'January', 'February', 'March', 'April', 'May', 'June', 'July', 'August', 'September', 'October', 'November', 'December'};numColors = 100; % 颜色数量colors =makeColorMap(jet, numColors);figure('Position',[476 246 511 620])p = 0.2;hold on;for i = size(data, 2):-1:1    [f, x] = ksdensity(data(:, i));    fShifted = f + i * p;    plot(x, fShifted, 'LineWidth', 1.5, 'HandleVisibility', 'off');    yline(i * p, '-.', 'LineWidth', 1, 'HandleVisibility', 'off');    % 计算整个分布的最小和最大纵坐标    minY = min(fShifted);    maxY = max(fShifted);    for j = 1:length(x)-1        Xfill = [x(j), x(j+1), x(j+1), x(j)];        Yfill = [i * p, i * p, fShifted(j+1), fShifted(j)];        avgY = mean(Yfill(3:4));         colorIdx = round(((avgY - minY) / (maxY - minY)) * (numColors - 1)) + 1;        fill(Xfill, Yfill, colors(colorIdx, :), 'EdgeColor', 'none', 'FaceAlpha', 0.6);    endendyTick = (1:size(data, 2)) * p;set(gca, 'YTick', yTick, 'YTickLabel', lgLabel, ...    'LineWidth', 1.5, 'XMinorTick', 'on', 'TickDir', 'out', ...    'fontname', 'Times new Roman');xlabel('XXXX-Value');ylabel('YYYY-Value');title('Ridge Plot');colormap(colors);cBar = colorbar;cBar.TickDirection = 'out';cBar.LineWidth = 1;cBar.TickLength = 0.02;cBar.FontName = 'Times new Roman';hold off;7 x) w) U  \7 e: n; c4 ~

    p1b2waiqaf464015160737.png

    p1b2waiqaf464015160737.png

    & c/ S6 G$ P, S6 n3 }) J$ ?) b' f8 H- a3 X. u1 t. r
    四分位点
    # v* P! Y! S. ]  T
  • data = randn(100,12) + [20 22 24 26 28 31 30 28 26 24 22 20];lgLabel = {'January', 'February', 'March', 'April', 'May', 'June', 'July', 'August', 'September', 'October', 'November', 'December'};colors = makeColorMap(jet, size(data, 2));figure('Position', [476 246 511 620])p = 0.2;hold on;for i = size(data, 2):-1:1    [f, x] = ksdensity(data(:, i));    fShifted = f + i * p;    pHandle = plot(x, fShifted, 'color', colors(i,:), 'LineWidth', 1.5, 'HandleVisibility', 'off');    yline(i * p, '-.', 'LineWidth', 1, 'Color', colors(i,:), 'HandleVisibility', 'off')    Xfill = [x, fliplr(x)];    Yfill = [fShifted, ones(1, length(x)) * i * p];    fill(Xfill, Yfill, pHandle.Color, 'EdgeColor', 'none', 'FaceAlpha', 0.3);    % 计算并标记四分位点    quartiles = quantile(data(:, i), [0.25 0.50 0.75]);    for q = quartiles        [~, idx] = min(abs(x-q));        plot(q, fShifted(idx), 'o', 'MarkerFaceColor', pHandle.Color, 'MarkerEdgeColor', 'k');    endendyTick = (1:size(data, 2)) * p;set(gca, 'YTick', yTick, ...    'YTickLabel', lgLabel, ...    'LineWidth', 1.5, 'XMinorTick', 'on', 'TickDir', 'out', ...    'fontname', 'Times new Roman');xlabel('XXXX-Value');ylabel('YYYY-Value');title('Ridge Plot');hold off;6 {/ `* {4 w4 E$ ^3 ]# Q

    tkw5ew5dd1x64015160837.png

    tkw5ew5dd1x64015160837.png
    . k( H7 F8 U+ U! f9 s7 p  U3 k8 D
  • data = randn(100,12) + [20 22 24 26 28 31 30 28 26 24 22 20];lgLabel = {'January', 'February', 'March', 'April', 'May', 'June', 'July', 'August', 'September', 'October', 'November', 'December'};colors = makeColorMap(jet, size(data, 2));figure('Position', [476 246 511 620])p = 0.2;hold on;for i = size(data, 2):-1:1    [f, x] = ksdensity(data(:, i));    fShifted = f + i * p;    pHandle = plot(x, fShifted, 'color', colors(i,:), 'LineWidth', 1.5, 'HandleVisibility', 'off');    yline(i * p, '-.', 'LineWidth', 1, 'Color', colors(i,:), 'HandleVisibility', 'off');    Xfill = [x, fliplr(x)];    Yfill = [fShifted, ones(1, length(x)) * i * p];    fill(Xfill, Yfill, pHandle.Color, 'EdgeColor', 'none', 'FaceAlpha', 0.3);    % 计算并标记四分位点,并绘制竖线    quartiles = quantile(data(:, i), [0.25 0.50 0.75]);    for q = quartiles        [~, idx] = min(abs(x-q));        plot(q, fShifted(idx), 'o', 'MarkerFaceColor', pHandle.Color, 'MarkerEdgeColor', 'k');        line([q q], [fShifted(idx) i * p], 'Color', pHandle.Color, 'LineStyle', '-.','LineWidth', 1);    endendyTick = (1:size(data, 2)) * p;set(gca, 'YTick', yTick, ...    'YTickLabel', lgLabel, ...    'LineWidth', 1.5, 'XMinorTick', 'on', 'TickDir', 'out', ...    'fontname', 'Times new Roman');xlabel('XXXX-Value');ylabel('YYYY-Value');title('Ridge Plot');hold off;
    ' l0 l/ Q9 ?) |, o

    3oyzwyp5d3y64015160937.png

    3oyzwyp5d3y64015160937.png

    3 K7 R: J7 |, o3 q其中makeColorMap函数代码之前「一张图搞定绘图配色问题」有详细介绍。
    0 t; i. i: D$ W- -THE END- -5 Z" D( W# R) J2 v9 o

    & U7 u% p$ g7 s' x- u源码下载:gitee下载:https://gitee.com/iDMatlab/ridgePlot
    ( T/ H* z4 v- F0 h" ~: r

    lyfpe12qmhn64015161037.png

    lyfpe12qmhn64015161037.png
    ' K1 T0 i! E' o( o/ j
    QQ 群下载:
    ' ^) f# B' ~! x0 K7 v# I8 ^

    pet3hwsrpzp64015161137.png

    pet3hwsrpzp64015161137.png

    + f: X5 d) L4 ~) M+ s  \fileexchange 下载:9 d) Y! N) U8 [

    fvnmrlt5as564015161237.png

    fvnmrlt5as564015161237.png
    3 |. S! H: k8 K( H  N4 I% w+ T
    * n3 m4 G+ E2 q, S" L* A) w- m
    参考资料:
    , [0 R# R- J& b$ }2 W【1】https://it.sohu.com/a/704677145_121123706
    8 t: A. g+ R$ n/ m6 Z

    beerrujtgnf64015161337.gif

    beerrujtgnf64015161337.gif

    5 K6 O( ^: Q& F
    ; \9 u) H% C6 u送书活动) z- Z0 R& J) m" o: b

    1 S8 C% N' ^! m2 ]6 i7 Z% {
    : S: m$ C. N4 S5 x# l- k1 G
    & M9 a8 o. T% m$ E$ H/ a包邮赠送 「北京大学出版社赞助《3D科研绘图与学术图表绘制从入门到精通》, `$ J  L/ `6 {+ E( K/ k* u; P
    7 T$ S4 l( U' K  l) {
    专业级3D科研绘图与学术图表绘制指南:以“设计基本概念+软件底层原理+案例实际操作”的思路进行全方位讲解,涵盖化学、材料学、生物医学等领域的科学可视化的艺术化表达
    8 X2 v4 [/ P. X& [7 y实例丰富:我们涵盖各类绘图软件与工具,让你能够自如运用不同技术绘制出高质量的图表。内容全面:全流程讲解3D科研绘图与学术图表绘制的方法,有效填补了现有同类型参考书的空白。经验总结:作者多年一线研发实战经验全面归纳整理,毫无保留分享技术要领。大咖力荐:多位大型科技公司技术高管和高校相关领域教研专家推荐。
  • 全彩印刷:图表案例精彩呈现,带来良好的阅读体验,方便理解和学习。4 G' e  ?9 [$ N( o
    了解更多/ ^: q1 \8 C) T' J& |- k& ?+ Y) j
    【抽奖方式及满足条件】:1 Y: G# U* A/ Z: Y  K
    1.关注「好玩的MATLAB 」公众号和视频号
    2 w; H2 v6 j' Q& b  C: t9 o7 Z# S- v7 Q7 g; n5 B6 k7 Z% q
    2.给本文点【】+【在看】;) \, ]( L8 d" V! ?; O' Z. O
    3.留言区评论点赞最多的前2名。
    3 t6 T0 x; x; Q- ^$ b4 X! v4.本活动只针对从未获过奖的同学,之前获过奖的小伙伴,不用参加。
    ( }, R5 @. m4 ^& r, U7 V* f$ k同时满足上述4个条件的读者朋友,包邮赠送一本.
    % k3 D+ k  C  A【开奖时间】:2023年11月15日中午12点
    4 ~6 Z9 X) y/ A7 S$ s2 |8 o【领奖方式】:在开奖时加小编私人微信:idmatlab
      ?. `$ D' x- E扫一扫加管理员微信+ R/ W8 M! O; l# l2 Z2 R5 a1 b7 ~( S8 J

    , R, O! s) g, k, u5 K: \$ \
  • 回复

    使用道具 举报

    发表回复

    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则


    联系客服 关注微信 下载APP 返回顶部 返回列表