Thank you for the explanation Jürgen.

That makes intuitive sense. A shared-memory single threaded service is a
reasonable abstraction.

Another approach, is to compile a subset of APL to an intermediate
representation.

Is there a way to export the AST?
in addition - is there an in-repl method of viewing help and/or arguments
for system variables & functions?

By the way, a minor regression: segfaulting, but only after exiting.
```
      )OFF
====================================================
SEGMENTATION FAULT
thread: 0x7f8747766700
thread_cSegmentation fault
```

Thanks again,
- Rowan

On Wed, Oct 16, 2019 at 12:06 PM Dr. Jürgen Sauermann <
mail@jürgen-sauermann.de> wrote:

> Hi Blake,
>
> it is sort of working, but I could well use some help in troubleshooting
> the remaining problems. I can help fixing them, but finding their root
> cause
> (and making them reproducible) is a different story.
>
> My current interpretation of various benchmarks that Elias Mårtenson and
> myself did some years ago is that the bandwidth of the memory interface
> between the CPUs (or cores) and the memory is the limiting factor, and no
> matter how efficient the APL interpreter is, this bottleneck will dictate
> the
> speedup that can be achieved.
>
> As an example, from 1985 to 1990, myself and 4 students had built a the
> hardware of a parallel APL machine with 32 CPUs and measured a speedup
> of close to 32 for sufficiently large vectors.
>
> In contrast, if I remember correctly, then  Elias achieved a speedup of 12
> with
> 80 CPUs using the parallel feature of GNU APL. The only difference that
> I can see between our 1990 machine (called Datis-P-256 because the
> architecture
> could be scaled up to 256 processors) was the memory architecture:
>
> Datis-P had one separate memory for each CPU, while current multicore
> boxes share their memory module(s) among different cores. That simply
> boils down to the fact that the memory bandwidth of Datis-P scaled with the
> number of processors, while the number of cores on a typical multi-core box
> does not. As long as this is the case, parallel APL remains severely
> limited
> in terms of the speedup that can be achieved.
>
> Best Regards,
> Jürgen Sauermann
>
>
>
> On 10/16/19 12:58 PM, Blake McBride wrote:
>
> Greetings,
>
> I think getting the parallel processing working is important.  It may be
> that for various reasons the speedup in general cases is minimal and not
> worth the effort.  However, I'd imagine that there are particular use-cases
> utilizing large arrays where the speedup would be substantial.  That is
> when those types of enhancements would make APL a real benefit.
>
> Thanks.
>
> Blake
>
>
> On Wed, Oct 16, 2019 at 5:27 AM Dr. Jürgen Sauermann <
> mail@jürgen-sauermann.de> wrote:
>
>> Hi Rowan,
>>
>> fixed in *SVN 1191*.
>>
>> You should not be too enthusiastic, though, because the speed-ups that
>> can be achieved are somewhat disappointing. And due to that, I
>> haven't put too much effort into fixing faults (sometimes apl hangs
>> on a semaphore when parallel execution is enabled).
>>
>> Best Regards,
>> Jürgen Sauermann
>>
>>
>> On 10/16/19 5:15 AM, Rowan Cannaday wrote:
>>
>> Hello,
>>
>> intrigued by the ability to parallelize APL, thought I'd try to test it:
>>
>> `apl --cfg` followed by a line of '=' signs followed by `apl -q`:
>>
>>
>> configurable options:
>> ---------------------
>>     ASSERT_LEVEL_WANTED=2
>>     SECURITY_LEVEL_WANTED=0 (default)
>>     APSERVER_PATH=/tmp/GNU-APL/APserver (default)
>>     APSERVER_PORT=16366 (default)
>>     APSERVER_TRANSPORT=0 (default)
>>     CORE_COUNT_WANTED=2
>>     DYNAMIC_LOG_WANTED=yes
>>     MAX_RANK_WANTED=8 (default)
>>     RATIONAL_NUMBERS_WANTED=yes
>>     SHORT_VALUE_LENGTH_WANTED=12, therefore:
>>         sizeof(Value)       : 456 bytes
>>         sizeof(Cell)        :  24 bytes
>>         sizeof(Value header): 168 bytes
>>
>>     VALUE_CHECK_WANTED=yes
>>     VALUE_HISTORY_WANTED=yes
>>     VF_TRACING_WANTED=no (default)
>>     VISIBLE_MARKERS_WANTED=yes
>>
>> how ./configure was (probably) called:
>> --------------------------------------
>>     ./configure  'CORE_COUNT_WANTED=2' 'DEVELOP_WANTED=yes'
>> 'VALUE_HISTORY_WANTED=yes' 'VISIBLE_MARKERS_WANTED=yes'
>> '--enable-maintainer-mode'
>>
>> BUILDTAG:
>> ---------
>>     Project:        GNU APL
>>     Version / SVN:  1.8 / 1190M
>>     Build Date:     2019-10-16 02:45:24 UTC
>>     Build OS:       Linux 5.2.0-3-amd64 x86_64
>>     config.status:  'CORE_COUNT_WANTED=2' 'DEVELOP_WANTED=yes'
>> 'VALUE_HISTORY_WANTED=yes' 'VISIBLE_MARKERS_WANTED=yes'
>> '--enable-maintainer-mode'
>>     Archive SVN:    1161
>>
>>
>> ================================================================================
>>
>> $ apl -q
>>
>>
>> ====================================================
>> SEGMENTATION FAULT
>> thread: 0x7f6078042e00
>> thread_contexts_count: 2
>> busy_worker_count:     0
>> active_core_count:     1
>> thread # 0:               0 RUN  job:   0 no-name
>> thread #-1:               0 RUN  job:   0 no-name
>>
>>
>> ----------------------------------------
>> -- Stack trace at main.cc:88
>> ----------------------------------------
>> 0x7F6078FD1BBB __libc_start_main
>> 0x5631406C386D  main
>> 0x5631406CAD8D   init_apl(int, char const**)
>> 0x5631407E881B    Parallel::init(bool)
>> 0x563140832E2D     Thread_context::init_parallel(CoreCount, bool)
>> 0x7F60794E5B18      sem_init
>> 0x7F60794E8510
>> 0x5631406CA95A
>> ========================================
>> ====================================================
>>
>>
>>
>>
>

Reply via email to