That’s right! You better not run, you better not hide, you better watch out for brand new robot holiday videos on Robohub! Drop your submissions down our chimney at editors@robohub.org and share the spirit of the season, like these vids-of-Christmas-past
We’re beginning to see more and more jobs being performed by machines, even creative tasks like writing music or painting can now be carried out by a computer.
But how and when will machines be able to explain themselves? Should we be worrying about an artificial intelligence taking over our world or are there bigger and more imminent challenges that advances in machine learning are presenting here and now?
Join Professor Brian Cox, the Royal Society Professor of Public Engagement, as he brings together experts on AI and machine learning to discuss key issues that will shape our future. Panelists include:
In this fascinating animation from Oxford Sparks, we take a look at how statistics and computer science can be used to make machines that learn for themselves, without being explicitly programmed.
Machine learning is a burgeoning breed of artificial intelligence (AI), and it’s all around us already; on our phones, powering social networks, helping the police and doctors, scientists and mayors. But how does it work? Enjoy the video below, and visit Oxford Sparks to discover more science and research from Oxford University.
You might also enjoy the following posts about AI and AI/robotics policy:
The population of the scenic ski-resort Davos, nestled in the Swiss Alps, swelled by nearly +3,000 people between the 17th and 20th of January. World leaders, academics, business tycoons, press and interlopers of all varieties were drawn to the 2017 World Economic Forum (WEF) Annual Meeting. The WEF is the foremost creative force for engaging the world’s top leaders in collaborative activities to shape the global, regional and industry agendas for the coming year and beyond. Perhaps unsurprisingly given recent geopolitical events, the theme of this year’s forum was Responsive and Responsible Leadership.
With the onset of the fourth industrial revolution, increasingly discontented segments of society not experiencing congruous economic and social progress are in danger of existential uncertainty and exclusion. Responsive and Responsible Leadership entails inclusive development and equitable growth, both nationally and globally. It also involves working rapidly to close generational divides by exercising shared stewardship of those systems that are critical to our prosperity.
In the end, leaders from all walks of life at the Annual Meeting 2017 must be ready to react credibly and responsibly to societal and global concerns that have been neglected for too long.”
Developing last year’s theme—“The fourth industrial revolution”—this year’s luminaries posited questions, among many others, concerning incipient robotics and artificial intelligence technologies set to have a pronounced impact on the global economy and global consciousness alike. What can we learn from the first wave of AI? How can the humanitarian sector benefit from big data algorithms? How will drone technology change the face of warfare? Can AI and computational tech help foster responsive and responsible leadership? What are the downsides of technology in the fourth industrial revolution?
Enjoy a selection of tech-themed videos below.
And a bit about global science including big data, open source science and education.
On the 15th November 2016, the IEEE’s AI and Ethics Summit posed the question: “Who does the thinking?” In a series of key-note speeches and lively panel discussions, leading technologists, legal thinkers, philosophers, social scientists, manufacturers and policy makers considered such issues as:
The social, technological and philosophical questions orbiting AI.
Proposals to program ethical algorithms with human values to machines.
The social implications of the applications of AI.
These videos aim to teach you how to begin programming your NAO with Python. The NAO can be programmed using several programming languages, including C++, MATLAB, JAVA, LabVIEW and Python. Instead of using the drag and drop boxes in the Choreograph, we’re going to get our NAO robot walking and talking using coding.
Tutorial 1: Speech
Helpful hints:
Follow these steps to create a box that we could put our python code into, and have our robot speak: “Hello”. “Hello I am a robot”.
Right click the main section box and go to “add new box”
Create a name for the box
Input main image
Select the type of box
Now we’re having a look at the script. Go into the scripts and click ok. And there we have our NAO little box. If we click into it, we have the python code. What we are going to do is change some of the codes to get our robot to speak.
Double click the box
Select the piece of code you need to alter to get our robot to speak(“def onInput_onStart(self)”)
Take out the pass section
Type in “ttsproxy = ALProxy(“ALTextToSpeech”)”. (Make sure you get the comment in there).
Underneath that, we are going to put “ttsproxy.say” and add the comment “Hello, I am a robot”.
The first line could create an object that gives us access to the robot’s text to speech capabilities. This object is assigned to the variable ttsProxy. We can access the object later through the name ttsProxy. I am going to mount the top line, and the alspeech is there. The second line calls a different function site. This function takes an argument “Hello, I am a robot” and then he uses a string or sequence of characters between two double quoted marks. The robot will speak the string that will pass to the say message aloud. There are your simple first steps into python and choreograph.
You can now, hopefully, get your NAO robot to talk by using your python programming skills. Now have a play with it’s behavior to see if you can get your NAO to say a longer sentence, or maybe even sing a song. Have a play, and use your imagination!
Tutorial 2: Walking
Helpful hints:
No we’re going get your robot to walk using Python. The NAO can be program to walk to any point using the in-build Python Programming Language instead of using the drag and drop boxes in the choregraphe. Python is more expressive and allows you to do things like computing trigonometric calculations on the robot.
Right click the main section box and go to “add new box”
Create a name for the box
Input main image
Select the type of box
First, we want our robot to stand up. Drag a stand up icon into the box. I am actually using the NAO key so the 3D robot in the robot view, and this because we need to put the robot on connecting so we can see what’s going on quite clearly. Oversee when you are using this on the real robot and never forget to trigger on the motors and connect everything up properly.
Open the Code Box
Go to “def onInput_onStart(self):”
Write “motionProxy = ALProxy(“ALMotion”)”
On the next line write “walkTo(0.2,0.0,0.0)”
End it with “self.onStopped()”
The first line is a proxy called ALmotion, which what is we created here, which allows us to call the motion functions up. The second line is the walkTo, which moves the robot to a specific distance. Now, look on the decimal places: see that .2 is X and Y and the radius, so he’s going to move .2 forward. Then if I start playing with the other numbers here, he’ll move to the Y radius and then to the other turning point as well. The final bit is the self.on. To stop this, we will call and tell the choregraphe to stop the procedure when it is at the end and just simple loop and loop and loop.
If we are good, we should see this now on the 3D NAO. So if I hit play, we can see it walking along. Well done guys, you can now get your NAO Robot to walk by using
your Python programming skills. Tread carefully!
If you liked this article, you may also enjoy these:
Back pain is one of the leading causes of work absenteeism in the UK, with 8.8 million days lost to work-related muscoskeletal disorders per year. On average, each case causes 16 days of absenteeism, and chronic conditions can cause some absences to become permanent.
But working in a bent forward, back straining posture is unavoidable in a great many professions, like in hospital, agricultural and warehouses environments to name but a few. This regular exposure to demanding postures increases the risk of debilitating pain, which can severely reduce productivity and moral in the workforce.
The Laevo Exoskeleton aims to alleviate this problem. The Laevo is a unique, wearable back-support that aids users working in a bent forward posture or lifting objects. The wearable frame carries part of the upper body weight of the user, thereby decreasing the strain on the lower back and improves the long-term employability of employees.
Video 1: The product
Video 2: See it in action
If you liked this article, you may also enjoy these:
Ghost Robotics—a leader in fast and lightweight direct-drive legged robots—announced recently that its Minitaur model has been updated with advanced reactive behaviors for navigating grass, rock, sand, snow and ice fields, urban objects and debris, and vertical terrain.
The latest gaits adapt reactively to unstructured environments to maintain balance, ascend steep inclines up to 35º, climb up to 15cm curb-sized steps, crouch to fit under crawl spaces as low as 27cm, and operate at variable speeds and turning rates. Minitaur’s high-force capabilities enable it to leap up to 40cm onto ledges and across gaps of up to 80cm. Its high control bandwidth allows it to actively balance on two legs, and its high speed operation allows its legs to navigate challenging environments rapidly, whilst reacting to unexpected contact.
“Our primary focus since releasing the Minitaur late last year has been expanding its behaviors to traverse a wide range of terrains and real-world operating scenarios,” said Gavin Kenneally, and Avik De, Co-founders of Ghost Robotics. “In a short time, we have shown that legged robots not only have superior baseline mobility over wheels and tracks in a variety of environments and terrains, but also exhibit a diverse set of behaviors that allow them to easily overcome natural obstacles. We are excited to push the envelope with future capabilities, improved hardware, as well as integrated sensing and autonomy.”
Ghost Robotics is designing next-generation legged robots that they claim are superior to wheeled and tracked autonomous vehicles in real-world field applications. They are also attempting to substantially reduce costs to drive adoption and scalable deployments. Whilst a commercial version of the Ghost Minitaur robot is slated for delivery in the future, the current development platform is in high demand, and has been shipped to many top robotics researchers worldwide (Carnegie Mellon, University of Pennsylvania, University of Washington, U.S. Army Research Labs and Google) for use in a broad range of research and commercialization initiatives.
“We are pleased with our R&D progress towards commercializing the Ghost Minitaur to prove legged robots can surpass the performance of wheel and track UGVs, while keeping the cost model low to support volume adoption—which is certainly not the case with existing bipedal and quadrupedal robot vendors,” said Jiren Parikh, Ghost Robotics, CEO.
In the coming quarters, the company plans to demonstrate further improvements in mobility, built-in manipulation capabilities, integration with more sensors, built-in autonomy for operation with reduced human intervention, as well as increased mechanical robustness and durability for operation in harsh environments. Watch this space.
If you enjoyed this article, you might also be interested in:
This handy video-tutorial course gives an introduction to the Robot Operating System (ROS), including many of the available tools that are commonly used in robotics. With the help of different examples, the tutorials offer a great starting point to learn programming robots. You will learn how to create software including simulation, to interface sensors and actuators, and to integrate control algorithms.
The course consists of a guided tutorial and exercises with increasing level of difficulty working with an autonomous robot. We provide recordings of the lectures and give an introduction to the exercises. From the course website, you can download all the material including exercise sheets and templates, and use the provided Virtual Machine (VM) image to start programming right away.
Objectives:
ROS architecture: Master nodes, topics, messages, services, parameters and actions
Console commands: Navigating and analyzing the ROS system and the catkin workspace
Creating ROS packages: Structure, launch-files, and best practices
ROS C++ client library (roscpp): Creating your own ROS C++ programs
Simulating with ROS: Gazebo simulator, robot models (URDF) and simulation environments (SDF)
Working with visualizations (RViz) and user interface tools (rqt)
UgCS is easy-to-use software for planning and flying UAV drone-survey missions. It supports almost any UAV platform, providing convenient tools for areal and linear surveys and enabling direct drone control. What’s more, UgCS enables professional land survey mission planning using photogrammetry techniques.
How to plan photogrammetry mission with UgCS
Standard land surveying photogrammetry mission planning with UgCS can be divided into following steps :
Obtain input data
Plan mission
Deploy ground control points
Fly mission
Image geotagging
Data processing
Map import to UgCS (optional)
Step one: Obtain input data
Firstly, to reach the desired result, input settings have to be defined:
Required GSD (ground sampling distance – size of single pixel on ground),
Survey area boundaries,
Required forward and side overlap.
GSD and area boundaries are usually defined by the customer’s requirements for output material parameters, for example by scale and resolution of digital map. Overlap should be chosen according to specific conditions of surveying area and requirements of data processing software.
Each data processing software (e.g., Pix4D, Agisoft Photoscan, Dronedeploy, Acute 3d) has specific requirements for side and forward overlaps for different surfaces. To choose correct values, please refer to documentation of chosen software. In general, 75% forward and 60% side overlap will be a good choice. Overlapping should be increased for areas with small amount of visual cues, for example for deserts or forests.
Often, aerial photogrammetry beginners are excited about the option to produce digital maps with extremely high resolution (1-2cm/pixel), and to use very small GSD for mission planning. This is very bad practice. Small GSD will result in longer flight time, hundreds of photos for each acre, tens of hours of processing and heavy output files. GSD should be set according to the output requirements of the digital map.
Other limitations can occur. For example, GSD of 10cm/pixel is required, but designed to use a Sony A6000 camera. Based on mentioned GSD and camera’s parameters, the flight altitude would be set to 510 meters. In most countries, maximum allowed altitude of UAV’s (without special permission) is limited to 120m/400ft AGL (above ground). Taking into account the maximum allowed altitude, the maximum possible GSD in this case could be no more than 2.3cm.
Step two: Plan your mission
Mission planning consists of two stages:
Initial planning,
Route optimisation.
-Initial planning:
The first step is to set surveying area using UgCS Photogrammetry tool. Area can be set using visual cues on underlying map or using exact coordinates of edges. The result – survey area is marked with yellow boundaries (Figure 1).
The next step is to set GSD and overlapping for the camera in Photogrammetry tool’s settings window (Figure 2).
To take photos in Photogrammetry tool’s setting window, define the control action of the camera (Figure 3). Set camera by distance triggering action with default values.
At this point, initial route planning is completed. UgCS will automatically calculate photogrammetry route (see Figure 4).
-Route optimisation
To optimise the route, it’s calculated parameters should be known: altitude, estimated flight time, number of shots, etc.
Part of the route’s calculated information can be found in the elevation profile window. To access the elevation profile window (if it is not visible on screen) click the parameters icon on the route card (lower-right corner, see Figure 5), and from the drop-down menu select show elevation:
The elevation profile window will present an estimated route length, duration, waypoint count and min/max altitude data:
To get other calculated values, open route log by clicking on route status indicator: the green check-mark (upper-right corner, see Figure 7) of the route card:
Using route parameters, it can be optimised to be more efficient and safe.
-Survey line direction
By default, UgCS will trace survey lines from south to north. But, in most cases, it will be more optimal to fly parallel to the longest boundary line of the survey area. To change survey line direction, edit direction angle field in the photogrammetry tool. In the example, by changing angle to 135 degrees, the number of passes is reduced from five (Figure 4) to four (Figure 8) and route length is 1km instead of 1.3km.
-Altitude type
UgCS Photogrammetry tool has the option to define how to trace the route according to altitude, with constant altitude above ground (AGL) or above mean sea level (AMSL). Please refer to your data processing software requirements as to which altitude tracking method it recommend.
In the UgCS team’s experience, the choice of altitude type depends on desired result. For orthophotomap (standard aerial land survey output format) it is better to choose AGL to ensure constant GSD for the entire map. If the aim is to produce DEM or 3D reconstruction, use AMSL so the data processing software has more data to correctly determine ground elevation by photos in order to provide more qualitative output.
In this case, UgCS will calculate flight altitude based on the lowest point of the survey area.
If AGL is selected in photogrammetry tool’s settings, UgCS will calculate the altitude for each waypoint. But in this case, terrain following will be rough if no “additional waypoints” are added (see Figure 10).
Therefore, if AGL is used, add some “additional waypoints” flags and UgCS will calculate a flight plan with elevation profile accordingly (see Figure 11).
-Speed
In general, if flight speed is increased it will minimise flight time. But high speed in combination with large camera exposure can result in blurred images. In most cases 10m/s is the best choice.
-Camera control method
UgCS supports 3 camera control methods (actions):
Make a shot (trigger camera) in waypoint,
Make shot every N seconds,
Make shot every N meters.
Not all autopilots support all 3 camera control options. For example (quite old) DJI A2 does support all three options, but newer (starting from Phantom 3 and up to M600) cameras support only triggering in waypoints and by time. DJI promised to implement triggering by distance, but it’s not available yet.
Here are some benefits and drawbacks for all three methods:
In conclusion:
Trigger in waypoints should be preferred when possible
Trigger by time should be used only if no other method is possible
Trigger by distance should be used when triggering in waypoints is not possible to use
To select triggering method in UgCS Photogrammetry tool accordingly, use one of three available icons:
Set camera mode
Set camera by time
Set camera by distance
-Glibal control
Drones, e.g., DJI Phantom 3, Phantom 4, Inspire, M100 or M600 with integrated gimbal, have the option to control camera position as part of an automatic route plan.
It is advisable to set camera to nadir position in the first waypoint, and in horizontal position before landing to prevent lenses from potential damage.
To set camera position, select the waypoint preceding the photogrammetry area and click set camera attitude/zoom (Figure 12) and enter “90” in the “Tilt” field (Figure 13).
As described previously, this waypoint should be a Stop&Turn type, otherwise the drone could skip this action.
To set camera to horizontal position, select last waypoint of survey route and click set camera attitude/zoom and enter “0” in the “Tilt” field.
-Turn types
Most autopilots or multirotor drones support different turn types in waypoints. Most popular DJI drones have three turn-types:
Stop and Turn: drone flies to the fixed point accurately, stays at that fixed point and then flies to next fixed point.
Bank Turn: the drone would fly with constant speed from one point to another without stopping.
Adaptive Bank Turn: It is almost the same performance like Bank Turn mode (Figure 13), but the real flight routine will be more accurately than Bank Turn.
It is advisable not to use Bank Turn for photogrammetry missions. Drone interprets Bank Turns as “recommendation destination waypoint”. The drone will fly towards this direction but will almost never pass through the waypoint. Because drone will not pass the waypoint, no action will be executed, meaning the camera will not be triggered, etc.
Adaptive Bank Turn should be used with caution because a drone can miss waypoints and, again, no camera triggering will be initiated.
Sometimes, adaptive bank turn type has to be used in order to have shorter flight time compared to stop and turn. When using adaptive bank turns, it is recommended to use overshot (see below) for the photogrammetry area.
-Overshot
Initially overshot was implemented for fixed wing (airplane) drones in order to have enough space for manoeuvring a U-turn.
Overshot can be set in photogrammetry tool to add an extra segment to both ends of each survey line.
In the example (Figure 15) can be seen that UgCS added 40m additional segments to both ends of each survey line (comparing to Figure 8).
Adding overshot is useful for copter-UAVs in two situations:
When Adaptive Bank Turns are used (or similar method for non-DJI drones), adding overshot will increase the chance that drone will precisely enter survey line and camera control action will be triggered. UgCS Team recommends to specify overshot that is approximately equal to distance between the parallel survey lines.
When Stop and Turn type is in use in combination with action to trigger camera in waypoints, there is a possibility that before making the shot, drone will start rotation to next waypoint – it can result in having photos with wrong orientation or blurred. To avoid that, shorter overshot has to be set, for example 5m. Don’t specify too short value (< 3m) because some drones could ignore waypoints, that are too close.
-Takeoff point
It is important to check the takeoff area at site before flying any mission! To better explain best practice on how to set takeoff point, first discuss an example of how it should not be done. Supposing that the takeoff point in our example mission (Figure 17) would be from the point marked with the airplane-icon, and drone pilot would upload the route on the ground with set automatic mission for automatic take-off.
Most drones in automatic takeoff mode would climb to low altitude about 3-10meters and then fly straight towards the first waypoint. Other drones would fly towards first waypoint straight from ground. Looking closely at the example map (Figure 17), some trees between the takeoff point and the first waypoint can be noticed. In this example, the drone more likely will not reach a safe altitude and will hit the trees.
Not only the surroundings can affect takeoff planning. Drone manufacturers can change drones elevation behavior in drone firmware, therefore after firmware updates it is recommended that you check drones automatic takeoff mode.
Also, a very important consideration is that most small UAVs use relative altitude for mission planing. Altitude counted relatively according to first waypoint is a second reason why an actual takeoff point should be near the first waypoint, and on the same terrain level.
UgCS Team recommends placing the first waypoint as close as possible to actual takeoff point and specifying a safe takeoff altitude (≈30m in most situations will be above any trees, see Figure 18). This is the only method that warrants safe takeoff for any mission. It also protects from any weird drone behaviour and unpredictable firmware updates, etc.
-Entry point to the survey grid
In the previous example, (see Figure 18), it can be noticed, that after adding the takeoff point, the route’s survey grid entry point was changed. This is because if additional waypoint is added subsequently to the photogrammetry area, UgCS will plan to fly the survey grid starting from nearest corner to the previous waypoint.
To change the entry point to survey grid, set additional waypoint close to the desired starting corner (see Figure 19).
-Landing point
If no landing point will be added outside the photogrammetry area after the survey mission, the drone will fly and hover in the last waypoint. There are two options for landing:
Take manual control over the drone and fly to landing point manually,
Activate the Return Home command in UgCS or from Remote Controller (RC).
In situations when the radio link with the drone is lost, for example if the survey area is large or there are problems with the remote controller, depending on the drone and it’s settings, one of these actions can occur:
Drone will return to home location automatically if lost radio link with ground station,
Drone will fly to last waypoint of survey area and hover as long as battery capacity will enable that, then: drone will perform emergency landing, or it will try to fly to home location.
The recommendation is to add an explicit landing points to the route in order to avoid relying on unpredictable drone behavior or settings.
If the drone doesn’t support automatic landing, or the pilot prefers to land manually, place the route’s last waypoint over the planned landing point with an altitude for comfortable manual drone descending and landing above any obstacles in the surrounding area. In general 30m is best choice.
-Action execution
Photogrammetry tool has a magic parameter “Action Execution” with three possible values:
Every point
At start
Forward passes
This parameter defines how and where camera actions specified for photogrammetry tool will be executed.
The most useful option for photogrammetry/survey missions is to set forward passes, the drone will make photos only on survey lines, but will not make excess photos on perpendicular lines.
-Complex survey areas
UgCS enables photogrammetry/survey mission planning for irregular areas, having functionality to combine any number of photogrammetry areas in one route, avoiding splitting the area in separate routes.
For example, if a mission has to be planned for two fields connected in a T-shape, and if these two fields are marked as one photogrammetry area, the whole route will not be optimal, regardless any direction of survey lines.
If the survey area is marked as two photogrammetry areas within one route, survey lines for each area can be optimised individually (see Figure 21).
Step three: deploy ground control points
Ground control points are mandatory if the survey output map has to be precisely aligned to coordinates on Earth.
There are lots of discussions about the necessity of ground control points in cases when a drone is equipped with Real Time Kinematics (RTK) GPS receivers with centimeter-level accuracy. This is useful, but the drone coordinates are not in themselves sufficient because, for precise map aligning, image center coordinates are necessary.
Data processing softwares like Agisoft Photoscan, Dronedeplay, Pix4d, Icarus OneButton and others will produce very accurate maps using geotagged images, but the real precision of the map will not be known without ground control points.
Conclusion: ground control points have to be used to create survey-grade result. For a map with approximate precision, it is sufficient to rely just on RTK GPS and the capabilities of data processing software.
Step four: fly your mission
For carefully planned missions, flying it is the most straightforward step. Mission execution differs according to the type of UAV and equipment used, therefore it will not be described in detail in this article (please refer to equipment’s and UgCS documentation).
Important issues before flying:
In most countries there are strict regulations for UAV usage. Always comply with the regulations! Usually these rules can be found on web-site of local aviation authority.
In some countries special permission for any kind of aerial photo/video shooting is needed. Please check local regulations.
In most cases missions are planned before arriving to flying location (e.g., in office, at home) using satellite imaginary from Google maps, Bing, etc. Before flying always check actual circumstances at the location. There could be a need to adjust take-off/landing points, for example, to avoid tall obstacles (e.g., trees, masts, power lines) in your survey area.
Step five: image geotagging
Image geotagging is optional if ground control points were used, but almost any data processing software will require less time to process geotagged images.
Some of the latest and professional drones with integrated cameras can geotag images automatically during flight. In other cases images can be geotagged in UgCS after flight.
Very important: UgCS uses the telemetry log from drone, that is received via radio channel, to extract the drone’s altitude for any given moment (when pictures were taken). To geotag pictures using UgCS, assure robust telemetry reception during flight.
For detailed information how to geotag images using UgCS refer to UgCS User Manual.
Step six: data processing
For data processing, use third party software or services available on the market.
From UgCS Team experience, the most powerful and flexible software is Agisoft Photoscan (http://www.agisoft.com/), but sometimes too much user input is required to get necessary results. The most uncomplicated solution for users is online service Dronedeploy (https://www.dronedeploy.com/). All other software packages and services will fit somewhere between these two in terms of complexity and power.
Step seven (optional): import created map to UgCS
Should the need arise for the mission to be repeated in the future, UgCS enables importing the GeoTiff file as a map layer and using it for mission planning. More detailed instructions can be found in UgCS User Manual. See the result of an imported map created using UgCS photogrammetry tool imported as GeoTiff file in Figure 22.
Hi, I’m Ben. I was a member of the team that developed a new walking mechanism, TrotBot, that we eventually scaled up to the size of a mini-van (you can read my original post here). Now, at DIYwalkers, I’ve posted plans for TrotBot Ver. 2, designed to handle the weight of the EV3 brick. As you can see in the following videos, we were able to improve TrotBot by borrowing some ideas from a galloping horse.
Just like lunges are more tiring by simply walking, robots with bumpy gaits require more power to walk. This may not be a problem at small scales, but as a robot’s weight increases, smoother gaits are required. TrotBot Ver. 1 has somewhat of a bumpy gait, but as you can see in my video below, TrotBot’s weight at LEGO-scale is low enough that it walks well:
However, when I added LEGO’s relatively heavy EV3 brick to TrotBot it didn’t perform so well. To reduce its power requirements, I needed to smooth TrotBot’s gait, which I did by adding active feet that mimic the leg action of a galloping horse.
Background on TrotBot and its Feet
Our goal for TrotBot was to create a walking mechanism capable of walking on rough terrain and areas generally inaccessible to wheeled vehicles, so we designed its linkage to step high. We initially prototyped TrotBot in LEGO with 8 legs. It walked well enough that we—somewhat naively—thought we could scale it up to mini-van size with only 8 legs. A team of us spent most of that summer’s boiling hot weekends building our large TrotBot in my garage, only to find, during our first walking test, that too much torque was required to drive the robot up from the gait’s low point. As we discovered, large walkers should always have at least one foot in contact with the ground at each corner, like how a car’s four wheels are always in contact with the ground. Below, I simulated one corner of a 12 leg version of TrotBot, and as you can see we should have scaled up TrotBot with 12 legs like Theo Jansen’s famous Strandbeest has:
It would have required too many new parts to switch to a 12 leg version of TrotBot, and we didn’t want to start over from scratch, so instead we explored ideas for active feet that could smooth TrotBot’s 8 legged gait.
Using a galloping horse’s gait as inspiration we sought to add some sort of second foot to each leg that would mimic how a horse’s rear then front legs land in pairs. This resulted in the additional linkage that we call TrotBot’s “heel” which increased TrotBot’s foot-contact with the ground by about 10%, reduced how much the feet skidded, and increased the step-height of TrotBot’s rear legs. Shown below is a video comparing TrotBot with these “heels” to a galloping horse:
Next, we explored adding some sort of toe that would push down on the ground as the foot begins to lift, just like how humans use their toes to walk. We installed one of these toe ideas on our large TrotBot but they didn’t smooth the gait enough, and since they were attached to the legs at a fixed angle they tended to catch on obstacles. Catching on obstacles occasionally caused the linkage to lock and gears to grind. In other words, this toe compromised our main goal of creating a mechanism that could walk on rough terrain! Here’s a photo of that toe:
Looking again to a galloping horse for inspiration we started to experiment with linkages that mimicked how horses paw their hooves backward and then keep them folded back as they lift their legs to strike the ground again. We discovered a few options that mimicked this action, and they smoothed the gait by increasing TrotBot’s foot-contact by another 10% while maintaining its high foot-path. I added one of these toe options to TrotBot Ver. 2, and while I couldn’t make a toe with accurate dimensions using LEGO’s integer-based beams, it still smoothes TrotBot’s gait significantly:
Click here for instructions on how to build your own TrotBot Ver. 2!
Today we are looking at how to program your NAO Robot for Human Interaction. Watch the video and follow the steps below to get interactive with your robot pal!
Create an animation of movements
Right click, select “Create a new box”
Select “Timeline”
We want the robot to do 3 things, a five high, a hello, and a goodbye move:
On the Timeline Edit Box
Name: High Five
Image: Click “Edit”
On the Edit box image
Click “Browse” and select a file
Click “OK”
Now, as you can remember, if we take it to the box, we can get access to the NAO’s Timeline. Mine now is connected to the PC. So what I’m going to do is I’m going to set some points of the NAO to do some movements. As I have said before on one of my tutorial I’m going to make it set all the joints to the whole body.
We want to make him look like he is doing a high five:
Right click the arm
Click “Stiffen chain on/off”
Raise his arm up
Set joints and keyframe
Select “Arms”
Click “Play” on the Motion Controller
That’s a quite quick high five actually. What we want to do is to actually give him a pause when he got his arm in the air. So, the way we do that is to copy and paste the keyframe.
Grab a few already built in animation, just to show you how much it works:
Go to Motions>Animations
Drag a “Hello” box to the workspace
Drag a “Wipe Forehead” box for a goodbye move to the workspace
We want to hear him speak, so:
Go to Voice
Drag a “Speech Recognition” box to the workspace
Drag a “Switch Case”
Connect the “Speech Recognition” box to the “Switch Case” box
On the first case, write “Hello” and connect to the “Hello” box
On the second case, write “High Five” and connect it to the “High Five” box
On the third case, write “Goodbye” and connect it to the “Wipe Forehand” box
Set parameters of Speech Recognition
Word list: Hi; High Five; Goodbye;
Play with the threshold to see what works better
Click “OK”
So there we have a speech recognition, he will listen to what I am saying and then we will act a motion. Now, what we need to do is to make sure that the robot doesn’t repeat it, so you know, it doesn’t loop back. Before we do that, we are going to:
Drag 3 “Say” box to the workspace so he can speak back to us
On the “Switch case”, connect the “Hello” case on the “Say” box
Localized Text
Change the language to English(United States)
Write “Hi” on the textbox
Connect the “High Five” case on the “Say (1)” box
Localized Text
Change the language to English(United States)
Write “High Five” on the textbox
Connect the “Goodbye” case on the “Say(2)” box
Localized Text
Change the language to English(United States)
Write “Goodbye” on the textbox
So, here’s what we are saying, he recognizes it, says a word and does an animation, now what we want to do is we don’t want him to loop, as in he keeps hearing the same sound and maybe he starts to hear himself and repeat himself, so to stop that we need to connect the end of the motion boxes back to the “Speech Recognition” box. A simple output to the input speech.
I am going to make a little change actually, instead of “Hello”, we should put “Hi” here and I’m going to put “Hi” in there which is already done because they have to match otherwise if it doesn’t match he won’t recognize it. So if he hit “Load”
Philip: High Five!
Nao: High Five!
Philip: Goodbye!
Nao: Goodbye!
Philip: Hi!
Nao: Hello!
Brilliant! So that looks likes he’s working very well, so again if we says “Hi”, “High Five” or “Good bye” then he will greet you. If you walk in to room and you say “Hi” to a robot, obviously, he will do his animation and say a speech. Here you can use your imagination and try different things, different animations.
If you liked this article, you may also enjoy these from Robo-Phil:
The Robot Academy is a new learning resource from Professor Peter Corke and the Queensland University of Technology (QUT), the team behind the award-winning Introduction to Robotics and Robotic Vision courses. There are over 200 lessons available, all for free.
Educators are encouraged to use the Academy content to support teaching and learning in class or set them as flipped learning tasks. You can easily create viewing lists with links to lessons or masterclasses. Under Resources, you can download a Robotics Toolbox and Machine Vision Toolbox, which are useful for simulating classical arm-type robotics, such as kinematics, dynamics, and trajectory generation.
The lessons were created in 2015 for the Introduction to Robotics and Robotic Vision courses. We describe our approach to creating the original courses in the article, An Innovative Educational Change: Massive Open Online Courses in Robotics and Robotic Vision. The courses were designed for university undergraduate students but many lessons are suitable for anybody, see the difficulty rating on each lesson.
Under Masterclasses, students can choose a subject and watch a set of videos related to that particular topic. Single lessons can offer a short training segment or a refresher. Three online courses, Introducing Robotics, are also offered.
Below are two examples of a lesson and masterclass. We encourage everyone to take a look at the QUT Robot Academy by visiting our website.
Single Lesson
Out and about with robots
In this video, we look at a diverse range of real-world robots and discuss what they do and how they do it.
Masterclass
Robot joint control: Introduction (Video 1 of 12)
In this video, students learn how we make robot joints move to the angles or positions that are required to achieve the desired end-effector motion. This is the job of the robot’s joint controller. In the lecture, we will take discuss the realms of control theory.
Robot joint control: Architecture (video 2 of 12)
In this lecture, we discuss a robot joint is a mechatronic system comprising motors, sensors, electronics and embedded computing that implements a feedback control system.
Robot joint control: Actuators (video 3 of 12)
Actuators are the components that actually move the robot’s joint. So, let’s look at a few different actuation technologies that are used in robots.
To watch the rest of the video series, visit their website.
If you enjoyed this article, you may also want to read:
The Robot Academy is a new learning resource from Professor Peter Corke and the Queensland University of Technology (QUT), the team behind the award-winning Introduction to Robotics and Robotic Vision courses. There are over 200 lessons available, all for free.
The lessons were created in 2015 for the Introduction to Robotics and Robotic Vision courses. We describe our approach to creating the original courses in the article, An Innovative Educational Change: Massive Open Online Courses in Robotics and Robotic Vision. The courses were designed for university undergraduate students but many lessons are suitable for anybody, as you can easily see the difficulty rating for each lesson. Below are several examples of image formation and 3D vision.
The geometry of image formation
The real world has three dimensions but an image has only two. We can use linear algebra and homogeneous coordinates to understand what’s going on. This more general approach allows us to model the positions of pixels in the sensor array and to derive relationships between points on the image and points on an arbitrary plane in the scene.
How is an image formed? The real world has three dimensions but an image has only two: how does this happen and what are the consequences? We can use simple geometry to understand what’s going on.
An image is a two-dimensional projection of a three-dimensional world. The big problem with this projection is that big distant objects appear the same size as small close objects. For people, and robots, it’s important to distinguish these different situations. Let’s look at how humans and robots can determine the scale of objects and estimate the 3D structure of the world based on 2D images.
At the beginning of the decade, George Whitesides helped rewrite the rules of what a machine could be with the development of biologically inspired “soft robots.” Now he’s poised to rewrite them again, with help from some plastic drinking straws.
Inspired by arthropod insects and spiders, Whitesides and Alex Nemiroski, a former postdoctoral fellow in Whitesides’ Harvard lab, have created a type of semi-soft robot capable of standing and walking. The team also created a robotic water strider capable of pushing itself along the liquid surface. The robots are described in a recently published paper in the journal Soft Robotics.
Unlike earlier generations of soft robots, which could stand and awkwardly walk by inflating air chambers in their bodies, the new robots are designed to be far nimbler. Though real-world applications are still far off, the researchers hope the robots eventually could be used in search operations following natural disasters or in conflict zones.
“If you look around the world, there are a lot of things, like spiders and insects, that are very agile,” said Whitesides, the Woodford L. and Ann A. Flowers University Professor at Harvard. “They can move rapidly, climb on various items, and are able to do things that large, hard robots can’t do because of their weight and form factor. They are among the most versatile organisms on the planet. The question was, how can we build something like that?”
The answer, Nemiroski said, came in the form of your average drinking straw.
“This all started with an observation that George made, that polypropylene tubes have an excellent strength-to-weight ratio. That opened the door to creating something that has more structural support than purely soft robots have,” he said. “That was the building block, and then we took inspiration from arthropods to figure out how to make a joint and how to use the tubes as an exoskeleton. From there it was a question of how far can your imagination go? Once you have a Lego brick, what kind of castle can you build with it?”
What they built, he said, is a surprisingly simple joint.
Whitesides and Nemiroski began by cutting a notch in the straws, allowing them to bend. The scientists then inserted short lengths of tubing which, when inflated, would force the joints to extend. A rubber tendon attached on either side would then cause the joint to retract when the tubing deflated.
Armed with that simple concept, the team built a one-legged robot capable of crawling, and moved up in complexity as they added a second and then a third leg, allowing the robot to stand on its own.
“With every new level of systems complexity, we would have to go back to the original joint and make modifications to make it capable of exerting more force or to be able to support the weight of larger robots,” Nemiroski said. “Eventually, when we graduated to six- or eight-legged arthrobots, making them walk became a challenge from a programming perspective. For example, we looked at the way ants and spiders sequence the motion of their limbs and then tried to figure out whether aspects of these motions were applicable to what we were doing or whether we’d need to develop our own type of walking tailored to these specific types of joints.”
While Nemiroski and colleagues were able to control simple robots by hand, using syringes, they turned to computers to control the sequencing of their limbs as the designs increased in complexity.
“We put together a microcontroller run by Arduino that uses valves and a central compressor,” he said. “That allowed us the freedom to evolve their gait rapidly.”
Though Nemiroski and colleagues were able to replicate ants’ distinctive “triangle” gait using their six-legged robot, duplicating a spider-like gait proved far trickier.
“A spider has the ability to modulate the speed at which it extends and contracts its joints to carefully time which limbs are moving forward or backward at any moment,” Nemiroski said. “But in our case, the joints’ motion is binary due to the simplicity of our valving system. Either you switch the valve to the pressure source to inflate the balloon in the joint, and thus extend the limb, or you switch the valve to atmosphere to deflate the joint and thus retract the limb. So in the case of the eight-legged robot, we had to develop our own gait compatible with the binary motion of our joints. I’m sure it’s not a brand-new gait, but we could not duplicate precisely how a spider moves for this robot.”
Developing a system that can fine-tune the speed of actuation of the legs, Nemiroski said, would be a useful goal for future research, and would require programmable control over the flow rate supplied to each joint.
“We hit that limitation in the system, which I’m actually pretty proud of, because it means we pushed it to its absolute limit,” he said. “We took the basic concept and asked how far can we go before we would have to make radical alterations to how these limbs work, and we found that limit at the eight-legged robot. We were able to make it walk, but if you wanted to make it walk faster, or to add more limbs — for example, to support a load — you would have to start rethinking the system from the ground up.”
Though it may be years before the robots find their way into real-world applications, Whitesides believes the techniques used in their development — particularly the use of everyday, off-the-shelf materials — can point the way toward future innovations.
“I don’t see any reason to reinvent wheels,” he said. “If you look at drinking straws, they can make them at, effectively, zero cost and with great strength, so why not use them? These are academic prototypes, so they’re very light weight, but it would be fairly easy to imagine building these with a lightweight structural polymer that could hold a substantial weight.”
“What’s really attractive here is the simplicity,” added Nemiroski. “This is something George has been championing for some time, and something I grew to appreciate deeply while I was in his lab. For all the complexity of movement and structural integrity we get out of these robots, they’re remarkably simple in terms of construction and control. Using a single, easy-to-find material and a single concept for an actuator, we could achieve complex, multidimensional motion.”
This research was supported with funding from the U.S. Department of Energy, DARPA, the Natural Sciences and Engineering Research Council of Canada, the National Science Foundation, the Swedish Research Council, and the Wyss Institute for Biologically Inspired Engineering at Harvard University.
The Robot Academy is a new learning resource from Professor Peter Corke and the Queensland University of Technology (QUT), the team behind the award-winning Introduction to Robotics and Robotic Vision courses. There are over 200 lessons available, all for free.
The lessons were created in 2015 for the Introduction to Robotics and Robotic Vision courses. We describe our approach to creating the original courses in the article, An Innovative Educational Change: Massive Open Online Courses in Robotics and Robotic Vision. The courses were designed for university undergraduate students but many lessons are suitable for anybody, as you can easily see the difficulty rating for each lesson. Below are lessons from inverse kinematics and robot motion.
In this video lecture, we will learn about inverse kinematics, that is, how to compute the robot’s joint angles given the desired pose of their end-effector and knowledge about the dimensions of its links. We will also learn about how to generate paths that lead to a smooth coordinated motion of the end-effector.
Inverse kinematics for a 2-joint robot arm using geometry
In this lesson, we revisit the simple 2-link planar robot and determine the inverse kinematic function using simple geometry and trigonometry.
Inverse kinematics for a 2-joint robot arm using algebra
Singapore and MIT have been at the forefront of autonomous vehicle development. First, there were self-driving golf buggies. Then, an autonomous electric car. Now, leveraging similar technology, MIT and Singaporean researchers have developed and deployed a self-driving wheelchair at a hospital.
Spearheaded by Daniela Rus, the Andrew (1956) and Erna Viterbi Professor of Electrical Engineering and Computer Science and director of MIT’s Computer Science and Artificial Intelligence Laboratory, this autonomous wheelchair is an extension of the self-driving scooter that launched at MIT last year — and it is a testament to the success of the Singapore-MIT Alliance for Research and Technology, or SMART, a collaboration between researchers at MIT and in Singapore.
Rus, who is also the principal investigator of the SMART Future Urban Mobility research group, says this newest innovation can help nurses focus more on patient care as they can get relief from logistics work which includes searching for wheelchairs and wheeling patients in the complex hospital network.
“When we visited several retirement communities, we realized that the quality of life is dependent on mobility. We want to make it really easy for people to move around,” Rus says.
“Within the framework of the European project ROBOTT-NET we are developing software and robotic solutions for the prevention and control of rodents in enclosed spaces”, says Marco Lorenzo, Service Supervisor at Irabia Control De Plagas.
You can learn more about the urban pest control project here:
This type of prevention is designed to help technicians and companies have better efficiency and control and a faster response, when it comes to controlling rodent pests.
“The project uses a mobile autonomous robotic platform with a robot arm to introduce a camera into the trap. It captures an image that is uploaded to the cloud”.
“The project is in collaboration with Robotnik, which is responsible for the assembly of the robot; and Hispavista, which is in charge of the cloud part”, Marco Lorenzo adds.
Aritz Zabaleta, a Systems Technician at Hispavista Labs explains that the application consists of two components:
“The first manages the entire fleet of robots that communicate with the server in the cloud and it processes the information collected by them. The second component is the one that allows customers to access processed images”.
If you want to watch more fascinating robotics videos, you can explore ROBOTT-NET’s pilot projects on our YouTube-channel.