subdelete

The subdelete operator deletes data from an array according to coordinates specified by one or more secondary arrays, called pick arrays.

Synopsis

subdelete ( ARRAY_NAME, PICK_0 [ , PICK_n ]* )

Summary

The subdelete operator deletes cells from an array based on coordinates selected by the pick array inputs. The pick arrays are processed with the same algorithm used by subarray, but instead of returning the selected cells as subarray does, subdelete deletes them. Refer to the https://paradigm4.atlassian.net/wiki/spaces/scidb/pages/3395881545 documentation for a detailed discussion of pick arrays and the grid, cell-wise, and hybrid selection modes.

Examples

Start with a small 3x3 cube of values:

AFL% create array m3x3<v:int64>[i=0:2; j=0:2; k=0:2]; Query was executed successfully AFL% store(build(m3x3, i*100 + j*10 + k), m3x3); Query was executed successfully AFL% scan(m3x3); {i,j,k} v {0,0,0} 0 {0,0,1} 1 {0,0,2} 2 {0,1,0} 10 {0,1,1} 11 {0,1,2} 12 {0,2,0} 20 {0,2,1} 21 {0,2,2} 22 {1,0,0} 100 {1,0,1} 101 {1,0,2} 102 {1,1,0} 110 {1,1,1} 111 {1,1,2} 112 {1,2,0} 120 {1,2,1} 121 {1,2,2} 122 {2,0,0} 200 {2,0,1} 201 {2,0,2} 202 {2,1,0} 210 {2,1,1} 211 {2,1,2} 212 {2,2,0} 220 {2,2,1} 221 {2,2,2} 222 AFL%

Use grid selection to delete all cells with (i, j) values in the cross product of {1} x {0, 2}:

AFL% subdelete(m3x3, CON> build(<i:int64>, from:'[[1]]'), CON> build(<j:int64>, from:'[[0, 2]]')); Query was executed successfully AFL% scan(m3x3); {i,j,k} v {0,0,0} 0 {0,0,1} 1 {0,0,2} 2 {0,1,0} 10 {0,1,1} 11 {0,1,2} 12 {0,2,0} 20 {0,2,1} 21 {0,2,2} 22 {1,1,0} 110 {1,1,1} 111 {1,1,2} 112 {2,0,0} 200 {2,0,1} 201 {2,0,2} 202 {2,1,0} 210 {2,1,1} 211 {2,1,2} 212 {2,2,0} 220 {2,2,1} 221 {2,2,2} 222 AFL%

Use cell-wise selection to delete the particular cells at {2,2,1} and {1,1,2}:

AFL% subdelete(m3x3, CON> build(<i:int64, j:int64, k:int64>, CON> from:'[[(2, 2, 1), (1, 1, 2)]]')); Query was executed successfully AFL% scan(m3x3); {i,j,k} v {0,0,0} 0 {0,0,1} 1 {0,0,2} 2 {0,1,0} 10 {0,1,1} 11 {0,1,2} 12 {0,2,0} 20 {0,2,1} 21 {0,2,2} 22 {1,1,0} 110 {1,1,1} 111 {2,0,0} 200 {2,0,1} 201 {2,0,2} 202 {2,1,0} 210 {2,1,1} 211 {2,1,2} 212 {2,2,0} 220 {2,2,2} 222 AFL%