mirror of
				https://github.com/xythrez/RustMP.git
				synced 2025-10-26 03:31:00 +00:00 
			
		
		
		
	Fixed minor issues in reduction, added pseudo matmul test
This commit is contained in:
		
					parent
					
						
							
								7e4b3fc25e
							
						
					
				
			
			
				commit
				
					
						ab10c5fef3
					
				
			
		
					 2 changed files with 20 additions and 15 deletions
				
			
		|  | @ -18,7 +18,6 @@ impl Student { | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| } | } | ||||||
| 
 |  | ||||||
| fn main() { | fn main() { | ||||||
|     let numbers: Vec<Student> = vec![]; |     let numbers: Vec<Student> = vec![]; | ||||||
| 
 | 
 | ||||||
|  | @ -41,18 +40,21 @@ fn main() { | ||||||
|         println!("{:?}", num); |         println!("{:?}", num); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |     let a:Vec<Vec<i32>> = vec![vec![1,2,3],vec![4,5,6],vec![7,8,9]]; | ||||||
|  |     let n = a.len(); | ||||||
|  |     let mut c = vec![vec![0;n];n]; | ||||||
|     let mut x = 0; |     let mut x = 0; | ||||||
|     // let mut y = 1;
 |  | ||||||
|     par_for! { |     par_for! { | ||||||
|         for i in 0..10, reduction x#+, { |         // I feel like we shouldn't need to capture a here
 | ||||||
|             // let mut lock = x.write();
 |         for k in 0..n, capturing a, reduction x#+, { | ||||||
|             // *lock += 7;
 |             critical! { | ||||||
|             // y *= 6;
 |                 read a; | ||||||
|             x += 2; |                 x += a[1][k]*a[k][0]; | ||||||
|  |             } | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|     println!("{:?}", x); |     c[1][0] = x; | ||||||
| 
 |     println!("{:?}", c[1][0]); | ||||||
|     // let mut local = 0;
 |     // let mut local = 0;
 | ||||||
|     // par_for! {
 |     // par_for! {
 | ||||||
|     // for i in 1..32, blocksize 1, capturing numbers, private local, {
 |     // for i in 1..32, blocksize 1, capturing numbers, private local, {
 | ||||||
|  |  | ||||||
							
								
								
									
										15
									
								
								src/lib.rs
									
										
									
									
									
								
							
							
						
						
									
										15
									
								
								src/lib.rs
									
										
									
									
									
								
							|  | @ -111,7 +111,10 @@ macro_rules! __internal_par_for { | ||||||
|             let __rmp_tpm_mtx = rustmp::ThreadPoolManager::get_instance_guard(); |             let __rmp_tpm_mtx = rustmp::ThreadPoolManager::get_instance_guard(); | ||||||
|             let __rmp_tpm = __rmp_tpm_mtx.lock().unwrap(); |             let __rmp_tpm = __rmp_tpm_mtx.lock().unwrap(); | ||||||
|             let __rmp_iters = __rmp_tpm.split_iterators($iter, $size); |             let __rmp_iters = __rmp_tpm.split_iterators($iter, $size); | ||||||
|             let __rmp_red_vals = rustmp::Capture::new(Vec::with_capacity(__rmp_iters.len())); |             let mut __rmp_red_vals = Vec::new(); | ||||||
|  |             // let mut __rmp_count = 0;
 | ||||||
|  |             $(__rmp_red_vals.push(Vec::new()); $red_name = $red_name;)* | ||||||
|  |             let __rmp_red_vals = rustmp::Capture::new(__rmp_red_vals); | ||||||
|             for iter in __rmp_iters { |             for iter in __rmp_iters { | ||||||
|                 $(let $captured = $captured.clone();)* |                 $(let $captured = $captured.clone();)* | ||||||
|                 let __rmp_red_vals = __rmp_red_vals.clone(); |                 let __rmp_red_vals = __rmp_red_vals.clone(); | ||||||
|  | @ -121,14 +124,14 @@ macro_rules! __internal_par_for { | ||||||
|                     for &$name in &iter |                     for &$name in &iter | ||||||
|                         $blk |                         $blk | ||||||
|                     let mut __rmp_temp = __rmp_red_vals.write(); |                     let mut __rmp_temp = __rmp_red_vals.write(); | ||||||
|                     $(__rmp_temp.push($red_name);)* |                     let mut __rmp_counter = 0; | ||||||
|  |                     $(__rmp_temp[__rmp_counter].push($red_name); __rmp_counter += 1;)* | ||||||
|                 })); |                 })); | ||||||
|             } |             } | ||||||
|             __rmp_tpm.exec(__rmp_tasks); |             __rmp_tpm.exec(__rmp_tasks); | ||||||
|             let mut __rmp_temp = __rmp_red_vals.read(); |             let mut __rmp_temp = __rmp_red_vals.read(); | ||||||
|             for i in 0..__rmp_temp.len() { |             let mut __rmp_counter = 0; | ||||||
|                 $($red_name = $red_name $red_op __rmp_temp[i];)* |             $($red_name = __rmp_temp[__rmp_counter].iter().fold($red_name, |x, &y| {x $red_op y}); __rmp_counter += 1;)*; | ||||||
|             } |  | ||||||
|         } |         } | ||||||
|         $(let $captured = $captured.unwrap();)* |         $(let $captured = $captured.unwrap();)* | ||||||
|     }; |     }; | ||||||
|  | @ -193,7 +196,7 @@ macro_rules! __internal_par_for { | ||||||
|     captured($($captured:ident)*), |     captured($($captured:ident)*), | ||||||
|     private($($private:ident)*), |     private($($private:ident)*), | ||||||
|     reduction($($red_name:ident, $red_op:tt)*), |     reduction($($red_name:ident, $red_op:tt)*), | ||||||
|     reduction $($new_name:ident#$new_op:tt)*, |     reduction $($new_name:ident#$new_op:tt);*, | ||||||
|     $($rem:tt)+) => { |     $($rem:tt)+) => { | ||||||
|         rustmp::__internal_par_for!( |         rustmp::__internal_par_for!( | ||||||
|             var_name($name), |             var_name($name), | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue