The cue co-ordinates were mapped out as 3's onto the 2-d map, this gives the location of the cue tip.
The cue angle is also an output of the Hough Transform but the angle given needed to be altered to match the physics engine:
Actual Cue Angle = Cue Angle + Theta -90
Theta is the angle of the image rotation, -90 in order to match the Hough angle to the Physics Engine
The ball closest to the cue tip needs to be found in order to apply the Cue angle to it. This is done by calculating the distance of each ball to the cue tip and the shortest distance gives the cue ball. For testing purposes the cue will have a red tip as it makes it much easier to detect.
Testing of the application as a whole project, was to be done by building a 'Database' of 20 images which work in the correct lighting conditions. The image Analysis was very sensitive to the lighting conditions in the room and outside weather can have a big effect on the noise found in the image.
Chris
Saturday, 21 April 2012
Thursday, 19 April 2012
Cue detection
The cue will be detected as a straight line in the image, this means that the hough transform can be used to calculate the angle of the cue. However how can you detect the full 360 degree angle or end of the cue as the hough lines go through the whole image?
The cue has already been filtered using the filtering limits given in the post Revised Image Analysis 2. So find the pixels the hough line and the filtering cross and this finds the pixels the cue is in. The equations to calculate these pixels is given below.
j is the increment through the hough matrix and is always less than rhoHeight, rhoHeight is the size of the hough matrix accumulator in the rho direction
The cue has already been filtered using the filtering limits given in the post Revised Image Analysis 2. So find the pixels the hough line and the filtering cross and this finds the pixels the cue is in. The equations to calculate these pixels is given below.
j is the increment through the hough matrix and is always less than rhoHeight, rhoHeight is the size of the hough matrix accumulator in the rho direction
Tuesday, 17 April 2012
Changes to Code
One Week Until Bench Inspection....AAARRRGGHH!!!
There were problems found in the givens scaling function, sometimes the ball co-ordinates are lost during the shrinking. This is because it is going from a 1024x768 image to a 800x400 model of the table.
In order to overcome this, pixels which contained a 1,2 or 3 could not be overwritten and this meant no data was lost.
The rotation matrix was also altered to that the theta found was negated (theta = -theta) this gave the correct direction of rotation
Chris
There were problems found in the givens scaling function, sometimes the ball co-ordinates are lost during the shrinking. This is because it is going from a 1024x768 image to a 800x400 model of the table.
In order to overcome this, pixels which contained a 1,2 or 3 could not be overwritten and this meant no data was lost.
The rotation matrix was also altered to that the theta found was negated (theta = -theta) this gave the correct direction of rotation
Chris
Thursday, 12 April 2012
Revised Image Analysis (part 2)
In part one it was decided to use the HSV colour space to filter out the unnecessary parts of the image. There are 3 main sections needed; the table co-ordinates, ball co-ordinates and cue angle. After extensive testing the required filtering of each component was found.
To filter for the table the following filtering will be used; 0.22<Hue<0.49
T0 filter for the ball; Hue<0.21 or 0.2<=Hue<0.5 and value>=0.64 or Hue>0.49
To filter for the cue; Hue<0.1 or Hue>0.9
It was decided from the testing that it would be easiest to detect red balls as the values for Hue stayed relatively constant over the testing.
To filter for the table the following filtering will be used; 0.22<Hue<0.49
T0 filter for the ball; Hue<0.21 or 0.2<=Hue<0.5 and value>=0.64 or Hue>0.49
To filter for the cue; Hue<0.1 or Hue>0.9
It was decided from the testing that it would be easiest to detect red balls as the values for Hue stayed relatively constant over the testing.
Tuesday, 10 April 2012
Getting and Using the Pocket Co-ordinates
The Pockets were marked as 1's on the 2-d map of the table. Only the Corner pockets were found, not the centre pockets as these could be added later.
The table was split into quarters as it was assumed the image taken would be close enough to the table so that each pocket would be in a quarter of the image.
The image was then scanned and the 4 corner pockets were found and saved in two arrays; One which stored the X co-ordinates and one which stored the Y Co-ordinates.
Theta (for Rotation) = arctan(Ytopright-Ytopleft)/(Xtopright-Xtopleft)
Xshift = Xtopleft, Yshift = Ytopleft
resize X = Xbottomright
resize Y = Ybottomright
Chris
The table was split into quarters as it was assumed the image taken would be close enough to the table so that each pocket would be in a quarter of the image.
The image was then scanned and the 4 corner pockets were found and saved in two arrays; One which stored the X co-ordinates and one which stored the Y Co-ordinates.
Theta (for Rotation) = arctan(Ytopright-Ytopleft)/(Xtopright-Xtopleft)
Xshift = Xtopleft, Yshift = Ytopleft
resize X = Xbottomright
resize Y = Ybottomright
Chris
Saturday, 7 April 2012
Getting JSON string as an Integer
The Get data algorithm returns the JSON as a string, it is required to convert the string as an integer.
The string contains new lines ("\n") within it so getting the integer was more difficult than it first appeared.
To get the integer from a string , the following JAVA code is used:
Integer.ParseInt(string)
Chris
The string contains new lines ("\n") within it so getting the integer was more difficult than it first appeared.
To get the integer from a string , the following JAVA code is used:
Integer.ParseInt(string)
Chris
Tuesday, 3 April 2012
Text to Speech and New Layout
For reference for the blog, text to speech will be referred to as tts.
Reference to the tts sdk is found at http://developer.android.com/reference/android/speech/tts/TextToSpeech.html
Again, the New Boston gives tutorials on using the Text to Speech :
http://thenewboston.org/watch.php?cat=6&number=187
The tts needs to be initialised, this is done using the OnInitListener, the language is then set to UK.
The phrases for the text to speech are:
Instructions:
Reference to the tts sdk is found at http://developer.android.com/reference/android/speech/tts/TextToSpeech.html
Again, the New Boston gives tutorials on using the Text to Speech :
http://thenewboston.org/watch.php?cat=6&number=187
The tts needs to be initialised, this is done using the OnInitListener, the language is then set to UK.
The phrases for the text to speech are:
- Your Shot will be a Hit
- Your Shot will be a Miss
- No Server Found
It was discovered that the TTS works on a standalone Activity but when the TTs was integrated into the Tab View, it couldn't be initialised.
So a new layout for the application was to be created.
This would be a menu which contained 3 buttons; Start, Instructions and Preferences.
The background colour of this menu is set to be; "009900"
Menu:
Sunday, 1 April 2012
Deadlines
Bench Inspection day is 24th April so the project needs to all be working before then.
The Thesis is due in on 3rd May.
The Thesis is due in on 3rd May.
Subscribe to:
Posts (Atom)