dm_2d_circ_pt_elecs

PURPOSE ^

DM_2D_CIRC_PT_ELECS: Create circle mesh (or radius 1) refined with electrodes

SYNOPSIS ^

function fmdl = dm_2d_circ_pt_elecs( elec_pts, pfix, spacing);

DESCRIPTION ^

 DM_2D_CIRC_PT_ELECS: Create circle mesh (or radius 1) refined with electrodes
 fmdl = dm_2d_circ_pt_elecs( elec_pts, pfix, spacing);
     at points on the electrodes
 fmdl = dm_2d_circ_pt_elecs( elec_pts, pfix, ...
               [base_spacing, refine_ratio, gradient]);
 elec_pts = cell fcn of N x [x,y,{z}] for each electrode
    normally only two points are specified (at start and end of electrode)
    eg elec_pts{1} = [-.1,1;.1,1];
 pfix = any fixed points to provide to the model (default = [])
 param(1) = base_spacing - edge length away from refined nodes (eg 0.1)
 param(2) = refine_ratio - relative refinement near points (eg. 10)
 param(3) = gradient     - transition slope of refinement (eg 0.1)

 Example: Three electrodes 2 on boundary and one internal
  elec_pts = {[1,0],[0,1;sin(0.2),cos(0.2)],[0.5,0.5]};
  fmdl= dm_2d_circ_pt_elecs( elec_pts, [], [0.15,10,0.05] );

 Example:
  n_elecs= 14; elec_width= 0.1; hw= elec_width/2;
  th = linspace(0,2*pi,n_elecs+1); th(end)=[];
  for i=1:n_elecs;
     ti = th(i) + [hw;-hw];
     elec_pts{i} = [sin(ti),cos(ti)];
  end
  fmdl= dm_2d_circ_pt_elecs( elec_pts, [], [0.10,10,0.02] );

 See also: dm_2d_pt_elecs

CROSS-REFERENCE INFORMATION ^

This function calls: This function is called by:

SUBFUNCTIONS ^

SOURCE CODE ^

0001 function fmdl = dm_2d_circ_pt_elecs( elec_pts, pfix, spacing);
0002 % DM_2D_CIRC_PT_ELECS: Create circle mesh (or radius 1) refined with electrodes
0003 % fmdl = dm_2d_circ_pt_elecs( elec_pts, pfix, spacing);
0004 %     at points on the electrodes
0005 % fmdl = dm_2d_circ_pt_elecs( elec_pts, pfix, ...
0006 %               [base_spacing, refine_ratio, gradient]);
0007 % elec_pts = cell fcn of N x [x,y,{z}] for each electrode
0008 %    normally only two points are specified (at start and end of electrode)
0009 %    eg elec_pts{1} = [-.1,1;.1,1];
0010 % pfix = any fixed points to provide to the model (default = [])
0011 % param(1) = base_spacing - edge length away from refined nodes (eg 0.1)
0012 % param(2) = refine_ratio - relative refinement near points (eg. 10)
0013 % param(3) = gradient     - transition slope of refinement (eg 0.1)
0014 %
0015 % Example: Three electrodes 2 on boundary and one internal
0016 %  elec_pts = {[1,0],[0,1;sin(0.2),cos(0.2)],[0.5,0.5]};
0017 %  fmdl= dm_2d_circ_pt_elecs( elec_pts, [], [0.15,10,0.05] );
0018 %
0019 % Example:
0020 %  n_elecs= 14; elec_width= 0.1; hw= elec_width/2;
0021 %  th = linspace(0,2*pi,n_elecs+1); th(end)=[];
0022 %  for i=1:n_elecs;
0023 %     ti = th(i) + [hw;-hw];
0024 %     elec_pts{i} = [sin(ti),cos(ti)];
0025 %  end
0026 %  fmdl= dm_2d_circ_pt_elecs( elec_pts, [], [0.10,10,0.02] );
0027 %
0028 % See also: dm_2d_pt_elecs
0029 
0030 % (C) 2009 Andy Adler. License: GPL version 2 or version 3
0031 % $Id: dm_2d_circ_pt_elecs.m 6926 2024-05-31 15:34:13Z bgrychtol $
0032 
0033 
0034 if ischar(elec_pts) && strcmp(elec_pts,'UNIT_TEST'); do_unit_test; return; end
0035 if ischar(elec_pts) && strcmp(elec_pts,'CALIBRATE'); do_calibrate; return; end
0036 
0037 copt.cache_obj = {elec_pts, spacing};
0038 copt.fstr = 'dm_2d_circ_pt_elecs';
0039 fmdl = eidors_cache(@do_circ_pt_elecs,{elec_pts, pfix, spacing}, copt);
0040 
0041 function fmdl = do_circ_pt_elecs( elec_pts, pfix, spacing )
0042 params.base_spacing = spacing(1);
0043 params.refine_ratio = spacing(2);
0044 params.gradient     = spacing(3);
0045 
0046 bbox= [-1,-1;1,1];
0047 
0048 eidors_cache('boost_priority',-4);
0049 fmdl= dm_2d_pt_elecs( elec_pts, [], params, @circle, [-1,-1;1,1] );
0050 eidors_cache('boost_priority',+4);
0051 
0052 fmdl.name = sprintf('dm_2d_circ_pt_elec');
0053 
0054 function d= circle(p,params);
0055   d = sqrt(sum(p.^2,2)) - 1; 
0056 
0057 %%%%%%%%%%%%%%%%%%%%%%%%%%%% TESTING %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
0058 
0059 function do_unit_test
0060    elec_pts = {[1,0],[0,1;sin(0.2),cos(0.2)],[0.5,0.5]};
0061    fmdl= dm_2d_circ_pt_elecs( elec_pts, [], [0.15,10,0.05] );
0062    subplot(221); show_fem(fmdl);
0063    for i=1:length(elec_pts)
0064       unit_test_cmp(sprintf('Elec%d(%d)',1,i), ...
0065          mean(fmdl.nodes(fmdl.electrode(i).nodes,:),1), mean(elec_pts{i},1), .01);
0066    end
0067 
0068 
0069 % Example:
0070    n_elecs= 14; elec_width= 0.1; hw= elec_width/2;
0071    th = linspace(0,2*pi,n_elecs+1); th(end)=[];
0072    for i=1:n_elecs;
0073       ti = th(i) + [hw;-hw];
0074       elec_pts{i} = [sin(ti),cos(ti)];
0075    end
0076    fmdl= dm_2d_circ_pt_elecs( elec_pts, [], [0.10,10,0.02] );
0077    subplot(222); show_fem(fmdl)
0078    for i=1:length(elec_pts)
0079       unit_test_cmp(sprintf('Elec%d(%d)',2,i), ...
0080          mean(fmdl.nodes(fmdl.electrode(i).nodes,:),1), mean(elec_pts{i},1), .01);
0081    end
0082    eidors_msg('CHECK FIGURE - should have 3 and 16 electrodes',0);
0083 
0084 % find example models that work well with the values defined in mk_common_model
0085 function do_calibrate
0086 
0087 % meas = calc_range(0.05*([1,1.1,1.2,1.4,1.6,2.0,2.5,3,4,5,7,10,15,20]),0,1)
0088   meas = calc_range(0.02,3,0.10),%- level 1
0089 % meas = calc_range(0.03,10,0.05),%- level 3
0090 
0091 % meas = calc_range(0.02,10,0.05),%- level 3
0092 % meas = calc_range(0.02,20,0.05),%- level 3
0093  % As a start, set p2 = 1. This is uniform, and we can choose the
0094  % target refinement levels, and calculate the centre mesh density
0095  % OR setting p3=1 also gives uniform
0096 
0097 function meas = calc_range(p1range,p2,p3)
0098   n_elecs= 8; elec_width= 0.1; hw= elec_width/2;
0099   th = linspace(0,2*pi,n_elecs+1); th(end)=[];
0100   for i=1:n_elecs;
0101      ti = th(i) + [hw;-hw];
0102      elec_pts{i} = [sin(ti),cos(ti)];
0103   end
0104 
0105   for i = 1:length(p1range)
0106      p1 = p1range(i);
0107      fmdl= dm_2d_circ_pt_elecs( elec_pts, [], [p1,p2,p3]);
0108      nd= fmdl.nodes; nn= size(nd,1);
0109      ne= size(fmdl.elems,1);
0110      nc= sum( nd(:,1).^2 + nd(:,2).^2 < 0.5^2);
0111      nl= sum( (nd(:,1)-1).^2 + nd(:,2).^2 < 0.2^2);
0112      meas(i,:) = [p1,p2,p3,[nn,ne,nc,nl]/1000];
0113 
0114   end;
0115 show_fem(fmdl)
0116

Generated on Sun 29-Dec-2024 11:41:59 by m2html © 2005