123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435(*
Copyright 2013-2018 RIKEN
Copyright 2018-2025 Chiba Institude of Technology
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
*)(* Author: Masatomo Hashimoto <m.hashimoto@stair.center> *)openLabel_commontypeatomic_sub=|Read|Write|Capture|Updateletatomic_sub_to_string=function|Read->"Read"|Write->"Write"|Capture->"Capture"|Update->"Update"letatomic_sub_to_simple_string=function|Read->"read"|Write->"write"|Capture->"capture"|Update->"update"letsimd_to_stringb=ifbthen"Simd"else""letsimd_to_simple_stringb=ifbthen" simd"else""letseq_cst_to_stringb=ifbthen".SeqCst"else""letseq_cst_to_simple_stringb=ifbthen" seq_cst"else""typeconstruct_type=|C_parallel|C_sections|C_do|C_taskgroupletconstruct_type_to_string=function|C_parallel->"C_parallel"|C_sections->"C_sections"|C_do->"C_do"|C_taskgroup->"C_taskgroup"letconstruct_type_to_string_=function|C_parallel->"Parallel"|C_sections->"Sections"|C_do->"Do"|C_taskgroup->"Taskgroup"letconstruct_type_to_simple_string=function|C_parallel->"parallel"|C_sections->"sections"|C_do->"do"|C_taskgroup->"taskgroup"typet=|ERROR|Atomicofatomic_suboption*bool(* seq_cst *)|Barrier|Criticalofnameoption|Doofbool(* simd or not *)|Flush|Master|Ordered|Parallel|ParallelDoofbool(* simd or not *)|ParallelSections|ParallelWorkshare|Section|Sections|Single|Task|Taskwait|Taskyield|Threadprivate|Workshare|EndAtomic|EndCriticalofnameoption|EndDoofbool(* simd or not *)|EndMaster|EndOrdered|EndParallel|EndSections|EndSingle|EndTask|EndWorkshare|EndParallelDoofbool(* simd or not *)|EndParallelSections|EndParallelWorkshare(* 4.0 *)|Simd|EndSimd|DeclareSimdofname|Target|EndTarget|TargetData|EndTargetData|TargetUpdate|DeclareTarget|Teams|EndTeams|Distributeofbool(* simd or not *)|EndDistributeofbool(* simd or not *)|DistributeParallelDoofbool(* simd or not *)|EndDistributeParallelDoofbool(* simd or not *)|TargetTeams|EndTargetTeams|TeamsDistributeofbool(* simd or not *)|EndTeamsDistributeofbool(* simd or not *)|TargetTeamsDistributeofbool(* simd or not *)|EndTargetTeamsDistributeofbool(* simd or not *)|TeamsDistributeParallelDoofbool(* simd or not *)|EndTeamsDistributeParallelDoofbool(* simd or not *)|TargetTeamsDistributeParallelDoofbool(* simd or not *)|EndTargetTeamsDistributeParallelDoofbool(* simd or not *)|Taskgroup|EndTaskgroup|Cancelofconstruct_type|CancellationPointofconstruct_type|DeclareReductionletto_string=function|ERROR->"ERROR"|Atomic(a_opt,seq_cst)->"Atomic"^(opt_to_stringatomic_sub_to_string~prefix:"."a_opt)^(seq_cst_to_stringseq_cst)|Barrier->"Barrier"|Criticaln_opt->"Critical"^(string_opt_to_string~prefix:":"n_opt)|Dosimd->"Do"^(simd_to_stringsimd)|Flush->"Flush"|Master->"Master"|Ordered->"Ordered"|Parallel->"Parallel"|ParallelDosimd->"ParallelDo"^(simd_to_stringsimd)|ParallelSections->"ParallelSections"|ParallelWorkshare->"ParallelWorkshare"|Section->"Section"|Sections->"Sections"|Single->"Single"|Task->"Task"|Taskwait->"Taskwait"|Taskyield->"Taskyield"|Threadprivate->"Threadprivate"|Workshare->"Workshare"|EndAtomic->"EndAtomic"|EndCriticaln_opt->"EndCritical"^(string_opt_to_string~prefix:":"n_opt)|EndDosimd->"EndDo"^(simd_to_stringsimd)|EndMaster->"EndMaster"|EndOrdered->"EndOrdered"|EndParallel->"EndParallel"|EndSections->"EndSections"|EndSingle->"EndSingle"|EndTask->"EndTask"|EndWorkshare->"EndWorkshare"|EndParallelDosimd->"EndParallelDo"^(simd_to_stringsimd)|EndParallelSections->"EndParallelSections"|EndParallelWorkshare->"EndParallelWordshare"(* 4.0 *)|Simd->"Simd"|EndSimd->"EndSimd"|DeclareSimdn->"DeclareSimd:"^n|Target->"Target"|EndTarget->"EndTarget"|TargetData->"TargetData"|EndTargetData->"EndTargetData"|TargetUpdate->"TargetUpdate"|DeclareTarget->"DeclareTarget"|Teams->"Teams"|EndTeams->"EndTeams"|Distributesimd->"Distribute"^(simd_to_stringsimd)|EndDistributesimd->"EndDistribute"^(simd_to_stringsimd)|DistributeParallelDosimd->"DistributeParallelDo"^(simd_to_stringsimd)|EndDistributeParallelDosimd->"EndDistributeParallelDo"^(simd_to_stringsimd)|TargetTeams->"TargetTeams"|EndTargetTeams->"EndTargetTeams"|TeamsDistributesimd->"TeamsDistribute"^(simd_to_stringsimd)|EndTeamsDistributesimd->"EndTeamsDistribute"^(simd_to_stringsimd)|TargetTeamsDistributesimd->"TargetTeamsDistribute"^(simd_to_stringsimd)|EndTargetTeamsDistributesimd->"EndTargetTeamsDistribute"^(simd_to_stringsimd)|TeamsDistributeParallelDosimd->"TeamsDistributeParallelDo"^(simd_to_stringsimd)|EndTeamsDistributeParallelDosimd->"EndTeamsDistributeParallelDo"^(simd_to_stringsimd)|TargetTeamsDistributeParallelDosimd->"TargetTeamsDistributeParallelDo"^(simd_to_stringsimd)|EndTargetTeamsDistributeParallelDosimd->"EndTargetTeamsDistributeParallelDo"^(simd_to_stringsimd)|Taskgroup->"Taskgroup"|EndTaskgroup->"EndTaskgroup"|Cancelc->"Cancel:"^(construct_type_to_stringc)|CancellationPointc->"CancellationPoint:"^(construct_type_to_stringc)|DeclareReduction->"DeclareReduction"letto_simple_string=function|ERROR->"<error>"|Atomic(a_opt,seq_cst)->"atomic"^(opt_to_stringatomic_sub_to_simple_string~prefix:" "a_opt)^(seq_cst_to_simple_stringseq_cst)|Barrier->"barrier"|Criticaln_opt->"critical"^(string_opt_to_string~prefix:" ("~suffix:")"n_opt)|Dosimd->"do"^(simd_to_simple_stringsimd)|Flush->"flush"|Master->"master"|Ordered->"ordered"|Parallel->"parallel"|ParallelDosimd->"parallel do"^(simd_to_simple_stringsimd)|ParallelSections->"parallel sections"|ParallelWorkshare->"parallel workshare"|Section->"section"|Sections->"sections"|Single->"single"|Task->"task"|Taskwait->"taskwait"|Taskyield->"taskyield"|Threadprivate->"threadprivate"|Workshare->"workshare"|EndAtomic->"end atomic"|EndCriticaln_opt->"end critical"^(string_opt_to_string~prefix:" ("~suffix:")"n_opt)|EndDosimd->"end do"^(simd_to_simple_stringsimd)|EndMaster->"end master"|EndOrdered->"end ordered"|EndParallel->"end parallel"|EndSections->"end sections"|EndSingle->"end single"|EndTask->"end task"|EndWorkshare->"end workshare"|EndParallelDosimd->"end parallel do"^(simd_to_simple_stringsimd)|EndParallelSections->"end parallel sections"|EndParallelWorkshare->"end parallel wordshare"(* 4.0 *)|Simd->"simd"|EndSimd->"end simd"|DeclareSimdn->"declare simd ("^n^")"|Target->"target"|EndTarget->"end target"|TargetData->"target data"|EndTargetData->"end target data"|TargetUpdate->"target update"|DeclareTarget->"declare target"|Teams->"teams"|EndTeams->"end teams"|Distributesimd->"distribute"^(simd_to_simple_stringsimd)|EndDistributesimd->"end distribute"^(simd_to_simple_stringsimd)|DistributeParallelDosimd->"distribute parallel do"^(simd_to_simple_stringsimd)|EndDistributeParallelDosimd->"end distribute parallel do"^(simd_to_simple_stringsimd)|TargetTeams->"target teams"|EndTargetTeams->"end target teams"|TeamsDistributesimd->"teams distribute"^(simd_to_simple_stringsimd)|EndTeamsDistributesimd->"end teams distribute"^(simd_to_simple_stringsimd)|TargetTeamsDistributesimd->"target teams distribute"^(simd_to_simple_stringsimd)|EndTargetTeamsDistributesimd->"end target teams distribute"^(simd_to_simple_stringsimd)|TeamsDistributeParallelDosimd->"teams distribute parallel do"^(simd_to_simple_stringsimd)|EndTeamsDistributeParallelDosimd->"end teams distribute parallel do"^(simd_to_simple_stringsimd)|TargetTeamsDistributeParallelDosimd->"target teams distribute parallel do"^(simd_to_simple_stringsimd)|EndTargetTeamsDistributeParallelDosimd->"end target teams distribute parallel do"^(simd_to_simple_stringsimd)|Taskgroup->"taskgroup"|EndTaskgroup->"end taskgroup"|Cancelc->"cancel "^(construct_type_to_simple_stringc)|CancellationPointc->"cancellation point "^(construct_type_to_simple_stringc)|DeclareReduction->"declare reduction"letto_tag=function|ERROR->"ERROR",[]|Atomic(a_opt,seq_cst)->"OmpAtomic"^(opt_to_stringatomic_sub_to_stringa_opt)^(seq_cst_to_stringseq_cst),[]|Barrier->"OmpBarrier",[]|Criticaln_opt->"OmpCritical",(string_opt_to_attrname_attr_namen_opt)|Dosimd->"OmpDo"^(simd_to_stringsimd),[]|Flush->"OmpFlush",[]|Master->"OmpMaster",[]|Ordered->"OmpOrdered",[]|Parallel->"OmpParallel",[]|ParallelDosimd->"OmpParallelDo"^(simd_to_stringsimd),[]|ParallelSections->"OmpParallelSections",[]|ParallelWorkshare->"OmpParallelWorkshare",[]|Section->"OmpSection",[]|Sections->"OmpSections",[]|Single->"OmpSingle",[]|Task->"OmpTask",[]|Taskwait->"OmpTaskwait",[]|Taskyield->"OmpTaskyield",[]|Threadprivate->"OmpThreadprivate",[]|Workshare->"OmpWorkshare",[]|EndAtomic->"OmpEndAtomic",[]|EndCriticaln_opt->"OmpEndCritical",(string_opt_to_attrname_attr_namen_opt)|EndDosimd->"OmpEndDo"^(simd_to_stringsimd),[]|EndMaster->"OmpEndMaster",[]|EndOrdered->"OmpEndOrdered",[]|EndParallel->"OmpEndParallel",[]|EndSections->"OmpEndSections",[]|EndSingle->"OmpEndSingle",[]|EndTask->"OmpEndTask",[]|EndWorkshare->"OmpEndWorkshare",[]|EndParallelDosimd->"OmpEndParallelDo"^(simd_to_stringsimd),[]|EndParallelSections->"OmpEndParallelSections",[]|EndParallelWorkshare->"OmpEndParallelWordshare",[](* 4.0 *)|Simd->"OmpSimd",[]|EndSimd->"OmpEndSimd",[]|DeclareSimdn->"OmpDeclareSimd",[name_attr_name,n]|Target->"OmpTarget",[]|EndTarget->"OmpEndTarget",[]|TargetData->"OmpTargetData",[]|EndTargetData->"OmpEndTargetData",[]|TargetUpdate->"OmpTargetUpdate",[]|DeclareTarget->"OmpDeclareTarget",[]|Teams->"OmpTeams",[]|EndTeams->"OmpEndTeams",[]|Distributesimd->"OmpDistribute"^(simd_to_stringsimd),[]|EndDistributesimd->"OmpEndDistribute"^(simd_to_stringsimd),[]|DistributeParallelDosimd->"OmpDistributeParallelDo"^(simd_to_stringsimd),[]|EndDistributeParallelDosimd->"OmpEndDistributeParallelDo"^(simd_to_stringsimd),[]|TargetTeams->"OmpTargetTeams",[]|EndTargetTeams->"OmpEndTargetTeams",[]|TeamsDistributesimd->"OmpTeamsDistribute"^(simd_to_stringsimd),[]|EndTeamsDistributesimd->"OmpEndTeamsDistribute"^(simd_to_stringsimd),[]|TargetTeamsDistributesimd->"OmpTargetTeamsDistribute"^(simd_to_stringsimd),[]|EndTargetTeamsDistributesimd->"OmpEndTargetTeamsDistribute"^(simd_to_stringsimd),[]|TeamsDistributeParallelDosimd->"OmpTeamsDistributeParallelDo"^(simd_to_stringsimd),[]|EndTeamsDistributeParallelDosimd->"OmpEndTeamsDistributeParallelDo"^(simd_to_stringsimd),[]|TargetTeamsDistributeParallelDosimd->"OmpTargetTeamsDistributeParallelDo"^(simd_to_stringsimd),[]|EndTargetTeamsDistributeParallelDosimd->"OmpEndTargetTeamsDistributeParallelDo"^(simd_to_stringsimd),[]|Taskgroup->"OmpTaskgroup",[]|EndTaskgroup->"OmpEndTaskgroup",[]|Cancelc->"OmpCancel",["type",construct_type_to_string_c]|CancellationPointc->"OmpCancellationPoint",["type",construct_type_to_string_c]|DeclareReduction->"OmpDeclareReduction",[]letget_name=function|Criticaln_opt|EndCriticaln_opt->beginmatchn_optwith|Somen->n|_->raiseNot_foundend|_->raiseNot_foundletget_name_opt=function|Criticaln_opt|EndCriticaln_opt->n_opt|_->Noneletis_specification_part=function|ERROR|DeclareSimd_|DeclareTarget|Threadprivate|DeclareReduction->true|_->falseletis_execution_part=function|ERROR|Atomic_|EndAtomic|Critical_|EndCritical_|Do_|EndDo_|Master|EndMaster|Ordered|EndOrdered|Parallel|EndParallel|Sections|Section|EndSections|Single|EndSingle|Task|EndTask|Workshare|EndWorkshare|ParallelDo_|EndParallelDo_|ParallelSections|EndParallelSections|ParallelWorkshare|EndParallelWorkshare|Simd|EndSimd|Target|EndTarget|Teams|EndTeams|Distribute_|EndDistribute_|DistributeParallelDo_|EndDistributeParallelDo_|TargetTeams|EndTargetTeams|TeamsDistribute_|EndTeamsDistribute_|TargetTeamsDistribute_|EndTargetTeamsDistribute_|TeamsDistributeParallelDo_|EndTeamsDistributeParallelDo_|TargetTeamsDistributeParallelDo_|EndTargetTeamsDistributeParallelDo_|Taskgroup|EndTaskgroup|Barrier|Flush|Taskwait|Taskyield|TargetData|EndTargetData|TargetUpdate|Cancel_|CancellationPoint_->true|_->falseletanonymize=function|Atomic(_,_)->Atomic(None,false)|Critical_->CriticalNone|EndCritical_->EndCriticalNone|l->l