Compound applications A compound application consists of a main program and one or more subsidiary programs. The main program executes the subsidiary programs in sequence. It maintains a state file that records which subsidiary programs have already completed. It assigns to each subsidiary application a subrange of the overall 'fraction done' range of 0..1. For example, if there are two subsidiary applications with equal runtime, the first would have range 0 to 0.5 and the second would have range 0.5 to 1.
The main program must not call boinc_init() or boinc_finish(). Its logic is as follows:
read state file for each remaining subsidiary application: boinc_parse_init_data_file() aip.fraction_done_start = x aip.fraction_done_end = y boinc_write_init_data_file() run the app write state file exit(0)where x and y are the appropriate fraction done range limits.
Each subsidiary program should use the normal BOINC API, including calls to boinc_fraction_done() with values ranging from 0 to 1.
If the graphics is handled in a program that runs concurrently with
the subsidiary applications, it can call
boinc_init(false)
to designate it as a non-worker thread.
This program can then use the BOINC graphics API, but not the API
calls that handle checkpointing and status updates to BOINC.
It must call boinc_finish(false)
to terminate.
";
page_tail();
?>