Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Unifying algorithms and examples (code) #320

Open
PudottaPommin opened this issue Aug 1, 2018 · 3 comments
Open

Unifying algorithms and examples (code) #320

PudottaPommin opened this issue Aug 1, 2018 · 3 comments
Labels
Discussion This is open for a discussion.

Comments

@PudottaPommin
Copy link
Member

PudottaPommin commented Aug 1, 2018

Hey,

when I was looking through code examples, I noticed, each implementation is different from each other. Which is expected in some way. But we should try to unify things like:

  • input values
  • printed output
  • naming of functions - where possible

When you change from one language to another, it's sometimes hard to understand what that algorithm does.

Example: Monte Carlo
Java implemented everything as static functions with sample size 1000.
JS is functions, which is fine (JS versioning is different topic) with sample size 100000000.
Swift is mix of objects/functions (can't say if good/bad, I don't know Swift) with sample size 10000.
@julianschacher is making C# implentation which uses OOP and looks good. So it could be example for OOP languages implementation.

You may agree with me or not, I can be wrong in this, but it's worth discussion.

@leios
Copy link
Member

leios commented Aug 1, 2018

I thought we were generally trying to keep the implementations as consistent as we can; however, small things (like the number of points in MC) are easy to slip through the cracks. This is a good point to bring up, though and we should definitely see which implementations are not consistent enough.

@jiegillet
Copy link
Member

I don't really mind if things like sample size is different, what I care about are the algorithms.
Function names are a bit more important, but they will have to be different to some extent because of different styles guides.
OOP versus functions is better left up to the author and reviewers, in my opinion.

If we want to unify input, then we should go all the way and impose a set of tests with edge cases and stuff. I suspect many implementations are a little too lax. This might be a pain in the ass to implement though

@jiegillet jiegillet added the Discussion This is open for a discussion. label Aug 1, 2018
@PudottaPommin
Copy link
Member Author

Yes, we have to leave differences in languages aside, because that's something we can not change.
And yes, this thing is a lot of work, because there is quite a few algorithms with many implementations.
I'm not sure about those tests, how you think they should look or be implemented.

About inputs, they should be same as are in algorithm explanation (if there is some) ie. C example for matrix in GE

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Discussion This is open for a discussion.
Projects
None yet
Development

No branches or pull requests

3 participants