diff --git a/launch/sim/orocos_component_params.launch b/launch/sim/orocos_component_params.launch index 0b3a45e..7323e32 100644 --- a/launch/sim/orocos_component_params.launch +++ b/launch/sim/orocos_component_params.launch @@ -39,10 +39,10 @@ static_deadband: [0.001, 0.001, 0.001, 0.01, 0.01, 0.01, 0.01] static_effort: [4.0, 1.0, 2.0, 1.0, 0.2, 0.2, 0.05] static_eps: 0.020 - #i_gains: [5.0, 5.0, 4.0, 3.0, 0.3, 0.2, 0.2] - #i_clamps: [0.1, 0.1, 0.1, 0.1, 0.1, 0.1, 0.1] + i_gains: [5.0, 5.0, 5.0, 5.0, 5.0, 3.0, 3.0] + i_clamps: [0.5, 0.5, 0.5, 0.8, 0.8, 0.5, 0.5] compensate_friction: false - verbose: false + verbose: true p_gains: [350.0, 300.0, 200.0, 170.0, 12.0, 12.0, 1.0] @@ -57,10 +57,10 @@ velocity_tolerance: [2.0, 2.0, 2.0, 2.0, 2.0, 2.0, 2.0] - p_gains: [350.0, 350.0, 350.0, 300.0, 25.0, 25.0, 2.0] - d_gains: [30.0, 30.0, 20.0, 10.0, 4.5, 3.5, 0.8] - position_tolerance: [0.5, 0.5, 0.5, 0.5, 0.5, 0.5, 0.5] - velocity_tolerance: [2.0, 2.0, 2.0, 2.0, 2.0, 2.0, 2.0] + p_gains: [300.0, 250.0, 250.0, 200.0, 25.0, 25.0, 2.0] + d_gains: [18.0, 18.0, 15.0, 15.0, 10.5, 4.5, 3.5] + position_tolerance: [1.0, 1.0, 1.0, 1.0, 0.5, 0.5, 0.5] + velocity_tolerance: [4.0, 3.0, 4.0, 3.0, 4.0, 2.0, 2.0] @@ -93,12 +93,12 @@ max_jerks: [2.5, 2.5, 2.5, 2.5, 5.5, 5.5, 5.0] - position_tolerance: [0.5, 0.5, 0.5, 0.5, 0.5, 0.5, 0.5] - velocity_tolerance: [3.2, 3.2, 3.2, 3.2, 3.0, 3.0, 3.0] + position_tolerance: [1.5, 1.5, 1.5, 1.5, 1.0, 0.5, 0.5] + velocity_tolerance: [5.2, 5.2, 5.2, 4.2, 3.0, 3.0, 3.0] goal_position_tolerance: [0.05, 0.05, 0.05, 0.05, 0.1, 0.1, 0.1] goal_velocity_tolerance: [0.5, 0.5, 0.5, 0.5, 0.5, 0.5, 0.5] - max_velocities: [1.5, 1.5, 1.5, 1.5, 1.5, 1.5, 1.5] - max_accelerations: [1.5, 1.5, 1.5, 4.0, 8.0, 8.0, 8.0] + max_velocities: [2.5, 2.5, 2.5, 3.5, 3.5, 5.5, 5.5] + max_accelerations: [1.5, 1.5, 1.5, 1.5, 1.5, 1.5, 1.5] max_jerks: [2.5, 2.5, 2.5, 2.5, 5.5, 5.5, 5.0] @@ -109,15 +109,15 @@ target_frame: "" #$(arg tf_prefix)/cmd singularity_avoidance_gain: 0.0 joint_center_gain: 0.0 - linear_p_gain: 500.0 + linear_p_gain: 600.0 linear_d_gain: 100.0 angular_p_gain: 5.0 - angular_d_gain: 1.5 + angular_d_gain: 0.7 #angular_p_gain: 5.0 #angular_d_gain: 1.5 - linear_effort_threshold: 50.0 + linear_effort_threshold: 5000.0 linear_position_threshold: 0.1 - angular_effort_threshold: 5.0 + angular_effort_threshold: 500.0 angular_position_threshold: 1.5 nullspace_damping: 0.0 jointspace_damping: 0.0 diff --git a/launch/sim/wam7_sim.launch b/launch/sim/wam7_sim.launch index d6e3b37..82fd619 100644 --- a/launch/sim/wam7_sim.launch +++ b/launch/sim/wam7_sim.launch @@ -10,6 +10,7 @@ --> + @@ -33,7 +34,7 @@ - + @@ -83,7 +84,7 @@ command="$(find xacro)/xacro.py '$(find lcsr_barrett)/models/stage.urdf.xacro'" /> - @@ -115,7 +116,7 @@ # WAM Parameters wam: - velocity_cutoff_frequency: 300 + velocity_cutoff_frequency: 20 # Hand Parameters hand: @@ -123,20 +124,21 @@ admittance_gain: 0.1 trap_vel: 2.0 trap_accel: 10.0 - p_gain: 10.0 + p_gain: 1.7 i_gain: 0.0 i_clamp: 0.0 - d_gain: 0.02 - max_torque: 3.0 + d_gain: 0.0 + max_torque: 5.0 stop_torque: 3.0 spread_p_gain: 5.0 spread_d_gain: 0.0 finger_acceleration: 1.0 + outer_coupling_p_gain: 3.0 + outer_coupling_d_gain: 0.0 + # disabled essentially inner_breakaway_gain: 0.001 - inner_breakaway_torque: 0.5 + inner_breakaway_torque: 1000.0 outer_recouple_velocity: 1.0 - outer_coupling_p_gain: 5.0 - outer_coupling_d_gain: 0.1 diff --git a/launch/sim/wam7_sim.urdf.xacro b/launch/sim/wam7_sim.urdf.xacro index bfd7b3a..c0fe42c 100644 --- a/launch/sim/wam7_sim.urdf.xacro +++ b/launch/sim/wam7_sim.urdf.xacro @@ -12,10 +12,10 @@ $(arg lua_script) - ~ + /gazebo B08 wam - 0.033 + 0.33 raw_planning_scene @@ -27,7 +27,7 @@ - + diff --git a/launch/wam7_planning.launch b/launch/wam7_planning.launch index a2e67ce..ccecc94 100644 --- a/launch/wam7_planning.launch +++ b/launch/wam7_planning.launch @@ -1,4 +1,7 @@ + + + @@ -11,10 +14,15 @@ + + - - + + + + + @@ -24,7 +32,7 @@ - + diff --git a/lua/lcsr_barrett.lua b/lua/lcsr_barrett.lua index c32f789..66c9161 100644 --- a/lua/lcsr_barrett.lua +++ b/lua/lcsr_barrett.lua @@ -15,6 +15,9 @@ function lcsr_barrett(sim, prefix) --[[ set up TF component -]] depl:import("rtt_tf") depl:loadComponent("tf","rtt_tf::RTT_TF") + --depl:setActivity( "tf" 0.01, + --depl:getAttribute("HighestPriority"):get(), + --rtt.globals.ORO_SCHED_OTHER) tf = depl:getPeer("tf") tf:configure() tf:start() diff --git a/lua/load_controllers.lua b/lua/load_controllers.lua index 5ebf8c2..218b115 100644 --- a/lua/load_controllers.lua +++ b/lua/load_controllers.lua @@ -81,6 +81,7 @@ function load_controllers(depl, scheme, prefix) connect(wam, "position_out", ik, "positions_in"); connect( ik, "trajectories_out", traj_rml, "joint_traj_cmd_in"); ik:connectPeers(tf) + ik:connectServices(tf) --[[ Create a cartesian interpolator --]] cart_servo_name = prefix.."cart_servo" @@ -91,6 +92,7 @@ function load_controllers(depl, scheme, prefix) connect(wam, "position_out", cart_servo, "positions_in"); connect( cart_servo, "framevel_out", jtns, "framevel_in"); cart_servo:connectPeers(tf) + cart_servo:connectServices(tf) --[[ Create a coulomb friction compensator --]] coulomb_name = prefix.."coulomb" diff --git a/models/manipulation_platform.material b/models/manipulation_platform.material new file mode 100644 index 0000000..f3edb01 --- /dev/null +++ b/models/manipulation_platform.material @@ -0,0 +1,16 @@ + +material lcsr_barrett/ManipulationPlatform +{ + receive_shadows on + + technique + { + pass main + { + ambient 0.7 0.7 0.7 1.0 + diffuse 0.2 0.2 0.2 1.0 + specular 0.1 0.1 0.1 1.000000 0.00500 + } + } +} + diff --git a/models/manipulation_platform.sdf b/models/manipulation_platform.sdf new file mode 100644 index 0000000..a61e9b8 --- /dev/null +++ b/models/manipulation_platform.sdf @@ -0,0 +1,79 @@ + + + + + 0 0 0.5 0 0 0 + true + + + 10.0 + + + 1.0 + 0.0 + 0.0 + 1.0 + 0.0 + 1.0 + + + + + + 1 1 1 + + + + + + + 1 1 1 + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + 50000 + 8 + + + diff --git a/models/manipulation_platform.sdf.xacro b/models/manipulation_platform.sdf.xacro new file mode 100644 index 0000000..19a0cb3 --- /dev/null +++ b/models/manipulation_platform.sdf.xacro @@ -0,0 +1,61 @@ + + + + + true + + true + + 50000 + 8 + + + 10.0 + + 1.0 + 0.0 + 0.0 + 1.0 + 0.0 + 1.0 + + + + + + 1 1 0.1 + + + + + + + 1.0 + + + + + + + + + + + + + + false + + + + + 1 1 0.1 + + + + + + diff --git a/models/manipulation_platform.urdf.xacro b/models/manipulation_platform.urdf.xacro index b85d240..14ebad6 100644 --- a/models/manipulation_platform.urdf.xacro +++ b/models/manipulation_platform.urdf.xacro @@ -21,13 +21,13 @@ - + - + diff --git a/models/meshes/manipulation_platform.blend b/models/meshes/manipulation_platform.blend index 62b5032..2e4e64f 100644 Binary files a/models/meshes/manipulation_platform.blend and b/models/meshes/manipulation_platform.blend differ diff --git a/models/meshes/manipulation_platform.dae b/models/meshes/manipulation_platform.dae index b009d46..98600a1 100644 --- a/models/meshes/manipulation_platform.dae +++ b/models/meshes/manipulation_platform.dae @@ -3,10 +3,10 @@ Blender User - Blender 2.71.0 commit date:2014-06-12, commit time:18:39, hash:169c95b + Blender 2.76.0 commit date:2015-11-03, commit time:10:56, hash:f337fea - 2015-09-07T18:11:28 - 2015-09-07T18:11:28 + 2016-02-22T16:51:21 + 2016-02-22T16:51:21 Z_UP @@ -90,7 +90,7 @@ 1 3 0.15 - 75 + 1.308997 1 1 0 @@ -101,10 +101,24 @@ - + + + canvas.png + + - + + + + canvas_png + + + + + canvas_png-surface + + @@ -114,14 +128,17 @@ 0 0 0 1 - 0.06400918 0.02817589 0.01199546 1 + - 0.1185567 0.03223746 0.01195687 1 + 50 + + + 1 @@ -131,17 +148,17 @@ - - + + - 0.4488365 0.2494305 0 0.4488365 -0.2494307 0 -0.4488366 -0.2494307 0 -0.4488363 0.2494306 0 0.4488366 0.2494304 0.3048 0.4488362 -0.2494308 0.3048 -0.4488367 -0.2494306 0.3048 -0.4488365 0.2494305 0.3048 + 0.08142977 0.649546 0 0.08142977 -0.6495462 0 -0.08142983 -0.6495462 0 -0.08142983 0.6495463 0 0.08142977 0.6495457 0.3048 0.08142971 -0.6495466 0.3048 -0.08142989 -0.649546 0.3048 -0.08142983 0.649546 0.3048 0.08142977 0 0 0 0.6495461 0 0.08142977 0.6495459 0.1524 0 -0.6495462 0 0.08142971 -0.6495464 0.1524 -0.08142983 0 0 -0.08142983 -0.6495461 0.1524 -0.08142983 0.6495462 0.1524 0.08142977 -3.96584e-7 0.3048 0 0.6495459 0.3048 0 -0.6495463 0.3048 -0.08142983 0 0.3048 0 0 0 0 -1.91247e-7 0.3048 0.08142977 -2.42581e-7 0.1524 0 -0.6495462 0.1524 -0.08142983 0 0.1524 0 0.649546 0.1524 - + @@ -149,23 +166,33 @@ - 0 0 -1 0 0 1 1 -1.01559e-6 9.77766e-7 -2.65596e-7 -1 2.44442e-7 -1 3.58444e-7 -2.9333e-7 1.32798e-7 1 2.44442e-7 0 0 -1 0 0 1 1 0 -6.84436e-7 0 -1 -5.37771e-7 -1 4.77926e-7 -4.88883e-7 1.32798e-7 1 2.44442e-7 + 0 0 -1 0 0 1 1 0 0 -3.65988e-6 -1 0 -1 0 0 2.19593e-6 1 0 5.63452e-7 0 1 1 0 1.95553e-7 1 0 0 1 0 0 -1.46395e-6 -1 6.00374e-7 -2.19593e-6 -1 -7.03493e-7 -3.65988e-6 -1 1.06326e-6 -1 0 -1.95553e-7 -1 0 -1.95553e-7 -1 0 0 2.19593e-6 1 6.00374e-7 1.46395e-6 1 -5.66e-7 1.46395e-6 1 6.00374e-7 1 0 0 -1.46395e-6 -1 -6.00374e-7 -1 0 -1.95553e-7 2.19593e-6 1 1.20075e-6 -5.63452e-7 0 1 1 0 0 1 0 -1.95553e-7 1 0 0 0 -1 6.00374e-7 0 -1 -6.00374e-7 -2.19593e-6 -1 -1.80112e-6 -1 0 0 -1 0 -1.95553e-7 1.46395e-6 1 1.20075e-6 2.19593e-6 1 1.80112e-6 1.46395e-6 1 6.00374e-7 - + + + 0.4982646 0.5 0.4376332 0.09105581 0.2612134 0.150125 0.4982646 0.4999999 0.3218448 0.5590693 0.2612133 0.1501252 0.5267158 0.6918975 0.2545875 0.783012 0.2403619 0.6870632 0.5267159 0.6918974 0.350296 0.7509667 0.3360704 0.6550179 0.5124904 0.5959487 0.5267161 0.6918973 0.7988441 0.6007829 0.4982646 0.5 0.3218448 0.5590693 0.3360704 0.6550179 0.558896 0.9089442 0.4982646 0.5 0.3218448 0.5590693 0.7353157 0.8498748 0.6746845 0.4409307 0.4982646 0.5 0.6746845 0.4409307 0.6140531 0.03198659 0.4376332 0.09105581 0.6746844 0.4409305 0.4982646 0.4999999 0.4376332 0.09105581 0.735316 0.8498745 0.5588961 0.908944 0.4982646 0.4999999 0.5588961 0.908944 0.3824761 0.9680133 0.3218448 0.5590693 0.5124902 0.5959488 0.2403619 0.6870632 0.2261363 0.5911145 0.7846184 0.5048342 0.5124902 0.5959488 0.4982646 0.5 0.7988439 0.600783 0.5267158 0.6918975 0.5124902 0.5959488 0.5124902 0.5959488 0.3360704 0.6550179 0.3218448 0.5590693 0.6889101 0.5368794 0.5124902 0.5959488 0.4982646 0.5 0.7031357 0.6328282 0.5267159 0.6918974 0.5124902 0.5959488 0.4982647 0.5 0.5124904 0.5959487 0.7846187 0.5048342 0.2403621 0.6870632 0.5124904 0.5959487 0.4982647 0.5 0.2545878 0.7830118 0.5267161 0.6918973 0.5124904 0.5959487 0.5267161 0.6918973 0.5124903 0.5959487 0.3360704 0.6550179 0.6889101 0.5368794 0.5124903 0.5959487 0.5267161 0.6918973 0.6746845 0.4409307 0.4982646 0.5 0.5124903 0.5959487 0.3218448 0.5590693 0.4982646 0.5 0.2612134 0.150125 0.4376332 0.09105581 0.4982646 0.4999999 0.2612133 0.1501252 0.5124902 0.5959488 0.5267158 0.6918975 0.2403619 0.6870632 0.5124902 0.5959488 0.5267159 0.6918974 0.3360704 0.6550179 0.7846187 0.5048342 0.5124904 0.5959487 0.7988441 0.6007829 0.5124903 0.5959487 0.4982646 0.5 0.3360704 0.6550179 0.3824762 0.9680134 0.558896 0.9089442 0.3218448 0.5590693 0.558896 0.9089442 0.7353157 0.8498748 0.4982646 0.5 0.4982646 0.5 0.6746845 0.4409307 0.4376332 0.09105581 0.614053 0.03198635 0.6746844 0.4409305 0.4376332 0.09105581 0.6746844 0.4409305 0.735316 0.8498745 0.4982646 0.4999999 0.4982646 0.4999999 0.5588961 0.908944 0.3218448 0.5590693 0.4982646 0.5 0.5124902 0.5959488 0.2261363 0.5911145 0.7703928 0.4088855 0.7846184 0.5048342 0.4982646 0.5 0.7846184 0.5048342 0.7988439 0.600783 0.5124902 0.5959488 0.4982646 0.5 0.5124902 0.5959488 0.3218448 0.5590693 0.6746845 0.4409307 0.6889101 0.5368794 0.4982646 0.5 0.6889101 0.5368794 0.7031357 0.6328282 0.5124902 0.5959488 0.770393 0.4088854 0.4982647 0.5 0.7846187 0.5048342 0.2261363 0.5911145 0.2403621 0.6870632 0.4982647 0.5 0.2403621 0.6870632 0.2545878 0.7830118 0.5124904 0.5959487 0.3502961 0.7509667 0.5267161 0.6918973 0.3360704 0.6550179 0.703136 0.6328281 0.6889101 0.5368794 0.5267161 0.6918973 0.6889101 0.5368794 0.6746845 0.4409307 0.5124903 0.5959487 + + + + + + + - + - 3 3 3 3 3 3 3 3 3 3 3 3 -

1 0 2 0 3 0 7 1 6 1 5 1 4 2 5 2 1 2 5 3 6 3 2 3 2 4 6 4 7 4 0 5 3 5 7 5 0 6 1 6 3 6 4 7 7 7 5 7 0 8 4 8 1 8 1 9 5 9 2 9 3 10 2 10 7 10 4 11 0 11 7 11

+ + 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 +

20 0 0 11 0 1 2 0 2 21 1 3 19 1 4 6 1 5 16 2 6 5 2 7 12 2 8 18 3 9 6 3 10 14 3 11 24 4 12 19 4 13 7 4 14 9 5 15 3 5 16 15 5 17 9 0 18 20 0 19 13 0 20 0 0 21 8 0 22 20 0 23 8 0 24 1 0 25 11 0 26 16 6 27 21 6 28 18 6 29 4 1 30 17 1 31 21 1 32 17 1 33 7 1 34 19 1 35 22 7 36 12 7 37 1 7 38 10 8 39 22 8 40 8 8 41 4 9 42 16 9 43 22 9 44 23 10 45 14 10 46 2 10 47 12 11 48 23 11 49 11 11 50 5 12 51 18 12 52 23 12 53 13 13 54 24 13 55 15 13 56 14 14 57 24 14 58 13 14 59 6 15 60 19 15 61 24 15 62 17 16 63 25 16 64 15 16 65 10 17 66 25 17 67 17 17 68 0 18 69 9 18 70 25 18 71 13 0 72 20 0 73 2 0 74 18 1 75 21 1 76 6 1 77 22 19 78 16 19 79 12 19 80 23 20 81 18 20 82 14 20 83 15 21 84 24 21 85 7 21 86 25 22 87 9 22 88 15 22 89 3 0 90 9 0 91 13 0 92 9 0 93 0 0 94 20 0 95 20 0 96 8 0 97 11 0 98 5 1 99 16 1 100 18 1 101 16 23 102 4 23 103 21 23 104 21 1 105 17 1 106 19 1 107 8 24 108 22 24 109 1 24 110 0 25 111 10 25 112 8 25 113 10 26 114 4 26 115 22 26 116 11 27 117 23 27 118 2 27 119 1 28 120 12 28 121 11 28 122 12 29 123 5 29 124 23 29 125 3 4 126 13 4 127 15 4 128 2 30 129 14 30 130 13 30 131 14 31 132 6 31 133 24 31 134 7 32 135 17 32 136 15 32 137 4 33 138 10 33 139 17 33 140 10 34 141 0 34 142 25 34 143

@@ -183,10 +210,12 @@
1 0 0 0 0 1 0 0 0 0 1 0 0 0 0 1 - + - + + + diff --git a/models/meshes/manipulation_platform.stl b/models/meshes/manipulation_platform.stl index 4e0a2db..d3969b5 100644 Binary files a/models/meshes/manipulation_platform.stl and b/models/meshes/manipulation_platform.stl differ diff --git a/models/meshes/platform.blend b/models/meshes/platform.blend new file mode 100644 index 0000000..2e5fa93 Binary files /dev/null and b/models/meshes/platform.blend differ diff --git a/models/meshes/platform.blend1 b/models/meshes/platform.blend1 new file mode 100644 index 0000000..1a2d25b Binary files /dev/null and b/models/meshes/platform.blend1 differ diff --git a/models/meshes/platform.dae b/models/meshes/platform.dae new file mode 100644 index 0000000..40758e7 --- /dev/null +++ b/models/meshes/platform.dae @@ -0,0 +1,220 @@ + + + + + Blender User + Blender 2.76.0 commit date:2015-11-03, commit time:10:56, hash:f337fea + + 2016-02-25T00:21:50 + 2016-02-25T00:21:50 + + Z_UP + + + + + + + 49.13434 + 1.777778 + 0.1 + 100 + + + + + + 0 + 0 + 0 + + + + + + + + + 1 1 1 + 1 + 0 + 0.00111109 + + + + + 0.000999987 + 1 + 0.1 + 0.1 + 1 + 1 + 1 + 2 + 0 + 1 + 1 + 1 + 1 + 1 + 0 + 2880 + 2 + 30.002 + 1.000799 + 0.04999995 + 29.99998 + 1 + 2 + 0 + 0 + 1 + 1 + 1 + 1 + 8192 + 1 + 1 + 0 + 1 + 1 + 1 + 3 + 0 + 0 + 0 + 0 + 0 + 1 + 1 + 1 + 3 + 0.15 + 75 + 1 + 1 + 0 + 1 + 1 + 0 + + + + + + + + + + + + 0 0 0 1 + + + 0 0 0 1 + + + 0.64 0.64 0.64 1 + + + 0.5 0.5 0.5 1 + + + 50 + + + 1 + + + + + + + + + + + + + + + + -1 -1 -0.06669718 -0.986477 -0.986477 0.133867 -1 1 -0.06669718 -0.986477 0.986477 0.133867 1 -1 -0.06669718 0.986477 -0.986477 0.133867 1 1 -0.06669718 0.986477 0.986477 0.133867 -1 -1 0.02569544 -0.986477 0 0.133867 -1 1 0.02569544 -1 0 -0.06669718 0 0.986477 0.133867 1 1 0.02569544 0 1 -0.06669718 0.986477 0 0.133867 1 -1 0.02569544 1 0 -0.06669718 0 -0.986477 0.133867 0 -1 -0.06669718 0 0 0.133867 0 0 -0.06669718 0 -1 0.02569544 1 0 0.02569544 0 1 0.02569544 -1 0 0.02569544 -1 0 0.1180881 -1 1 0.1180881 0 1 0.1180881 1 1 0.1180881 1 0 0.1180881 1 -1 0.1180881 0 -1 0.1180881 -1 -1 0.1180881 -0.4932385 0 0.133867 0.4932385 0 0.133867 0 -0.4932385 0.133867 0 0.4932385 0.133867 -0.986477 0.4932385 0.133867 0.4932385 0.986477 0.133867 0.986477 -0.4932385 0.133867 -0.4932385 -0.986477 0.133867 -0.986477 -0.4932385 0.133867 -0.4932385 0.986477 0.133867 0.986477 0.4932385 0.133867 0.4932385 -0.986477 0.133867 0.4932385 0.4932385 0.133867 0.4932385 -0.4932385 0.133867 -0.4932385 -0.4932385 0.133867 -0.4932385 0.4932385 0.133867 -0.7398578 0 0.133867 0.2466192 0 0.133867 0 -0.7398578 0.133867 0 0.2466192 0.133867 -0.986477 0.7398578 0.133867 0.7398578 0.986477 0.133867 0.986477 -0.7398578 0.133867 -0.7398578 -0.986477 0.133867 -0.986477 -0.2466192 0.133867 -0.2466192 0.986477 0.133867 0.986477 0.2466192 0.133867 0.2466192 -0.986477 0.133867 -0.2466192 0 0.133867 0.7398578 0 0.133867 0 -0.2466192 0.133867 0 0.7398578 0.133867 -0.986477 0.2466192 0.133867 0.2466192 0.986477 0.133867 0.986477 -0.2466192 0.133867 -0.2466192 -0.986477 0.133867 -0.986477 -0.7398578 0.133867 -0.7398578 0.986477 0.133867 0.986477 0.7398578 0.133867 0.7398578 -0.986477 0.133867 0.2466192 0.4932385 0.133867 0.7398578 0.4932385 0.133867 0.4932385 0.2466192 0.133867 0.4932385 0.7398578 0.133867 0.2466192 -0.4932385 0.133867 0.7398578 -0.4932385 0.133867 0.4932385 -0.7398578 0.133867 0.4932385 -0.2466192 0.133867 -0.7398578 -0.4932385 0.133867 -0.2466192 -0.4932385 0.133867 -0.4932385 -0.7398578 0.133867 -0.4932385 -0.2466192 0.133867 -0.7398578 0.4932385 0.133867 -0.2466192 0.4932385 0.133867 -0.4932385 0.2466192 0.133867 -0.4932385 0.7398578 0.133867 -0.2466192 0.7398578 0.133867 -0.2466192 0.2466192 0.133867 -0.7398578 0.2466192 0.133867 -0.2466192 -0.2466192 0.133867 -0.2466192 -0.7398578 0.133867 -0.7398578 -0.7398578 0.133867 0.7398578 -0.2466192 0.133867 0.7398578 -0.7398578 0.133867 0.2466192 -0.7398578 0.133867 0.7398578 0.7398578 0.133867 0.7398578 0.2466192 0.133867 0.2466192 0.2466192 0.133867 0.2466192 0.7398578 0.133867 0.2466192 -0.2466192 0.133867 -0.7398578 -0.2466192 0.133867 -0.7398578 0.7398578 0.133867 0.5 1 -0.06669718 0.5 1 0.1180881 0.5 1 0.02569544 0.75 1 0.02569544 0.75 1 0.1180881 0.75 1 -0.06669718 0.25 1 -0.06669718 0.25 1 0.1180881 0.25 1 0.02569544 -0.5 1 0.02569544 -0.5 1 -0.06669718 -0.5 1 0.1180881 -0.25 1 -0.06669718 -0.25 1 0.02569544 -0.25 1 0.1180881 -0.75 1 0.02569544 -0.75 1 -0.06669718 -0.75 1 0.1180881 -1 0.5 0.1180881 -1 0.5 0.02569544 -1 0.5 -0.06669718 -1 0.75 0.1180881 -1 0.75 -0.06669718 -1 0.75 0.02569544 -1 0.25 0.1180881 -1 0.25 0.02569544 -1 0.25 -0.06669718 -1 -0.5 -0.06669718 -1 -0.5 0.1180881 -1 -0.5 0.02569544 -1 -0.75 -0.06669718 -1 -0.75 0.1180881 -1 -0.75 0.02569544 -1 -0.25 0.02569544 -1 -0.25 0.1180881 -1 -0.25 -0.06669718 -0.5 -1 0.02569544 -0.5 -1 0.1180881 -0.5 -1 -0.06669718 -0.75 -1 0.1180881 -0.75 -1 0.02569544 -0.75 -1 -0.06669718 -0.25 -1 0.02569544 -0.25 -1 0.1180881 -0.25 -1 -0.06669718 0.5 -1 -0.06669718 0.5 -1 0.02569544 0.5 -1 0.1180881 0.25 -1 -0.06669718 0.25 -1 0.1180881 0.25 -1 0.02569544 0.75 -1 -0.06669718 0.75 -1 0.02569544 0.75 -1 0.1180881 1 -0.5 -0.06669718 1 -0.5 0.1180881 1 -0.5 0.02569544 1 -0.25 -0.06669718 1 -0.25 0.1180881 1 -0.25 0.02569544 1 -0.75 0.1180881 1 -0.75 0.02569544 1 -0.75 -0.06669718 1 0.5 0.02569544 1 0.5 -0.06669718 1 0.5 0.1180881 1 0.25 -0.06669718 1 0.25 0.02569544 1 0.25 0.1180881 1 0.75 0.1180881 1 0.75 0.02569544 1 0.75 -0.06669718 + + + + + + + + + + -0.7071068 0.7071068 0 -0.5773503 0.5773503 -0.5773503 -0.7071068 0 -0.7071068 0.7071068 0.7071068 0 0.5773503 0.5773503 -0.5773503 0 0.7071068 -0.7071068 0.7071068 -0.7071068 0 0.5773503 -0.5773503 -0.5773503 0.7071068 0 -0.7071068 -0.7071068 -0.7071068 0 -0.5773503 -0.5773503 -0.5773503 0 -0.7071068 -0.7071068 0 0 -1 0 0.4178734 0.9085053 -0.330249 0.330249 0.8842349 -0.4178734 0 0.9085053 0 0 1 0 -1 0 0 -0.9379 0.3469058 -0.6580374 -0.6580374 0.366024 1 0 0 0.9379 0 0.3469058 0.6580374 -0.6580374 0.366024 0 1 0 0 0.9379 0.3469058 0.6580374 0.6580374 0.366024 -1 0 0 -0.9379 0 0.3469058 -0.6580374 0.6580374 0.366024 0.330249 0.330249 0.8842349 0.4178734 0 0.9085053 0.330249 -0.330249 0.8842349 0 -0.4178734 0.9085053 -0.330249 -0.330249 0.8842349 + + + + + + + + + + 0.625 0.5128477 0.625 0.4666514 0.6475836 0.4666514 0.375 0.5128477 0.375 0.4666514 0.3975836 0.4666514 0.125 0.5128477 0.125 0.4666514 0.1475836 0.4666514 0.875 0.5128477 0.875 0.4666514 0.8975836 0.4666514 0.2377848 0.1501199 0.304211 0.2165462 0.1713584 0.2829726 0.3728421 0.9564633 0.3051788 0.9792215 0.2907249 0.8821746 0.3150261 0.5682749 0.2473629 0.5910331 0.2329088 0.4939857 0.5856791 0.4772418 0.5180161 0.5 0.5035621 0.4029527 0.6434951 0.8654303 0.5758321 0.8881885 0.5613781 0.7911415 0.304211 0.3493989 0.2377848 0.4158252 0.1713584 0.2829726 0.1713584 0.2829726 0.1049321 0.4158252 0.03850573 0.3493989 0.1049321 0.1501199 0.1713584 0.2829726 0.03850573 0.2165462 0 0.5128477 0 0.4666514 0.03898954 0.4666514 0 0.5590441 0 0.5128477 0.03898954 0.5128477 0.875 0.5590441 0.875 0.5128477 0.8975836 0.5128477 0.25 0.5128477 0.25 0.4666514 0.2889896 0.4666514 0.25 0.5590441 0.25 0.5128477 0.2889896 0.5128477 0.125 0.5590441 0.125 0.5128477 0.1475836 0.5128477 0.5 0.5128477 0.5 0.4666514 0.5389896 0.4666514 0.5 0.5590441 0.5 0.5128477 0.5389896 0.5128477 0.375 0.5590441 0.375 0.5128477 0.3975836 0.5128477 0.75 0.5128477 0.75 0.4666514 0.7889896 0.4666514 0.75 0.5590441 0.75 0.5128477 0.7889896 0.5128477 0.625 0.5590441 0.625 0.5128477 0.6475836 0.5128477 0.3892051 0.8185322 0.3903584 0.8176673 0.3903584 0.8452714 0.5844526 0.8464247 0.5835876 0.8452714 0.6111918 0.8452714 0.6123451 0.6511773 0.6111918 0.6520423 0.6111918 0.6244381 0.4170976 0.6232848 0.4179626 0.6244381 0.3903584 0.6244381 0.3903584 0.7072506 0.3903584 0.7348547 0.3892051 0.7348547 0.4731709 0.8452714 0.5007751 0.8452714 0.5007751 0.8464247 0.6111918 0.7624589 0.6111918 0.7348547 0.6123451 0.7348547 0.5283793 0.6244381 0.5007751 0.6244381 0.5007751 0.6232848 0.6145871 0.671336 0.5469241 0.6940942 0.5324701 0.5970473 0.7499138 0.6258195 0.6822504 0.6485777 0.6677964 0.5515309 0.7788217 0.8199138 0.7111585 0.842672 0.6967044 0.745625 0.5567712 0.2831476 0.489108 0.3059058 0.474654 0.2088586 0.6920977 0.237631 0.6244345 0.2603893 0.6099805 0.1633422 0.7210057 0.4317253 0.6533424 0.4544835 0.6388884 0.3574362 0.2861181 0.3741806 0.2184548 0.3969388 0.2040008 0.2998917 0.4214445 0.3286641 0.3537814 0.3514223 0.3393274 0.2543752 0.4503525 0.5227584 0.3826894 0.5455166 0.3682353 0.4484692 0.3439341 0.762369 0.2762709 0.7851272 0.2618169 0.6880804 0.4792605 0.7168526 0.4115973 0.7396108 0.3971434 0.6425639 0.5081685 0.9109469 0.4405054 0.9337051 0.4260514 0.8366581 0.4937146 0.8138999 0.4260514 0.8366581 0.4115973 0.7396108 0.5613781 0.7911415 0.4937146 0.8138999 0.4792605 0.7168526 0.5758321 0.8881885 0.5081685 0.9109469 0.4937146 0.8138999 0.4648066 0.6198057 0.3971434 0.6425639 0.3826894 0.5455166 0.5324701 0.5970473 0.4648066 0.6198057 0.4503525 0.5227584 0.5469241 0.6940942 0.4792605 0.7168526 0.4648066 0.6198057 0.3294802 0.6653222 0.2618169 0.6880804 0.2473629 0.5910331 0.3971434 0.6425639 0.3294802 0.6653222 0.3150261 0.5682749 0.4115973 0.7396108 0.3439341 0.762369 0.3294802 0.6653222 0.4358985 0.425711 0.3682353 0.4484692 0.3537814 0.3514223 0.5035621 0.4029527 0.4358985 0.425711 0.4214445 0.3286641 0.5180161 0.5 0.4503525 0.5227584 0.4358985 0.425711 0.4069906 0.2316169 0.3393274 0.2543752 0.3248734 0.1573281 0.474654 0.2088586 0.4069906 0.2316169 0.3925365 0.1345698 0.489108 0.3059058 0.4214445 0.3286641 0.4069906 0.2316169 0.2716641 0.2771335 0.2040008 0.2998917 0.1895468 0.2028446 0.3393274 0.2543752 0.2716641 0.2771335 0.2572101 0.1800863 0.3537814 0.3514223 0.2861181 0.3741806 0.2716641 0.2771335 0.7065518 0.3346779 0.6388884 0.3574362 0.6244345 0.2603893 0.7742153 0.3119196 0.7065518 0.3346779 0.6920977 0.237631 0.7886693 0.4089669 0.7210057 0.4317253 0.7065518 0.3346779 0.6776438 0.1405839 0.6099805 0.1633422 0.5955265 0.06629502 0.7453073 0.1178256 0.6776438 0.1405839 0.6631897 0.04353678 0.7597613 0.2148727 0.6920977 0.237631 0.6776438 0.1405839 0.5423172 0.1861004 0.474654 0.2088586 0.4602001 0.1118115 0.6099805 0.1633422 0.5423172 0.1861004 0.5278632 0.08905333 0.6244345 0.2603893 0.5567712 0.2831476 0.5423172 0.1861004 0.7643678 0.7228668 0.6967044 0.745625 0.6822504 0.6485777 0.8320313 0.7001085 0.7643678 0.7228668 0.7499138 0.6258195 0.8464853 0.7971554 0.7788217 0.8199138 0.7643678 0.7228668 0.7354598 0.5287727 0.6677964 0.5515309 0.6533424 0.4544835 0.8031232 0.5060143 0.7354598 0.5287727 0.7210057 0.4317253 0.8175772 0.6030611 0.7499138 0.6258195 0.7354598 0.5287727 0.6001331 0.5742892 0.5324701 0.5970473 0.5180161 0.5 0.6677964 0.5515309 0.6001331 0.5742892 0.5856791 0.4772418 0.6822504 0.6485777 0.6145871 0.671336 0.6001331 0.5742892 0.6290411 0.7683834 0.5613781 0.7911415 0.5469241 0.6940942 0.6967044 0.745625 0.6290411 0.7683834 0.6145871 0.671336 0.7111585 0.842672 0.6434951 0.8654303 0.6290411 0.7683834 0.5712251 0.3801945 0.5035621 0.4029527 0.489108 0.3059058 0.6388884 0.3574362 0.5712251 0.3801945 0.5567712 0.2831476 0.6533424 0.4544835 0.5856791 0.4772418 0.5712251 0.3801945 0.300572 0.4712275 0.2329088 0.4939857 0.2184548 0.3969388 0.3682353 0.4484692 0.300572 0.4712275 0.2861181 0.3741806 0.3826894 0.5455166 0.3150261 0.5682749 0.300572 0.4712275 0.3583881 0.8594164 0.2907249 0.8821746 0.2762709 0.7851272 0.4260514 0.8366581 0.3583881 0.8594164 0.3439341 0.762369 0.4405054 0.9337051 0.3728421 0.9564633 0.3583881 0.8594164 0.4262082 0.5590441 0.4262082 0.5128477 0.4610104 0.5128477 0.4262082 0.5128477 0.4262082 0.4666514 0.4610104 0.4666514 0.5559834 0.8452714 0.5565601 0.8464247 0.5286676 0.8464247 0.3975836 0.5590441 0.3975836 0.5128477 0.4262082 0.5128477 0.3975836 0.5128477 0.3975836 0.4666514 0.4262082 0.4666514 0.5565601 0.8464247 0.5559834 0.8452714 0.5835876 0.8452714 0.4610104 0.5590441 0.4610104 0.5128477 0.5 0.5128477 0.4610104 0.5128477 0.4610104 0.4666514 0.5 0.4666514 0.5283793 0.8452714 0.5286676 0.8464247 0.5007751 0.8464247 0.5737918 0.5128477 0.5737918 0.4666514 0.6024164 0.4666514 0.4179626 0.8452714 0.4455668 0.8452714 0.4449901 0.8464247 0.5737918 0.5590441 0.5737918 0.5128477 0.6024164 0.5128477 0.5389896 0.5128477 0.5389896 0.4666514 0.5737918 0.4666514 0.4455668 0.8452714 0.4731709 0.8452714 0.4728826 0.8464247 0.5389896 0.5590441 0.5389896 0.5128477 0.5737918 0.5128477 0.6024164 0.5128477 0.6024164 0.4666514 0.625 0.4666514 0.3903584 0.8452714 0.4179626 0.8452714 0.4170976 0.8464247 0.6024164 0.5590441 0.6024164 0.5128477 0.625 0.5128477 0.6762082 0.5590441 0.6762082 0.5128477 0.7110105 0.5128477 0.6762082 0.5128477 0.6762082 0.4666514 0.7110105 0.4666514 0.3903584 0.790063 0.3892051 0.7906398 0.3892051 0.7627473 0.6475836 0.5590441 0.6475836 0.5128477 0.6762082 0.5128477 0.6475836 0.5128477 0.6475836 0.4666514 0.6762082 0.4666514 0.3892051 0.7906398 0.3903584 0.790063 0.3903584 0.8176673 0.3903584 0.7624589 0.3892051 0.7627473 0.3892051 0.7348547 0.7110105 0.5590441 0.7110105 0.5128477 0.75 0.5128477 0.7110105 0.5128477 0.7110105 0.4666514 0.75 0.4666514 0.8237918 0.5128477 0.8237918 0.4666514 0.8524164 0.4666514 0.3903584 0.6520423 0.3903584 0.6796464 0.3892051 0.6790698 0.8237918 0.5590441 0.8237918 0.5128477 0.8524164 0.5128477 0.8524164 0.5128477 0.8524164 0.4666514 0.875 0.4666514 0.3903584 0.6244381 0.3903584 0.6520423 0.3892051 0.6511773 0.8524164 0.5590441 0.8524164 0.5128477 0.875 0.5128477 0.7889896 0.5128477 0.7889896 0.4666514 0.8237918 0.4666514 0.3903584 0.6796464 0.3903584 0.7072506 0.3892051 0.7069622 0.7889896 0.5590441 0.7889896 0.5128477 0.8237918 0.5128477 0.9262082 0.5128477 0.9262082 0.4666514 0.9610105 0.4666514 0.4455668 0.6244381 0.4449901 0.6232848 0.4728826 0.6232848 0.9262082 0.5590441 0.9262082 0.5128477 0.9610105 0.5128477 0.8975836 0.5128477 0.8975836 0.4666514 0.9262082 0.4666514 0.4449901 0.6232848 0.4455668 0.6244381 0.4179626 0.6244381 0.8975836 0.5590441 0.8975836 0.5128477 0.9262082 0.5128477 0.4731709 0.6244381 0.4728826 0.6232848 0.5007751 0.6232848 0.9610105 0.5590441 0.9610105 0.5128477 1 0.5128477 0.9610105 0.5128477 0.9610105 0.4666514 1 0.4666514 0.0737918 0.5590441 0.0737918 0.5128477 0.1024163 0.5128477 0.5835876 0.6244381 0.5559834 0.6244381 0.5565601 0.6232848 0.0737918 0.5128477 0.0737918 0.4666514 0.1024163 0.4666514 0.03898954 0.5590441 0.03898954 0.5128477 0.0737918 0.5128477 0.5559834 0.6244381 0.5283793 0.6244381 0.5286676 0.6232848 0.03898954 0.5128477 0.03898954 0.4666514 0.0737918 0.4666514 0.1024163 0.5128477 0.1024163 0.4666514 0.125 0.4666514 0.1024163 0.5590441 0.1024163 0.5128477 0.125 0.5128477 0.6111918 0.6244381 0.5835876 0.6244381 0.5844526 0.6232848 0.1762082 0.5590441 0.1762082 0.5128477 0.2110104 0.5128477 0.1762082 0.5128477 0.1762082 0.4666514 0.2110104 0.4666514 0.6111918 0.6796464 0.6123451 0.6790698 0.6123451 0.7069622 0.2110104 0.5590441 0.2110104 0.5128477 0.25 0.5128477 0.2110104 0.5128477 0.2110104 0.4666514 0.25 0.4666514 0.6111918 0.7072506 0.6123451 0.7069622 0.6123451 0.7348547 0.1475836 0.5590441 0.1475836 0.5128477 0.1762082 0.5128477 0.1475836 0.5128477 0.1475836 0.4666514 0.1762082 0.4666514 0.6123451 0.6790698 0.6111918 0.6796464 0.6111918 0.6520423 0.3237918 0.5590441 0.3237918 0.5128477 0.3524164 0.5128477 0.6111918 0.8176673 0.6111918 0.790063 0.6123451 0.7906398 0.3237918 0.5128477 0.3237918 0.4666514 0.3524164 0.4666514 0.2889896 0.5590441 0.2889896 0.5128477 0.3237918 0.5128477 0.6111918 0.790063 0.6111918 0.7624589 0.6123451 0.7627473 0.2889896 0.5128477 0.2889896 0.4666514 0.3237918 0.4666514 0.6111918 0.8452714 0.6111918 0.8176673 0.6123451 0.8185322 0.3524164 0.5128477 0.3524164 0.4666514 0.375 0.4666514 0.3524164 0.5590441 0.3524164 0.5128477 0.375 0.5128477 0.6475836 0.5128477 0.625 0.5128477 0.6475836 0.4666514 0.3975836 0.5128477 0.375 0.5128477 0.3975836 0.4666514 0.1475836 0.5128477 0.125 0.5128477 0.1475836 0.4666514 0.8975836 0.5128477 0.875 0.5128477 0.8975836 0.4666514 0.304211 0.2829726 0.1713584 0.2829726 0.304211 0.2497593 0.1713584 0.1501199 0.2045716 0.1501199 0.1713584 0.2829726 0.2377848 0.1501199 0.2709979 0.1501199 0.304211 0.183333 0.304211 0.1501199 0.304211 0.183333 0.2709979 0.1501199 0.304211 0.2165462 0.304211 0.2497593 0.1713584 0.2829726 0.1713584 0.2829726 0.2045716 0.1501199 0.2377848 0.1501199 0.2377848 0.1501199 0.304211 0.183333 0.304211 0.2165462 0.3583881 0.8594164 0.3728421 0.9564633 0.2907249 0.8821746 0.300572 0.4712275 0.3150261 0.5682749 0.2329088 0.4939857 0.5712251 0.3801945 0.5856791 0.4772418 0.5035621 0.4029527 0.6290411 0.7683834 0.6434951 0.8654303 0.5613781 0.7911415 0.2045716 0.4158252 0.1713584 0.4158252 0.1713584 0.2829726 0.1713584 0.2829726 0.304211 0.2829726 0.304211 0.3161857 0.304211 0.3161857 0.304211 0.3493989 0.1713584 0.2829726 0.304211 0.3826121 0.304211 0.4158252 0.2709979 0.4158252 0.2709979 0.4158252 0.2377848 0.4158252 0.304211 0.3493989 0.2045716 0.4158252 0.1713584 0.2829726 0.2377848 0.4158252 0.304211 0.3493989 0.304211 0.3826121 0.2709979 0.4158252 0.07171893 0.4158252 0.03850573 0.4158252 0.03850573 0.3826121 0.03850573 0.3826121 0.03850573 0.3493989 0.07171893 0.4158252 0.03850573 0.3161857 0.03850573 0.2829726 0.1713584 0.2829726 0.1713584 0.2829726 0.1713584 0.4158252 0.1381452 0.4158252 0.1381452 0.4158252 0.1049321 0.4158252 0.1713584 0.2829726 0.07171893 0.4158252 0.03850573 0.3493989 0.1049321 0.4158252 0.03850573 0.3161857 0.1713584 0.2829726 0.03850573 0.3493989 0.1713584 0.2829726 0.03850573 0.2829726 0.03850573 0.2497593 0.03850573 0.2497593 0.03850573 0.2165462 0.1713584 0.2829726 0.03850573 0.183333 0.03850573 0.1501199 0.07171893 0.1501199 0.07171893 0.1501199 0.1049321 0.1501199 0.03850573 0.183333 0.1381452 0.1501199 0.1713584 0.1501199 0.1713584 0.2829726 0.1713584 0.2829726 0.1049321 0.1501199 0.1381452 0.1501199 0.03850573 0.183333 0.1049321 0.1501199 0.03850573 0.2165462 0.03898954 0.5128477 0 0.5128477 0.03898954 0.4666514 0.03898954 0.5590441 0 0.5590441 0.03898954 0.5128477 0.8975836 0.5590441 0.875 0.5590441 0.8975836 0.5128477 0.2889896 0.5128477 0.25 0.5128477 0.2889896 0.4666514 0.2889896 0.5590441 0.25 0.5590441 0.2889896 0.5128477 0.1475836 0.5590441 0.125 0.5590441 0.1475836 0.5128477 0.5389896 0.5128477 0.5 0.5128477 0.5389896 0.4666514 0.5389896 0.5590441 0.5 0.5590441 0.5389896 0.5128477 0.3975836 0.5590441 0.375 0.5590441 0.3975836 0.5128477 0.7889896 0.5128477 0.75 0.5128477 0.7889896 0.4666514 0.7889896 0.5590441 0.75 0.5590441 0.7889896 0.5128477 0.6475836 0.5590441 0.625 0.5590441 0.6475836 0.5128477 0.3892051 0.8464247 0.3892051 0.8185322 0.3903584 0.8452714 0.6123451 0.8464247 0.5844526 0.8464247 0.6111918 0.8452714 0.6123451 0.6232848 0.6123451 0.6511773 0.6111918 0.6244381 0.3892051 0.6232848 0.4170976 0.6232848 0.3903584 0.6244381 0.3892051 0.7069622 0.3903584 0.7072506 0.3892051 0.7348547 0.4728826 0.8464247 0.4731709 0.8452714 0.5007751 0.8464247 0.6123451 0.7627473 0.6111918 0.7624589 0.6123451 0.7348547 0.5286676 0.6232848 0.5283793 0.6244381 0.5007751 0.6232848 0.6001331 0.5742892 0.6145871 0.671336 0.5324701 0.5970473 0.7354598 0.5287727 0.7499138 0.6258195 0.6677964 0.5515309 0.7643678 0.7228668 0.7788217 0.8199138 0.6967044 0.745625 0.5423172 0.1861004 0.5567712 0.2831476 0.474654 0.2088586 0.6776438 0.1405839 0.6920977 0.237631 0.6099805 0.1633422 0.7065518 0.3346779 0.7210057 0.4317253 0.6388884 0.3574362 0.2716641 0.2771335 0.2861181 0.3741806 0.2040008 0.2998917 0.4069906 0.2316169 0.4214445 0.3286641 0.3393274 0.2543752 0.4358985 0.425711 0.4503525 0.5227584 0.3682353 0.4484692 0.3294802 0.6653222 0.3439341 0.762369 0.2618169 0.6880804 0.4648066 0.6198057 0.4792605 0.7168526 0.3971434 0.6425639 0.4937146 0.8138999 0.5081685 0.9109469 0.4260514 0.8366581 0.4792605 0.7168526 0.4937146 0.8138999 0.4115973 0.7396108 0.5469241 0.6940942 0.5613781 0.7911415 0.4792605 0.7168526 0.5613781 0.7911415 0.5758321 0.8881885 0.4937146 0.8138999 0.4503525 0.5227584 0.4648066 0.6198057 0.3826894 0.5455166 0.5180161 0.5 0.5324701 0.5970473 0.4503525 0.5227584 0.5324701 0.5970473 0.5469241 0.6940942 0.4648066 0.6198057 0.3150261 0.5682749 0.3294802 0.6653222 0.2473629 0.5910331 0.3826894 0.5455166 0.3971434 0.6425639 0.3150261 0.5682749 0.3971434 0.6425639 0.4115973 0.7396108 0.3294802 0.6653222 0.4214445 0.3286641 0.4358985 0.425711 0.3537814 0.3514223 0.489108 0.3059058 0.5035621 0.4029527 0.4214445 0.3286641 0.5035621 0.4029527 0.5180161 0.5 0.4358985 0.425711 0.3925365 0.1345698 0.4069906 0.2316169 0.3248734 0.1573281 0.4602001 0.1118115 0.474654 0.2088586 0.3925365 0.1345698 0.474654 0.2088586 0.489108 0.3059058 0.4069906 0.2316169 0.2572101 0.1800863 0.2716641 0.2771335 0.1895468 0.2028446 0.3248734 0.1573281 0.3393274 0.2543752 0.2572101 0.1800863 0.3393274 0.2543752 0.3537814 0.3514223 0.2716641 0.2771335 0.6920977 0.237631 0.7065518 0.3346779 0.6244345 0.2603893 0.7597613 0.2148727 0.7742153 0.3119196 0.6920977 0.237631 0.7742153 0.3119196 0.7886693 0.4089669 0.7065518 0.3346779 0.6631897 0.04353678 0.6776438 0.1405839 0.5955265 0.06629502 0.7308533 0.02077847 0.7453073 0.1178256 0.6631897 0.04353678 0.7453073 0.1178256 0.7597613 0.2148727 0.6776438 0.1405839 0.5278632 0.08905333 0.5423172 0.1861004 0.4602001 0.1118115 0.5955265 0.06629502 0.6099805 0.1633422 0.5278632 0.08905333 0.6099805 0.1633422 0.6244345 0.2603893 0.5423172 0.1861004 0.7499138 0.6258195 0.7643678 0.7228668 0.6822504 0.6485777 0.8175772 0.6030611 0.8320313 0.7001085 0.7499138 0.6258195 0.8320313 0.7001085 0.8464853 0.7971554 0.7643678 0.7228668 0.7210057 0.4317253 0.7354598 0.5287727 0.6533424 0.4544835 0.7886693 0.4089669 0.8031232 0.5060143 0.7210057 0.4317253 0.8031232 0.5060143 0.8175772 0.6030611 0.7354598 0.5287727 0.5856791 0.4772418 0.6001331 0.5742892 0.5180161 0.5 0.6533424 0.4544835 0.6677964 0.5515309 0.5856791 0.4772418 0.6677964 0.5515309 0.6822504 0.6485777 0.6001331 0.5742892 0.6145871 0.671336 0.6290411 0.7683834 0.5469241 0.6940942 0.6822504 0.6485777 0.6967044 0.745625 0.6145871 0.671336 0.6967044 0.745625 0.7111585 0.842672 0.6290411 0.7683834 0.5567712 0.2831476 0.5712251 0.3801945 0.489108 0.3059058 0.6244345 0.2603893 0.6388884 0.3574362 0.5567712 0.2831476 0.6388884 0.3574362 0.6533424 0.4544835 0.5712251 0.3801945 0.2861181 0.3741806 0.300572 0.4712275 0.2184548 0.3969388 0.3537814 0.3514223 0.3682353 0.4484692 0.2861181 0.3741806 0.3682353 0.4484692 0.3826894 0.5455166 0.300572 0.4712275 0.3439341 0.762369 0.3583881 0.8594164 0.2762709 0.7851272 0.4115973 0.7396108 0.4260514 0.8366581 0.3439341 0.762369 0.4260514 0.8366581 0.4405054 0.9337051 0.3583881 0.8594164 0.4610104 0.5590441 0.4262082 0.5590441 0.4610104 0.5128477 0.4610104 0.5128477 0.4262082 0.5128477 0.4610104 0.4666514 0.5283793 0.8452714 0.5559834 0.8452714 0.5286676 0.8464247 0.4262082 0.5590441 0.3975836 0.5590441 0.4262082 0.5128477 0.4262082 0.5128477 0.3975836 0.5128477 0.4262082 0.4666514 0.5844526 0.8464247 0.5565601 0.8464247 0.5835876 0.8452714 0.5 0.5590441 0.4610104 0.5590441 0.5 0.5128477 0.5 0.5128477 0.4610104 0.5128477 0.5 0.4666514 0.5007751 0.8452714 0.5283793 0.8452714 0.5007751 0.8464247 0.6024164 0.5128477 0.5737918 0.5128477 0.6024164 0.4666514 0.4170976 0.8464247 0.4179626 0.8452714 0.4449901 0.8464247 0.6024164 0.5590441 0.5737918 0.5590441 0.6024164 0.5128477 0.5737918 0.5128477 0.5389896 0.5128477 0.5737918 0.4666514 0.4449901 0.8464247 0.4455668 0.8452714 0.4728826 0.8464247 0.5737918 0.5590441 0.5389896 0.5590441 0.5737918 0.5128477 0.625 0.5128477 0.6024164 0.5128477 0.625 0.4666514 0.3892051 0.8464247 0.3903584 0.8452714 0.4170976 0.8464247 0.625 0.5590441 0.6024164 0.5590441 0.625 0.5128477 0.7110105 0.5590441 0.6762082 0.5590441 0.7110105 0.5128477 0.7110105 0.5128477 0.6762082 0.5128477 0.7110105 0.4666514 0.3903584 0.7624589 0.3903584 0.790063 0.3892051 0.7627473 0.6762082 0.5590441 0.6475836 0.5590441 0.6762082 0.5128477 0.6762082 0.5128477 0.6475836 0.5128477 0.6762082 0.4666514 0.3892051 0.8185322 0.3892051 0.7906398 0.3903584 0.8176673 0.3903584 0.7348547 0.3903584 0.7624589 0.3892051 0.7348547 0.75 0.5590441 0.7110105 0.5590441 0.75 0.5128477 0.75 0.5128477 0.7110105 0.5128477 0.75 0.4666514 0.8524164 0.5128477 0.8237918 0.5128477 0.8524164 0.4666514 0.3892051 0.6511773 0.3903584 0.6520423 0.3892051 0.6790698 0.8524164 0.5590441 0.8237918 0.5590441 0.8524164 0.5128477 0.875 0.5128477 0.8524164 0.5128477 0.875 0.4666514 0.3892051 0.6232848 0.3903584 0.6244381 0.3892051 0.6511773 0.875 0.5590441 0.8524164 0.5590441 0.875 0.5128477 0.8237918 0.5128477 0.7889896 0.5128477 0.8237918 0.4666514 0.3892051 0.6790698 0.3903584 0.6796464 0.3892051 0.7069622 0.8237918 0.5590441 0.7889896 0.5590441 0.8237918 0.5128477 0.9610105 0.5128477 0.9262082 0.5128477 0.9610105 0.4666514 0.4731709 0.6244381 0.4455668 0.6244381 0.4728826 0.6232848 0.9610105 0.5590441 0.9262082 0.5590441 0.9610105 0.5128477 0.9262082 0.5128477 0.8975836 0.5128477 0.9262082 0.4666514 0.4170976 0.6232848 0.4449901 0.6232848 0.4179626 0.6244381 0.9262082 0.5590441 0.8975836 0.5590441 0.9262082 0.5128477 0.5007751 0.6244381 0.4731709 0.6244381 0.5007751 0.6232848 1 0.5590441 0.9610105 0.5590441 1 0.5128477 1 0.5128477 0.9610105 0.5128477 1 0.4666514 0.1024163 0.5590441 0.0737918 0.5590441 0.1024163 0.5128477 0.5844526 0.6232848 0.5835876 0.6244381 0.5565601 0.6232848 0.1024163 0.5128477 0.0737918 0.5128477 0.1024163 0.4666514 0.0737918 0.5590441 0.03898954 0.5590441 0.0737918 0.5128477 0.5565601 0.6232848 0.5559834 0.6244381 0.5286676 0.6232848 0.0737918 0.5128477 0.03898954 0.5128477 0.0737918 0.4666514 0.125 0.5128477 0.1024163 0.5128477 0.125 0.4666514 0.125 0.5590441 0.1024163 0.5590441 0.125 0.5128477 0.6123451 0.6232848 0.6111918 0.6244381 0.5844526 0.6232848 0.2110104 0.5590441 0.1762082 0.5590441 0.2110104 0.5128477 0.2110104 0.5128477 0.1762082 0.5128477 0.2110104 0.4666514 0.6111918 0.7072506 0.6111918 0.6796464 0.6123451 0.7069622 0.25 0.5590441 0.2110104 0.5590441 0.25 0.5128477 0.25 0.5128477 0.2110104 0.5128477 0.25 0.4666514 0.6111918 0.7348547 0.6111918 0.7072506 0.6123451 0.7348547 0.1762082 0.5590441 0.1475836 0.5590441 0.1762082 0.5128477 0.1762082 0.5128477 0.1475836 0.5128477 0.1762082 0.4666514 0.6123451 0.6511773 0.6123451 0.6790698 0.6111918 0.6520423 0.3524164 0.5590441 0.3237918 0.5590441 0.3524164 0.5128477 0.6123451 0.8185322 0.6111918 0.8176673 0.6123451 0.7906398 0.3524164 0.5128477 0.3237918 0.5128477 0.3524164 0.4666514 0.3237918 0.5590441 0.2889896 0.5590441 0.3237918 0.5128477 0.6123451 0.7906398 0.6111918 0.790063 0.6123451 0.7627473 0.3237918 0.5128477 0.2889896 0.5128477 0.3237918 0.4666514 0.6123451 0.8464247 0.6111918 0.8452714 0.6123451 0.8185322 0.375 0.5128477 0.3524164 0.5128477 0.375 0.4666514 0.375 0.5590441 0.3524164 0.5590441 0.375 0.5128477 + + + + + + + + + 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 0.9960784 0.9960784 0.9960784 1 1 1 1 1 1 1 1 1 0.9960784 0.9960784 0.9960784 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 1 1 1 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 1 1 1 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 0.9960784 0.9960784 0.9960784 1 1 1 1 1 1 0.9960784 0.9960784 0.9960784 1 1 1 1 1 1 0.9960784 0.9960784 0.9960784 1 1 1 1 1 1 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 1 1 1 1 1 1 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 1 1 1 1 1 1 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 1 1 1 1 1 1 0.9960784 0.9960784 0.9960784 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 1 1 1 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 1 1 1 1 1 1 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 1 1 1 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 1 1 1 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 1 1 1 1 1 1 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 1 1 1 1 1 1 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 1 1 1 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 1 1 1 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 1 1 1 1 1 1 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 1 1 1 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 1 1 1 1 1 1 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 1 1 1 1 1 1 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 1 1 1 1 1 1 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 1 1 1 1 1 1 0.9960784 0.9960784 0.9960784 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 0.9960784 0.9960784 0.9960784 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 0.9960784 0.9960784 0.9960784 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 0.9960784 0.9960784 0.9960784 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 1 1 1 1 1 1 1 1 1 0.9960784 0.9960784 0.9960784 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 0.9960784 0.9960784 0.9960784 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 0.9960784 0.9960784 0.9960784 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 1 1 1 1 1 1 1 1 1 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 1 1 1 1 1 1 1 1 1 1 1 1 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 0.9960784 0.9960784 0.9960784 1 1 1 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 1 1 1 1 1 1 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 0.9960784 0.9960784 0.9960784 1 1 1 1 1 1 0.9960784 0.9960784 0.9960784 1 1 1 1 1 1 0.9960784 0.9960784 0.9960784 1 1 1 0.9960784 0.9960784 0.9960784 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 0.9960784 0.9960784 0.9960784 1 1 1 1 1 1 0.9960784 0.9960784 0.9960784 1 1 1 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 1 1 1 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 1 1 1 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 1 1 1 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 1 1 1 0.9960784 0.9960784 0.9960784 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 1 1 1 1 1 1 0.9960784 0.9960784 0.9960784 1 1 1 1 1 1 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 1 1 1 1 1 1 0.9960784 0.9960784 0.9960784 1 1 1 1 1 1 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 1 1 1 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 1 1 1 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 1 1 1 0.9960784 0.9960784 0.9960784 1 1 1 1 1 1 0.9960784 0.9960784 0.9960784 1 1 1 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 1 1 1 0.9960784 0.9960784 0.9960784 1 1 1 1 1 1 0.9960784 0.9960784 0.9960784 1 1 1 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 1 1 1 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 1 1 1 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 1 1 1 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 1 1 1 0.9960784 0.9960784 0.9960784 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 0.9960784 0.9960784 0.9960784 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 0.9960784 0.9960784 0.9960784 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 0.9960784 0.9960784 0.9960784 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 0.9960784 0.9960784 0.9960784 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 0.9960784 0.9960784 0.9960784 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 0.9960784 0.9960784 0.9960784 1 1 1 1 1 1 1 1 1 1 1 1 0.9960784 0.9960784 0.9960784 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 0.9960784 0.9960784 0.9960784 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 0.9960784 0.9960784 0.9960784 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 0.9960784 0.9960784 0.9960784 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 0.9960784 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 0.9960784 0.9960784 0.9960784 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 0.9960784 0.9960784 0.9960784 1 1 1 1 1 1 1 1 1 1 1 1 0.9960784 0.9960784 0.9960784 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 0.9960784 0.9960784 0.9960784 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 0.9960784 0.9960784 0.9960784 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 + + + + + + + + + + + + + + + + + 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 +

10 0 0 0 2 1 1 1 128 2 2 2 13 3 3 3 6 4 4 4 111 5 5 5 16 6 6 6 4 7 7 7 168 8 8 8 8 9 9 9 0 10 10 10 147 11 11 11 106 5 12 12 170 8 13 13 21 12 14 14 71 13 15 15 3 14 16 16 54 15 17 17 50 16 18 18 9 15 19 19 58 15 20 20 51 16 21 21 20 16 22 22 64 16 23 23 67 13 24 24 12 13 25 25 65 16 26 26 160 8 27 27 151 11 28 28 21 12 29 29 21 12 30 30 144 11 31 31 133 2 32 32 116 5 33 33 21 12 34 34 126 2 35 35 22 17 36 36 19 11 37 37 154 11 38 38 32 18 39 39 22 17 40 40 156 17 41 41 33 19 42 42 8 9 43 43 146 17 44 44 23 20 45 45 17 8 46 46 172 8 47 47 30 21 48 48 23 20 49 49 173 20 50 50 31 22 51 51 16 6 52 52 167 20 53 53 24 23 54 54 14 5 55 55 118 5 56 56 28 24 57 57 24 23 58 58 119 23 59 59 29 25 60 60 13 3 61 61 109 23 62 62 25 26 63 63 11 2 64 64 141 2 65 65 26 27 66 66 25 26 67 67 139 26 68 68 27 28 69 69 10 0 70 70 129 26 71 71 127 27 72 72 54 15 73 73 3 14 74 74 110 24 75 75 55 13 76 76 7 29 77 77 166 21 78 78 56 30 79 79 5 31 80 80 145 18 81 81 57 32 82 82 1 33 83 83 58 15 84 84 9 15 85 85 26 27 86 86 59 13 87 87 12 13 88 88 28 24 89 89 60 30 90 90 15 30 91 91 30 21 92 92 61 32 93 93 18 32 94 94 32 18 95 95 74 16 96 96 37 16 97 97 53 16 98 98 75 16 99 99 46 16 100 100 76 16 101 101 55 13 102 102 39 13 103 103 77 16 104 104 78 16 105 105 36 16 106 106 52 16 107 107 79 16 108 108 47 16 109 109 80 16 110 110 63 16 111 111 35 16 112 112 81 16 113 113 82 16 114 114 42 15 115 115 70 15 116 116 83 16 117 117 48 16 118 118 84 16 119 119 62 16 120 120 34 16 121 121 85 16 122 122 86 16 123 123 38 15 124 124 66 15 125 125 87 16 126 126 49 16 127 127 88 16 128 128 59 13 129 129 43 13 130 130 89 16 131 131 90 16 132 132 89 16 133 133 49 16 134 134 65 16 135 135 90 16 136 136 87 16 137 137 12 13 138 138 59 13 139 139 90 16 140 140 91 16 141 141 88 16 142 142 34 16 143 143 53 16 144 144 91 16 145 145 62 16 146 146 37 16 147 147 87 16 148 148 91 16 149 149 92 16 150 150 66 15 151 151 9 15 152 152 88 16 153 153 92 16 154 154 50 16 155 155 49 16 156 156 86 16 157 157 92 16 158 158 93 16 159 159 85 16 160 160 48 16 161 161 64 16 162 162 93 16 163 163 83 16 164 164 20 16 165 165 62 16 166 166 93 16 167 167 94 16 168 168 84 16 169 169 41 32 170 170 52 16 171 171 94 16 172 172 69 32 173 173 36 16 174 174 83 16 175 175 94 16 176 176 95 16 177 177 70 15 178 178 1 33 179 179 84 16 180 180 95 16 181 181 57 32 182 182 48 16 183 183 82 16 184 184 95 16 185 185 96 16 186 186 81 16 187 187 47 16 188 188 68 30 189 189 96 16 190 190 79 16 191 191 15 30 192 192 63 16 193 193 96 16 194 194 97 16 195 195 80 16 196 196 45 32 197 197 56 30 198 198 97 16 199 199 73 32 200 200 40 30 201 201 79 16 202 202 97 16 203 203 98 16 204 204 52 16 205 205 18 32 206 206 80 16 207 207 98 16 208 208 61 32 209 209 47 16 210 210 78 16 211 211 98 16 212 212 99 16 213 213 77 16 214 214 46 16 215 215 72 30 216 216 99 16 217 217 75 16 218 218 7 29 219 219 55 13 220 220 99 16 221 221 100 16 222 222 76 16 223 223 35 16 224 224 60 30 225 225 100 16 226 226 63 16 227 227 44 30 228 228 75 16 229 229 100 16 230 230 101 16 231 231 53 16 232 232 20 16 233 233 76 16 234 234 101 16 235 235 51 16 236 236 46 16 237 237 74 16 238 238 101 16 239 239 102 16 240 240 65 16 241 241 37 16 242 242 77 16 243 243 102 16 244 244 74 16 245 245 39 13 246 246 67 13 247 247 102 16 248 248 103 16 249 249 64 16 250 250 36 16 251 251 81 16 252 252 103 16 253 253 78 16 254 254 35 16 255 255 51 16 256 256 103 16 257 257 104 16 258 258 58 15 259 259 42 15 260 260 85 16 261 261 104 16 262 262 82 16 263 263 34 16 264 264 50 16 265 265 104 16 266 266 105 16 267 267 54 15 268 268 38 15 269 269 89 16 270 270 105 16 271 271 86 16 272 272 43 13 273 273 71 13 274 274 105 16 275 275 107 24 276 276 108 23 277 277 114 23 278 278 108 23 279 279 106 5 280 280 112 5 281 281 39 13 282 282 107 24 283 283 113 24 284 284 110 24 285 285 109 23 286 286 108 23 287 287 109 23 288 288 111 5 289 289 106 5 290 290 107 24 291 291 39 13 292 292 55 13 293 293 113 24 294 294 114 23 295 295 24 23 296 296 114 23 297 297 112 5 298 298 14 5 299 299 67 13 300 300 113 24 301 301 28 24 302 302 115 23 303 303 116 5 304 304 122 5 305 305 71 13 306 306 43 13 307 307 117 24 308 308 117 24 309 309 115 23 310 310 121 23 311 311 119 23 312 312 118 5 313 313 116 5 314 314 43 13 315 315 59 13 316 316 120 24 317 317 120 24 318 318 119 23 319 319 115 23 320 320 121 23 321 321 122 5 322 322 2 1 323 323 3 14 324 324 71 13 325 325 123 24 326 326 123 24 327 327 121 23 328 328 10 0 329 329 124 27 330 330 125 26 331 331 131 26 332 332 125 26 333 333 126 2 334 334 132 2 335 335 38 15 336 336 124 27 337 337 130 27 338 338 127 27 339 339 129 26 340 340 125 26 341 341 129 26 342 342 128 2 343 343 126 2 344 344 124 27 345 345 38 15 346 346 54 15 347 347 66 15 348 348 130 27 349 349 26 27 350 350 130 27 351 351 131 26 352 352 25 26 353 353 131 26 354 354 132 2 355 355 11 2 356 356 135 26 357 357 133 2 358 358 136 2 359 359 70 15 360 360 42 15 361 361 134 27 362 362 134 27 363 363 135 26 364 364 138 26 365 365 138 26 366 366 136 2 367 367 0 10 368 368 1 33 369 369 70 15 370 370 137 27 371 371 137 27 372 372 138 26 373 373 8 9 374 374 139 26 375 375 141 2 376 376 133 2 377 377 42 15 378 378 58 15 379 379 140 27 380 380 140 27 381 381 139 26 382 382 135 26 383 383 142 17 384 384 144 11 385 385 150 11 386 386 41 32 387 387 143 18 388 388 149 18 389 389 143 18 390 390 142 17 391 391 148 17 392 392 146 17 393 393 147 11 394 394 144 11 395 395 143 18 396 396 41 32 397 397 57 32 398 398 145 18 399 399 146 17 400 400 142 17 401 401 69 32 402 402 149 18 403 403 32 18 404 404 149 18 405 405 148 17 406 406 22 17 407 407 148 17 408 408 150 11 409 409 19 11 410 410 153 18 411 411 152 17 412 412 158 17 413 413 73 32 414 414 45 32 415 415 153 18 416 416 152 17 417 417 151 11 418 418 157 11 419 419 155 18 420 420 156 17 421 421 152 17 422 422 45 32 423 423 61 32 424 424 155 18 425 425 156 17 426 426 154 11 427 427 151 11 428 428 158 17 429 429 157 11 430 430 4 7 431 431 159 18 432 432 158 17 433 433 16 6 434 434 5 31 435 435 73 32 436 436 159 18 437 437 161 21 438 438 162 20 439 439 165 20 440 440 162 20 441 441 160 8 442 442 163 8 443 443 40 30 444 444 161 21 445 445 164 21 446 446 164 21 447 447 165 20 448 448 23 20 449 449 165 20 450 450 163 8 451 451 17 8 452 452 68 30 453 453 164 21 454 454 30 21 455 455 166 21 456 456 167 20 457 457 162 20 458 458 167 20 459 459 168 8 460 460 160 8 461 461 161 21 462 462 40 30 463 463 56 30 464 464 171 21 465 465 169 20 466 466 176 20 467 467 72 30 468 468 44 30 469 469 171 21 470 470 169 20 471 471 170 8 472 472 177 8 473 473 174 21 474 474 173 20 475 475 169 20 476 476 44 30 477 477 60 30 478 478 174 21 479 479 173 20 480 480 172 8 481 481 170 8 482 482 7 29 483 483 72 30 484 484 175 21 485 485 176 20 486 486 177 8 487 487 6 4 488 488 175 21 489 489 176 20 490 490 13 3 491 491 129 26 492 492 10 0 493 493 128 2 494 494 109 23 495 495 13 3 496 496 111 5 497 497 167 20 498 498 16 6 499 499 168 8 500 500 146 17 501 501 8 9 502 502 147 11 503 503 17 8 504 504 21 12 505 505 172 8 506 506 14 5 507 507 112 5 508 508 21 12 509 509 106 5 510 510 111 5 511 511 177 8 512 512 6 4 513 513 177 8 514 514 111 5 515 515 170 8 516 516 172 8 517 517 21 12 518 518 21 12 519 519 112 5 520 520 106 5 521 521 106 5 522 522 177 8 523 523 170 8 524 524 105 16 525 525 71 13 526 526 54 15 527 527 104 16 528 528 50 16 529 529 58 15 530 530 103 16 531 531 51 16 532 532 64 16 533 533 102 16 534 534 67 13 535 535 65 16 536 536 154 11 537 537 19 11 538 538 21 12 539 539 21 12 540 540 17 8 541 541 163 8 542 542 163 8 543 543 160 8 544 544 21 12 545 545 168 8 546 546 4 7 547 547 157 11 548 548 157 11 549 549 151 11 550 550 160 8 551 551 154 11 552 552 21 12 553 553 151 11 554 554 160 8 555 555 168 8 556 556 157 11 557 557 147 11 558 558 0 10 559 559 136 2 560 560 136 2 561 561 133 2 562 562 147 11 563 563 141 2 564 564 11 2 565 565 21 12 566 566 21 12 567 567 19 11 568 568 150 11 569 569 150 11 570 570 144 11 571 571 21 12 572 572 147 11 573 573 133 2 574 574 144 11 575 575 141 2 576 576 21 12 577 577 133 2 578 578 21 12 579 579 11 2 580 580 132 2 581 581 132 2 582 582 126 2 583 583 21 12 584 584 128 2 585 585 2 1 586 586 122 5 587 587 122 5 588 588 116 5 589 589 128 2 590 590 118 5 591 591 14 5 592 592 21 12 593 593 21 12 594 594 116 5 595 595 118 5 596 596 128 2 597 597 116 5 598 598 126 2 599 599 156 17 600 600 22 17 601 601 154 11 602 602 155 18 603 603 32 18 604 604 156 17 605 605 145 18 606 606 33 19 607 607 146 17 608 608 173 20 609 609 23 20 610 610 172 8 611 611 174 21 612 612 30 21 613 613 173 20 614 614 166 21 615 615 31 22 616 616 167 20 617 617 119 23 618 618 24 23 619 619 118 5 620 620 120 24 621 621 28 24 622 622 119 23 623 623 110 24 624 624 29 25 625 625 109 23 626 626 139 26 627 627 25 26 628 628 141 2 629 629 140 27 630 630 26 27 631 631 139 26 632 632 127 27 633 633 27 28 634 634 129 26 635 635 27 28 636 636 127 27 637 637 3 14 638 638 29 25 639 639 110 24 640 640 7 29 641 641 31 22 642 642 166 21 643 643 5 31 644 644 33 19 645 645 145 18 646 646 1 33 647 647 140 27 648 648 58 15 649 649 26 27 650 650 120 24 651 651 59 13 652 652 28 24 653 653 174 21 654 654 60 30 655 655 30 21 656 656 155 18 657 657 61 32 658 658 32 18 659 659 101 16 660 660 74 16 661 661 53 16 662 662 100 16 663 663 75 16 664 664 76 16 665 665 99 16 666 666 55 13 667 667 77 16 668 668 98 16 669 669 78 16 670 670 52 16 671 671 97 16 672 672 79 16 673 673 80 16 674 674 96 16 675 675 63 16 676 676 81 16 677 677 95 16 678 678 82 16 679 679 70 15 680 680 94 16 681 681 83 16 682 682 84 16 683 683 93 16 684 684 62 16 685 685 85 16 686 686 92 16 687 687 86 16 688 688 66 15 689 689 91 16 690 690 87 16 691 691 88 16 692 692 90 16 693 693 59 13 694 694 89 16 695 695 87 16 696 696 90 16 697 697 49 16 698 698 37 16 699 699 65 16 700 700 87 16 701 701 65 16 702 702 12 13 703 703 90 16 704 704 62 16 705 705 91 16 706 706 34 16 707 707 20 16 708 708 53 16 709 709 62 16 710 710 53 16 711 711 37 16 712 712 91 16 713 713 50 16 714 714 92 16 715 715 9 15 716 716 34 16 717 717 88 16 718 718 50 16 719 719 88 16 720 720 49 16 721 721 92 16 722 722 83 16 723 723 93 16 724 724 48 16 725 725 36 16 726 726 64 16 727 727 83 16 728 728 64 16 729 729 20 16 730 730 93 16 731 731 69 32 732 732 94 16 733 733 41 32 734 734 18 32 735 735 52 16 736 736 69 32 737 737 52 16 738 738 36 16 739 739 94 16 740 740 57 32 741 741 95 16 742 742 1 33 743 743 41 32 744 744 84 16 745 745 57 32 746 746 84 16 747 747 48 16 748 748 95 16 749 749 79 16 750 750 96 16 751 751 47 16 752 752 40 30 753 753 68 30 754 754 79 16 755 755 68 30 756 756 15 30 757 757 96 16 758 758 73 32 759 759 97 16 760 760 45 32 761 761 5 31 762 762 56 30 763 763 73 32 764 764 56 30 765 765 40 30 766 766 97 16 767 767 61 32 768 768 98 16 769 769 18 32 770 770 45 32 771 771 80 16 772 772 61 32 773 773 80 16 774 774 47 16 775 775 98 16 776 776 75 16 777 777 99 16 778 778 46 16 779 779 44 30 780 780 72 30 781 781 75 16 782 782 72 30 783 783 7 29 784 784 99 16 785 785 63 16 786 786 100 16 787 787 35 16 788 788 15 30 789 789 60 30 790 790 63 16 791 791 60 30 792 792 44 30 793 793 100 16 794 794 51 16 795 795 101 16 796 796 20 16 797 797 35 16 798 798 76 16 799 799 51 16 800 800 76 16 801 801 46 16 802 802 101 16 803 803 74 16 804 804 102 16 805 805 37 16 806 806 46 16 807 807 77 16 808 808 74 16 809 809 77 16 810 810 39 13 811 811 102 16 812 812 78 16 813 813 103 16 814 814 36 16 815 815 47 16 816 816 81 16 817 817 78 16 818 818 81 16 819 819 35 16 820 820 103 16 821 821 82 16 822 822 104 16 823 823 42 15 824 824 48 16 825 825 85 16 826 826 82 16 827 827 85 16 828 828 34 16 829 829 104 16 830 830 86 16 831 831 105 16 832 832 38 15 833 833 49 16 834 834 89 16 835 835 86 16 836 836 89 16 837 837 43 13 838 838 105 16 839 839 113 24 840 840 107 24 841 841 114 23 842 842 114 23 843 843 108 23 844 844 112 5 845 845 67 13 846 846 39 13 847 847 113 24 848 848 107 24 849 849 110 24 850 850 108 23 851 851 108 23 852 852 109 23 853 853 106 5 854 854 110 24 855 855 107 24 856 856 55 13 857 857 28 24 858 858 113 24 859 859 24 23 860 860 24 23 861 861 114 23 862 862 14 5 863 863 12 13 864 864 67 13 865 865 28 24 866 866 121 23 867 867 115 23 868 868 122 5 869 869 123 24 870 870 71 13 871 871 117 24 872 872 123 24 873 873 117 24 874 874 121 23 875 875 115 23 876 876 119 23 877 877 116 5 878 878 117 24 879 879 43 13 880 880 120 24 881 881 117 24 882 882 120 24 883 883 115 23 884 884 10 0 885 885 121 23 886 886 2 1 887 887 27 28 888 888 3 14 889 889 123 24 890 890 27 28 891 891 123 24 892 892 10 0 893 893 130 27 894 894 124 27 895 895 131 26 896 896 131 26 897 897 125 26 898 898 132 2 899 899 66 15 900 900 38 15 901 901 130 27 902 902 124 27 903 903 127 27 904 904 125 26 905 905 125 26 906 906 129 26 907 907 126 2 908 908 127 27 909 909 124 27 910 910 54 15 911 911 9 15 912 912 66 15 913 913 26 27 914 914 26 27 915 915 130 27 916 916 25 26 917 917 25 26 918 918 131 26 919 919 11 2 920 920 138 26 921 921 135 26 922 922 136 2 923 923 137 27 924 924 70 15 925 925 134 27 926 926 137 27 927 927 134 27 928 928 138 26 929 929 8 9 930 930 138 26 931 931 0 10 932 932 33 19 933 933 1 33 934 934 137 27 935 935 33 19 936 936 137 27 937 937 8 9 938 938 135 26 939 939 139 26 940 940 133 2 941 941 134 27 942 942 42 15 943 943 140 27 944 944 134 27 945 945 140 27 946 946 135 26 947 947 148 17 948 948 142 17 949 949 150 11 950 950 69 32 951 951 41 32 952 952 149 18 953 953 149 18 954 954 143 18 955 955 148 17 956 956 142 17 957 957 146 17 958 958 144 11 959 959 145 18 960 960 143 18 961 961 57 32 962 962 143 18 963 963 145 18 964 964 142 17 965 965 18 32 966 966 69 32 967 967 32 18 968 968 32 18 969 969 149 18 970 970 22 17 971 971 22 17 972 972 148 17 973 973 19 11 974 974 159 18 975 975 153 18 976 976 158 17 977 977 159 18 978 978 73 32 979 979 153 18 980 980 158 17 981 981 152 17 982 982 157 11 983 983 153 18 984 984 155 18 985 985 152 17 986 986 153 18 987 987 45 32 988 988 155 18 989 989 152 17 990 990 156 17 991 991 151 11 992 992 16 6 993 993 158 17 994 994 4 7 995 995 31 22 996 996 159 18 997 997 16 6 998 998 31 22 999 999 5 31 1000 1000 159 18 1001 1001 164 21 1002 1002 161 21 1003 1003 165 20 1004 1004 165 20 1005 1005 162 20 1006 1006 163 8 1007 1007 68 30 1008 1008 40 30 1009 1009 164 21 1010 1010 30 21 1011 1011 164 21 1012 1012 23 20 1013 1013 23 20 1014 1014 165 20 1015 1015 17 8 1016 1016 15 30 1017 1017 68 30 1018 1018 30 21 1019 1019 161 21 1020 1020 166 21 1021 1021 162 20 1022 1022 162 20 1023 1023 167 20 1024 1024 160 8 1025 1025 166 21 1026 1026 161 21 1027 1027 56 30 1028 1028 175 21 1029 1029 171 21 1030 1030 176 20 1031 1031 175 21 1032 1032 72 30 1033 1033 171 21 1034 1034 176 20 1035 1035 169 20 1036 1036 177 8 1037 1037 171 21 1038 1038 174 21 1039 1039 169 20 1040 1040 171 21 1041 1041 44 30 1042 1042 174 21 1043 1043 169 20 1044 1044 173 20 1045 1045 170 8 1046 1046 29 25 1047 1047 7 29 1048 1048 175 21 1049 1049 13 3 1050 1050 176 20 1051 1051 6 4 1052 1052 29 25 1053 1053 175 21 1054 1054 13 3 1055 1055

+
+
+
+
+ + + + + 0.6858805 -0.3173701 0.6548619 7.481132 0.7276338 0.3124686 -0.6106656 -6.50764 -0.01081678 0.8953432 0.4452454 5.343665 0 0 0 1 + + + + -0.2908646 -0.7711008 0.5663932 4.076245 0.9551712 -0.1998834 0.2183912 1.005454 -0.05518906 0.6045247 0.7946723 5.903862 0 0 0 1 + + + + 0.5 0 0 0 0 0.5 0 0 0 0 0.5 0 0 0 0 1 + + + + + + + + + + + + + +
\ No newline at end of file diff --git a/models/meshes/platform.stl b/models/meshes/platform.stl new file mode 100644 index 0000000..8534689 Binary files /dev/null and b/models/meshes/platform.stl differ diff --git a/scripts/attached_object_visualizer.py b/scripts/attached_object_visualizer.py index 21b0328..8f0f3ff 100755 --- a/scripts/attached_object_visualizer.py +++ b/scripts/attached_object_visualizer.py @@ -56,7 +56,7 @@ def __init__(self): self.attached_marker_arrays = {} - self.marker_pub = rospy.Publisher('markers', MarkerArray) + self.marker_pub = rospy.Publisher('markers', MarkerArray, queue_size=1) self.planning_scene_sub = rospy.Subscriber('attached_collision_object', AttachedCollisionObject, self.aco_cb) diff --git a/scripts/hydra_teleop.py b/scripts/hydra_teleop.py index 40b14e7..c276561 100755 --- a/scripts/hydra_teleop.py +++ b/scripts/hydra_teleop.py @@ -2,6 +2,7 @@ import rospy +from std_msgs.msg import Float64 import sensor_msgs.msg from lcsr_barrett.wam_teleop import * @@ -33,6 +34,7 @@ class HydraTeleop(WAMTeleop): SIDE_MAP = {'left': LEFT, 'right': RIGHT} def __init__(self): + self.last_cmd_time = rospy.Time.now() # Get WAMTeleop params self.side = self.SIDE_MAP.get(rospy.get_param("~side",''), self.RIGHT) @@ -40,19 +42,29 @@ def __init__(self): input_frame_id = rospy.get_param('~input_frame', '/hydra_'+self.SIDE_STR[self.side]+'_grab') super(HydraTeleop, self).__init__(input_ref_frame_id, input_frame_id) + # Alpha pub + self.alpha_pub = rospy.Publisher('/alpha', Float64) + self.opacity = 1.0 + # Get the clutch button # This is the (0-based) index of the button in the clutch joy topic - self.clutch_button = rospy.get_param('~clutch_button', 0) + self.deadman_button = rospy.get_param('~deadman_button', None) + self.augmenter_button = rospy.get_param('~augmenter_button', None) + # Get the clutch duration # This is the time over which the cart command scale is increased self.clutch_duration = rospy.get_param('~clutch_duration', 0.3) + self.gripper_min = 1.0 + self.gripper_max = 0.0 + # Button state self.last_buttons = [0] * 16 - self.clutch_enabled = False + self.deadman_engaged = False self.clutch_enable_time = None - self.cart_scale = None + self.augmenter_engaged = False + self.last_joy_cmd = rospy.Time.now() # Hydra Joy input @@ -62,23 +74,33 @@ def __init__(self): def clutch_cb(self, msg): """Handle clutch joy messages.""" - clutch_enabled_now = msg.buttons[self.clutch_button] + # If the deadman_button isn't set, then assume it's the first button pressed after startup + if self.deadman_button is None or self.augmenter_button is None: + if msg.buttons.count(1) == 1: + try: + button_index = msg.buttons.index(1) + except ValueError: + return + if self.deadman_button is None: + rospy.loginfo("Using clutch button {} for deadman.".format(button_index)) + self.deadman_button = button_index + elif self.augmenter_button is None and button_index != self.deadman_button: + rospy.loginfo("Using clutch button {} for Gugmenter.".format(button_index)) + self.augmenter_button = button_index + return + + # Get the current deadman and augmenter state + deadman_engaged_now = msg.buttons[self.deadman_button] or msg.buttons[self.augmenter_button] + self.augmenter_engaged = msg.buttons[self.augmenter_button] - if self.clutch_enabled != clutch_enabled_now: - # The clutch has changed mode - if clutch_enabled_now: + # Check if the clutch state has changed + if self.deadman_engaged != deadman_engaged_now: + if deadman_engaged_now: # The clutch has been enabled self.clutch_enable_time = rospy.Time.now() - else: - # The clutch has been disabled, so stop the hand - self.hand_cmd.mode = [oro_barrett_msgs.msg.BHandCmd.MODE_VELOCITY] * 4 - self.hand_cmd.cmd = [0.0, 0.0, 0.0, 0.0] - self.hand_pub.publish(self.hand_cmd) - self.last_hand_cmd = rospy.Time.now() - self.deadman_engaged = False # Update the clutch value - self.clutch_enabled = clutch_enabled_now + self.deadman_engaged = deadman_engaged_now def joy_cb(self, msg): """Generate a cart/hand cmd from a hydra joy message""" @@ -90,38 +112,73 @@ def joy_cb(self, msg): self.check_for_backwards_time_jump() + # Get gripper range + gripper_val = msg.axes[self.BOT_TRIGGER[side]] + self.gripper_min = min(self.gripper_min, gripper_val) + self.gripper_max = max(self.gripper_max, gripper_val) + + # Don't run too fast if msg.header.stamp - self.last_joy_cmd < rospy.Duration(0.03): self.last_joy_cmd = msg.header.stamp return - if (rospy.Time.now() - self.last_hand_cmd) < rospy.Duration(0.03): + # Do nothing until gripper range has been established + if self.gripper_max < self.gripper_min or abs(self.gripper_min - self.gripper_max) < 0.5: + rospy.logdebug("Trigger has not yet been calibrated, please move it through it's entire range.") + rospy.logdebug("{} <= {} <= {}".format(self.gripper_min, gripper_val, self.gripper_max)) return - # Update enabled fingers - self.move_f[0] = self.move_f[0] ^ (b[self.B1[side]] and not lb[self.B1[side]]) - self.move_f[1] = self.move_f[1] ^ (b[self.B2[side]] and not lb[self.B2[side]]) - self.move_f[2] = self.move_f[2] ^ (b[self.B3[side]] and not lb[self.B3[side]]) - self.move_spread = self.move_spread ^ (b[self.B4[side]] and not lb[self.B4[side]]) - self.move_all = self.move_all ^ (b[self.B_CENTER[side]] and not lb[self.B_CENTER[side]]) + # Don't run too fast (hydra publishes @ 250Hz) + if (rospy.Time.now() - self.last_cmd_time) < rospy.Duration(0.03): + return + self.last_cmd_time = rospy.Time.now() + + # Publish marker opacity + opacity_increment = 0.1 * msg.axes[self.THUMB_Y[side]] + if abs(opacity_increment) < 0.01: + opacity_increment = 0.0 + self.opacity = min(max(0.0, self.opacity + opacity_increment), 1.0) + self.alpha_pub.publish(Float64(self.opacity)) + + # Check if the clutch is engaged + reset_command = msg.buttons[self.TOP_TRIGGER[side]] == 1 + self.rescue_engaged = b[self.B_CENTER[side]] + + # Normalize and reshape the gripper value + normalized_gripper_val = (gripper_val - self.gripper_min) / (self.gripper_max - 0.04) + normalized_gripper_val = max(0.0, min(normalized_gripper_val, 1.0)) + #grasp_opening = (1.0 - (0.25 + 0.75*pow(normalized_gripper_val,1.0/3.0))) + grasp_opening = 0.4 - math.tan(normalized_gripper_val * 2.35 + 2) / 7 + rospy.logdebug("grasp {} => {} ({}, {})".format(gripper_val, normalized_gripper_val,self.gripper_min, self.gripper_max)) + + if self.deadman_engaged: + self.enable_tracking(reset=reset_command) + + cart_scale = min(1.0, (rospy.Time.now() - self.clutch_enable_time).to_sec() / self.clutch_duration) + + self.update_hand_cmd(grasp_opening, msg.axes[self.THUMB_X[side]]) + self.update_cart_cmd(cart_scale) + else: + self.disable_tracking() + self.hold_hand_cmd() + + # Publish direct and mediated commands + self.publish_hand_cmd(msg.header.stamp) + self.publish_cart_cmd(msg.header.stamp) + self.publish_telemanip_cmd( + self.deadman_engaged, + self.augmenter_engaged, + self.rescue_engaged, + reset_command, + msg.header.stamp) - # Check if the deadman is engaged - if self.clutch_enabled: - self.cart_scale = min(1.0, (rospy.Time.now() - self.clutch_enable_time).to_sec() / self.clutch_duration) - self.handle_hand_cmd(msg.axes[self.BOT_TRIGGER[side]], msg.axes[self.THUMB_X[side]]) - self.handle_cart_cmd(self.cart_scale) + # republish markers + self.publish_cmd_ring_markers(msg.header.stamp) # Update last raw command values self.last_buttons = msg.buttons self.last_axes = msg.axes - # Broadcast the command if it's defined - resync_pose = False - augmenter_engaged = msg.buttons[self.TOP_TRIGGER[side]] == 0 - grasp_opening = 1.0 - msg.axes[self.BOT_TRIGGER[side]] - self.publish_cmd(resync_pose, augmenter_engaged, grasp_opening, msg.header.stamp) - - # republish markers - self.publish_cmd_ring_markers(msg.header.stamp) def main(): diff --git a/src/lcsr_barrett/wam_teleop.py b/src/lcsr_barrett/wam_teleop.py index 207b70e..bf26868 100644 --- a/src/lcsr_barrett/wam_teleop.py +++ b/src/lcsr_barrett/wam_teleop.py @@ -3,6 +3,7 @@ import rospy from std_msgs.msg import ColorRGBA +from std_srvs.srv import Empty, EmptyRequest, EmptyResponse from visualization_msgs.msg import Marker, MarkerArray from telemanip_msgs.msg import TelemanipCommand import oro_barrett_msgs.msg @@ -12,6 +13,10 @@ from tf_conversions.posemath import fromTf, toTf, toMsg import math import time +import colorsys + +import ascent_augmenter.msg +from ascent_augmenter.state import State def sigm(s, r, x): @@ -22,6 +27,7 @@ def sign(v): return (1.0 if v < 0.0 else -1.0) def finger_point(a, r = 0.08, l = 0.025): + """Get the 3D point for the finger identifier""" # a: finger joint angle # r: marker radius # l: finger radius center offset @@ -39,9 +45,20 @@ def finger_point(a, r = 0.08, l = 0.025): return (D*dy + sign(dy) * dx * math.sqrt(desc), -D*dx - abs(dy) * math.sqrt(desc), -0.08) +# TODO: Make the augmenter and this script use the sane numbers for this +FINGER_MAX_POS = 140.0 / 180.0 * math.pi + +def finger_angle(opening): + """Get the finger angle based on the 0-1 grasp opening""" + + # Clip the finger command + return FINGER_MAX_POS*max(0, min(1.0, 1.0 - opening)) + + class WAMTeleop(object): def __init__(self, input_ref_frame_id, input_frame_id): + self.state = State() self.input_ref_frame_id = input_ref_frame_id self.input_frame_id = input_frame_id @@ -49,6 +66,7 @@ def __init__(self, input_ref_frame_id, input_frame_id): # Parameters self.tip_link = rospy.get_param('~tip_link') self.cmd_frame_id = rospy.get_param('~cmd_frame', 'wam/cmd') + self.hand_cmd_frame_id = rospy.get_param('~hand_cmd_base_frame', 'wam/hand_cmd_base') self.scale = rospy.get_param('~scale', 1.0) self.use_hand = rospy.get_param('~use_hand', True) @@ -58,21 +76,38 @@ def __init__(self, input_ref_frame_id, input_frame_id): self.broadcaster = tf.TransformBroadcaster() # State - self.cmd_origin = kdl.Frame() - self.tip_origin = kdl.Frame() + self.tracking = False + self.input_origin = kdl.Frame() + self.tip_origin = None#kdl.Frame() + + self.augmenter_resources = [] + self.augmenter_predicates = dict() # Command state + self.telemanip_cmd = TelemanipCommand() self.cmd_frame = None - self.deadman_engaged = False + self.augmenter_engaged = False + self.send_estop = False self.cmd_scaling = 0.0 + self.finger_pos = None + self.tracking_fingers = False # Command synchronized with actual gripper position + self.fingers_detached = True # Command synchronized with actual gripper position + + self.reset_service = rospy.Service( + 'reset_pose', + Empty, + self.reset_pose_cb) # Hand structures if self.use_hand: # Hand state self.hand_cmd = oro_barrett_msgs.msg.BHandCmd() - self.last_hand_cmd = rospy.Time.now() + self.last_hand_cmd_time = rospy.Time.now() self.hand_position = [0, 0, 0, 0] self.hand_velocity = [0, 0, 0, 0] + self.finger_mean = 0.0 + self.finger_cmd_pos = -1.0 + self.grasp_opening = 1.0 self.move_f = [True, True, True] self.move_spread = True @@ -88,6 +123,8 @@ def __init__(self, input_ref_frame_id, input_frame_id): # ROS generic telemanip command self.telemanip_cmd_pub = rospy.Publisher('telemanip_cmd_out', TelemanipCommand) + self.hand_cmd_joint_states_pub = rospy.Publisher('~hand/cmd_joint_states', sensor_msgs.msg.JointState) + # goal marker self.marker_pub = rospy.Publisher('master_target_markers', MarkerArray) @@ -165,6 +202,56 @@ def __init__(self, input_ref_frame_id, input_frame_id): m.mesh_use_embedded_materials = False self.master_target_markers.markers.append(m) + m = Marker() + m.header.frame_id = self.cmd_frame_id + m.ns = 'grasp_marker' + m.id = 0 + m.type = m.MESH_RESOURCE + m.action = 0 + p = m.pose.position + o = m.pose.orientation + p.x, p.y, p.z = (0,0,0) + o.x, o.y, o.z, o.w = (0, 0, 0, 1.0) + m.color = self.color_gray + m.color.a = 0.5 + m.scale.x = m.scale.y = m.scale.z = 0.01 + m.frame_locked = True + m.mesh_resource = 'package://lcsr_barrett/models/teleop_finger_marker.dae' + m.mesh_use_embedded_materials = False + self.master_target_markers.markers.append(m) + + m = Marker() + m.header.frame_id = self.cmd_frame_id + m.ns = 'palm_marker' + m.id = 0 + m.type = m.MESH_RESOURCE + m.action = 0 + p = m.pose.position + o = m.pose.orientation + p.x, p.y, p.z = (0,0,-0.12) + o.x, o.y, o.z, o.w = (0, 0, 0, 1.0) + m.color = self.color_gray + m.color.a = 0.5 + m.scale.x = m.scale.y = m.scale.z = 1.0 + m.frame_locked = True + m.mesh_resource = 'package://barrett_model/models/sw_meshes/bhand/bhand_palm_link_convex_decomposition.dae' + m.mesh_use_embedded_materials = False + self.master_target_markers.markers.append(m) + + # Augmenter integration + self.augmenter_state_sub = rospy.Subscriber( + 'gazebo/augmenter/state', + ascent_augmenter.msg.AugmenterState, + self.augmenter_state_cb) + + def reset_pose_cb(self, req): + rospy.logwarn('Resetting tip origin') + self.tip_origin = None + self.cmd_frame = fromTf(( + (0.835, 0.567, 0.532), + (0.447, 0.641, 0.486, -0.391))) + return EmptyResponse() + def check_for_backwards_time_jump(self): now = rospy.Time.now() if (now - self.last_time_check).to_sec() < 0.0: @@ -174,22 +261,35 @@ def check_for_backwards_time_jump(self): rospy.sleep(0.05) self.last_time_check = now + def augmenter_state_cb(self, msg): + self.state.assign_from_msg(msg) + + self.augmenter_resources = set(msg.resources + msg.pending_resources)#self.state.get_resources(remote=True) + self.augmenter_predicates = self.state.predicates + + #rospy.logwarn('resources: {}'.format(msg.resources)) + #rospy.logwarn('resources: {}'.format(self.augmenter_resources)) + + if self.augmenter_predicates.get('estop',False): + self.send_estop = False + + # If the gripper is being used, show that as the commanded value + if 'gripper' in self.augmenter_resources: + self.tracking_fingers = False + self.fingers_detached = True + def hand_state_cb(self, msg): - """update the hand state""" + """Process the hand state""" self.hand_position = [msg.position[2], msg.position[3], msg.position[4], msg.position[0]] self.hand_velocity = [msg.velocity[2], msg.velocity[3], msg.velocity[4], msg.velocity[0]] + self.finger_mean = sum(self.hand_position[0:3])/3.0 - def hold_cart_cmd(self): - """""" - - try: - self.cmd_frame.header.stamp = rospy.Time.now() - - except (tf.LookupException, tf.ConnectivityException, tf.ExtrapolationException) as ex: - rospy.logwarn(str(ex)) + if self.fingers_detached: + self.finger_cmd_pos = self.finger_mean - def handle_cart_cmd(self, scaling): - """""" + # Tracking / realtive offset control + def get_frames_(self): + """Get the TF frames for the teleop input and the end-effector""" try: # Get the current position of the hydra @@ -204,123 +304,225 @@ def handle_cart_cmd(self, scaling): self.tip_link, rospy.Time(0))) - # Capture the current position if we're starting to move - if not self.deadman_engaged: - self.deadman_engaged = True - self.cmd_origin = input_frame + except (tf.LookupException, tf.ConnectivityException, tf.ExtrapolationException) as ex: + rospy.logwarn(str(ex)) + return None, None + + return input_frame, tip_frame + + def enable_tracking(self, reset=False): + """Initiate tracking the user's cartesian input.""" + + if not self.tracking or reset: + rospy.loginfo("Enabling tracking (reset: {}).".format(reset)) + + # Get the input and tip frames + input_frame, tip_frame = self.get_frames_() + + if not input_frame or not tip_frame: + return + + # Save the input origin when tracking started + self.input_origin = input_frame + + # Save the tip origin when tracking started + # This is either the current tip frame, or the already-integrated cmd_frame + if reset or not self.tip_origin: self.tip_origin = tip_frame else: - self.cart_scaling = scaling - # Update commanded TF frame - cmd_twist = kdl.diff(self.cmd_origin, input_frame) - cmd_twist.vel = self.scale*self.cart_scaling*cmd_twist.vel - rospy.logwarn(cmd_twist) - self.cmd_frame = kdl.addDelta(self.tip_origin, cmd_twist) + self.tip_origin = self.cmd_frame - except (tf.LookupException, tf.ConnectivityException, tf.ExtrapolationException) as ex: - rospy.logwarn(str(ex)) + self.tracking = True + + + def disable_tracking(self): + """Stop tracking the user's cartesian input.""" + if self.tracking: + rospy.loginfo("Disabling tracking.") + + self.tracking = False + self.tracking_fingers = False + + # Cart command + def update_cart_cmd(self, scaling): + """Integrate the user's input if we're tracking it""" + + # Capture the current position if we're starting to move + if self.tracking and self.input_origin and self.tip_origin: + # Get the input and tip frames + input_frame, tip_frame = self.get_frames_() + + # Update scaling parameter + self.cart_scaling = scaling + + # Update commanded TF frame + cmd_twist = kdl.diff(self.input_origin, input_frame) + cmd_twist.vel = self.scale * self.cart_scaling * cmd_twist.vel + self.cmd_frame = kdl.addDelta(self.tip_origin, cmd_twist) + rospy.logdebug('Offset: {}'.format(cmd_twist)) + + def publish_cart_cmd(self, time): + """publish the raw tf frame and the telemanip command""" + + if not self.cmd_frame: + return + + # Broadcast command frame + cmd_frame_tf = toTf(self.cmd_frame) + self.broadcaster.sendTransform(cmd_frame_tf[0], cmd_frame_tf[1], time, + self.cmd_frame_id, 'world') - def handle_hand_cmd( + # Hand command + def update_hand_cmd( self, - finger_pos=None, + grasp_opening=None, spread_vel=None, spread_pos=None): - """""" - - # Capture the current position if we're starting to move - if self.deadman_engaged: - # Generate bhand command - f_max = 140.0/180.0*math.pi - - # Finger commands - finger_pos = f_max*max(0, min(1.0, finger_pos)) - finger_cmds = [2.0*(finger_pos-cur) for cur in self.hand_position[0:3]] - - # Spread command - if spread_pos is not None: - spread_pos = math.pi*max(0, min(1.0, spread_pos)) - spread_cmd = [(spread_pos-self.hand_position[3])] - elif spread_vel is not None: - spread_cmd = [3.0*(-1.0 + 2.0/(1.0 + math.exp(-4*spread_vel)))] - - new_cmd = finger_cmds + spread_cmd - new_mode = [oro_barrett_msgs.msg.BHandCmd.MODE_VELOCITY] * 4 - - for i in range(3): - if not self.move_f[i] or not self.move_all: - new_cmd[i] = 0.0 - new_mode[i] = oro_barrett_msgs.msg.BHandCmd.MODE_VELOCITY - if not self.move_spread or not self.move_all: - new_cmd[3] = 0.0 - else: - new_cmd = [0,0,0,0] - new_mode = [oro_barrett_msgs.msg.BHandCmd.MODE_VELOCITY] * 4 - - new_finger_cmd = [abs(old-new) > 0.1 - for (old, new) - in zip(self.hand_cmd.cmd[:3], new_cmd[:3])] - new_spread_cmd = [abs(old-new) > 0.1 - for (old, cur, new) - in [(self.hand_cmd.cmd[3], self.hand_velocity[3], new_cmd[3])]] - - # Only send a new command if the goal has changed - # TODO: take advantage of new SAME/IGNORE joint command mode - if True or any(new_finger_cmd) or any(new_spread_cmd): - self.hand_cmd.header.stamp = rospy.Time.now() - self.hand_cmd.mode = new_mode - self.hand_cmd.cmd = new_cmd - rospy.logdebug('hand command: \n'+str(self.hand_cmd)) + """Update the hand command reference.""" + + # Finger commands + finger_cmd_pos = finger_angle(grasp_opening) + finger_cmds = [2.0*(finger_cmd_pos-cur) for cur in self.hand_position[0:3]] + + # Spread command + if spread_pos is not None: + spread_pos = math.pi*max(0, min(1.0, spread_pos)) + spread_cmd = [(spread_pos-self.hand_position[3])] + elif spread_vel is not None: + spread_cmd = [3.0*(-1.0 + 2.0/(1.0 + math.exp(-4*spread_vel)))] + + # Check if the fingers are being tracked + if not self.tracking_fingers: + # If the fingers are commanded closed further than the current + # finger command, then re-sync command + if finger_cmd_pos > self.finger_mean or finger_cmd_pos > 0.95*FINGER_MAX_POS: + rospy.loginfo('Closed more than current mean. Tracking fingers.') + self.fingers_detached = False + self.tracking_fingers = True + + # Construct full command / mode + if self.tracking_fingers: + self.grasp_opening = grasp_opening + self.finger_cmd_pos = finger_cmd_pos + self.hand_cmd.mode = [oro_barrett_msgs.msg.BHandCmd.MODE_VELOCITY] * 4 + self.hand_cmd.cmd = finger_cmds + spread_cmd + + rospy.logdebug('opening: {} / {}'.format(grasp_opening, self.grasp_opening)) + + def hold_hand_cmd(self): + """Hold the hand at its current position.""" + + # Send commands to hold the hand steady + self.hand_cmd.mode = [oro_barrett_msgs.msg.BHandCmd.MODE_VELOCITY] * 4 + self.hand_cmd.cmd = [0,0,0,0] + + def set_hand_cmd(self, mode, cmd): + """Set the low-level hand mode/cmd""" + self.hand_cmd.mode = mode + self.hand_cmd.cmd = cmd + + def publish_hand_cmd(self, time): + """Publish a command to the hand.""" + self.hand_cmd.header.stamp = time + + # Only publish the command if the fingers are synchronized + if self.tracking_fingers: self.hand_pub.publish(self.hand_cmd) - self.last_hand_cmd = rospy.Time.now() + self.last_hand_cmd_time = time + rospy.logdebug('hand command: \n'+str(self.hand_cmd)) + + # Combined cart/hand command + def publish_telemanip_cmd(self, deadman_engaged, augmenter_engaged, resync_pose, send_estop, time): + + if not self.grasp_opening or not self.cmd_frame: + return + + # Broadcast telemanip command + self.telemanip_cmd.header.frame_id = 'world' + self.telemanip_cmd.header.stamp = time + + self.telemanip_cmd.grasp_opening = self.grasp_opening if self.tracking_fingers else -1.0 + self.telemanip_cmd.posetwist.pose = toMsg(self.cmd_frame) + + self.telemanip_cmd.resync_pose = resync_pose + self.telemanip_cmd.deadman_engaged = deadman_engaged or augmenter_engaged + self.telemanip_cmd.augmenter_engaged = augmenter_engaged + self.telemanip_cmd.estop = send_estop + + self.telemanip_cmd_pub.publish(self.telemanip_cmd) def publish_cmd_ring_markers(self, time): """publish wam command ring""" + # Color the master target markers for i,m in enumerate(self.master_target_markers.markers): m.header.stamp = time #rospy.Time.now() - if (i <3 and not self.move_f[i]) or (i==3 and not self.move_spread): - m.color = self.color_orange - elif not self.move_all: - m.color = self.color_red - else: - if self.deadman_engaged: - if self.engage_augmenter: - m.color = self.color_blue - else: - m.color = self.color_green + if i < 3: + if 'gripper' in self.augmenter_resources: + m.color = self.color_orange + elif self.telemanip_cmd.augmenter_engaged: + m.color = self.color_green + elif not self.tracking_fingers: + m.color = self.color_red else: - m.color = self.color_gray + m.color = self.color_blue - if i < 3: if i != 2: p = m.pose.position s = (-1.0 if i == 0 else 1.0) p.x, p.y, p.z = finger_point( self.hand_position[3] * s, l = 0.025 * s) + else: + if 'manipulator' in self.augmenter_resources: + m.color = self.color_orange + elif self.telemanip_cmd.augmenter_engaged: + m.color = self.color_green + elif self.augmenter_predicates.get('detached_command', False): + m.color = self.color_red + else: + m.color = self.color_blue - self.marker_pub.publish(self.master_target_markers) - - def publish_cmd(self, resync_pose, augmenter_engaged, grasp_opening, time): - """publish the raw tf frame and the telemanip command""" - - if not self.cmd_frame: - return + # Dim out the colors if the deadman isn't engaged + if not self.telemanip_cmd.deadman_engaged: + rgb = (m.color.r, m.color.g, m.color.b) + hsv = colorsys.rgb_to_hsv(*rgb) + mrgb = colorsys.hsv_to_rgb(hsv[0], hsv[1]/1.0, hsv[2]/2.0) + m.color = ColorRGBA(mrgb[0],mrgb[1],mrgb[2],1.0) - # Broadcast command frame - tform = toTf(self.cmd_frame) - self.broadcaster.sendTransform(tform[0], tform[1], time, self.cmd_frame_id, 'world') + # Publish the master target markers + self.marker_pub.publish(self.master_target_markers) - # Broadcast telemanip command - telemanip_cmd = TelemanipCommand() - telemanip_cmd.header.frame_id = 'world' - telemanip_cmd.header.stamp = time - telemanip_cmd.posetwist.pose = toMsg(self.cmd_frame) - telemanip_cmd.resync_pose = resync_pose - telemanip_cmd.deadman_engaged = self.deadman_engaged - telemanip_cmd.augmenter_engaged = augmenter_engaged - telemanip_cmd.grasp_opening = grasp_opening - telemanip_cmd.estop = False # TODO: add master estop control - self.telemanip_cmd_pub.publish(telemanip_cmd) + # Broadcast frame for hand state (future date it to frame-lock it) + # TODO: Get this frame from URDF + self.broadcaster.sendTransform( + (0,0,-0.12), + (0,0,0,1), + time+rospy.Duration(1.0), + self.hand_cmd_frame_id, + self.cmd_frame_id) + + # Determine if we should display the commanded or actual finger positions + finger_pos = self.finger_cmd_pos + + # Broadcast joint state for hand command + hand_joint_state = sensor_msgs.msg.JointState() + hand_joint_state.header.stamp = time+rospy.Duration(0.05) + hand_joint_state.name = [ + 'wam_cmd/bhand/finger_1/prox_joint', + 'wam_cmd/bhand/finger_2/prox_joint', + 'wam_cmd/bhand/finger_1/med_joint', + 'wam_cmd/bhand/finger_2/med_joint', + 'wam_cmd/bhand/finger_3/med_joint', + 'wam_cmd/bhand/finger_1/dist_joint', + 'wam_cmd/bhand/finger_2/dist_joint', + 'wam_cmd/bhand/finger_3/dist_joint'] + hand_joint_state.position = ( + 2*[0.0] + # Spread joints + 3*[finger_pos] + # Inner joints + 3*[finger_pos/3.0]) # Outer joints + hand_joint_state.velocity = [0.0] * 8 + hand_joint_state.effort = [0.0] * 8 + self.hand_cmd_joint_states_pub.publish(hand_joint_state)