-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathDDDR_Read_Sensor_A.java
More file actions
52 lines (38 loc) · 1.63 KB
/
DDDR_Read_Sensor_A.java
File metadata and controls
52 lines (38 loc) · 1.63 KB
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
import javax.safetycritical.PriorityScheduler;
import javax.realtime.*;
import javax.safetycritical.*;
import java.util.Random;
// Implementaion of a periodic event handler
public class DDDR_Read_Sensor_A extends PeriodicEventHandler {
AperiodicEvent e;
long interval;
double res;
Random generator = new Random();
public DDDR_Read_Sensor_A(AperiodicEvent e1) {
super(new PriorityParameters(PriorityScheduler.instance()
.getNormPriority()), new PeriodicParameters(null,
new RelativeTime(1, 0)), new StorageConfigurationParameters(
32768, 4096, 4096), 65536, "DDDR_Read_Sensor_A");
e=e1;
}
public void handleEvent() {
AbsoluteTime now =Clock.getRealtimeClock().getTime();
interval = now.subtract(DDDR_PMMission.lastVentricleActivityTime).getMilliseconds();
if( (interval > DDDR_PMMission.PVARP) && (interval < (DDDR_PMMission.PaceInterval-DDDR_PMMission.AVI)) && (DDDR_PMMission.Activity_A_Occured==false)){
res = generator.nextDouble();
//System.out.println("Sense A < 0.30");
if(res >= 0.3){
System.out.println("Intrinsic activity sensed in A");
//Save intrinsic activity Time of Atrium
DDDR_PMMission.lastAtriumActivityTime.set(now.getMilliseconds(),now.getNanoseconds());
DDDR_PMMission.Activity_A_Occured = true;
//Reset Ventricle flag
DDDR_PMMission.Activity_V_Occured =false;
}
}else if(interval >= (DDDR_PMMission.PaceInterval - DDDR_PMMission.AVI) && DDDR_PMMission.Activity_A_Occured == false ){
//Set Atrium activity flag
DDDR_PMMission.Activity_A_Occured = true;
e.fire();
}
}
}//end class