Mercurial > hg > Game > Cerium
view example/word_count/ppe/Exec.cc @ 2054:2e7a6f40672f draft
add param(4) in FileMapReduce.cc
author | masa |
---|---|
date | Fri, 29 Jan 2016 15:56:28 +0900 |
parents | 476fc75a5e17 |
children |
line wrap: on
line source
#include <stdio.h> #include <string.h> #include "Exec.h" #include "Func.h" /* これは必須 */ SchedDefineTask1(Exec,wordcount); static int wordcount(SchedTask *s, void *rbuf, void *wbuf) { long task_spwaned = (long)s->get_param(0); long division_size = (long)s->get_param(1); long length = (long)s->get_param(2); long out_size = (long)s->get_param(3); long allocation = task_spwaned + (long)s->x; char* i_data; unsigned long long* o_data; if (division_size) { i_data = (char*)s->get_input(rbuf,0) + allocation*division_size; o_data = (unsigned long long*)s->get_output(wbuf,1) + allocation*out_size; } else { i_data = (char*)s->get_input(0); o_data = (unsigned long long*)s->get_output(0); } unsigned long long *head_tail_flag = o_data +2; int word_flag = 0; int word_num = 0; int line_num = 0; int i = 0; head_tail_flag[0] = (i_data[0] != 0x20) && (i_data[0] != 0x0A); word_num -= 1-head_tail_flag[0]; for (; i < length; i++) { if (i_data[i] == 0x20) { // 空白 word_flag = 1; } else if (i_data[i] == 0x0A) { // 改行 line_num += 1; word_flag = 1; } else { word_num += word_flag; word_flag = 0; } } word_num += word_flag; head_tail_flag[1] = (i_data[i-1] != 0x20) && (i_data[i-1] != 0x0A); // s->printf("SPE word %d line %d\n",word_num,line_num); o_data[0] = (unsigned long long)word_num; o_data[1] = (unsigned long long)line_num; return 0; }