24小时热门版块排行榜    

CyRhmU.jpeg
南方科技大学公共卫生及应急管理学院2025级博士研究生招生报考通知
查看: 1323  |  回复: 7
当前主题已经存档。
当前只显示满足指定条件的回帖,点击这里查看本话题的所有回帖

phyfriday

金虫 (小有名气)

[交流] 【求助】20金求助matlab中contour plot命令的源码

急切求教各位高手,如何获知matlab中等高线命令--contour的算法或源代码?
回复此楼
光学--红外激光器
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

dnp

荣誉版主 (知名作家)

小木虫浪子

优秀版主

★ ★
phyfriday(金币+1,VIP+0):谢谢 4-28 19:49
kuhailangyu(金币+1,VIP+0):欢迎区长同志莅临指导! 4-29 20:40
引用回帖:
Originally posted by phyfriday at 2009-4-28 09:18:
谢谢3楼、4楼。
这个我也试过了,可是生成等高线的核心函数----h = specgraph.contourgroup('parent',parax,pvpairs{:})怎么才能调出来?对应于同一高度,利用contour命令生成等高线有许多条,现在我想对对这些等 ...

h = specgraph.contourgroup('parent',parax,pvpairs{:})这个命令是一个GUI函数语句,调用的是结构体specgraph.contourgroup的句柄,然后对这个句柄进行GUI操作,所以这个是一个命令,而不是一个函数,如果要调用的话,你必须明白parax, pvpairs这两个变量代表什么,需要对specgraph.contourgroup这结构体数据里面有什么东西有了解,所以,慢慢顺藤摸瓜吧~~
What would Jesus do?
6楼2009-04-28 15:07:46
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
查看全部 8 个回答

coldwind042

金虫 (正式写手)

也想知道,帮你顶!
2楼2009-04-27 13:44:23
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

hitzhang

木虫 (正式写手)

★ ★ ★ ★ ★
sunxiao(金币+3,VIP+0):thank you 4-28 05:24
phyfriday(金币+2,VIP+0):谢谢 4-28 09:19
function [cout, hand] = contour(varargin)
%CONTOUR Contour plot.
%   CONTOUR(Z) is a contour plot of matrix Z treating the values in Z
%   as heights above a plane.  A contour plot are the level curves
%   of Z for some values V.  The values V are chosen automatically.
%   CONTOUR(X,Y,Z) X and Y specify the (x,y) coordinates of the
%   surface as for SURF. The X and Y data will be transposed or sorted
%   to bring it to MESHGRID form depending on the span of the first
%   row and column of X (to orient the data) and the order of the
%   first row of X and the first column of Y (to sorted the data). The
%   X and Y data must be consistently sorted in that if the first
%   element of a column of X is larger than the first element of
%   another column that all elements in the first column are larger
%   than the corresponding elements of the second. Similarly Y must be
%   consistently sorted along rows.
%   CONTOUR(Z,N) and CONTOUR(X,Y,Z,N) draw N contour lines,
%   overriding the automatic value.
%   CONTOUR(Z,V) and CONTOUR(X,Y,Z,V) draw LENGTH(V) contour lines
%   at the values specified in vector V.  Use CONTOUR(Z,[v v]) or
%   CONTOUR(X,Y,Z,[v v]) to compute a single contour at the level v.
%   CONTOUR(AX,...) plots into AX instead of GCA.
%   [C,H] = CONTOUR(...) returns contour matrix C as described in
%   CONTOURC and a handle H to a contourgroup object.  This handle can
%   be used as input to CLABEL.
%
%   The contours are normally colored based on the current colormap
%   and are drawn as PATCH objects. You can override this behavior
%   with the syntax CONTOUR(...,LINESPEC) to draw the contours
%   with the color and linetype specified. See the help for PLOT
%   for more information about LINESPEC values.
%
%   The above inputs to CONTOUR can be followed by property/value
%   pairs to specify additional properties of the contour object.
%
%   Uses code by R. Pawlowicz to handle parametric surfaces and
%   inline contour labels.
%
%   Example:
%      [c,h] = contour(peaks); clabel(c,h), colorbar
%
%   See also CONTOUR3, CONTOURF, CLABEL, COLORBAR, MESHGRID.

%   Additional details:
%
%   CONTOUR uses CONTOUR3 to do most of the contouring.  Unless
%   a linestyle is specified, CONTOUR will draw PATCH objects
%   with edge color taken from the current colormap.  When a linestyle
%   is specified, LINE objects are drawn.
%
%   Thanks to R. Pawlowicz (IOS) rich@ios.bc.ca for 'contours.m' and
%   'clabel.m/inline_labels' so that contour now works with parametric
%   surfaces and inline contour labels.

%   Copyright 1984-2007 The MathWorks, Inc.
%   $Revision: 5.18.4.18 $  $Date: 2007/11/13 00:10:21 $

[v6,args] = usev6plotapi(varargin{:},'-mfilename',mfilename);
if v6
  [c,h] = Lcontourv6(args{:});
else
  % Parse possible Axes input
  error(nargchk(1,inf,nargin,'struct'));
  [cax,args] = axescheck(args{:});
  [pvpairs,args,msg] = parseargs(args); %#ok
  if ~isempty(msg), error(msg); end %#ok
  
  if isempty(cax) || isa(handle(cax),'hg.axes')
      cax = newplot(cax);
      parax = cax;
      hold_state = ishold(cax);
  else
      parax = cax;
      cax = ancestor(cax,'Axes');
      hold_state = true;
  end

  h = specgraph.contourgroup('parent',parax,pvpairs{:});
  set(h,'refreshmode','auto');
  c = get(h,'contourmatrix');
  
  if ~hold_state
    view(cax,2);
    set(cax,'box','on','layer','top');
    grid(cax,'off')
  end
  plotdoneevent(cax,h);
  h = double(h);
end

if nargout > 0
    cout = c;
    hand = h;
end

function [c,h] = Lcontourv6(varargin)  
% Parse possible Axes input
error(nargchk(1,6,nargin,'struct'));
[cax,args] = axescheck(varargin{:});

cax = newplot(cax);

[c,h,msg] = contour3(cax,args{:});
if ~isempty(msg), error(msg); end %#ok

set(h,'ZData',[]);

if ~ishold(cax)
  view(cax,2);
  set(cax,'Box','on');
  grid(cax,'off')
end

function [pvpairs,args,msg] = parseargs(args)
msg = '';
% separate pv-pairs from opening arguments
[args,pvpairs] = parseparams(args);

% check for special string arguments trailing data arguments
if ~isempty(pvpairs)
  [l,c,m,tmsg]=colstyle(pvpairs{1}); %#ok
  if isempty(tmsg)
    args = {args{:},pvpairs{1}};
    pvpairs = pvpairs(2:end);
  end
  msg = checkpvpairs(pvpairs);
end

nargs = length(args);
x = [];
y = [];
z = [];
if ischar(args{end})
  [l,c,m,tmsg] = colstyle(args{end}); %#ok
  if ~isempty(tmsg),
    msg = sprintf('Unknown option "%s".',args{end});
  end
  if ~isempty(c)
    pvpairs = {'linecolor',c,pvpairs{:}};
  end
  if ~isempty(l)
    pvpairs = {'linestyle',l,pvpairs{:}};
  end
  nargs = nargs - 1;
end
if (nargs == 2) || (nargs == 4)
  if (nargs == 2)
    z = datachk(args{1});
    pvpairs = {'zdata',z,pvpairs{:}};
  else
    x = datachk(args{1});
    y = datachk(args{2});
    z = datachk(args{3});      
    pvpairs = {'xdata',x,'ydata',y,'zdata',z,pvpairs{:}};
  end
  if (length(args{nargs}) == 1) && (fix(args{nargs}) == args{nargs})
    % N
    zmin = min(real(double(z()));
    zmax = max(real(double(z()));
    if args{nargs} == 1
      pvpairs = {'levellist',(zmin+zmax)/2, pvpairs{:}};
    else
      levs = linspace(zmin,zmax,args{nargs}+2);
      pvpairs = {'levellist',levs(2:end-1),pvpairs{:}};
    end
  else
    % levels
    pvpairs = {'levellist',unique(args{nargs}),pvpairs{:}};
  end
elseif (nargs == 1)
  z = datachk(args{1});
  pvpairs = {'zdata',z,pvpairs{:}};
elseif (nargs == 3)
  x = datachk(args{1});
  y = datachk(args{2});
  z = datachk(args{3});
  pvpairs = {'xdata',x,'ydata',y,'zdata',z,pvpairs{:}};
end
% Make sure that the data is consistent if x and y are specified.
if ~isempty(x)
    msg = xyzcheck(x,y,z);
end
if ~isempty(z) && isempty(msg)
    k = find(isfinite(z));
    zmax = max(z(k));
    zmin = min(z(k));
    if ~any(k)
        warning('MATLAB:contour:NonFiniteData','Contour not rendered for non-finite ZData');
    elseif isempty(z) || (zmax == zmin)
        warning('MATLAB:contour:ConstantData','Contour not rendered for constant ZData');
    end
end
args = [];
3楼2009-04-27 19:17:52
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

woshilsh

荣誉版主 (职业作家)

优秀版主

★ ★ ★
sunxiao(金币+2,VIP+0):thank you 4-28 05:25
phyfriday(金币+1,VIP+0):谢谢 4-28 09:19
楼上正解,直接找Help文件,或者在命令窗口打开嘛
[center][url=http://www.91cool.net/][img]http://id.91cool.net/sign/?name=小木虫印&say=各位版主辛苦了![/img][/url][/center]
4楼2009-04-27 19:41:10
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
普通表情 高级回复(可上传附件)
信息提示
请填处理意见