Indices: Difference between revisions
From NARS2000
Jump to navigationJump to search
(Created page with "<table border="1" cellpadding="5" cellspacing="0" rules="none" summary=""> <tr> <td> <table border="0" cellpadding="5" cellspacing="0" summary=""> <tr> <td valign…") |
Sudleyplace (talk | contribs) No edit summary |
||
(6 intermediate revisions by 2 users not shown) | |||
Line 7: | Line 7: | ||
<td></td> | <td></td> | ||
<td></td> | <td></td> | ||
<td>returns | <td>returns a simple integer vector or nested vector of integer vectors identical to <apll>(,R)/,⍳⍴R</apll>.</td> | ||
</tr> | </tr> | ||
</table> | </table> | ||
Line 13: | Line 13: | ||
</tr> | </tr> | ||
<tr> | <tr> | ||
<td><apll>R</apll> is a | <td><apll>R</apll> is a simple array of non-negative integers.</td> | ||
</tr> | </tr> | ||
<tr> | <tr> | ||
<td><apll>Z</apll> is an integer vector of | <td>For vector <apll>R</apll>, <apll>Z</apll> is an integer vector. For all other ranks of <apll>R</apll>, <apll>Z</apll> is a nested vector of integer vectors. In both case the length of <apll>Z</apll> is <apll>+/,R</apll>.</td> | ||
</tr> | </tr> | ||
<tr> | <tr> | ||
<td> | <td>For scalars or vectors, the result is equivalent to <apll>R/⍳⍴R</apll> which encapsulates a very common idiom in one symbol.</td> | ||
</tr> | |||
<tr> | |||
<td>For higher rank arrays, the result extends to produce a nested vector of vectors of the indices of all the positive integer elements of <apll>R</apll> replicated as per the corresponding value in <apll>R</apll>.</td> | |||
</tr> | |||
<tr> | |||
<td>This function is sensitive to <apll>⎕IO</apll>.</td> | |||
</tr> | </tr> | ||
</table> | </table> | ||
Line 25: | Line 31: | ||
<p>For example, in origin-0</p> | <p>For example, in origin-0</p> | ||
<apll> | <apll><pre> | ||
0 2 3 4 6 | ⍸,3 | ||
0 0 0 | |||
0 0 1 1 1 2 2 2 2</apll> | ⍬⍬⍬≡⍸3 ⍝ for scalar S, ⍸S ←→ S⍴⊂⍬ as per the definition R/⍳⍴R | ||
1 | |||
⍬≡⍸⍬ | |||
1 | |||
⍸1 0 1 1 1 0 1 | |||
0 2 3 4 6 | |||
⍸'Now is the time'=' ' | |||
3 6 10 | |||
⍸2 3 4 | |||
0 0 1 1 1 2 2 2 2 | |||
⍸⎕←2 3⍴⍳4 | |||
0 1 2 | |||
3 0 1 | |||
0 1 0 2 0 2 1 0 1 0 1 0 1 2 | |||
⍸1 2 3⍴⍳4 | |||
0 0 1 0 0 2 0 0 2 0 1 0 0 1 0 0 1 0 0 1 2 | |||
∇ Z←(Txt Rep) txtrep Z;a | |||
[1] ⍝ Replace Txt in Z with Rep. | |||
[2] :Assert 2=⍴⍴Z ⋄ :Assert (⍴Txt)≡⍴Rep | |||
[3] a←⍸Txt⍷Z | |||
[4] Z[⊃⊃¨,¨/¨a+⊂0(0..¯1+⍴Txt)]←((⍴a),⍴Rep)⍴Rep | |||
∇ | |||
'Now' 'Who' txtrep 4 13⍴'Now is the time...' | |||
Who is the ti | |||
me...Who is t | |||
he time...Who | |||
is the time.</pre></apll> |
Latest revision as of 17:49, 15 April 2018
|
||||
R is a simple array of non-negative integers. | ||||
For vector R, Z is an integer vector. For all other ranks of R, Z is a nested vector of integer vectors. In both case the length of Z is +/,R. | ||||
For scalars or vectors, the result is equivalent to R/⍳⍴R which encapsulates a very common idiom in one symbol. | ||||
For higher rank arrays, the result extends to produce a nested vector of vectors of the indices of all the positive integer elements of R replicated as per the corresponding value in R. | ||||
This function is sensitive to ⎕IO. |
For example, in origin-0
⍸,3 0 0 0 ⍬⍬⍬≡⍸3 ⍝ for scalar S, ⍸S ←→ S⍴⊂⍬ as per the definition R/⍳⍴R 1 ⍬≡⍸⍬ 1 ⍸1 0 1 1 1 0 1 0 2 3 4 6 ⍸'Now is the time'=' ' 3 6 10 ⍸2 3 4 0 0 1 1 1 2 2 2 2 ⍸⎕←2 3⍴⍳4 0 1 2 3 0 1 0 1 0 2 0 2 1 0 1 0 1 0 1 2 ⍸1 2 3⍴⍳4 0 0 1 0 0 2 0 0 2 0 1 0 0 1 0 0 1 0 0 1 2 ∇ Z←(Txt Rep) txtrep Z;a [1] ⍝ Replace Txt in Z with Rep. [2] :Assert 2=⍴⍴Z ⋄ :Assert (⍴Txt)≡⍴Rep [3] a←⍸Txt⍷Z [4] Z[⊃⊃¨,¨/¨a+⊂0(0..¯1+⍴Txt)]←((⍴a),⍴Rep)⍴Rep ∇ 'Now' 'Who' txtrep 4 13⍴'Now is the time...' Who is the ti me...Who is t he time...Who is the time.