Scripting in Matlab for Scaling of Model
- David John Saxby
- Posts: 83
- Joined: Mon May 09, 2011 8:39 pm
Scripting in Matlab for Scaling of Model
Hello,
I'm using v.3.0.1 and attempting to using Scripting + Matlab to run a scaling process within a larger Matlab data processing pipeline.
Reason for scripting instead of xml creation/editing: xml parsing in Matlab creates problems in OpenSim.
I used the example 'setupAndRunIKBatchExample.m' as a template to understand the process. Made the necessary changes where needed (ex: hard code the path and file of the generic model to the xml setup file, etc...).
Where I run into trouble is when trying to get/set the location of the marker data to be used in this instance of scaling.
Within larger code:
scaleTool.setSubjectMass(data.Mass);
scaleTool.setSubjectHeight(data.Height);
scaleTool.setName(name);
scaleTool.setMarkerDataFileName(fullpath);
scaleTool.setStartTime(initial_time);
scaleTool.setEndTime(final_time);
scaleTool.setOutputMotionFileName([results_folder '\' name '_linearScale.mot']);
Highlighted in red is the issue. This doesn't seem to be kosher for the scale tool. I'm a complete beginner with OpenSim's scripting tool, so what should I do to get and set these values?
If anyone has any advise I don't mind some experimental solutions?
Thanks very much,
David
I'm using v.3.0.1 and attempting to using Scripting + Matlab to run a scaling process within a larger Matlab data processing pipeline.
Reason for scripting instead of xml creation/editing: xml parsing in Matlab creates problems in OpenSim.
I used the example 'setupAndRunIKBatchExample.m' as a template to understand the process. Made the necessary changes where needed (ex: hard code the path and file of the generic model to the xml setup file, etc...).
Where I run into trouble is when trying to get/set the location of the marker data to be used in this instance of scaling.
Within larger code:
scaleTool.setSubjectMass(data.Mass);
scaleTool.setSubjectHeight(data.Height);
scaleTool.setName(name);
scaleTool.setMarkerDataFileName(fullpath);
scaleTool.setStartTime(initial_time);
scaleTool.setEndTime(final_time);
scaleTool.setOutputMotionFileName([results_folder '\' name '_linearScale.mot']);
Highlighted in red is the issue. This doesn't seem to be kosher for the scale tool. I'm a complete beginner with OpenSim's scripting tool, so what should I do to get and set these values?
If anyone has any advise I don't mind some experimental solutions?
Thanks very much,
David
- Ayman Habib
- Posts: 2252
- Joined: Fri Apr 01, 2005 12:24 pm
Re: Scripting in Matlab for Scaling of Model
Hi David,
There are two places in the ScaleToll where you can specify a trc file for marker data:
1. under "Marker data for measurements".
2. under "Marker data for static pose".
Please indicate which one you're trying to use and I'll point you to the correct syntax.
Best regards,
-Ayman
There are two places in the ScaleToll where you can specify a trc file for marker data:
1. under "Marker data for measurements".
2. under "Marker data for static pose".
Please indicate which one you're trying to use and I'll point you to the correct syntax.
Best regards,
-Ayman
- David John Saxby
- Posts: 83
- Joined: Mon May 09, 2011 8:39 pm
Re: Scripting in Matlab for Scaling of Model
Hi Ayman,
Thanks very much for the quick response (I know you get a lot of queries).
Can you provide me both instances of the syntax? I will only need to point to the trc file for scaling the bodies (measurements), but I'm interested in learning how to use scripting more generally so I can extend my script to other operations such as IK, ID, and Muscle analysis.
I'm not experienced with the API and learn best via example. Is their another source for examples in addition to the set scripts provided with the v.3.0.1 release?
Best,
David
Thanks very much for the quick response (I know you get a lot of queries).
Can you provide me both instances of the syntax? I will only need to point to the trc file for scaling the bodies (measurements), but I'm interested in learning how to use scripting more generally so I can extend my script to other operations such as IK, ID, and Muscle analysis.
I'm not experienced with the API and learn best via example. Is their another source for examples in addition to the set scripts provided with the v.3.0.1 release?
Best,
David
- Ayman Habib
- Posts: 2252
- Joined: Fri Apr 01, 2005 12:24 pm
Re: Scripting in Matlab for Scaling of Model
Hi David,
We're building the set of scripts and we sure would welcome more contributions from our users. Also the C++ API examples should be a good source since the syntax is very similar (in most cases).
For the ScaleTool:
Hope this helps,
-Ayman
We're building the set of scripts and we sure would welcome more contributions from our users. Also the C++ API examples should be a good source since the syntax is very similar (in most cases).
For the ScaleTool:
Code: Select all
scaleTool.getModelScaler().setMarkerFileName(filepath) // trc file for measurements
scaleTool.getMarkerPlacer().setStaticPoseFileName(filepath) // trc file for static pose
-Ayman
- David John Saxby
- Posts: 83
- Joined: Mon May 09, 2011 8:39 pm
Re: Scripting in Matlab for Scaling of Model
Hi Ayman,
Thanks a lot!
I'll finish this code and re-up to your site. We have a clinical gait analysis group within the SimTk site, which will be the future repository and distributor for some code.
In the short run, any convenient place to deposit this script?
David
Thanks a lot!
I'll finish this code and re-up to your site. We have a clinical gait analysis group within the SimTk site, which will be the future repository and distributor for some code.
In the short run, any convenient place to deposit this script?
David
- David John Saxby
- Posts: 83
- Joined: Mon May 09, 2011 8:39 pm
Re: Scripting in Matlab for Scaling of Model
Sorry one more,
Time range for scaling in my generic setup file is empty, as I plan to change this value depending on file length. I suppose I could hard code if there is not a programmatic solution.
scaleTool.getModelScaler().setTimeRange(final_time - initial_time)
??? No method 'setTimeRange' with matching
signature found for class
'org.opensim.modeling.ModelScaler'.
.getTimeRange() returns the empty value from the xml, as it should.
Is setTimeRange not operational? Should I use a different method?
David
Time range for scaling in my generic setup file is empty, as I plan to change this value depending on file length. I suppose I could hard code if there is not a programmatic solution.
scaleTool.getModelScaler().setTimeRange(final_time - initial_time)
??? No method 'setTimeRange' with matching
signature found for class
'org.opensim.modeling.ModelScaler'.
.getTimeRange() returns the empty value from the xml, as it should.
Is setTimeRange not operational? Should I use a different method?
David
- David John Saxby
- Posts: 83
- Joined: Mon May 09, 2011 8:39 pm
Re: Scripting in Matlab for Scaling of Model
Hello again,
So I could get the scaleTool.getModelScaler().setTimeRange to work. I don't know if I'm just using this method incorrectly, or if there is something wrong with its current state.
I hard coded the time range in the template xml, so unless I have files shorter than 0-0.1 seconds I think I'm ok.
I have another issue though.
Running the tool.
K>> scaleTool.run();
??? Assignment of char to Java arrays is not
allowed
Error in ==> run at 24
if ispc, script(script=='/')='\'; end
The name of the tool is constructed earlier in the script:
outfile = ['Setup_LinearScale' name '.xml'];
% write the tool
scaleTool.print([trc_data_folder '\' outfile]);
Any ideas?
David
So I could get the scaleTool.getModelScaler().setTimeRange to work. I don't know if I'm just using this method incorrectly, or if there is something wrong with its current state.
I hard coded the time range in the template xml, so unless I have files shorter than 0-0.1 seconds I think I'm ok.
I have another issue though.
Running the tool.
K>> scaleTool.run();
??? Assignment of char to Java arrays is not
allowed
Error in ==> run at 24
if ispc, script(script=='/')='\'; end
The name of the tool is constructed earlier in the script:
outfile = ['Setup_LinearScale' name '.xml'];
% write the tool
scaleTool.print([trc_data_folder '\' outfile]);
Any ideas?
David
- David John Saxby
- Posts: 83
- Joined: Mon May 09, 2011 8:39 pm
Re: Scripting in Matlab for Scaling of Model
Hey Guys,
Thought I would share my solution up to this point.
Earlier in this thread, I didn't realize the time range needed to be an array double and not an integer.
So I first define the range:
% From the trc file
initial_time = markerData.getStartFrameTime();
final_time = markerData.getLastFrameTime();
% Create an array double and apply the time range
TimeArray = ArrayDouble();
TimeArray.set(0,initial_time);
TimeArray.set(1,final_time);
% set the time range
scaleTool.getModelScaler().setTimeRange(TimeArray);
So the xml now contains the time range for the specific trial of interest. This logic (not exact syntax) should be extensible to IK, ID, etc...BUT I haven't tried yet.
My problem remains that when I attempt to execute the tool:
% Run Scale Tool
scaleTool.run();
It appears that there is some problem passing strings to java. What is odd is I define the string for the scale tool:
% Setup file for the linear scaling
outfile = [data.Name '_Setup_LinearScaling.xml'];
% write the tool
scaleTool.print([trc_data_folder '\' outfile]);
These variables appear as java strings in the variable editor. Also, when I pause my code and run the xml's manually in the GUI...it WORKS!
I understand the GUI to be calling the same underlying code as API scripting, so what is it about my code that gives me the error? Or phrased differently, why can the GUI handle the xml my code generates but not the API script?
Hope the first bit helps someone.
David
Thought I would share my solution up to this point.
Earlier in this thread, I didn't realize the time range needed to be an array double and not an integer.
So I first define the range:
% From the trc file
initial_time = markerData.getStartFrameTime();
final_time = markerData.getLastFrameTime();
% Create an array double and apply the time range
TimeArray = ArrayDouble();
TimeArray.set(0,initial_time);
TimeArray.set(1,final_time);
% set the time range
scaleTool.getModelScaler().setTimeRange(TimeArray);
So the xml now contains the time range for the specific trial of interest. This logic (not exact syntax) should be extensible to IK, ID, etc...BUT I haven't tried yet.
My problem remains that when I attempt to execute the tool:
% Run Scale Tool
scaleTool.run();
It appears that there is some problem passing strings to java. What is odd is I define the string for the scale tool:
% Setup file for the linear scaling
outfile = [data.Name '_Setup_LinearScaling.xml'];
% write the tool
scaleTool.print([trc_data_folder '\' outfile]);
These variables appear as java strings in the variable editor. Also, when I pause my code and run the xml's manually in the GUI...it WORKS!
I understand the GUI to be calling the same underlying code as API scripting, so what is it about my code that gives me the error? Or phrased differently, why can the GUI handle the xml my code generates but not the API script?
Hope the first bit helps someone.
David
- David John Saxby
- Posts: 83
- Joined: Mon May 09, 2011 8:39 pm
Re: Scripting in Matlab for Scaling of Model
Hey Guys,
Solution!
I thought the scaleTool had a run method due to an assumption on my part. I thought scaleTool was a member of Tool, similar to InverseKinematicsTool and DynamicsTool. Not so. Check the class hierarchy.
To execute the scale operation the method is process model scaler, not run or any other method.
The input includes the subject path, so make sure your file names are just the filename without the path included, or the method will add the path in front of path\filename and problems will arise (i.e path\path\filename). If it returns a zero check the print log.
The same method is used for the marker placer as well.
Note that there is no orthogonality between methods. The methods to run IK, ID, scale, etc... in terms of names for similar operations (i.e setting filenames, models, etc...) are not the same across methods.
Best,
David
Solution!
I thought the scaleTool had a run method due to an assumption on my part. I thought scaleTool was a member of Tool, similar to InverseKinematicsTool and DynamicsTool. Not so. Check the class hierarchy.
To execute the scale operation the method is process model scaler, not run or any other method.
The input includes the subject path, so make sure your file names are just the filename without the path included, or the method will add the path in front of path\filename and problems will arise (i.e path\path\filename). If it returns a zero check the print log.
The same method is used for the marker placer as well.
Note that there is no orthogonality between methods. The methods to run IK, ID, scale, etc... in terms of names for similar operations (i.e setting filenames, models, etc...) are not the same across methods.
Best,
David