import sigrokdecode as srd
+class SamplerateError(Exception):
+ pass
+
class Decoder(srd.Decoder):
api_version = 3
id = 'pwm'
desc = 'Analog level encoded in duty cycle percentage.'
license = 'gplv2+'
inputs = ['logic']
- outputs = ['pwm']
+ outputs = []
+ tags = ['Encoding']
channels = (
{'id': 'data', 'name': 'Data', 'desc': 'Data line'},
)
('period', 'Period'),
)
annotation_rows = (
- ('duty-cycle', 'Duty cycle', (0,)),
- ('period', 'Period', (1,)),
+ ('duty-cycle-vals', 'Duty cycles', (0,)),
+ ('periods', 'Periods', (1,)),
)
binary = (
('raw', 'RAW file'),
)
def __init__(self):
+ self.reset()
+
+ def reset(self):
+ self.samplerate = None
self.ss_block = self.es_block = None
- self.num_cycles = 0
def metadata(self, key, value):
if key == srd.SRD_CONF_SAMPLERATE:
self.put(self.ss_block, self.es_block, self.out_ann, [1, [period_s]])
def putb(self, data):
- # TODO Are these ss/es specs appropriate? It's the same value,
- # which represents a mere period counter, not sample numbers.
- # Probably should be:
- # self.put(self.ss_block, self.es_block, self.out_binary, data)
- self.put(self.num_cycles, self.num_cycles, self.out_binary, data)
+ self.put(self.ss_block, self.es_block, self.out_binary, data)
def decode(self):
+ if not self.samplerate:
+ raise SamplerateError('Cannot decode without samplerate.')
+
+ num_cycles = 0
average = 0
# Wait for an "active" edge (depends on config). This starts
# Get the next two edges. Setup some variables that get
# referenced in the calculation and in put() routines.
start_samplenum = self.samplenum
- pins = self.wait({0: 'e'})
+ self.wait({0: 'e'})
end_samplenum = self.samplenum
- pins = self.wait({0: 'e'})
+ self.wait({0: 'e'})
self.ss_block = start_samplenum
self.es_block = self.samplenum
self.putp(period_t)
# Update and report the new duty cycle average.
- self.num_cycles += 1
+ num_cycles += 1
average += percent
self.put(self.first_samplenum, self.es_block, self.out_average,
- float(average / self.num_cycles))
+ float(average / num_cycles))