Am 22.04.20 um 14:27 schrieb Allin Cottrell:
 On Wed, 22 Apr 2020, Allin Cottrell wrote:
> On Wed, 22 Apr 2020, Sven Schreiber wrote:
>
>> Am 22.04.2020 um 07:56 schrieb Artur Tarassow:
>>> Hi all,
>>>
>>> I've detected a weird gretl behaviour when trying to apply the 
>>> "foreach"
>>> loop type over vector entries. Loop index "i" is printed very round
>>> but
>>> the printf-command in the loop-block is only shown at the very last
>>> iteration for the very first iteration.
>>
>> Actually I thought this use isn't supported.
>
> It's not supported. What Artur is seeing is the effect of gretl 
> treating id as a string (matrices not being accepted). There's only 
> one iteration because only one string: "eval $i" prints id (a column 
> vector); the number i equals 1 on the single iteration. 
Thanks for the clarification, Allin. But then, should gretl not throw an 
error of the foreach-loop is feeded with a matrix which is not being 
accepted?
 To be a little clearer (perhaps), Artur's code
 <hansl>
 matrix id = seq(1,3)'
 loop foreach i id
   smpl full
   eval $i
   smpl firm == i --restrict
   printf "\n%.0f -- %d\n", i, min(firm)
 endloop
 </hansl>
 translates to the following:
 <hansl>
 matrix id = seq(1,3)'
 smpl full
 eval id
 smpl firm == 1 --restrict
 printf "\n%.0f -- %d\n", 1, min(firm)
 </hansl>
 and as such the output is correct. 
Ok, I understand the translation but still not why the look actually 
starts at all.
Best,
Artur