Implement Kalman Filter
Closed this issue ยท 7 comments
References
Hey @mandar2812 ,
I come across Mozilla Science Lab and found your project interesting. I would like to contribute to this project, Please let me know do i need to implement linear kalman filter or something else?
I know python and can try to code in Python.
Cheers,
Amit Kumar Jaiswal
Hi @amitkumarj441 ,
Good to see your interest in contributing to development, implementing Kalman filter in python would create some problems in integrating it into the Scala shell environment. If you like, you can work on creating a python port of DynaML using Py4j, this can be a sub-project in itself. If you have used pyspark, this will be something of that sort. I have created a new issue for this purpose: #21.
Regards,
Mandar
Hi @mandar2812 ,
I know basics of Scala and can try to code in Scala, but before that i have to use breeze numerical computing library for 1st order DLM so please let me know where i can initiate a PR or do i need to create a folder, if yes, then where?? Please let me know about this!
Thank you
Amit Kumar Jaiswal
Sounds great!, I will assign this ticket to you. Take your time to get comfortable with scala if you feel like, or you can pick it up as you go. Also please join the gitter channel. After you sign in using your github account, we can chat in the DynaML chat room and also in private to discuss how you can implement Kalman filter using breeze vectors and DynaML models API. I will keep you posted soon on the details you need to know about the API on gitter.
Looking forward to working with you!
Regards,
Mandar
@amitkumarj441 : you can start by forking the repo on your github, and later after we finish the implementation I can merge your PR.
Hi @mandar2812 ,
Now Kalman filter implementation is completed.
Do we need to anything more in this part?
If not, then close this issue for now and in-future re-open again this issue for further development!
Cheers,
Amit Kumar Jaiswal
So a status report on where this stands ...
KFilter
andgeneralDLM
objects use some interesting things for example thetype
membersLoglikelihood
, as I understand now in Scala type members are the dual of Generics, so far in DynaML I have used generics but we can convert some of the code to type members to make it more readable.KFilter
andgeneralDLM
should be converted to classes or abstract classes which extend theModel[T, Q, R]
interface, by implementing thepredict(point: Q): R
methodKFilter
andgeneralDLM
should be generalized so they can predict targets for input features that are breezeDenseVector[Double]
instances.KFilter
andgeneralDLM
can be thought of in general terms, as Dynamic models and a good abstract API of interfaces can be written which is extended for specific examples like linear Kalman filtering with real valued targets and vector/matrix input points.