| 3.3.2.39 MarkMark-cmd Mark command deletes (-d) or sets a missing value (-m) to a specified dataset range. It can also manipulate masking of data points.
 
 Syntax:mark  option dataset [range] Options:-d; Delete elements from datasetSyntax: mark -d dataset [range]
 Delete elements from dataset. If dataset is in a worksheet, this command deletes the specified rows (of all columns in the worksheet) from the worksheet. For example, the following script deletes row index 10 to row index 20 from the current worksheet, cell contents are shifted up: 
   range bb = col(2)[10:20];
  mark -d bb; To delete rows from the specified column only, use mark -dc.
 -da; Ask before deleting elements from datasetSyntax: mark -da dataset
 Ask before deleting elements from dataset. Similar to the -d option, if dataset is in a worksheet, this command option will delete rows from other columns in the worksheet. For example, the following script deletes row index 10 to row index 20 in the current worksheet, after a dialog prompt: 
   range bb = col(2)[10:20];
  mark -da bb; -dc; Delete elements from Column RangeSyntax: mark -dc columnRange
 (Origin 8) Delete elements from columnRange. This command option will not delete rows from other columns in the worksheet, which the -d option will. For example, the following script deletes row index 10 to row index 20 from col(2) only in the current worksheet, while other columns are unchanged: 
   range bb = col(2)[10:20];
  mark -dc bb; -m; Turn dataset elements (cells) into missing valuesSyntax: mark -m dataset [range]
 Turn the dataset elements (cells) into missing values. For example:
 range bb = col(2)[3:6];
mark -m bb; // set col(2) row 3-6 to missing values If the range is omitted, all cells in the dataset will become missing. 
 Col(dataset)="";is equivalent to the Mark -m command without the range specification. If the cell must be set to a null (to make the cell empty), you can issue like:
   for(ii=1; ii<wks.maxrows; ii++) col(2)[ii]$=""; -mc; Clear marked dataSyntax: mark -mc Dataset
 Clear data that has been marked on a graph, replacing marked data with missing values.
 -md; Clear all data in marked rowsSyntax: mark -md Dataset
 Clear data between data markers in a graph, replacing marked data with missing values.  Differs from the mark -mc option in that all worksheet rows corresponding to marked data rows are cleared.
 -r; Clear all the data markersSyntax: mark -r
Clear all data markers in a graph.
 
| Note: We should turn the currently selected tool back to Pointer before we execute this command. For example: dotool 0;
mark -r; |  -s1, -s2, ... -s9;Set mask with masking valueSyntax: mark -s1, -s2, ... -s9
 -s1 will set mask with masking value of 1, and -s9 will set mask with mask value of 9, while -st will toggle.
 -sl; Paste mask pattern to a range of datasetSyntax: mark -sl file range
 Apply the mask pattern saved in file to range. See also mark -sscommand of how to save a mask pattern.
For example, mark -ss mymask col(A); //save mask pattern of col(A) in current worksheet to "mymask" file
mark -sl mymask col(B); //paste mask pattern in "mymask" file to col(B) -slr; Paste mask pattern to a range of dataset cyclicallySyntax: mark -sl file range
 Apply the mask pattern saved in file to range cyclically. For example,
 range r1=col(A):col(B);
mark -ss "mymask" r1;
range r2=col(C):col(F);
//cyclically apply mask status to two blocks of ranges: C&D, and E&F
mark -slr "mymask" r2; See also mark -sscommand of how to save a mask pattern. -ss; Copy mask pattern of a range of datasetSyntax: mark -ss file range
 Copy mask pattern of range into file. See also mark -slcommand of how to paste the mask pattern.
For example, mark -ss mymask col(A); //save mask pattern of col(A) in current worksheet to "mymask" file
mark -sl mymask col(B); //paste mask pattern in "mymask" file to col(B) -st;Toggle mask off and on for a range of datasetSyntax: mark -st Dataset
 After a range of data has been masked in the graph using mark -w1, toggle the mask off and on for a range of dataset. For example: 
   range bb = col(2)[3:6];
  mark -st bb;  // mask off col(2) row 3-6 in current active dataset -sw; Swap masked and unmasked points in datasetSyntax: mark -sw dataset
 Swap masked and unmasked points in dataset. For example: 
   mark -sw %C; -u; Update all graphs with masked dataSyntax: mark -u
 Update all graphs with masked data.
Use this command after changing one of the global mask properties with the following system variables:
 
| @MC | Mask color.  Follows the colors in the color palette:  1 = black, 2 = red, 3 = green, 4 = blue, etc. |  
| @MM | Enable or disable mask.  0 = enable (masked points are not included in analysis).  1 = disable (masked points are included in analysis). |  
| @MP | Show or hide masked data points in graph.  0 = show.  1 = hide. | 
 
	| /Tip_icon.png?v=0) | You can override show/hide masked points at the plot or page level:
 | 
 -w1 or -w1u; Mask a rangeMinimum Origin Version Required: 8.51 SR0 Syntax: mark -w1 [range]
 Mask a range either in the worksheet or graph. 
 Syntax: mark -w1u [range]
 Mask a range either in the worksheet or graph. This option supports undo.
 When data is masked, it is automatically excluded from analysis. The '1' in -w1 and w1u is 'one'.
 Note1: If no range is specified, then the command works on the active worksheet selection. You can programmatically select using the worksheet -s c1 r1 c2 r2 command.   // mask selected data
  worksheet -s 1 2 1 4;  // set range to rows 2 - 4 in column 1
  mark -w1;  // mask this range of data
  // mask data range by passing column name
  mark -w1u wcol(1)[10:15]; // mask rows 10 - 15 in column 1
  // mask data range by passing range variable
  range rr = [Book1]Sheet1!col(2);  // set range to column 2
  mark -w1 rr[10:30];  // mask rows 10 - 30 in column 2
  // mask data block
  range rBlock = wcol(2)[8]:wcol(4)[10];  // data block
  mark -w1 rBlock;  // mask a data block Note2:  To determine if a data point in a data plot is masked, use the following notation: 
 datasetName<dataPointIndex> =
 A return value of 0 indicates the point is not masked.  1 indicates the point is masked. For example, to determine if the fourth data point in the Book1_b data plot is masked, use:
   // using dataset name
  ii = Book1_b<4>;
  ii = ;
  // using column name
  ii = [Book1]Sheet1!col(1)<3>;
  ii = ;
 
  // using range
  range rr = col(2);
  ii = rr<2>;
  ii = ; -wd or -wdu; Remove mask from a rangeSyntax: mark -wd
 Remove the mask from a range either in the worksheet or graph.
 Syntax: mark -wdu
 Remove the mask from a range either in the worksheet or graph. This option supports undo.
 Complete Mask/Unmask example (code is destructive):
 doc -s; // Shut off the Save warning flag
doc -n; // Start a new project
string strBk$ = %H;
col(1)=data(1,10);
col(2)=uniform(10);
col(3)=col(2)+.2;
plotxy (1,2:3);
string strGr$ = %H;
range rap1 = 1;
set rap1 -c 4;
win -s tv;
ty -b Data created and plotted;
win -a %(strBk$);
range ra1 = 2; // This is a worksheet range, so column = 2
mark -w1 ra1[3:8]; // range uses only rows 3 to 8
range ra2 = 3[3:8]; // This is a worksheet subrange, column 3, rows 3 to 8
mark -w1u ra2; // mask the whole subrange with undo support
ty -b Rows 3 to 8 masked in each Y column.
Graph updates to show masked points as red.
Now we will remove the mask for rows 5 and 6.;
win -a %(strGr$);
range -w ra3 = 1[5:6];
mark -wd ra3;
range -w ra4 = 2;
mark -wdu ra4[5:6]; -wtu; Toggle mask over a selected rangeSyntax: mark -wtu
 Toggle the mask off and on for the selected range.
 -wxu; Toggle mask over a selected range, key on first cellSyntax: mark -wxu
 Toggle the mask off and on for the selected range. Differs from -wtu in that the mask state of the first cell in the range determines whether to toggle on or off. If some cells in the selected range are masked and some are not, a mask will be uniformly applied or uniformly removed, depending on the current mask state of the first cell.
 -x; Create an associated X datasetSyntax: mark -x dataset [range]
 Create an associated X dataset called dataset_X, which contains whatever X values are associated with the current worksheet.
 
 See AlsoX-Functions colmask and wcellmask are faster than mark command and simpler to use.
 E.g, to mask all missing value and blank value in a worksheet, run this single line X-Function:
 
colmask irng:=1:0 cond:=eq val:=nan; 
 Using mark with looping of rows and columns is way more complicated and will take forever for large worksheet
 |