chunks 20/20
parent
24a5dd57b6
commit
5857726201
|
@ -78,10 +78,3 @@ NOTES ON USE:
|
||||||
# define FCPP_LINK static
|
# define FCPP_LINK static
|
||||||
# endif
|
# endif
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifndef DrBegin
|
|
||||||
#define DrBegin() switch (s.__pc__){ case 0:;
|
|
||||||
#define DrEnd() default: Assert(!"Invalid __pc__"); }
|
|
||||||
#define DrYield(pc, n) { s.__pc__ = pc; *state = s; return(n); case pc:; }
|
|
||||||
#define DrReturn(n) { s.__pc__ = -1; return(n); }
|
|
||||||
#endif
|
|
File diff suppressed because it is too large
Load Diff
|
@ -210,7 +210,7 @@ run_experiment(Experiment *exp, char *filename, int verbose, int chunks){
|
||||||
int k, chunk_size, is_last;
|
int k, chunk_size, is_last;
|
||||||
|
|
||||||
extension = file_extension(make_string_slowly(filename));
|
extension = file_extension(make_string_slowly(filename));
|
||||||
|
|
||||||
if (match(extension, "cpp") || match(extension, "h")){
|
if (match(extension, "cpp") || match(extension, "h")){
|
||||||
file_data = dump_file(filename);
|
file_data = dump_file(filename);
|
||||||
if (file_data.size < (100 << 10)){
|
if (file_data.size < (100 << 10)){
|
||||||
|
@ -226,7 +226,9 @@ run_experiment(Experiment *exp, char *filename, int verbose, int chunks){
|
||||||
|
|
||||||
file_cpp.data = (char*)file_data.data;
|
file_cpp.data = (char*)file_data.data;
|
||||||
file_cpp.size = file_data.size;
|
file_cpp.size = file_data.size;
|
||||||
|
|
||||||
|
ld.tb = (char*)malloc(file_data.size + 1);
|
||||||
|
|
||||||
{
|
{
|
||||||
i64 start;
|
i64 start;
|
||||||
|
|
||||||
|
@ -245,15 +247,18 @@ run_experiment(Experiment *exp, char *filename, int verbose, int chunks){
|
||||||
is_last = 1;
|
is_last = 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
ld = new_lex::cpp_lex_nonalloc(ld, (char*)file_data.data + k, k, chunk_size, &exp->testing_stack);
|
int result = new_lex::cpp_lex_nonalloc(&ld, (char*)file_data.data + k, chunk_size, &exp->testing_stack);
|
||||||
|
if (result == 0 || result == 2) break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else{
|
else{
|
||||||
new_lex::cpp_lex_nonalloc(ld, (char*)file_data.data, 0, file_data.size, &exp->testing_stack);
|
new_lex::cpp_lex_nonalloc(&ld, (char*)file_data.data, file_data.size, &exp->testing_stack);
|
||||||
}
|
}
|
||||||
time.fsm += (__rdtsc() - start);
|
time.fsm += (__rdtsc() - start);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
free(ld.tb);
|
||||||
|
|
||||||
if (exp->correct_stack.count != exp->testing_stack.count){
|
if (exp->correct_stack.count != exp->testing_stack.count){
|
||||||
pass = 0;
|
pass = 0;
|
||||||
if (verbose >= 0){
|
if (verbose >= 0){
|
||||||
|
@ -315,13 +320,13 @@ show_time(Times t, int repeats, char *type){
|
||||||
f32 speed_up = ((f32)t.handcoded) / t.fsm;
|
f32 speed_up = ((f32)t.handcoded) / t.fsm;
|
||||||
printf(
|
printf(
|
||||||
"\n%s time for %d repeates\n"
|
"\n%s time for %d repeates\n"
|
||||||
OUTLINE("%d")
|
OUTLINE("%lld")
|
||||||
OUTLINE("%d")
|
OUTLINE("%lld")
|
||||||
OUTLINE("%f"),
|
OUTLINE("%f"),
|
||||||
type,
|
type,
|
||||||
repeats,
|
repeats,
|
||||||
OUTLINE_VAR(i32, t.handcoded),
|
OUTLINE_VAR(i64, t.handcoded),
|
||||||
OUTLINE_VAR(i32, t.fsm),
|
OUTLINE_VAR(i64, t.fsm),
|
||||||
OUTLINE_VAR(f32, speed_up)
|
OUTLINE_VAR(f32, speed_up)
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
@ -329,9 +334,17 @@ show_time(Times t, int repeats, char *type){
|
||||||
#define BASE_DIR "w:/4ed/data/test/"
|
#define BASE_DIR "w:/4ed/data/test/"
|
||||||
|
|
||||||
int main(){
|
int main(){
|
||||||
int repeats = 1;
|
|
||||||
int verbose_level = 0;
|
int repeats = 100;
|
||||||
int chunks = 64;
|
int verbose_level = -1;
|
||||||
|
int chunk_start = 0;
|
||||||
|
int chunk_end = 1024;
|
||||||
|
#define TEST_FILE "lexer_test.cpp"
|
||||||
|
#define SINGLE_ITEM 0
|
||||||
|
|
||||||
|
int chunks = (chunk_start > 0 && chunk_start <= chunk_end);
|
||||||
|
int c = 0;
|
||||||
|
|
||||||
char test_directory[] = BASE_DIR;
|
char test_directory[] = BASE_DIR;
|
||||||
File_List all_files = {};
|
File_List all_files = {};
|
||||||
Experiment exp = {};
|
Experiment exp = {};
|
||||||
|
@ -348,16 +361,16 @@ int main(){
|
||||||
AllowLocal(test_directory);
|
AllowLocal(test_directory);
|
||||||
AllowLocal(all_files);
|
AllowLocal(all_files);
|
||||||
|
|
||||||
#if 1
|
#if SINGLE_ITEM
|
||||||
(void)(repeats);
|
(void)(repeats);
|
||||||
(void)(verbose_level);
|
(void)(verbose_level);
|
||||||
|
|
||||||
#define TEST_FILE "crazywords.cpp"
|
|
||||||
|
|
||||||
if (chunks){
|
if (chunks){
|
||||||
begin_t(&chunk_exp_t);
|
begin_t(&chunk_exp_t);
|
||||||
printf("With chunks of %d\n", chunks);
|
printf("With chunks of %d\n", chunks);
|
||||||
run_experiment(&chunk_exp, BASE_DIR TEST_FILE, 1, chunks);
|
for (c = chunk_start; c <= chunk_end; ++c){
|
||||||
|
run_experiment(&chunk_exp, BASE_DIR TEST_FILE, 1, c);
|
||||||
|
}
|
||||||
end_t(&chunk_exp_t);
|
end_t(&chunk_exp_t);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -375,11 +388,21 @@ int main(){
|
||||||
if (all_files.infos[i].folder == 0){
|
if (all_files.infos[i].folder == 0){
|
||||||
if (chunks){
|
if (chunks){
|
||||||
begin_t(&chunk_exp_t);
|
begin_t(&chunk_exp_t);
|
||||||
run_experiment(&chunk_exp, all_files.infos[i].filename.str, verbose_level, chunks);
|
for (c = chunk_start; c <= chunk_end; ++c){
|
||||||
|
run_experiment(&chunk_exp, all_files.infos[i].filename.str, verbose_level, c);
|
||||||
|
}
|
||||||
end_t(&chunk_exp_t);
|
end_t(&chunk_exp_t);
|
||||||
}
|
}
|
||||||
|
|
||||||
begin_t(&exp_t);
|
begin_t(&exp_t);
|
||||||
run_experiment(&exp, all_files.infos[i].filename.str, verbose_level, 0);
|
if (verbose_level == -1 && chunks){
|
||||||
|
for (c = chunk_start; c <= chunk_end; ++c){
|
||||||
|
run_experiment(&exp, all_files.infos[i].filename.str, verbose_level, 0);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else{
|
||||||
|
run_experiment(&exp, all_files.infos[i].filename.str, verbose_level, 0);
|
||||||
|
}
|
||||||
end_t(&exp_t);
|
end_t(&exp_t);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -387,6 +410,7 @@ int main(){
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
if (chunks){
|
if (chunks){
|
||||||
|
printf("chunks of sizes %d through %d tested\n", chunk_start, chunk_end);
|
||||||
printf("chunked passed %d / %d tests\n", chunk_exp.passed_total, chunk_exp.test_total);
|
printf("chunked passed %d / %d tests\n", chunk_exp.passed_total, chunk_exp.test_total);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue