You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
			
				
					93 lines
				
				3.1 KiB
			
		
		
			
		
	
	
					93 lines
				
				3.1 KiB
			| 
								 
											5 years ago
										 
									 | 
							
								#include <assert.h>
							 | 
						||
| 
								 | 
							
								#include <math.h>
							 | 
						||
| 
								 
											6 years ago
										 
									 | 
							
								#include "commonmodel.h"
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								#include "common/mat.h"
							 | 
						||
| 
								 | 
							
								#include "common/timing.h"
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								void frame_init(ModelFrame* frame, int width, int height,
							 | 
						||
| 
								 | 
							
								                      cl_device_id device_id, cl_context context) {
							 | 
						||
| 
								 | 
							
								  int err;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  transform_init(&frame->transform, context, device_id);
							 | 
						||
| 
								 | 
							
								  frame->transformed_width = width;
							 | 
						||
| 
								 | 
							
								  frame->transformed_height = height;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 
											5 years ago
										 
									 | 
							
								  frame->transformed_y_cl = clCreateBuffer(context, CL_MEM_READ_WRITE,
							 | 
						||
| 
								 
											5 years ago
										 
									 | 
							
								                                           (size_t)frame->transformed_width*frame->transformed_height, NULL, &err);
							 | 
						||
| 
								 
											6 years ago
										 
									 | 
							
								  assert(err == 0);
							 | 
						||
| 
								 
											5 years ago
										 
									 | 
							
								  frame->transformed_u_cl = clCreateBuffer(context, CL_MEM_READ_WRITE,
							 | 
						||
| 
								 
											5 years ago
										 
									 | 
							
								                                           (size_t)(frame->transformed_width/2)*(frame->transformed_height/2), NULL, &err);
							 | 
						||
| 
								 
											6 years ago
										 
									 | 
							
								  assert(err == 0);
							 | 
						||
| 
								 
											5 years ago
										 
									 | 
							
								  frame->transformed_v_cl = clCreateBuffer(context, CL_MEM_READ_WRITE,
							 | 
						||
| 
								 
											5 years ago
										 
									 | 
							
								                                           (size_t)(frame->transformed_width/2)*(frame->transformed_height/2), NULL, &err);
							 | 
						||
| 
								 
											6 years ago
										 
									 | 
							
								  assert(err == 0);
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  frame->net_input_size = ((width*height*3)/2)*sizeof(float);
							 | 
						||
| 
								 
											5 years ago
										 
									 | 
							
								  frame->net_input = clCreateBuffer(context, CL_MEM_READ_WRITE,
							 | 
						||
| 
								 
											6 years ago
										 
									 | 
							
								                                frame->net_input_size, (void*)NULL, &err);
							 | 
						||
| 
								 | 
							
								  assert(err == 0);
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  loadyuv_init(&frame->loadyuv, context, device_id, frame->transformed_width, frame->transformed_height);
							 | 
						||
| 
								 | 
							
								}
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								float *frame_prepare(ModelFrame* frame, cl_command_queue q,
							 | 
						||
| 
								 | 
							
								                           cl_mem yuv_cl, int width, int height,
							 | 
						||
| 
								 | 
							
								                           mat3 transform) {
							 | 
						||
| 
								 | 
							
								  int err;
							 | 
						||
| 
								 | 
							
								  transform_queue(&frame->transform, q,
							 | 
						||
| 
								 | 
							
								                  yuv_cl, width, height,
							 | 
						||
| 
								 | 
							
								                  frame->transformed_y_cl, frame->transformed_u_cl, frame->transformed_v_cl,
							 | 
						||
| 
								 | 
							
								                  frame->transformed_width, frame->transformed_height,
							 | 
						||
| 
								 | 
							
								                  transform);
							 | 
						||
| 
								 | 
							
								  loadyuv_queue(&frame->loadyuv, q,
							 | 
						||
| 
								 | 
							
								                frame->transformed_y_cl, frame->transformed_u_cl, frame->transformed_v_cl,
							 | 
						||
| 
								 | 
							
								                frame->net_input);
							 | 
						||
| 
								 | 
							
								  float *net_input_buf = (float *)clEnqueueMapBuffer(q, frame->net_input, CL_TRUE,
							 | 
						||
| 
								 | 
							
								                                            CL_MAP_READ, 0, frame->net_input_size,
							 | 
						||
| 
								 | 
							
								                                            0, NULL, NULL, &err);
							 | 
						||
| 
								 | 
							
								  clFinish(q);
							 | 
						||
| 
								 | 
							
								  return net_input_buf;
							 | 
						||
| 
								 | 
							
								}
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								void frame_free(ModelFrame* frame) {
							 | 
						||
| 
								 | 
							
								  transform_destroy(&frame->transform);
							 | 
						||
| 
								 | 
							
								  loadyuv_destroy(&frame->loadyuv);
							 | 
						||
| 
								 
											5 years ago
										 
									 | 
							
								  clReleaseMemObject(frame->net_input);
							 | 
						||
| 
								 | 
							
								  clReleaseMemObject(frame->transformed_v_cl);
							 | 
						||
| 
								 | 
							
								  clReleaseMemObject(frame->transformed_u_cl);
							 | 
						||
| 
								 | 
							
								  clReleaseMemObject(frame->transformed_y_cl);
							 | 
						||
| 
								 
											6 years ago
										 
									 | 
							
								}
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 
											5 years ago
										 
									 | 
							
								void softmax(const float* input, float* output, size_t len) {
							 | 
						||
| 
								 | 
							
								  float max_val = -FLT_MAX;
							 | 
						||
| 
								 | 
							
								  for(int i = 0; i < len; i++) {
							 | 
						||
| 
								 | 
							
								    const float v = input[i];
							 | 
						||
| 
								 | 
							
								    if( v > max_val ) {
							 | 
						||
| 
								 | 
							
								      max_val = v;
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								  }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  float denominator = 0;
							 | 
						||
| 
								 | 
							
								  for(int i = 0; i < len; i++) {
							 | 
						||
| 
								 | 
							
								    float const v = input[i];
							 | 
						||
| 
								 | 
							
								    float const v_exp = expf(v - max_val);
							 | 
						||
| 
								 | 
							
								    denominator += v_exp;
							 | 
						||
| 
								 | 
							
								    output[i] = v_exp;
							 | 
						||
| 
								 | 
							
								  }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  const float inv_denominator = 1. / denominator;
							 | 
						||
| 
								 | 
							
								  for(int i = 0; i < len; i++) {
							 | 
						||
| 
								 | 
							
								    output[i] *= inv_denominator;
							 | 
						||
| 
								 | 
							
								  }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								}
							 | 
						||
| 
								 
											6 years ago
										 
									 | 
							
								
							 | 
						||
| 
								 | 
							
								float sigmoid(float input) {
							 | 
						||
| 
								 | 
							
								  return 1 / (1 + expf(-input));
							 | 
						||
| 
								 | 
							
								}
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								float softplus(float input) {
							 | 
						||
| 
								 | 
							
								  return log1p(expf(input));
							 | 
						||
| 
								 | 
							
								}
							 |