At
Jump to navigation
Jump to search
At (@
) is a primitive dyadic operator that is similar to J and K's Amend in functionality. In Dyalog APL, At handles a subset of the cases of the Under operator that pertain to modifying elements at specific positions in an array.
Description
At takes two operator arguments, and it has many overloads based on the types of its arguments.
A call to At is of the form X(f@g)Y
where X
is optional.
g
specifies the indices of the right argument that should be modified.- Function: Must apply to
Y
, and return a boolean array of positions which should be modified. - Array: Specifies the indices directly. If this is a scalar, it is repeated as necessary.
- Function: Must apply to
f
specifies what happens to the elements at those positions.- Function: Applies to all the selected elements at once. If
X
is given, then it is bound to this function (X∘f
). - Array: Replaces the selected elements.
- Function: Applies to all the selected elements at once. If
Examples
⍝ Simple replacement (1 2 3@4 5 6)7 5 4 10 3 6 9 2 1 8 7 5 4 1 2 3 9 2 1 8 (0@2 4) 1 2 3 4 5 1 0 3 0 5 ⍝ f is a function 10 (×@2 4) 1 2 3 4 5 1 20 3 40 5 (÷@2 4) 1 2 3 4 5 1 0.5 3 0.25 5 ⍝ g is a function '*'@(2∘|) 1 2 3 4 5 ⍝ Boolean selection 1 0 1 0 1 * 2 * 4 * ⍝ f and g are functions 10 (×@(≤∘3)) 3 1 4 1 5 30 10 4 10 5 ⌽@(2∘|) 1 2 3 4 5 ⍝ Reversal of sub-array 1 3 5 5 2 3 4 1
See Also
External Links
Lessons
Documentation
Publications
Prefix friendly @ by Aaron Hsu and Roger Hui