-
Notifications
You must be signed in to change notification settings - Fork 0
/
thought_for_the_day.rb
105 lines (93 loc) · 3.3 KB
/
thought_for_the_day.rb
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
# thought for the day rss -> speech to text
# https://twitter.com/DJPDeveloper
#
# tested with ruby 2.0.0 y 2.1.1
require 'rexml/document'
require 'open-uri'
require 'uri'
require 'net/http'
require 'json'
# require 'open-uri'
# this is a script to show how to connect to IdolOnDemand as a rest service
# and apply speech to text analysis
# insert your api_key here, you can request by registering at
# https://www.idolondemand.com/signup.html
# and then go to Tools->Account->Manage Your API Keys
$api_key= "xxx"
# how long to wait between status requests
$status_wait= 30
# fuente RSS
#$rss_source='http://downloads.bbc.co.uk/podcasts/radio4/thought/rss.xml'
$rss_source='http://www.bbc.co.uk/programmes/p00szxv6/episodes/downloads.rss'
# language for Speech analisis
$audio_language="en-GB"
# language for Sentiment analisis
$sentiment_language="eng"
##########
## wait for a REST request
def wait_on_status(jobid)
uri = URI("http://api.idolondemand.com/1/job/status/" + jobid)
uri.query = URI.encode_www_form(:apikey => $api_key)
res = Net::HTTP.get_response(uri, p_addr = $proxy_host, p_port = $proxy_port)
obj = JSON.parse(res.body)
if obj['status'] == 'queued'
puts "job [#{jobid}] #{obj['status']}, waiting #{$status_wait} seconds"
sleep($status_wait)
wait_on_status(jobid)
end
end
##########
## retrieve results of a job
def job_results(jobid)
wait_on_status(jobid)
puts "Retrieving results for job [#{jobid}]"
uri = URI("http://api.idolondemand.com/1/job/result/" + jobid)
uri.query = URI.encode_www_form(:apikey => $api_key)
res = Net::HTTP.get_response(uri, p_addr = $proxy_host, p_port = $proxy_port)
return JSON.parse(res.body)['actions']
end
##########
## POST a new job and wait for results
def iod_request (api, params)
uri = URI("http://api.idolondemand.com/1/api/async/#{api}/v1")
uri.query = URI.encode_www_form(params)
res = Net::HTTP.get_response(uri, p_addr = $proxy_host, p_port = $proxy_port)
jobid = JSON.parse(res.body)['jobID']
puts "Post request jobid [#{jobid}]"
return job_results(jobid)
end
##########
## Run Sentiment Analysis on a text string
def sentiment(text)
return iod_request('analyzesentiment',
{:text => text, :language => $sentiment_language, :apikey => $api_key})
end
##########
## Run Speech Analysis on a media asset
def speech_analysis(url)
return iod_request('recognizespeech',
{:url => url, :language => $audio_language, :apikey => $api_key})
end
##########
## Format output
def analyze(title,link)
puts "Analysing Item #{title}"
puts "URL #{link}"
sa_content = speech_analysis(link)[0]['result']['document'][0]['content']
# serialize to debug the data structure
#File.open('sa_res', 'w+') do |f|
# Marshal.dump(sa_res, f)
#end
puts "Speech Analysis => #{sa_content}"
puts "Sentiment => #{sentiment(sa_content)[0]['result']}"
end
##########
# main starts here
# request RSS y send each item for speech analysis and sentiment
puts "Get media Items from RSS feed and analyze them voice->text->sentiment"
## get RSS feed
puts "Retrieving RSS #{$rss_source}"
REXML::Document.new(open(URI.parse($rss_source))).elements.
each('rss/channel/item') {|item|
analyze(item.elements['title'].text,
item.elements['link'].text)}