|
|
@@ -1,20 +1,11 @@
|
|
1
|
1
|
#[macro_use]
|
|
2
|
2
|
extern crate clap;
|
|
3
|
|
-extern crate time;
|
|
4
|
3
|
extern crate task1;
|
|
5
|
4
|
extern crate sys_info;
|
|
6
|
5
|
|
|
7
|
|
-mod tests;
|
|
8
|
|
-
|
|
9
|
|
-use std::sync::mpsc::{Sender, channel};
|
|
10
|
|
-use time::get_time;
|
|
11
|
6
|
use clap::App;
|
|
12
|
|
-use time::Duration;
|
|
13
|
|
-use std::sync::Arc;
|
|
14
|
|
-use std::sync::atomic::AtomicBool;
|
|
15
|
|
-use std::sync::atomic::Ordering::Relaxed;
|
|
16
|
|
-use std::{process, thread};
|
|
17
|
|
-use task1::{Solution, verify_product};
|
|
|
7
|
+use std::process;
|
|
|
8
|
+use task1::search_with_threads;
|
|
18
|
9
|
|
|
19
|
10
|
|
|
20
|
11
|
pub fn main() {
|
|
|
@@ -25,7 +16,7 @@ pub fn main() {
|
|
25
|
16
|
// Speichere alle Argumente in Variablen
|
|
26
|
17
|
// Falls ein Wert für ein Argument nicht existiert, lade einen default-Wert
|
|
27
|
18
|
let base = matches.value_of("base").unwrap_or("1");
|
|
28
|
|
- let diff = Arc::new(String::from(matches.value_of("difficulty").unwrap_or("1")));
|
|
|
19
|
+ let diff = String::from(matches.value_of("difficulty").unwrap_or("1"));
|
|
29
|
20
|
let cpus = sys_info::cpu_num().unwrap_or(1).to_string();
|
|
30
|
21
|
let threads = matches.value_of("threads").unwrap_or(&cpus);
|
|
31
|
22
|
let sync = matches.is_present("sync");
|
|
|
@@ -33,7 +24,7 @@ pub fn main() {
|
|
33
|
24
|
let wait = matches.is_present("wait");
|
|
34
|
25
|
let verbosity = matches.occurrences_of("verbose");
|
|
35
|
26
|
|
|
36
|
|
- let mut time_measurement = false;
|
|
|
27
|
+ let mut time = false;
|
|
37
|
28
|
|
|
38
|
29
|
// Falls irgendein Zeichen nicht hexadezimal ist, breche ab.
|
|
39
|
30
|
if diff.chars().any(|c| !c.is_digit(16)) {
|
|
|
@@ -44,7 +35,7 @@ pub fn main() {
|
|
44
|
35
|
// Falls das Unterkommando timings angegeben wurde aktiviere die Zeitmessung.
|
|
45
|
36
|
if let Some(ref sub_command) = matches.subcommand {
|
|
46
|
37
|
if sub_command.name.eq("timings") {
|
|
47
|
|
- time_measurement = true;
|
|
|
38
|
+ time = true;
|
|
48
|
39
|
}
|
|
49
|
40
|
}
|
|
50
|
41
|
|
|
|
@@ -64,7 +55,7 @@ pub fn main() {
|
|
64
|
55
|
}
|
|
65
|
56
|
|
|
66
|
57
|
// Versuche Strings der Basis und Threadanzahl zu usize zu parsen
|
|
67
|
|
- // Anderenfalls
|
|
|
58
|
+ // Anderenfalls gebe den fehlerhaften Paramter aus.
|
|
68
|
59
|
match (base.parse::<usize>(), threads.parse::<usize>()) {
|
|
69
|
60
|
(Ok(b), Ok(t)) => {
|
|
70
|
61
|
println!("Please wait...");
|
|
|
@@ -73,97 +64,12 @@ pub fn main() {
|
|
73
|
64
|
println!("Searching with {} threads", t);
|
|
74
|
65
|
}
|
|
75
|
66
|
|
|
76
|
|
- let total_start = get_time();
|
|
77
|
|
-
|
|
78
|
|
- let mut children = vec![];
|
|
79
|
|
-
|
|
80
|
|
- let (solution_tx, solution_rx) = channel();
|
|
81
|
|
- let (timing_tx, timing_rx) = channel();
|
|
82
|
|
-
|
|
83
|
|
- let found = Arc::new(AtomicBool::new(false));
|
|
84
|
|
- let m = time_measurement && verbosity > 0;
|
|
85
|
|
-
|
|
86
|
|
- if t > 1 {
|
|
87
|
|
-
|
|
88
|
|
- for i in 0..t {
|
|
89
|
|
- let diff = diff.clone();
|
|
90
|
|
- let solution_tx = solution_tx.clone();
|
|
91
|
|
- let timing_tx = timing_tx.clone();
|
|
92
|
|
- let found = found.clone();
|
|
93
|
|
-
|
|
94
|
|
- children.push(thread::spawn(move || {
|
|
95
|
|
-
|
|
96
|
|
- search_hash(
|
|
97
|
|
- &diff,
|
|
98
|
|
- b,
|
|
99
|
|
- i,
|
|
100
|
|
- t,
|
|
101
|
|
- sync,
|
|
102
|
|
- found,
|
|
103
|
|
- special,
|
|
104
|
|
- solution_tx,
|
|
105
|
|
- timing_tx,
|
|
106
|
|
- m,
|
|
107
|
|
- )
|
|
108
|
|
- }));
|
|
109
|
|
- }
|
|
110
|
|
- } else {
|
|
111
|
|
- search_hash(
|
|
112
|
|
- &diff,
|
|
113
|
|
- b,
|
|
114
|
|
- 0,
|
|
115
|
|
- 1,
|
|
116
|
|
- sync,
|
|
117
|
|
- found,
|
|
118
|
|
- special,
|
|
119
|
|
- solution_tx,
|
|
120
|
|
- timing_tx,
|
|
121
|
|
- m,
|
|
122
|
|
- )
|
|
123
|
|
- }
|
|
124
|
|
-
|
|
125
|
|
- match solution_rx.recv() {
|
|
126
|
|
- Ok(sol) => {
|
|
127
|
|
- let total_end = get_time();
|
|
128
|
|
- println!("Number: {} --> hash: {}", sol.number, sol.hash);
|
|
129
|
|
- if time_measurement && verbosity == 0 {
|
|
130
|
|
- let diff = total_end - total_start;
|
|
131
|
|
- let s = diff.num_seconds();
|
|
132
|
|
- let ms = diff.num_milliseconds();
|
|
133
|
|
- let us = diff.num_microseconds().unwrap_or(ms * 1000);
|
|
134
|
|
- println!("(Duration {}s / {}ms / {}us)", s, ms, us);
|
|
135
|
|
- }
|
|
136
|
|
- }
|
|
137
|
|
- Err(_) => {}
|
|
138
|
|
- }
|
|
139
|
|
-
|
|
140
|
|
- let mut sum_loops = 0usize;
|
|
141
|
|
- let mut sum_time: Duration = Duration::zero();
|
|
142
|
|
-
|
|
143
|
|
- for child in children {
|
|
144
|
|
-
|
|
145
|
|
- if time_measurement && verbosity > 0 {
|
|
146
|
|
- match timing_rx.recv() {
|
|
147
|
|
- Ok(stats) => {
|
|
148
|
|
- sum_time = sum_time + stats.0;
|
|
149
|
|
- sum_loops += stats.1;
|
|
150
|
|
- }
|
|
151
|
|
- Err(_) => {}
|
|
152
|
|
- }
|
|
153
|
|
- }
|
|
154
|
|
-
|
|
155
|
|
- if wait {
|
|
156
|
|
- let _ = child.join();
|
|
157
|
|
- }
|
|
|
67
|
+ let mut sync_opt = None;
|
|
|
68
|
+ if sync {
|
|
|
69
|
+ sync_opt = Some(special);
|
|
158
|
70
|
}
|
|
159
|
71
|
|
|
160
|
|
- if time_measurement && verbosity > 0 {
|
|
161
|
|
- println!("Sum Loops in Producers: {}", sum_loops);
|
|
162
|
|
- let s = sum_time.num_seconds();
|
|
163
|
|
- let ms = sum_time.num_milliseconds();
|
|
164
|
|
- let us = sum_time.num_microseconds().unwrap_or(ms * 1000);
|
|
165
|
|
- println!("Sum Duration in Producers: {}s / {}ms / {}us", s, ms, us);
|
|
166
|
|
- }
|
|
|
72
|
+ search_with_threads(t,diff,b,time, verbosity,sync_opt,wait);
|
|
167
|
73
|
|
|
168
|
74
|
}
|
|
169
|
75
|
(_, Err(_)) => {
|
|
|
@@ -177,41 +83,3 @@ pub fn main() {
|
|
177
|
83
|
};
|
|
178
|
84
|
}
|
|
179
|
85
|
|
|
180
|
|
-pub fn search_hash(
|
|
181
|
|
- hash: &String,
|
|
182
|
|
- base: usize,
|
|
183
|
|
- current: usize,
|
|
184
|
|
- total: usize,
|
|
185
|
|
- sync: bool,
|
|
186
|
|
- found: Arc<AtomicBool>,
|
|
187
|
|
- special: usize,
|
|
188
|
|
- solution_tx: Sender<Solution>,
|
|
189
|
|
- timing_tx: Sender<(Duration, usize)>,
|
|
190
|
|
- measure: bool,
|
|
191
|
|
-) {
|
|
192
|
|
- let max = <usize>::max_value();
|
|
193
|
|
- let mut n = current;
|
|
194
|
|
-
|
|
195
|
|
- let thread_start = get_time();
|
|
196
|
|
- while n < max {
|
|
197
|
|
-
|
|
198
|
|
- if n % special == 0 && found.load(Relaxed) {
|
|
199
|
|
- break;
|
|
200
|
|
- }
|
|
201
|
|
-
|
|
202
|
|
- if let Some(solution) = verify_product(base, n, hash) {
|
|
203
|
|
- if sync {
|
|
204
|
|
- found.store(true, Relaxed);
|
|
205
|
|
- }
|
|
206
|
|
-
|
|
207
|
|
- let _ = solution_tx.send(solution);
|
|
208
|
|
- break;
|
|
209
|
|
- }
|
|
210
|
|
- n += total;
|
|
211
|
|
- }
|
|
212
|
|
-
|
|
213
|
|
- if measure {
|
|
214
|
|
- let thread_end = get_time();
|
|
215
|
|
- let _ = timing_tx.send((thread_end - thread_start, n));
|
|
216
|
|
- }
|
|
217
|
|
-}
|