Back to Forum | View unanswered posts | View active topics
Topic review - minimize overhead when returning objects from procedures |
Author |
Message |
|
|
Post subject: |
Re: minimize overhead when returning objects from procedures |
data:image/s3,"s3://crabby-images/d397e/d397e9399be039beaeb5f823282774c60c35f171" alt="Reply with quote Reply with quote" |
|
special rules for ring/qring: - assignment does not copy - nameof(basering) is always a local variable name even if defined in another procedure - if there are several names for the current barering, removing nameof(basering) sets nameof(basering) to one of the others (so nameof(basering is always defind as long as there is any basering)
Jack wrote: If that is really so bad, could this be prevented by the language itself? No, it is like converting module to matrix and vice versa: quite useful and sometimes necessary but should not be done too often. Or like shooting yourself in the foot:: sometimes useful, one can still walk, but generally not recommended.
And: reference is an experimental feature: it can/will be removed/changed/renamed etc.
special rules for ring/qring: - assignment does not copy - nameof(basering) is always a local variable name even if defined in another procedure - if there are several names for the current barering, removing nameof(basering) sets nameof(basering) to one of the others (so nameof(basering is always defind as long as there is any basering)
Jack wrote: If that is really so bad, could this be prevented by the language itself? No, it is like converting module to matrix and vice versa: quite useful and sometimes necessary but should not be done too often. Or like shooting yourself in the foot:: sometimes useful, one can still walk, but generally not recommended.
And: reference is an experimental feature: it can/will be removed/changed/renamed etc.
|
|
|
data:image/s3,"s3://crabby-images/2145e/2145e0ac0968424c92450baccbd0d3fd5f51d6ea" alt="Post Post" |
Posted: Tue Oct 15, 2013 9:47 am |
|
|
data:image/s3,"s3://crabby-images/2553b/2553b21a2d1a08a546ac63f02e49bbd6a504012b" alt="" |
|
|
Post subject: |
Re: there are special rules for rings |
data:image/s3,"s3://crabby-images/d397e/d397e9399be039beaeb5f823282774c60c35f171" alt="Reply with quote Reply with quote" |
|
hannes wrote: For ring/qring reference should not be used: there are special rules for rings which do not apply for references!
Could you step a little bit more into detail: which specials rules for rings do not apply when using references? If that is really so bad, could this be prevented by the language itself? Jack
[quote="hannes"] For ring/qring reference should not be used: there are special rules for rings which do not apply for references!
[/quote]
Could you step a little bit more into detail: which specials rules for rings do not apply when using references?
If that is really so bad, could this be prevented by the language itself?
Jack
|
|
|
data:image/s3,"s3://crabby-images/2145e/2145e0ac0968424c92450baccbd0d3fd5f51d6ea" alt="Post Post" |
Posted: Mon Oct 14, 2013 3:40 pm |
|
|
data:image/s3,"s3://crabby-images/2553b/2553b21a2d1a08a546ac63f02e49bbd6a504012b" alt="" |
|
|
Post subject: |
Re: minimize overhead when returning objects from procedures |
data:image/s3,"s3://crabby-images/d397e/d397e9399be039beaeb5f823282774c60c35f171" alt="Reply with quote Reply with quote" |
|
For usual types: it depends. The time consuming operations are the same in nature and count (clean up the old content, move the new one to the destination) if return is compared to reference.
For ring/qring reference should not be used: there are special rules for rings which do not apply for references!
If you are looking for the fastest method with minimal memory foot print, the construction of the object as global one may be the best method but this has other negative aspects.
For usual types: it depends. The time consuming operations are the same in nature and count (clean up the old content, move the new one to the destination) if return is compared to reference.
For ring/qring reference should not be used: there are special rules for rings which do not apply for references!
If you are looking for the fastest method with minimal memory foot print, the construction of the object as global one may be the best method but this has other negative aspects.
|
|
|
data:image/s3,"s3://crabby-images/2145e/2145e0ac0968424c92450baccbd0d3fd5f51d6ea" alt="Post Post" |
Posted: Fri Oct 11, 2013 11:32 am |
|
|
data:image/s3,"s3://crabby-images/2553b/2553b21a2d1a08a546ac63f02e49bbd6a504012b" alt="" |
|
|
Post subject: |
minimize overhead when returning objects from procedures |
data:image/s3,"s3://crabby-images/d397e/d397e9399be039beaeb5f823282774c60c35f171" alt="Reply with quote Reply with quote" |
|
What is a reasonable method in Singular ( less copying, less memory usage footprint ) to return rings and other objects from procedures if there are several calling levels
- use return() or - update a passed list reference parameter? or - < put your approach here>
What is a reasonable method in Singular ( less copying, less memory usage footprint ) to return rings and other objects from procedures if there are several calling levels
- use return() or - update a passed list reference parameter? or - < put your approach here>
|
|
|
data:image/s3,"s3://crabby-images/2145e/2145e0ac0968424c92450baccbd0d3fd5f51d6ea" alt="Post Post" |
Posted: Thu Oct 10, 2013 12:35 pm |
|
|
data:image/s3,"s3://crabby-images/2553b/2553b21a2d1a08a546ac63f02e49bbd6a504012b" alt="" |
|
|
It is currently Fri May 13, 2022 10:58 am
|
|