-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathDDDR_Read_Sensor_V.java
More file actions
60 lines (45 loc) · 2.05 KB
/
DDDR_Read_Sensor_V.java
File metadata and controls
60 lines (45 loc) · 2.05 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
52
53
54
55
56
57
58
59
60
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_V extends PeriodicEventHandler {
Random generator = new Random();
AperiodicEvent e;
DDDR_ModeChange fmc = new DDDR_ModeChange();
long interval;
double res;
public DDDR_Read_Sensor_V(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.lastAtriumActivityTime).getMilliseconds();
if((interval <= DDDR_PMMission.AVI) && (DDDR_PMMission.Activity_V_Occured == false)) {
res = generator.nextDouble();
//System.out.println("Sensed V < 0.90");
if(res >= 0.9){
System.out.println("Intrinsic activity sensed in V");
//Save intrinsic activity Time of Ventricle
DDDR_PMMission.lastVentricleActivityTime.set(Clock.getRealtimeClock().getTime().getMilliseconds(),Clock.getRealtimeClock().getTime().getNanoseconds());
DDDR_PMMission.Activity_V_Occured=true;
////Reset Atrium flag
DDDR_PMMission.Activity_A_Occured=false;
// mode update changing due to completion of one cycle (Atrium and Ventricle pacing or sensing)
fmc.funModeChange(DDDR_PMMission.oldTime, now);
DDDR_PMMission.oldTime.set(now.getMilliseconds(),now.getNanoseconds());
}
}else if((interval > DDDR_PMMission.AVI) && (DDDR_PMMission.Activity_V_Occured == false)){
//Set Ventricle activity flag
DDDR_PMMission.Activity_V_Occured = true;
e.fire();
// mode update changing due to completion of one cycle (Atrium and Ventricle pacing or sensing)
fmc.funModeChange(DDDR_PMMission.oldTime, now);
DDDR_PMMission.oldTime.set(now.getMilliseconds(),now.getNanoseconds());
}
}
}//end class