forked from BerkeleyLearnVerify/Scenic
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #1 from Berkeley-UAV/airsim
Airsim
- Loading branch information
Showing
27 changed files
with
238,063 additions
and
74 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,2 +1,2 @@ | ||
,point.objects.object0.position[0],point.objects.object0.position[1],point.objects.object0.position[2],rho | ||
0,6.562315408426532,0.07216232119218624,0.0,False | ||
,point.objects.object0000.position[0],point.objects.object0000.position[1],point.objects.object0000.position[2],point.objects.object0183.position[0],point.objects.object0183.position[1],point.objects.object0183.position[2],point.objects.object0184.position[0],point.objects.object0184.position[1],point.objects.object0184.position[2],point.objects.object0185.position[0],point.objects.object0185.position[1],point.objects.object0185.position[2],point.objects.object0186.position[0],point.objects.object0186.position[1],point.objects.object0186.position[2],point.objects.object0187.position[0],point.objects.object0187.position[1],point.objects.object0187.position[2],rho | ||
0,0.0,182.15847435580088,12.0,-31.57378903787832,226.96346121163208,4.980050019073486,41.66522160655998,193.8849795332645,4.980050019073486,37.4566338765801,175.27174471452568,4.980050019073486,-24.38182543180618,229.4351317177681,4.980050019073486,41.66873910321773,193.8825056642247,11.980050019073486,False |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,84 @@ | ||
import math | ||
|
||
# NOTE: add your world info path here | ||
param worldInfoPath = "examples/airsim/worldInfo/nh" | ||
|
||
model scenic.simulators.airsim.model | ||
|
||
# This demo includes 1 adversarial drone, and 1 drone (ego) looking for this adversary. | ||
|
||
class AdversaryDrone(Drone): # Drone class defined in model.scenic | ||
patrolPoints: [] | ||
patrolPointsProb: [] | ||
|
||
# Find the adversary. drone1 is the adversary target | ||
behavior FindAdversary(positions, speed = 5): | ||
# try-interrupt statements: https://scenic-lang.readthedocs.io/en/latest/reference/statements.html#try-interrupt-statement | ||
try: | ||
print("POSSIBLE POSITIONS:") | ||
print(positions) | ||
while ((distance from self to drone1) >= 1): | ||
selectedPoint = Discrete({positions[0]:drone1.patrolPointsProb[0], | ||
positions[1]:drone1.patrolPointsProb[1], | ||
positions[2]:drone1.patrolPointsProb[2], | ||
positions[3]:drone1.patrolPointsProb[3]}) | ||
|
||
print("EGO CHECKING POSITION:") | ||
print(selectedPoint) | ||
|
||
do FlyToPosition(selectedPoint, speed=speed, tolerance=1,pidMode=True) # FlyToPosition behavior defined in behaviors.scenic | ||
|
||
interrupt when (distance from self to drone1) < 15: | ||
# when I see that I am within 15 meters of adversary, follow it | ||
print("FOLLOWING ADVERSARY") | ||
do Follow(drone1, speed=10, tolerance=1, offset=(0,0,0)) # Follow behavior defined in behaviors.scenic | ||
|
||
interrupt when distance from self to drone1 < 7: | ||
# when I get within 7 meters of adversary, terminate scenario | ||
print("ADVERSARY FOUND") | ||
terminate | ||
|
||
# Adversary behavior. Patrol through given points. | ||
behavior AdversaryBehavior(points, speed): | ||
do Patrol(points, loop=True, speed=speed) # Patrol behavior defined in behaviors.scenic | ||
|
||
ground = getPrexistingObj("nh") | ||
area1 = RectangularRegion(Vector(0,0,0), 0, 10, 70) | ||
area2 = RectangularRegion(Vector(0,0,0), 0, 70, 10) | ||
|
||
workspaceArea = area1.union(area2) | ||
|
||
platforms = [] | ||
blockCount = 4 | ||
for i in range(blockCount): | ||
platforms.append(new StaticObj on ground, | ||
contained in workspaceArea, | ||
with assetName "Cone", # use * to pick a random asset in assets | ||
with parentOrientation 0, | ||
with width 5, | ||
with length 5, | ||
with height 10) | ||
|
||
points = [] | ||
for plat in platforms: | ||
point = new Point on plat | ||
points.append(point.position) | ||
|
||
adversarySpawn = Options(points) | ||
|
||
# Adversary drone spawning at random point | ||
drone1 = new AdversaryDrone at adversarySpawn + (0,0,2), | ||
with behavior AdversaryBehavior(points, speed=2) | ||
# drone1.patrolPoints = possiblePoints | ||
drone1.patrolPointsProb = [0.4, 0.2, 0.1, 0.3] # Probability distribution on the patrolPoints | ||
|
||
# ego drone spawning somwhere in the middle of the workspace area | ||
ego = new Drone at (Range(-5, 5),Range(-5, 5),10), | ||
with behavior FindAdversary(points, speed=5) | ||
|
||
|
||
|
||
# took too long to locate so terminate after x seconds | ||
terminate after 15 seconds | ||
|
||
record final (distance to drone1) as dist |
Oops, something went wrong.