// examples/cartesian translated by mycpp_main // BEGIN mycpp output #include "mycpp/runtime.h" namespace cartesian { // forward declare } GLOBAL_STR(S_gpk, "--"); GLOBAL_STR(S_bum, "-|_"); GLOBAL_STR(S_Cja, "ABC"); GLOBAL_STR(S_AEi, "ab"); namespace cartesian { // declare void Cartesian(List* dims, List* out); void run_tests(); void run_benchmarks(); } // declare namespace cartesian namespace cartesian { // define void Cartesian(List* dims, List* out) { List* rest = nullptr; StackRoot _root0(&dims); StackRoot _root1(&out); StackRoot _root2(&rest); if (len(dims) == 1) { for (StrIter it(dims->at(0)); !it.Done(); it.Next()) { BigStr* ch = it.Value(); StackRoot _for(&ch ); out->append(ch); } } else { rest = Alloc>(); Cartesian(dims->slice(1), rest); for (StrIter it(dims->at(0)); !it.Done(); it.Next()) { BigStr* ch = it.Value(); StackRoot _for(&ch ); for (ListIter it(rest); !it.Done(); it.Next()) { BigStr* r = it.Value(); StackRoot _for(&r ); out->append(str_concat(ch, r)); } } } } void run_tests() { List* out = nullptr; List* tmp = nullptr; List* tmp2 = nullptr; StackRoot _root0(&out); StackRoot _root1(&tmp); StackRoot _root2(&tmp2); out = Alloc>(); tmp = NewList(std::initializer_list{S_AEi}); Cartesian(tmp, out); for (ListIter it(out); !it.Done(); it.Next()) { BigStr* s = it.Value(); StackRoot _for(&s ); print(s); } print(S_gpk); out = Alloc>(); tmp2 = NewList(std::initializer_list{S_AEi, S_bum, S_Cja}); Cartesian(tmp2, out); for (ListIter it(out); !it.Done(); it.Next()) { BigStr* s = it.Value(); StackRoot _for(&s ); print(s); } } void run_benchmarks() { int i; int n; List* out = nullptr; StackRoot _root0(&out); i = 0; n = 100000; while (i < n) { out = Alloc>(); Cartesian(NewList(std::initializer_list{S_AEi, S_bum, S_Cja}), out); i = (i + 1); mylib::MaybeCollect(); } } } // define namespace cartesian int main(int argc, char **argv) { gHeap.Init(); char* b = getenv("BENCHMARK"); if (b && strlen(b)) { // match Python's logic fprintf(stderr, "Benchmarking...\n"); cartesian::run_benchmarks(); } else { cartesian::run_tests(); } gHeap.CleanProcessExit(); }