Multi-input multi-output time encoding and decoding machines

Information

  • Patent Grant
  • 8023046
  • Patent Number
    8,023,046
  • Date Filed
    Tuesday, December 22, 2009
    15 years ago
  • Date Issued
    Tuesday, September 20, 2011
    13 years ago
Abstract
Methods and systems for encoding and decoding signals using a Multi-input Multi-output Time Encoding Machine (TEM) and Time Decoding Machine are disclosed herein.
Description
BACKGROUND

1. Field


The present application relates to methods and systems for a Multi-input Multi-output (MIMO) Time Encoding Machines (TEMs) and Time Decoding Machines (TDMs) as well as uses of TEMs and TDMs for encoding and decoding video signals.


2. Background Art


Most signals in the natural world are analog, i.e., cover a continuous range of amplitude values. However, most computer systems for processing these signals are binary digital systems. Generally, synchronous analog-to-digital (A/D) converters are used to capture analog signals and present a digital approximation of the input signal to a computer processor. That is, at precise moments in time synchronized to a system clock, the amplitude of the signal of interest is captured as a digital value. When sampling the amplitude of an analog signal, each bit in the digital representation of the signal represents an increment of voltage, which defines the resolution of the A/D converter. Analog-to-digital conversion is used in numerous applications, such as communications where a signal to be communicated can be converted from an analog signal, such as voice, to a digital signal prior to transport along a transmission line.


Applying traditional sampling theory, a band limited signal can be represented with a quantifiable error by sampling the analog signal at a sampling rate at or above what is commonly referred to as the Nyquist sampling rate. It is a continuing trend in electronic circuit design to reduce the available operating voltage provided to integrated circuit devices. In this regard, power supply voltages for circuits are constantly decreasing. While digital signals can be processed at the lower supply voltages, traditional synchronous sampling of the amplitude of a signal becomes more difficult as the available power supply voltage is reduced and each bit in the A/D or D/A converter reflects a substantially lower voltage increment.


Time Encoding Machines (TEMs) can encode analog information in the time domain using only asynchronous circuits. Representation in the time domain can be an alternative to the classical sampling representation in the amplitude domain. Applications for TEMs can be found in low power nano-sensors for analog-to-discrete (A/D) conversion as well as in modeling olfactory systems, vision and hearing in neuroscience.


SUMMARY

Systems and methods for using MIMO TEMs and TDMs are disclosed herein.


According to some embodiments of the disclosed subject matter, methods for encoding a plurality (M) of components of a signal include filtering each of the M components into a plurality (N) filtered signals and encoding each of the N filtered-signals using at least one Time Encoding Machine (TEM) to generate a plurality (N) of TEM-encoded filtered signals. In some embodiments include the TEM can be an integrate-and-fire neuron, can have multiplicative coupling, and/or can be an asynchronous sigma/delta modulator. In some embodiments, a bias value can be added to each of the N filtered-signals. In some embodiments, the M signals can be irregularly sampled.


In further embodiments, each of the N filtered signals can be represented by the equation vj=(hj)T*u, where hj=[hj1, hj2, . . . hjM]T is a filtering vector corresponding to one of the N filtered signals represented by j. In some embodiments, the N TEM-encoded filtered signals can represented by qkj, where qkjjδj−bj(tk+1j−tkj), for all times represented by a value kεcustom character, and each of the N filtered signals represented by a value j, j=1, 2, . . . N, where kj is an integration constant, δj is a threshold value, and bj is a bias value for each of the N filtered signals.


According to some embodiments of the disclosed subject matter, methods for decoding a TEM-encoded signal include, receiving a plurality (N) of TEM-encoded filtered signals, decoding the N TEM-encoded filtered signals using at least one Time Decoding Machine (TDM) to generate a plurality (N) of TDM-decoded signal components, and filtering each of the N TDM-decoded signal components into a plurality (M) of output signals components. In some embodiments, one of the M output signal components, represented by the i-th component of the vector valued signal u, |ui(t)|≦ci, can be recovered by solving for









u
i



(
t
)


=




j
=
1

N










k

𝔍









c
k
j




ψ
k
ji



(
t
)






,





where ψkji(t)=({tilde over (h)}ji*g)(t−skj), for all i, i=1, 2, . . . M, skj=(tk+1j+tkj)/2, {tilde over (h)}ji is the involution of hji, hji is represented in a TEM-filterbank








h


(
t
)


=

[





h
11



(
t
)






h
12



(
t
)









h

1

M




(
t
)








h
21



(
t
)






h
22



(
t
)









h

2

M




(
t
)






















h

N





1




(
t
)






h

N





2




(
t
)









h
NM



(
t
)





]


,





and [cj]k=ckj j=1, 2, . . . N, where c=[c1, c2, . . . , cN]T, c=G+q, where q=[q1, q2, . . . , qN]T and [qj]k=qkj and








[

G
ij

]

kl

=




m
=
1

M












j




k






j





k
+
1








h
im

*


h
~

jm

*

g


(

t
-

s
l
j


)










s

.








In some embodiments, the M TEM-encoded signals can be irregularly sampled.


According to some embodiments of the disclosed subject matter, methods for encoding a video stream signal include filtering the video stream signal into a plurality (N) of spatiotemporal field signals, and encoding each of the N spatiotemporal field signals with a Time Encoding Machine to generate a plurality (N) of TEM-encoded spatiotemporal field signals. In some embodiments, the spatiotemporal field signals can be described by an equation









v
j



(
t
)


=




-



+






(





X








D
j



(

x
,
y
,
s
,

)




I


(

x
,
y
,

t
-
s


)









x








y




)




s




,





where Dj(x,y,s)


is a filter function, and I(x,y,t) represents the input video stream.


In some embodiments, the N TEM-encoded spatiotemporal field signals can be represented by a sampling function: ψkj(x,y,t)=D(x,y,−t)*g(t−skj), for k spike times, for each (x,y) in a bounded spatial set, where j corresponds to each of the N TEM-encoded spatiotemporal field signals, and where g(t)=sin(Ωt)/πt.


According to some embodiments of the disclosed subject matter, methods for decoding a TEM-encoded video stream signal include receiving a plurality (N) of TEM-encoded spatiotemporal field signals, decoding each of the N TEM-encoded spatiotemporal field signals using a Time Decoding Machine (TDM) to generate a TDM-decoded spatiotemporal field signal, and combining each of the TDM-decoded spatiotemporal field signals to recover the video stream signal.


In some embodiments, the decoding and combining can be achieved by applying an equation:








I


(

x
,
y
,
t

)


=




j
=
1

N










k

𝔍









c
k
j




ψ
k
j



(

x
,
y
,
t

)






,





where ψkj(x,y,t)=D(x,y,t)*g(t−skj), for k spike times, for each (x,y) in a bounded spatial set, where j corresponds to each of the N TEM-encoded spatiotemporal field signals, and where g(t)=sin(Ωt)πt, and where [cj]k=ckj and c=[c1, c2, . . . c1]T, c=G+q, where T denotes a transpose, q=[q1, q2, . . . qN]T, [qj]k=qkj and G+ denotes a pseudoinverse, a matrix G is represented by






G
=

[




G
11




G
12







G

1

N







G
21




G
22







G

2

N





















G

N





1





G

N





2








G
NN




]






[Gij]k1=<Di(x,y,•)*g(•−tki),Dj(x,y,•)*g(•−tlj).


According to some embodiments of the disclosed subject matter, methods of altering a video stream signal include receiving a plurality (N) of TEM-encoded spatiotemporal field signals from a plurality (N) of TEM-filters applying a switching matrix to map the N TEM-encoded spatiotemporal field signals to a plurality (N) of reconstruction filters in a video stream signal TDM. In some embodiments for rotating the video stream signal the switching matrix can map each of the N TEM-encoded spatiotemporal field signals from a TEM-filter ([x,y], α, θ) to a reconstruction filter ([x,y], α, θ+lθ0), where lθ0 represents a desired value of rotation.


In some embodiments for zooming the video stream signal the switching matrix can map each of the N TEM-encoded spatiotemporal field signals from a TEM-filter ([x,y], α, θ) to a reconstruction filter ([x,y], α0mα, θ), where α0m represents a desired value of zoom.


In some embodiments for translating the video stream signal by a value [nb0, kb0] the switching matrix can map each of the N TEM-encoded spatiotemporal field signals from a TEM-filter ([x,y], α, θ) to a reconstruction filter at ([x+nb0, y+kb0], α, θ).


In some embodiments for zooming the video stream signal by a value α0m and translating the video stream signal by a value [nb0, kb0] the switching matrix can map each of the N TEM-encoded spatiotemporal field signals from a TEM-filter ([x,y], α, θ) to a reconstruction filter at ([x+α0mnb0, y+α0mkb0], α0mα, θ).


According to some embodiments of the disclosed subject matter, methods of encoding a video signal include inputting the video signal into a first and second time encoding machine (TEM), the first TEM including a first TEM-input and a first TEM-output, the second TEM including a second TEM-input and a second TEM-output, wherein the first TEM-output is connected to the first TEM-input and the second TEM-input to provide negative feedback and the second TEM-output is connected to the first TEM-input and the second TEM-input to provide positive feedback.


Some embodiments further include outputting a first set of trigger values from the first TEM according to an equation







u


(

t
k
1

)


=



+

δ
1


+




l
<
k









h
11



(


t
k
1

-

t
l
1


)



-



l









h
21



(


t
k
1

-

t
l
2


)




1

{


t
l
2

<

t
k
2


}





=


q
k
1

.







and outputting a second set of trigger values from the second TEM according to an equation







u


(

t
k
2

)


=



-

δ
2


+




l
<
k









h
22



(


t
k
2

-

t
l
2


)



-



l









h
12



(


t
k
2

-

t
l
1


)




1

{


t
l
1

<

t
k
2


}





=


q
k
2

.






Yet other embodiments further include outputting a first set of trigger values from the first TEM according to an equation












1




k






1





k
+
1








u


(
s
)









s



=



κ
1



δ
1


-


b
1



(


t

k
+
1

1

-

t
k
1


)


+




l
<
k













1




k






1





k
+
1









h
11



(

s
-

t
l
1


)






l












1




k






1





k
+
1








h
21



(

s
-

t
l
2


)







-







s







1

{


t
l
1

<

t
k
1


}







and







outputting a second set of trigger values from the second TEM according to an equation












2




k






2





k
+
1








u


(
s
)









s



=



κ
2



δ
2


-


b
2



(


t

k
+
1

1

-

t
k
1


)


+




l
<
k













2




k






2





k
+
1









h
22



(

s
-

t
l
2


)






l












2




k






2





k
+
1








h
12



(

s
-

t
l
1


)







-







s








1

{


t
l
1

<

t
k
1


}


.







According to some embodiments of the disclosed subject matter, methods of decoding a video signal include receiving first and second TEM-encoded signals and applying an equation








u


(
t
)


=





k

𝔍









c
k
1




ψ
k
1



(
t
)




+




k

𝔍









c
k
2




ψ
k
2



(
t
)






,





where ψkj(t)=g(t−tkj), for j=1, 2, g(t)=sin(Ωt)/πt, tεcustom character c=[c1; c2] and [cj]k=ckj, and a vector of coefficients c can be computed as c=G+q, where q=[q1; q2] with [qj]k=qkj and







G
=

[




G
11




G
12






G
21




G
22




]


,



[

G
ij

]

kl

=

<

x
k
i



,


ψ
l
j

>

,


for





all





j

=
1

,
2
,

and





k

,

l



.






The accompanying drawings, which are incorporated and constitute part of this disclosure, illustrate preferred embodiments of the disclosed subject matter and serve to explain its principles.





BRIEF DESCRIPTION OF THE DRAWINGS


FIG. 1 depicts a multiple input multiple output Time Encoding Machine architecture in accordance with some embodiments of the disclosed subject matter;



FIG. 2 depicts a multiple input multiple output Time Decoding Machine Architecture in accordance with some embodiments of the disclosed subject matter;



FIG. 3 depicts a multiple input multiple output irregular sampling architecture in accordance with some embodiments of the disclosed subject matter;



FIG. 4 depicts a video stream encoding device in accordance with some embodiments of the disclosed subject matter;



FIG. 5 depicts a video stream decoding device in accordance with some embodiments of the disclosed subject matter;



FIG. 6 depicts a second video stream decoding device in accordance with some embodiments of the disclosed subject matter;



FIG. 7 depicts a video stream encoding and decoding device in accordance with some embodiments of the disclosed subject matter;



FIG. 8 depicts a time encoding circuit in accordance with some embodiments of the disclosed subject matter;



FIG. 9 depicts a single neuron encoding circuit that includes an integrate-and-fire neuron with feedback in accordance with some embodiments of the disclosed subject matter;



FIG. 10 depicts two interconnected ON-OFF neurons each with its own feedback in accordance with some embodiments of the disclosed subject matter; and



FIG. 11 depicts two interconnected ON-OFF neurons each with its own feedback in accordance with some embodiments of the disclosed subject matter.





Throughout the drawings, the same reference numerals and characters, unless otherwise stated, are used to denote like features, elements, components or portions of the illustrated embodiments. Moreover, while the present disclosed subject matter will now be described in detail with reference to the Figs., it is done so in connection with the illustrative embodiments.


DETAILED DESCRIPTION

Improved systems, methods, and applications of Time Encoding and Decoding machines are disclose herein.


Asynchronous Sigma/Delta modulators as well as FM modulators can encode information in the time domain as described in “Perfect Recovery and Sensitivity Analysis of Time Encoded Bandlimited Signals” by A. A. Lazar and L. T. Toth (IEEE Transactions on Circuits and Systems—I: Regular Papers, 51(10):2060-2073, October 2004), which is incorporated by reference. More general TEMs with multiplicative coupling, feedforward and feedback have also been characterized by A. A. Lazar in “Time Encoding Machines with Multiplicative Coupling, Feedback and Feedforward” (IEEE Transactions on Circuits and Systems II: Express Briefs, 53(8):672-676, August 2006), which is incorporated by reference. TEMs realized as single and as a population of integrate-and-fire neurons are described by A. A. Lazar in “Multichannel Time Encoding with Integrate-and-Fire Neurons” (Neurocomputing, 65-66:401-407, 2005) and “information Representation with an Ensemble of Hodgkin-Huxley Neurons” (Neurocomputing, 70:1764-1771, June 2007), both of which are incorporated by reference. Single-input single-output (SIMO) TEMs are described in “Faithful Representation of Stimuli with a Population of Integrate-and-Fire Neurons” by A. A. Lazar and E. A. Pnevmatikakis (Neural Computation), which is incorporated by reference.


Multi-input multi-output (MIMO) TEMs can encode M-dimensional bandlimited signals into N-dimensional time sequences. A representation of M-dimensional bandlimited signals can be generated using an N×M-dimensional filtering kernel and an ensemble of N integrate-and-fire neurons. Each component filter of the kernel can receive input from one of the M component inputs and its output can be additively coupled to a single neuron. (While the embodiments described refer to “neurons,” it would be understood by one of ordinary skill that other kinds of TEMs can be used in place of neurons.)


As depicted in FIG. 1, in one embodiment, M components of a signal 101, can be filtered by a set of filters 102. The outputs of the filters can be additively coupled to a set of N TEMs 104 to generated a set of N spike-sequences or trigger times 105.


Let Ξ be the set of bandlimited functions with spectral support in [−Ω, Ω]. The functions ui=ui(t), tεcustom character in Ξ can model the M components of the input signal. Without any loss of generality the signal components (u1, u2, . . . uM) can have a common bandwidth Ω. Further, it can be assumed that the signals in Ξ have finite energy, or are bounded with respect to the L2 norm. Thus Ξ can be a Hilbert space with a norm induced by the inner product in the usual fashion.


ΞM can denote the space of vector valued bandlimited functions of the form u=[u1, u2, . . . , uM]T, where T denotes the transpose. ΞM can be a Hilbert space with inner product defined by










<
u

,


v


>

Ξ
M



=




i
=
1

M







<

u
i




,


v
i



>
Ξ






(
1
)








and with norm given by













u



Ξ
M

2

=




i
=
1

M










u
i



Ξ
2



,




(
2
)








where u=[u1, u2, . . . , uM]TεΞM and v=[v1, v2, . . . , vM]TεΞM.


We can let H: custom character be a filtering kernel 102 defined as:










H


(
t
)


=

[





h
11



(
t
)






h
12



(
t
)









h

1

M




(
t
)








h
21



(
t
)






h
22



(
t
)









h

2

M




(
t
)






















h

N





1




(
t
)






h

N





2




(
t
)









h
NM



(
t
)





]





(
3
)








where it can be assumed that supp(ĥij)[−Ω,Ω], for all i, i=1, 2, . . . , M and all j, j=1, 2, . . . N (supp denoting the spectral support and ^ denotes the Fourier transform). Filtering the signal u with the kernel H can lead to an N-dimensional vector valued signal v defined by:










v


=
Δ




H
*
u

=

[







i
=
1

M








h

1

i


*

u
i











i
=
1

M








h

2

i


*

u
i
















i
=
1

M








h
Ni

*

u
i






]



,




(
4
)








where * denotes the convolution. Equation (4) can be written as

vj=(hj)T*u,j,j=1, 2, . . . N  (5)

where hj=[hj1, hj2, . . . hjM]T is the filtering vector of the neuron, or TEM, j, j=1, 2, . . . N. A bias bj 103 can be added to the component vj of the signal v and the sum can be passed through an integrate-and-fire neuron with integration constant κj and threshold δj for all j, j=1, 2, . . . , N. The value (tkj), kεcustom character can be the sequence of trigger (or spike) times 105 generated by neuron j, j=1, 2, . . . , N. In sum, the TEM depicted in FIG. 1 can map the input bandlimited vector u into the vector time sequence (tkj), kεcustom character j=1, 2, . . . , N.


In some embodiments the t-transform can describe the input/output relationship of the TEM, or the mapping of the stimulus u(t), tεcustom character into the output spike sequence (tkj), kεcustom character j=1, 2, . . . , N. The t-transform for the j-th neuron can be written as














j
k


j

k
+
1






(



v
j



(
s
)


+

b
j


)








s



=


κ
j



δ
j



,
or




(
6
)











i
=
1

M










j
k


j

k
+
1






(


h
ji

*

u
i


)



(
s
)








s




=

q
k
j


,




(
7
)








where qkjjδj−bj(tk+1j−tkj), for all kεcustom character and j=1, 2, . . . N.


In some embodiments, as depicted in FIG. 2, recovering the stimuli or signal that was encoded 105 can be achieved by seeking the inverse of the t-transform 201. We can let g(t)=sin(Ωt)/πt, tεcustom character be the impulse response of a low pass filter (LPF) with cutoff frequency at Ω. From Equation (5) vjεΞ and therefore the t-transform defined by Equation (7) can be written in an inner-product form as:














i
=
1

M







<


h
ji

*

u
i




,



g
*

1

[


t
k
j

,

t

k
+
1

j


]



>=

q
k
j



or












i
=
1

M







<

u
i



,




h
~

ji

*
g
*

1

[


t
k
j

,

t

k
+
1

j


]



>=

q
k
j







(
8
)








where {tilde over (h)}ji is the involution of hji. From Equality (8) we can say that stimulus u=(u1, u2, . . . , uM)T can be measured by projecting it onto the sequence of functions ({tilde over (h)}j*g*1[tkj,tk+1j]), kεcustom character and j=1, 2, . . . N. The values of the measurements, qkj, kεcustom character and j=1, 2, . . . N, are available for recovery. Thus the TEM can act as a sampler of the stimulus u, and because the spike times can depend on the stimulus, the TEM can act as a stimulus dependent sampler.


With (tkj), kεcustom character the spike times of neuron j, the t-transform, as shown in Equation (8), can be written in an inner product form as

qkj=<u,φkj>  (9)

where










ϕ
k
j

=




h
~

j

*
g
*

1

[


t
k
j

,

t

k
+
1

j


]



=


[





h
~


j





1








h
~


j





2













h
~

jM




]


g
*

1

[


t
k
j

,

t

k
+
1

j


]








(
10
)








for all kεcustom character j=1, 2, . . . N, tεcustom character


The stimulus u 101 can be recovered from Equation (9) if φ=φkj, where kεcustom character j=1, 2, . . . N, is a frame for ΞM. Signal recover algorithms can be obtained using the frame ψ=(ψkj), kεcustom character j=1, 2, . . . N, where

ψkj(t)=({tilde over (h)}j*g)(t−skj),  (11)

and skj=(tk+1j+tkj)/2.


A filtering kernel H can be said to be BIBO stable if each of the filters hji=hji(t), tεcustom character, j=1, 2, . . . , N, and i=1, 2, . . . , M, is bounded-input bounded-output stable, i.e., ∥hji1custom charactercustom character|hji(s)|ds<∞. Filtering vectors hj=[hj1, hj2, . . . , hjM]T, j=1, 2, . . . , N, can be said to be BIBO stable if each of the components hji, i=1, 2, . . . M, is BIBO stable. Further, if Ĥ: custom charactercustom characterN×M is the Fourier transform of the filtering kernel H, then









[


H
^



(
w
)


]

nm

=











h
nm



(
s
)




exp


(

-
iws

)









s




,





for all n=1, 2, . . . , N, and m=1, 2, . . . , M, where i=√{square root over (−1)}. The filtering vectors hj can be said to have full spectral support if supp(ĥij)[−Ω, Ω], for all i, i=1, 2, . . . M. A BIBO filtering kernel H can be said to be invertible if Ĥ has rank M for all wε[−Ω, Ω]. Filtering vectors (hj), j=1, 2, . . . , N, can be called linearly independent if there do not exist real numbers αj, j=1, 2, . . . N, not all equal to zero, and real numbers αj, j=1, 2, . . . N, such that










j
=
1

N









a
j



(


h
j

*
g

)




(

t
-

α
j


)



=
0





for all t, tεcustom character (except on a set of Lebesgue-measure zero).


Assuming that the filters hj=hj(t), tεcustom character, are BIBO stable, linearly independent and have full spectral support for all j, j=1, 2, . . . N, and that matrix H is invertible, then the M-dimensional signal u=[u1, u2, . . . , uM]T can be recovered as











u


(
t
)


=




j
=
1

N










k

𝔍









c
k
j




ψ
k
j



(
t
)






,




(
12
)








where ckj, kεcustom character, j=1, 2, . . . N are suitable coefficients provided that:













j
=
1

N








b
j



κ
j



δ
j






M


Ω
π






(
13
)








and |ui(t)|<ci, i=1, 2, . . . M.


Letting [cj]k=ckj and c=[c1, c2, . . . , cl]T, the coefficients c can be computed as

c=G+q  (14)
202 where T denotes the transpose, q=[q1, q2, . . . , qN]T, [qj]k=qkj and G+ denotes the pseudoinverse. The entries of the matrix G can be given by










G
=

[




G
11




G
12







G

1

N







G
21




G
22







G

2

N





















G

N





1





G

N





2








G
NN




]


,











[

G
ij

]

kl

=



<

ψ
l
j



,


ϕ
k
i

>







=






m
=
1

M










i
k


i

k
+
1






h
im

*


h
~

jm

*

g


(

t
-

s
l
j


)





s












(
15
)








for all i=1, 2, . . . , N, j=1, 2, . . . , N, kεcustom charactercustom character.


Assume that the filtering vectors hj=hj(t), are BIBO stable, linearly independent and have full spectral support for all j, j=1, 2, . . . N, and that matrix H is invertible. If









j
=
1

N









b
j

/

κ
j




δ
j







diverges in N, then there can exist a number custom character such that for all N≧custom character the vector valued signal u can be recovered as










u


(
t
)


=




j
=
1

N










k

𝔍









c
k
j




ψ
k
j



(
t
)









(
16
)








and the ckj, kεcustom character, j=1, 2, . . . N, are given in the matrix form by c=G+q.


In some embodiments, the previously disclosed Multiple-Input-Multiple-Output scheme can be applied to an Irregular Sampling problem, as depicted in FIG. 3. While similar to the previously disclosed MIMO-TEM, integrate-and-fire neurons can be replaced by irregular (amplitude) samplers.


The samples for each signal 302 vj=hj1*u1+hj2*u2+ . . . +hjM*uM at times (skj), kεcustom character, j=1, 2, . . . N, respectively can be recovered and sk=(tk+1+tk)/2, kεcustom character.


As with previous embodiments, assuming that the filtering vectors hj are BIBO stable for all j=1, 2, . . . , N, and that H is invertible, the vector valued signal u, sampled with the circuit of FIG. 3, can be recovered as:










u


(
t
)


=




j
=
1

N










k

𝔍









c
k
j




ϕ
k
j



(
t
)









(
17
)








provided that






D
>

M


Ω
π







holds, where D is the total lower density. Further for [cj]k=ckj and c=[c1, c2, . . . cN]T, the vector of coefficients c can be computed as c=G+q, where q=[q1, q2, . . . qN]T and [qj]k=qkj. The entries of the G matrix can be given by:















[

G
ij

]

kl

=

<

ϕ
l
j



,


ψ
k
i

>







=




m
=
1

M








(


h
im

*


h
~

jm

*
g
*

1

[


t
i
j

,

t

i
+
1

j


]



)




(

S
k
i

)

.










(
18
)







In other embodiments, assuming that the filtering vectors hj are BIBO stable and have full spectral support for all j=1, 2, . . . N and that H is invertible, the vector valued signal u, sampled with the circuit of FIG. 3, can be recovered as









u
=




j
=
1

N










k













c
k
j





ψ
k
j



(
t
)


.








(
19
)








provided that






D
>

M


Ω
π







holds where D is the total lower density. Further for [cj]k=ckj and c=[c1, c2, . . . , cN]T, the vector of coefficients c can be computed as c=G+q, where q=[q1, q2, . . . , qN]T and [qj]k=qkj. The entries of the G matrix can be given by:















[

G
ij

]

kl

=

<

ψ
l
j



,


ψ
k
i

>







=




m
=
1

M








(


h
im

*


h
~

jm

*
g

)




(


S
k
i

-

S
l
j


)

.










(
20
)







In some embodiments, TEMs and TDMs can be used to encode and decode visual stimuli such as natural and synthetic video streams, for example movies or animations. Encoding and decoding visual stimuli is critical for, among other reasons, the storage, manipulation, and transmission of visual stimuli, such as multimedia in the form of video. Specifically, the neuron representation model and its spike data can be used to encode video from its original analog format into a “spike domain” or time-based representation; store, transmit, or alter such visual stimuli by acting on the spike domain representation; and decode the spike domain representation into an alternate representation of the visual stimuli, e.g., analog or digital. Moreover, in “acting” on the visual stimuli through use of the spike domain, one can dilate (or zoom) the visual stimuli, translate or move the visual stimuli, rotate the visual stimuli, and perform any other linear operation or transformation by acting or manipulating the spike domain representation of the visual stimuli.


Widely used modulation circuits such as Asynchronous Sigma/Delta Modulators and FM modulators have been shown to be instances of TEMs by A. A. Lazar and E. A. Pnevmatikakis in “A Video Time Encoding Machine” (IEEE International Conference on Image Processing, San Diego, Calif., Oct. 12-15, 2008), which is incorporated by reference. TEMs based on single neuron models such as integrate-and-fire (IAF) neurons, as described by A. A. Lazar in “Time Encoding with an Integrate-and-Fire Neuron with a Refractory Period” (Neurocomputing, 58-60:53-58, June 2004), which is incorporated by reference, and more general Hodgkin-Huxley neurons with multiplicative coupling, feedforward and feedback have been described by A. A. Lazar in “Time Encoding Machines with Multiplicative Coupling, Feedback and Feedforward,” which was incorporated by reference above. Multichannel TEMs realized with invertible filterbanks and invertible IAF neurons have been studied by A. A. Lazar in “Multichannel Time Encoding with Integrate-and-Fire Neurons,” which is incorporated by reference above, and TEMs realized with a population of integrate-and-fire neurons have been investigated by A. A. Lazar in “Information Representation with an Ensemble of Hodgkin-Huxley Neurons,” which was incorporated by reference above. An extensive characterization of single-input single-output (SIMO) TEMs can be found in A. A. Lazar and E. A. Pnevmatikakis' “Faithful Representation of Stimuli with a Population of Integrate-and-Fire Neurons,” which is incorporated by reference above.



FIG. 8 depicts an embodiment of a time encoding circuit. The circuit can model the responses of a wide variety of retinal ganglion cells (RGCs) and lateral geniculate nucleus (LGN) neurons across many different organisms. The neuron can fire whenever its membrane potential reaches a fixed threshold δ 801. After a spike 802 is generated, the membrane potential can reset through a negative feedback mechanism 803 that gets triggered by the just emitted spike 802. The feedback mechanism 803 can be modeled by a filter with impulse response h(t).


As previously described, TEMs can act as signal dependent samplers and encode information about the input signal as a time sequence. As described in “Perfect Recovery and Sensitivity Analysis of Time Encoded Bandlimited Signals” by A. A. Lazar and László T. Tóth, which is incorporated by reference above, this encoding can be quantified with the t-transform which describes in mathematical language the generation of the spike sequences given the input stimulus. This time encoding mechanism can be referred to as a single neuron TEM. Where (tk), kεcustom character, is the set of spike times of the output of the neuron, the t-transform of the TEM depicted in FIG. 1 can be written as










u


(

t
k

)


=

δ
+




l
<
k












h


(


t
k

-

t
l


)


.







(
21
)








Equation (21) can be written in inner product form as

<u,χk>=qk,  (22)

where








q
k

=


u


(

t
k

)


=

δ
+




l
<
k











h


(


t
k

-

t
l


)






,





χk(t)=g(t−tk), kεcustom character, and g(t)=sin(Ωt)/πt, tεcustom character, is the impulse response of a low pass filter with cutoff frequency Ω. The impulse response of the filter in the feedback loop can be causal, and can be decreasing with time.



FIG. 9 depicts an embodiment of a single neuron encoding circuit that includes an integrate-and-fire neuron with feedback. The t-transform of the encoding circuit can be written as













k

k
+
1





u


(
s
)









s



=

κδ
-

b


(


t

k
+
1


-

t
k


)


-




l
<
k









k

k
+
1





h


(

s
-

t
l


)









s






,




(
23
)








or in inner product form as











<
u

,


χ
k

>=

q
k


,




with








q
k

=

κδ
-

b


(


t

k
+
1


-

t
k


)


-




l
<
k









k

k
+
1





h


(

s
-

t
l


)









s











and









χ
k



(
t
)


=

g
*

1

[


t
k

,

t

k
+
1



]




,

for





all





k

,

k



.







(
24
)







In some embodiments, the bandlimited input stimulus u can be recovered as











u


(
t
)


=




k

𝒥












c
k




ψ
k



(
t
)





,




(
25
)








where ψk(t)=g(t−tk), provided that the spike density of the neuron is above the Nyquist rate Ω/π. For [c]k=ck, the vector of coefficients c can be computed as c=G+q, where G+ denotes the pseudoinverse of G, [q]k=qk and [G]kl=<χk, ψl>.



FIG. 10 depicts an embodiment consisting of two interconnected ON-OFF neurons each with its own feedback. Each neuron can be endowed with a level crossing detection mechanism 1001 with a threshold δ that takes a positive value 1 and a negative value 2, respectively. Whenever a spike is emitted, the feedback mechanism 1002 can reset the corresponding membrane potential. In addition, each spike can be communicated to the other neuron through a cross-feedback mechanism 1003. In general, this cross-feedback mechanism can bring the second neuron closer to its firing threshold and thereby increases its spike density. The two neuron model in FIG. 10 can mimic the ON and OFF bipolar cells in the retina and their connections through the non-spiking horizontal cells. This time encoding mechanism can be described as an ON-OFF TEM.


For the TEM depicted in FIG. 10, with (tkj), kεcustom character representing the set of spike times of the neuron j, the t-transform of the ON-OFF TEM can be described by the equations











u


(

t
k
1

)


=



+

δ
1


+




l
<
k








h
11



(


t
k
1

-

t
l
1


)



-



l








h
21



(


t
k
1

-

t
l
2


)




1

{


t
l
2

<

t
k
1


}





=

q
k
1











u


(

t
k
2

)


=



-

δ
2


+




l
<
k








h
22



(


t
k
2

-

t
l
2


)



-



l








h
12



(


t
k
2

-

t
l
1


)




1

{


t
l
1

<

t
k
2


}





=

q
k
2



,





(
26
)








for all k, kεcustom character. The equations (31) can be written in inner product form as

<u,xkj>=qkj  (27)

for all k, kεcustom character j, j=1, 2, where xkj(t)=g(t−tkj), j=1, 2.



FIG. 11 depicts an embodiment consisting of two interconnected ON-OFF neurons each with its own feedback. The t-transforms of the neurons depicted in FIG. 11 can be described by the equations














k
1



k
1

+
1





u


(
s
)









s



=



κ
1



δ
1


-


b
1



(


t

k
+
1

1

-

t
k
1


)


+




l
<
k










k
1



k
1

+
1





h
11



(

s
-

t
l
1


)




-



l










k
1



k
1

+
1










h
21



(

s
-

t
l
2


)





s







1

{


t
l
2

<

t
k
1


}


















k
2



k
2

+
1





u


(
s
)









s



=



κ
2



δ
2


-


b
2



(


t

k
+
1

1

-

t
k
1


)


+




l
<
k










k
2



k
2

+
1





h
22



(

s
-

t
l
2


)




-



l










k
2



k
2

+
1










h
12



(

s
-

t
l
1


)





s







1

{


t
l
1

<

t
k
2


}







,





(
28
)








or in inner product form as











<
u

,


x
k
j

>=

q
k
j








with








q
k
j

=




k
j



k
j

+
1





u


(
s
)









s




,

for





all





k

,

k



,
j
,

j
=
1

,
2.





(
29
)







In some embodiments, the input stimulus u can be recovered as











u


(
t
)


=





k













c
k
1




ψ
k
1



(
t
)




+




k













c
k
2




ψ
k
2



(
t
)






,




(
30
)








where ψkj(t)=g(t−tkj), j=1, 2, provided that the spike density of the TEM is above the Nyquist rate Ω/π. Moreover with c=[c1; c2] and [cj]k=ckj, the vector of coefficients c can be computed as c=G+q, where q=[q1; q2] with [qj]k=qkj and







G
=

[




G
11




G
12






G
21




G
22




]


,



[

G
ij

]

kl

=

<

x
k
i



,


ψ
l
j

>

,





for all j=1, 2, and k,lεcustom character


In one embodiment, as depicted in FIG. 4, let custom character denote the space of (real) analog video streams I(x,y,t) 401 which are bandlimited in time, continuous in space, and have finite energy. Assume that the video streams are defined on bounded spatial set X which is a compact subset of custom character Bandlimited in time can mean that for every (x0, y0)εX then I(x0, y0, y)εΞ, where Ξ is the space of bandlimited functions of finite energy. In some embodiments, custom character={I=I(x,y,t)|I(x0,y0,t)εΞ, ∀(x0,y0)εX and I(x,y,t0)εL2(X), ∀t0εcustom character)}. The space custom character, endowed with the inner product <•, •>: Hcustom charactercustom character defined by:

<I1,I2>=∫∫custom characterXI1(x,y,t)I2(x,y,t)dxdydt  (31)

can be a Hilbert space.


Assuming that each neuron or TEM j, j=1, 2, . . . , N has a spatiotemporal receptive field described by the function Dj(x,y,t) 402, filtering a video stream with the receptive field of the neuron j gives the output vj(t) 403, which can serve as the input to the TEM 404:











v
j



(
t
)


=




-



+






(





X








D
j



(

x
,
y
,
s

)




I


(

x
,
y
,

t
-
s


)









x




y




)









s

.







(
32
)








In some embodiments, the receptive fields of the neurons can have only spatial components, i.e. Dj(x,y,t)=Dsj(x,y)δ(t), where δ(t) is the Dirac function.


Where tkj, kεcustom character represents the spike time of neuron j, j=1, 2, . . . N, the t-transform can be written as








v
j



(

t
k
j

)


=


δ
j

+




l
<
k












h


(


t
k
j

-

t
l
j


)


.








In inner product form, this can be written as <I,ψkj>=qkj with







q
k
j

=


δ
j

+




l
<
k









h


(


t
k
j

-

t
l
j


)


.








The sampling function can be given by ψkj(x,y,t)={tilde over (D)}j(x,y,t)*g(t−skj) where {tilde over (D)}j(x,y,t)=Dj(x,y,−t). In embodiments with only spatial receptive fields, the sample functions can be written as φkj(x,y, t)=Dsj(x,y)*g(t−skj).


In some embodiments, as depicted in FIG. 5, decoding the TEM-encoded signal can be recovered using the same frame ψkj, j=1, 2, . . . N, kεcustom character, with ψkj(x,y,t)=D(x,y,t)*g(t−skj) 503, 402. Where the filters modeling the receptive fields Dj(x,y,t) are linearly independent and span the whole spatial domain of interest (i.e., for every t0εcustom character, Dj(x,y,t0))j forms a frame for L2(X)), if the total spike density diverges in N, then there can exist a number custom character such that if N≧custom character then the video stream I=I(x,y,t) can be recovered as










I


(

x
,
y
,
t

)


=




j
=
1

N










k










c
k
j




ψ
k
j



(

x
,
y
,
t

)









(
33
)








503 and ckj, kεcustom character, j=1, 2, . . . , N, are suitable coefficients.


Letting [cj]k=ckj and c=[c1, c2, . . . c1]T, the coefficients c can be computed as

c=G+q  (34)
502 where T denotes the transpose, q=[q1, q2, . . . qN]T, [qj]k=qkj and G+ denotes the pseudoinverse. The entries of the matrix G can be given by







G
=

[




G
11




G
12







G

1





N







G
21




G
22







G

2





N





















G

N





1





G

N





2








G
NN




]


,





[Gij]kl=<Di(x,y,•)*g(•−tki), Dj(x, y,•)*g(•−t1j)>. Where the receptive field is only in the spatial domain,








ψ
k
j



(
t
)


=




D
s
j



(

x
,
y

)




g


(

t
-

s
k
j


)









and




[

G
ij

]

kl


=


(





X








D
i



(

x
,
y

)





D
j



(

x
,
y

)









x




y




)




g


(


t
k
i

-

t
l
j


)


.







In some embodiments, as depicted in FIG. 6, bounded and surjective operations on the elements of a frame can preserve the frame's characteristics. As such, bounded and surjective operations can be performed on the frames while in the spike domain (after being encoded by one or more TEMs and prior to being decoded by one or more TDMs) to alter the characteristics of the video. In accordance with the disclosed subject matter, a method of dilating, translating, and rotating a visual stimuli can be achieved by applying, for example, the following function to the encoded visual stimuli:

ψα,x0,y0(x,y)=α−1Rθψ(a−1x−x0,a−1y−y0),
601 where α represents the amount of dilation and is a real number not including zero; x0, y0 represents the amount of translation; θ represents the amount of rotation between 0 and 2π; Rθψ(x,y)=ψ(x cos(θ)+y sin(θ),−x sin(θ)+y cos(θ)); and







ψ


(

x
,
y

)


=


1


2

π





exp
(


-

1
8




(


4






x
2


+

y
2


)


)




(










kx


-




k
2



/


2



)

.






In further embodiments, the alterations to the video can be achieved by using a switching-matrix 701, as depicted in FIG. 7. To rotate the video by an angle lθ0, lεcustom character the spike coming from filter element ([x,y], α, θ) can be mapped to the reconstruction filter at ([x,y], α, θ+lθ0). To dilate, or zoom the video by a value α0m, mεcustom character the spike coming from filter element ([x,y], α, θ) can be mapped to the reconstruction filter at ([x,y], α0m α, θ). To translate a video by [nb0, kb0], the spike coming from filter element ([x,y], α, θ) can be mapped to the reconstruction filter at ([x+nb0, y+kb0], α, θ). To simultaneous dilate by α0m and translate by [nb0, kb0], then the spike coming from filter element ([x,y], α, θ) can be mapped to the reconstruction filter at ([x+α0mnb0, y+α0mkb0], α0mα, θ).


The disclosed subject matter and methods can be implemented in software stored on computer readable storage media, such as a hard disk, flash disk, magnetic tape, optical disk, network drive, or other computer readable medium. The software can be performed by a processor capable of reading the stored software and carrying out the instructions therein.


The foregoing merely illustrates the principles of the disclosed subject matter. Various modifications and alterations to the described embodiments will be apparent to those skilled in the art in view of the teachings herein. It will thus be appreciated that those skilled in the art will be able to devise numerous techniques which, although not explicitly described herein, embody the principles of the disclosed subject matter and are thus within the spirit and scope of the disclosed subject matter.

Claims
  • 1. A method for encoding a plurality (M) of components of a signal comprising: filtering each of said M components into a plurality (N) of filtered signals; andencoding each of said N filtered-signals using at least one Time Encoding Machine (TEM) to generate a plurality (N) of TEM-encoded filtered signals.
  • 2. The method of claim 1 wherein said at least one TEM is an integrate-and-fire neuron.
  • 3. The method of claim 1 wherein said at least one TEM has multiplicative coupling.
  • 4. The method of claim 1 wherein said at least one TEM is an asynchronous sigma/delta modulator.
  • 5. The method of claim 1 further comprising adding to each of said N filtered-signals one of a plurality (N) of bias values.
  • 6. The method of claim 1 wherein said M signals are irregularly sampled.
  • 7. The method of claim 1 wherein each of said N filtered signals is represented by the equation vj=(hj)T*u,j, where Hj=[hj1, hj2, . . . hjM]T is a filtering vector corresponding to one of said N filtered signals represented by j.
  • 8. The method of claim 1 wherein said N TEM-encoded filtered signals are represented by qkj where qkj=κjδj−bj(tk+1j−tkj), for all times represented by a value kε, and each of said N filtered signals represented by a value j, j=1, 2, . . . N, where κj is an integration constant, δj is a threshold value, and bj is a bias value for each of said N filtered signals.
  • 9. A method for decoding a TEM-encoded signal comprising: receiving a plurality (N) of TEM-encoded filtered signals;decoding said N TEM-encoded filtered signals using at least one Time Decoding Machine (TDM) to generate a plurality (N) of TDM-decoded signal components; andfiltering each of said N TDM-decoded signal components into a plurality (M) of output signals components.
  • 10. The method of claim 9, wherein one of said M output signal components, represented by the i-th component of the vector valued signal u, |ui(t)|≦ci, can be recovered by solving for
  • 11. The method of claim 9, wherein said M TEM-encoded signals are irregularly sampled.
  • 12. A method of encoding a video stream signal comprising: filtering said video stream signal into a plurality (N) of spatiotemporal field signals; andencoding each of said N spatiotemporal field signals with a Time Encoding Machine to generate a plurality (N) of TEM-encoded spatiotemporal field signals.
  • 13. The method of claim 12 wherein said spatiotemporal field signals can be described by an equation:
  • 14. The method of claim 12 wherein said N TEM-encoded spatiotemporal field signals are represented by a sampling function: ψkj(x,y,t)=D(x,y,−t)*g(t−skj), for k spike times, for each (x, y) in a bounded spatial set, where j corresponds to each of said N TEM-encoded spatiotemporal field signals, and where g(t)=sin(Ωt)/πt.
  • 15. A method of decoding a TEM-encoded video stream signal comprising: receiving a plurality (N) of TEM-encoded spatiotemporal field signals;decoding each of said N TEM-encoded spatiotemporal field signals using a Time Decoding Machine (TDM) to generate a TDM-decoded spatiotemporal field signal; andcombining each of said TDM-decoded spatiotemporal field signals to recover said video stream signal.
  • 16. The method of claim 15 wherein said decoding and said combining are achieved by applying an equation:
  • 17. A method of altering a video stream signal comprising: receiving a plurality (N) of TEM-encoded spatiotemporal field signals from a plurality (N) of TEM-filters; andapplying a switching matrix to map said N TEM-encoded spatiotemporal field signals to a plurality (N) of reconstruction filters in a video stream signal TDM.
  • 18. The method of claim 17 for rotating said video stream signal wherein said switching matrix maps each of said N TEM-encoded spatiotemporal field signals from a TEM-filter ([x,y], α, θ) to a reconstruction filter ([x,y], α, θ+lθ0), where lθ0 represents a desired value of rotation.
  • 19. The method of claim 17 for zooming said video stream signal wherein said switching matrix maps each of said N TEM-encoded spatiotemporal field signals from a TEM-filter ([x,y], α, θ) to a reconstruction filter ([x,y], α0mα, θ), where α0m represents a desired value of zoom.
  • 20. The method of claim 17 for translating said video stream signal by a value [nb0, kb0] wherein said switching matrix maps each of said N TEM-encoded spatiotemporal field signals from a TEM-filter ([x,y], α, θ) to a reconstruction filter at ([x+nb0, y+kb0], α, θ).
  • 21. The method of claim 17 for zooming said video stream signal by a value α0m and translating said video stream signal by a value [nb0, kb0] wherein said switching matrix maps each of said N TEM-encoded spatiotemporal field signals from a TEM-filter ([x,y], α, θ) to a reconstruction filter at ([x+α0mnb0, y+α0mkb0], α0mα, θ).
  • 22. A method of encoding a video signal comprising: inputting said video signal into a first and second time encoding machine (TEM), said first TEM comprising a first TEM-input and a first TEM-output, said second TEM comprising a second TEM-input and a second TEM-output;wherein said first TEM-output is connected to said first TEM-input and said second TEM-input to provide negative feedback and said second TEM-output is connected to said first TEM-input and said second TEM-input to provide positive feedback.
  • 23. The method of claim 22 further comprising: outputting a first set of trigger values from said first TEM according to an equation
  • 24. The method of claim 22 further comprising: outputting a first set of trigger values from said first TEM according to an equation
  • 25. A method of decoding a video signal comprising: receiving first and second TEM-encoded signals; andapplying an equation
CROSS REFERENCE TO RELATED APPLICATIONS

This application is a continuation of International Patent Application Serial No. PCT/US08/068,790 filed Jun. 30, 2008, which is a CON of and claims priority to U.S. patent application Ser. No. 11/965,337, filed Dec. 27, 2007; which claims priority to U.S. Provisional Application Ser. No. 60/946,918, filed Jun. 28, 2007, and which claims priority to U.S. Provisional Application Ser. No. 61/037,224, filed Mar. 17, 2008. This application hereby incorporates by reference the disclosures of each of the above-listed applications in their entireties.

STATEMENT REGARDING FEDERALLY SPONSORED RESEARCH

This invention was made with government support under grants CCF-06-35252, awarded by the National Science Foundation, and R01 DC008701-01, awarded by the National Institutes of Health. The government has certain rights in the invention.

US Referenced Citations (16)
Number Name Date Kind
5392044 Kotzin et al. Feb 1995 A
5393237 Roy et al. Feb 1995 A
5424735 Arkas et al. Jun 1995 A
5511003 Agarwal Apr 1996 A
5568142 Velazquez et al. Oct 1996 A
6121910 Khoury et al. Sep 2000 A
6177910 Sathoff et al. Jan 2001 B1
6332043 Ogata Dec 2001 B1
6441764 Barron et al. Aug 2002 B1
6476749 Yeap et al. Nov 2002 B1
6476754 Lowenborg et al. Nov 2002 B2
6511424 Moore-Ede et al. Jan 2003 B1
7028271 Matsugu et al. Apr 2006 B2
7336210 Lazar Feb 2008 B2
20050190865 Lazar et al. Sep 2005 A1
20060261986 Lazar Nov 2006 A1
Related Publications (1)
Number Date Country
20100225824 A1 Sep 2010 US
Provisional Applications (2)
Number Date Country
60946918 Jun 2007 US
61037224 Mar 2008 US
Continuations (2)
Number Date Country
Parent PCT/US2008/068790 Jun 2008 US
Child 12645292 US
Parent 11965337 Dec 2007 US
Child PCT/US2008/068790 US