Remove Redundant Parentheses from String Expression

4 views (last 30 days)
S H
S H on 7 Jun 2016
Edited: S H on 10 Jun 2016
String contains a long expression. Part of it is:
'...+(G0*(G1-G2+G3))+((G4*(G5+G6)))-(((G7+G8))*((G9+G10+G11)))+...'
The redundant parentheses could be removed and the expression should look like:
'...+G0*(G1-G2+G3)+G4*(G5+G6)-(G7+G8)*(G9+G10+G11)+...'
Is there a simple Matlab script to do this?
  5 Comments
Walter Roberson
Walter Roberson on 8 Jun 2016
https://github.com/ewiger/decade/tree/master/lib/mparser
S H
S H on 10 Jun 2016
Thank you. I will look into https://github.com/ link.

Sign in to comment.

Answers (1)

Image Analyst
Image Analyst on 8 Jun 2016
Recall that Azzi answered this, or something pretty much similar, and you accepted his answer in http://www.mathworks.com/matlabcentral/answers/287777#answer_224489
  4 Comments
Star Strider
Star Strider on 10 Jun 2016
@S H —
Don’t get cheeky.
Revise the documentation for the Symbolic Math Toolbox simplify function.
S H
S H on 10 Jun 2016
Edited: S H on 10 Jun 2016
Yes symbolic tool fixes this but it also shuffles all the terms and tries to sort them based on variable names. That is why I want to process this expression as string only.
This question takes finding matching parentheses one step further because repetition must also be accounted.
How to solve this includes the following steps:
1. write an algorithm to find matching parentheses for any existing pair
2. See if there is any pair with more than one repetition and then eliminate all redundants

Sign in to comment.

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!