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

Mechanics benchmarks failing for old commits #28

Open
moorepants opened this issue Jun 13, 2016 · 6 comments
Open

Mechanics benchmarks failing for old commits #28

moorepants opened this issue Jun 13, 2016 · 6 comments

Comments

@moorepants
Copy link
Member

moorepants commented Jun 13, 2016

Example:

[  1.18%] · For sympy commit hash 6ef7f5b5:
[  1.18%] ·· Building for py2.7-fastcache-mpmath....
[  1.18%] ·· Benchmarking py2.7-fastcache-mpmath
[  1.19%] ··· Running physics.mechanics.kane.KanesMethodMassSpringDamper.time_kanesmethod_mass_spring_damper                                                                       failed
[  1.19%] ····· Traceback (most recent call last):
                  File "/home/moorepants/src/asv/asv/benchmark.py", line 685, in <module>
                    result = benchmark.do_run()
                  File "/home/moorepants/src/asv/asv/benchmark.py", line 405, in do_run
                    return self.run(*self._current_params)
                  File "/home/moorepants/src/asv/asv/benchmark.py", line 472, in run
                    timing = timer.timeit(number)
                  File "/home/moorepants/src/sympy_benchmarks/env/f5b82df50164b5d73101b16d6e2f197f/lib/python2.7/timeit.py", line 202, in timeit
                    timing = self.inner(it, self.timer)
                  File "/home/moorepants/src/sympy_benchmarks/env/f5b82df50164b5d73101b16d6e2f197f/lib/python2.7/timeit.py", line 100, in inner
                    _func()
                  File "benchmarks/physics/mechanics/kane.py", line 35, in time_kanesmethod_mass_spring_damper
                    self.KM.kanes_equations(self.body_list, self.force_list)
                  File "/home/moorepants/src/sympy_benchmarks/env/f5b82df50164b5d73101b16d6e2f197f/lib/python2.7/site-packages/sympy/physics/mechanics/kane.py", line 712, in kanes_equations
                    fr = self._form_fr(FL)
                  File "/home/moorepants/src/sympy_benchmarks/env/f5b82df50164b5d73101b16d6e2f197f/lib/python2.7/site-packages/sympy/physics/mechanics/kane.py", line 276, in _form_fr
                    vel_list, f_list = _f_list_parser(fl, N)
                  File "/home/moorepants/src/sympy_benchmarks/env/f5b82df50164b5d73101b16d6e2f197f/lib/python2.7/site-packages/sympy/physics/mechanics/functions.py", line 571, in _f_list_parser
                    vel_list, f_list = unzip(list(flist_iter()))
                  File "/home/moorepants/src/sympy_benchmarks/env/f5b82df50164b5d73101b16d6e2f197f/lib/python2.7/site-packages/sympy/physics/mechanics/functions.py", line 562, in flist_iter
                    for obj, force in fl:
                TypeError: 'Particle' object is not iterable

@jbm950

@jbm950
Copy link
Contributor

jbm950 commented Jun 13, 2016

At a glance this appears to be due to this line

self.KM.kanes_equations(self.body_list, self.force_list)

I remember discussing that the input order for kanes_equations() was swapped recently. What would you like me to do?

@moorepants
Copy link
Member Author

You can use the deprecated API and it will work for all past versions or put a check for version number (git commit hash) so that everything before that change uses old and everything after uses new.

@jbm950
Copy link
Contributor

jbm950 commented Jun 13, 2016

I found the commit. How do I tell what versions it was applied to?

@moorepants
Copy link
Member Author

I don't think it has been applied to any versions yet. It is post last release. You'll need to ask stackoverflow and the google about the git kungfu needed to figure that out.

@jbm950
Copy link
Contributor

jbm950 commented Jun 14, 2016

Opened a PR that should address this problem

@moorepants
Copy link
Member Author

The first one is now fixed but we also have this api change too:

[  0.07%] ····· Traceback (most recent call last):
                  File "/home/moorepants/src/asv/asv/benchmark.py", line 794, in <module>
                    commands[mode](args)
                  File "/home/moorepants/src/asv/asv/benchmark.py", line 765, in main_run
                    skip = benchmark.do_setup()
                  File "/home/moorepants/src/asv/asv/benchmark.py", line 498, in do_setup
                    result = Benchmark.do_setup(self)
                  File "/home/moorepants/src/asv/asv/benchmark.py", line 433, in do_setup
                    setup(*self._current_params)
                  File "/home/moorepants/src/sympy_benchmarks/benchmarks/physics/mechanics/lagrange.py", line 24, in setup
                    Pa.potential_energy = k * q**2 / 2.0
                AttributeError: can't set attribute

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants