-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathfunctions_library.cuh
306 lines (222 loc) · 15.1 KB
/
functions_library.cuh
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
#pragma once
#include <iostream>
#include <filesystem>
#include <fstream>
#include "cuda_runtime.h"
#include <curand.h>
#include "device_launch_parameters.h"
#include <thrust/system_error.h>
#include <thrust/system/cuda/error.h>
#include <sstream>
#include <curand_kernel.h>
#include <algorithm>
#include <random>
#include <chrono>
#include <string>
#include <vector>
#include <thread>
#include <mutex>
#include <shared_mutex>
#include <set>
using namespace std;
class functions_library
{
private:
shared_mutex g_mutex;
mutex gi_mutex;
// vector<T> print;
int tot_Blocks;
int tot_ThreadsperBlock;
int *CUDA_device_IDs;
int num_Cuda_devices;
int gpu_Limit;
int CPU_cores;
set<int> parent_Indexes_Unique;
vector<string> sequences;
vector<string> all_sequences_String;
vector<vector<pair<int, int>>> indexed_Source_Folders;
set<int> found_Tissue_Folder_Indexes;
// vector<string> sequence_Files;
public:
int *tot_Blocks_array;
int *tot_ThreadsperBlock_array;
string mode = "PARENT";
int genome_Size;
string cells_of_parents;
string cells_of_progeny;
string progeny_distribution_Type;
float progeny_scale, progeny_shape = 0;
float progeny_mean, progeny_dispersion = 0;
float progeny_prob;
int progeny_r;
int recombination_hotspots = 0;
int proof_reading_Activate_parent = 0;
int mutation_hotspots = 0;
float **CUDA_mutation_rates_Hotspot_generation;
int **CUDA_mutation_Regions_start_stop;
float **CUDA_A_0_mutation;
float **CUDA_T_1_mutation;
float **CUDA_G_2_mutation;
float **CUDA_C_3_mutation;
int *CUDA_stride_Array;
int **CUDA_recombination_hotspots_start_stop;
float **CUDA_A_0_Recombination;
float **CUDA_T_1_Recombination;
float **CUDA_G_2_Recombination;
float **CUDA_C_3_Recombination;
float **CUDA_A_0_fitness;
float **CUDA_T_1_fitness;
float **CUDA_G_2_fitness;
float **CUDA_C_3_fitness;
float **CUDA_A_0_survivability;
float **CUDA_T_1_survivability;
float **CUDA_G_2_survivability;
float **CUDA_C_3_survivability;
float **CUDA_A_0_probability_Proof_reading;
float **CUDA_T_1_probability_Proof_reading;
float **CUDA_G_2_probability_Proof_reading;
float **CUDA_C_3_probability_Proof_reading;
int **CUDA_sequence_Mutation_tracker;
functions_library();
functions_library(int tot_Blocks, int tot_ThreadsperBlock, int gpu_Limit, int CPU_cores);
functions_library(int *tot_Blocks_array, int *tot_ThreadsperBlock_array, int *CUDA_device_IDs, int num_Cuda_devices, int gpu_Limit, int CPU_cores);
void print_Cuda_device(int cuda_ID, int &tot_Blocks, int &tot_ThreadsperBlock);
void print_Cuda_devices(vector<string> cuda_IDs, int *CUDA_device_IDs, int num_Cuda_devices, int *tot_Blocks, int *tot_ThreadsperBlock);
void config_Folder(string location, string type_Folder);
void create_File(string location, string headers);
void create_File(string location);
void config_File_crash(string location, string headers);
void config_File_delete_create(string location, string headers);
void config_File_delete_create(string location);
void folder_Delete(string location);
void config_File_progeny(string location);
string read_Reference(string file_location, string &header, int &genome_Size);
string read_Reference(string file_location, int &genome_Size);
void split(vector<string> &line_Data, string line, char delim);
string to_Upper_Case(const string &text);
vector<string> get_Files(string folder, string extension);
int **create_INT_2D_arrays(int rows, int columns);
float **create_FLOAT_2D_arrays(int rows, int columns);
int **create_INT_2D_arrays_for_GPU(int rows, int columns);
float **create_FLOAT_2D_arrays_for_GPU(int rows, int columns);
int **create_Fill_2D_array(int rows, int columns, int fill_Value);
float **create_Fill_2D_array_FLOAT(int rows, int columns, float fill_Value);
int **Fill_2D_array_CUDA(int rows, int columns, int fill_Value, int **cuda_Progeny_numbers);
int **create_Progeny_Array(int parents_in_current_generation, int *stride_Progeny_Index, int total_Progeny, int num_Hotspots, int **cuda_Progeny_numbers, int fill_Value);
void progeny_Recombination_parents_array(int **progeny_recom_Index_Cuda, int total_Progeny, int num_Hotspots,
int *parent_and_their_cell_CUDA, int **cell_and_their_viruses_CUDA, int *per_Cell_max_viruses_CUDA,
float **CUDA_current_gen_Parent_data, int max_Count, int num_Unique_cells);
void progeny_Shuffle(int **progeny_recom_Index_Cuda, int num_Hotspots, int parents_in_current_generation, int *stride_Progeny_Index_CUDA);
float **create_current_Progeny_data(int total_Progeny, int num_Hotspots, int **progeny_recom_Index_Cuda, float **CUDA_current_gen_Parent_data, float *CUDA_parent_Proof_reading_probability, float *CUDA_progeny_Proof_reading_probability);
void array_Copy_Float(float **target_2D, float *D1_array, int row, int num_Values);
float *normal_distribution_CUDA(int num_of_values, float mean, float st_deviation);
int *poisson_distribution_CUDA(int num_of_values, float mean);
float *gamma_distribution_CUDA(int num_of_values, float shape, float scale);
int *binomial_distribution_CUDA(int num_of_values, float prob, int progeny_Number);
int *negative_binomial_distribution_CUDA(int num_of_values, float mean, float dispersion_Parameter);
float beta_Distribution(float &alpha, float &beta, mt19937 &gen);
void get_base_mutation(string query, char &base, int &mutation);
float **float_2D_Array_load_to_CUDA(float **host_Array, int rows, int columns);
int **int_2D_Array_load_to_CUDA(int **host_Array, int rows, int columns);
int *copy_1D_to_CUDA_INT(int *host_Array, int num_Values);
float *copy_1D_to_CUDA_FLOAT(float *host_Array, int num_Values);
int **load_to_Host(int **cuda_2D_Array, int rows, int columns);
float **load_to_Host_FLOAT(float **cuda_2D_Array, int rows, int columns);
int **create_CUDA_2D_int(int rows, int columns);
float **create_CUDA_2D_FLOAT(int rows, int columns);
void clear_Array_INT(int **CUDA_2D_array, int rows);
void clear_Array_FLOAT(float **CUDA_2D_array, int rows);
void clear_Array_float_CPU(float **array_cpu, int rows);
void clear_Array_int_CPU(int **array_cpu, int rows);
// ! CONFIGURE (distribution_Type == "Negative binomial")
int **progeny_distribution_CUDA(string &distribution_Type,
int &num_of_parents,
float &shape, float &scale,
float &mean, float &dispersion_Parameter,
float *cuda__Parent_finess,
float **CUDA_current_gen_Parent_data, int recombination_hotspots);
int sum_CUDA(int **cuda_Array_input, int num_Elements);
void mutate_Sequences(int **cuda_progeny_Sequences, float **CUDA_current_gen_Progeny_data, float *CUDA_progeny_Proof_reading_probability,
int current_Generation, int num_Mutation_hotspots,
float **CUDA_mutation_rates_Hotspot_generation, int **CUDA_mutation_Regions_start_stop, int **CUDA_sequence_Mutation_tracker,
int total_Progeny, int proof_Reading_Activate);
int **create_progeny_Sequences(int **cuda_parent_Sequences, int **progeny_recom_Index_Cuda, int num_Hotspots, int total_Progeny, int genome_SIZE, int **CUDA_recombination_hotspots_start_stop);
void find_Unique_values(int **CUDA_Array_2D, int total_Elements, int num_Recom_hotspots,
int start_Index,
string multi_READ, vector<string> &parent_IDs, string &parent_Sequences_Store,
int &genome_Size,
string &progeny_Sequences_Store,
int **CUDA_recombination_hotspots_start_stop,
int mutation_Activate,
float **CUDA_current_gen_Progeny_data, float *CUDA_progeny_Proof_reading_probability, int current_Generation, float **CUDA_mutation_rates_Hotspot_generation, int **CUDA_mutation_Regions_start_stop, int **CUDA_sequence_Mutation_tracker, int proof_Reading_Activate,
vector<string> &progeny_IDs);
void hard_Load_progeny(int generation, string &parent_Sequences_Store, int genome_Size,
vector<string> &parent_IDs,
int total_Progeny,
int **progeny_recom_Index_Cuda, int num_Hotspots, int **CUDA_recombination_hotspots_start_stop,
string multi_READ,
string &progeny_Sequences_Store, int mutation_Activate,
float **CUDA_current_gen_Progeny_data, float *CUDA_progeny_Proof_reading_probability, float **CUDA_mutation_rates_Hotspot_generation, int **CUDA_mutation_Regions_start_stop, int **CUDA_sequence_Mutation_tracker, int proof_Reading_Activate,
vector<string> &progeny_IDs);
string read_nFASTA(string file_location, int genome_Size);
void read_nFASTA_multi_Read(string parent_Sequences_Store, int genome_Size, int start, int stop, int *parent_Indexes, int generation_Current);
void read_nFASTA_multi_Read_CELLS(string parent_Sequences_Store, int genome_Size, int start, int stop, int **parent_Indexes_parents_and_their_Cells, int generation_Current);
void write_nFASTA_multi_WRITE(string progeny_Sequences_Store, int sum_Progeny_in_Generation, int genome_Size, int start, int stop, int **progeny_Sequences, int generation_Current);
void unique_Collect_Threads(int *unique_values_Array, int start, int stop);
void process_Cells(string &multi_READ, int &generation_Current, int &sum_Progeny_in_Generation,
int &num_of_Cells, int &start, int &stop,
vector<int> &cells_Start_Stop,
string &parent_Profiles_Store, int *parents,
string &parent_Sequences_Store,
string &progeny_File, string &progeny_Recombination_File, string &sequence_Profiles,
string &progeny_Sequences_Store, string progeny_Profile_Store,
int &processed_Cells, vector<int> &surviving_Progeny);
void read_Profiles_Single(string file_Names, float **current_gen_Parent_data, float *parent_Proof_reading_probability, int &parent_Index);
void read_Profiles_multi_Thread(int start, int stop, int cell_Start, int *parents,
float **current_gen_Parent_data, float *parent_Proof_reading_probability,
int generation_Current, string parent_Profiles_Store,
int *parent_Indexes);
void read_Profiles_multi_Thread_CELL(int start, int stop, int **parent_Indexes_parents_and_their_Cells,
float **current_gen_Parent_data, float *parent_Proof_reading_probability,
int generation_Current, string parent_Profiles_Store,
float **parent_survivability_Probabilities);
// void split(vector<string> &line_Data, string line, char delim);
int get_base_Index(string base);
int binary_Search(vector<int> &values, int value);
string clean_Line(string &line);
int **process_Reference_Sequences(vector<string> collect_Sequences, int &genome_Length, int &num_of_Sequences_current);
vector<string> convert_Sequences_Master(int **sequences, int &genome_Length, int &num_of_Sequences_current);
void sequence_to_string_Threads(int start, int stop, int **sequences, int genome_Length);
void sequence_Write_Configurator(vector<string> &sequence_Write_Store_All, vector<string> &sequence_Write_Store,
int &max_sequences_per_File, const string &folder_Location, int &last_seq_Num, vector<char> &seq_Status,
string sequence_Profiles_Location, string host, string tissue, int current_Generation);
void partial_Write_Check(vector<string> &sequence_Write_Store_All,
const string &folder_Location, int &last_seq_Num, vector<char> &seq_Status,
string sequence_Profiles_Location, string host, string tissue, int current_Generation);
void sequence_Write_Configurator(vector<string> &sequence_Write_Store_All, vector<string> &sequence_Write_Store,
int &max_sequences_per_File, const string &folder_Location, int &last_seq_Num, vector<char> &seq_Status);
void partial_Write_Check(vector<string> &sequence_Write_Store_All,
const string &folder_Location, int &last_seq_Num, vector<char> &seq_Status);
void sequence_Write_Configurator_transfer(vector<string> &sequence_Write_Store_All, vector<string> &sequence_Write_Store,
int &max_sequences_per_File, const string &folder_Location, int &last_seq_Num,
vector<char> &seq_Status,
string sequence_Profiles_Location, string host, string tissue, int current_Generation,
vector<int> &indexes_Written);
void partial_Write_Check_transfer(vector<string> &sequence_Write_Store_All,
const string &folder_Location, int &last_seq_Num,
vector<char> &seq_Status,
string sequence_Profiles_Location, string host, string tissue, int current_Generation,
vector<int> &indexes_Written);
vector<vector<pair<int, int>>> index_sequence_Folders(string &source_Target_file_Location, int &num_Tissues, int ¤t_Generation, string &multi_Read);
void thread_Index_sequence_Folders(int start, int stop, string source_Target_file_Location, int current_Generation);
vector<pair<int, int>> index_Source_folder(string &source_Target_file_Location, int &tissue_Index, int ¤t_Generation);
vector<pair<int, int>> index_Source_folder(string &source_Target_file_Location);
vector<string> find_Sequences_Master(string &source_Target_file_Location, vector<int> &sequence_List, int &tissue, vector<pair<int, int>> &indexed_Tissue_Folder, int ¤t_Generation, int &valid_Sequences);
vector<string> find_Sequences_Master(string &source_Target_file_Location, vector<int> &sequence_List, int &tissue, vector<pair<int, int>> &indexed_Tissue_Folder, int ¤t_Generation);
void thread_find_Files(int start, int stop, vector<int> sequence_List, vector<pair<int, int>> indexed_Tissue_Folder);
float date_to_Decimal(int year, int month, int day);
void decimal_to_Date(float decimal_Date, int &year, int &month, int &day);
string clean_Invisible(string line);
vector<pair<int, int>> index_sequence_Folder(string &source_Target_file_Location);
// int draw_Dead_or_Aline(float &prob);
};