OK - I have the next revival project sorted!
I'ts a bit of back to the future related to the ROBFIT code myself and Bob Coldwell of the University of Florida physics department developed towards the back end of the 1980's.
So that's the 'back' bit!
After 20 years I have managed to resurrect the Fortran files - from 3 1/2" floppies - just finding a drive to read these was an exercise in itself. Thanks to mumbam for digging out an old work computer - though she did then go on about how the version of Excel loaded on the machine was far better than the modern one which was slightly worrying.
Anyway I have now extracted the files - cold sweat as I remember the work put into writing these. All seem fine - I now have a list of files that makefiles,
BKGFIT
FSPDIS
FSPFIT
RAWDD
STDIS
STGEN
VRMAIN
XCALIBER
now need to figure out what they do, maybe I should read the book :O. However, I have contacted Bob and have decided to load this version of the code onto a proper 'open' repository.
That's the 'future' bit.
I have been reliably informed by Bambofy (many thanks again) that 'github' is the place for this so my very next task is to figure out how to do that.
The journey goes back in time.....
All things computing, software engineering and physics related! Now also including retirement stuff.
Saturday, 28 April 2012
Friday, 20 April 2012
Old - but - New!
What is new in the world of Fortran - other than there's a new version out or geekery around the code structure - what are people using it for?
How do you find out what's going on right now?
Have 'discovered' hastags and lists. That's Twitter speak ;)
I'm finding it a great medium for sharing and discussing ideas around innovation. Not entirely sure yet how effective this will be but these tools look like they will help. Also not sure it will work for Fortran updating etc but have started to monitor the community! You have been warned.
My view on Twitter advantages so far are that it has a wide reach so you get input from a more diverse audience (some of which you may not want - but it certainly adds variety to the discussions). LinkedIn discussions - the other media I use - tend to be a bit insular - you have to be in the group to participate - which is sometimes a good thing don't get me wrong. Twitter therefore for me seems to be a bit more dynamic and feels more alive for ideas. Though it is early days for our #arctki forum!
I was very sceptical before putting a bit of effort into Twitter - there is a lot of chatter. But if you tap into the right discussions I've found it to be great for discovering exactly what is happening in particular fields and quickly. The trick is to filter and organise the info so you don't get lost in the avalanche hence the # and lists.
Lets see what's going on in the Fortran world.....
How do you find out what's going on right now?
Have 'discovered' hastags and lists. That's Twitter speak ;)
I'm finding it a great medium for sharing and discussing ideas around innovation. Not entirely sure yet how effective this will be but these tools look like they will help. Also not sure it will work for Fortran updating etc but have started to monitor the community! You have been warned.
My view on Twitter advantages so far are that it has a wide reach so you get input from a more diverse audience (some of which you may not want - but it certainly adds variety to the discussions). LinkedIn discussions - the other media I use - tend to be a bit insular - you have to be in the group to participate - which is sometimes a good thing don't get me wrong. Twitter therefore for me seems to be a bit more dynamic and feels more alive for ideas. Though it is early days for our #arctki forum!
I was very sceptical before putting a bit of effort into Twitter - there is a lot of chatter. But if you tap into the right discussions I've found it to be great for discovering exactly what is happening in particular fields and quickly. The trick is to filter and organise the info so you don't get lost in the avalanche hence the # and lists.
Lets see what's going on in the Fortran world.....
Saturday, 14 April 2012
So how do you do it.......?
Still no decision on previously described workings.
However, started to mull over a couple of things related to how to position development going forward;
However, started to mull over a couple of things related to how to position development going forward;
- I have a foot high pillar of 3 1/2inch floppy disc's with a load of old Fortran code on them. I'm sure its all really useful recyclable, reusable full documented well structured code by-the-way! But what a waste - from a scientific viewpoint I'm sure there is something of use, I have a complete spectral analysis code ROBFIT on there somewhere. Though it is a version that's 20 years old! What to do?
- Everything, and I mean everything, is going 'social networking' mad. In fact I used the LinkedIn Fortran Programming Group to get going again on all things software. However, personally I find LinkedIn a bit of a 'static' medium, which is both a strength and a weakness. Its strength lies in it acting almost as a living (but passive) Google search - you can post questions and get learned responses without too much 'noise'. Its weakness, in my view, is you tend to end up in silo's on it. By that I mean if you start a discussion in a particular group then you may end up in a very 'deep' discussion thread but not necessarily a 'wide' discussion. Is there a better way of sharing with whole communities?
I'm sure someone has been through all this but I'm having fun going up the learning curve.
Saturday, 7 April 2012
End of Phase 2.....what now?
So the final report has been issued on the second of the 'Fortran Revival' activities - phew! Further development, as detailed in earlier posts, will require a significant investment in a - I was going to say rewrite, but its more of a 'create from scratch again' type activity.
The only professional way forward in my view being development of a fully specified, documented, validated and verified code written in an environment that allows proper maintenance processes to be put in place.
There are some suggestions that we could go back to pure Excel calculations - noooooooo - read earlier blogs for my view on that one. Breaks out in a cold sweat just thinking about it.....images of monstrous spreadsheets comes to mind.....no wait.....that's the finance department!
Wonder what the next project could be......
The only professional way forward in my view being development of a fully specified, documented, validated and verified code written in an environment that allows proper maintenance processes to be put in place.
There are some suggestions that we could go back to pure Excel calculations - noooooooo - read earlier blogs for my view on that one. Breaks out in a cold sweat just thinking about it.....images of monstrous spreadsheets comes to mind.....no wait.....that's the finance department!
Wonder what the next project could be......
Saturday, 31 March 2012
Coding can be bad for your health!
So we have managed to now complete the assessment of all three codes.
Conclusion - don't try and programme anything complicated in Excel. I had concerns about using this environment to do the scientific calculations before we started this review exercise but now I am absolutely certain its a poor choice. The problem is its easy to get something going - and therein lies the mainissue. Unless your are very very very structured, particularly when writing VBA and using Excel sheets to feed and record results, it is too easy to implement bad practice into the coding. Cutting and pasting data (was that to the right cell), macros (must have seemed like a good idea at the time), sheets for storing mass data (is there a limit in Excel?) are all inappropriate functionality for producing robust, verified and validated (in the proper sense) code.
We are simply going to have to rewrite the whole lot if we want to take these codes forward.
Just come across this quote from a 2002 paper on 'Spreadsheet Engineering' by
Thomas A. Grossman
School of Business and Management, University of San Francisco,
San Francisco, California, USA 94117-1045
tagrossman@usfca.edu
referenced from;
http://www.eusprig.org/best-practice.htm
which kind of sums up what should be done - ten years on!
"People have programmed computers for at least five decades. Over this time there has emerged a
field called “software engineering” that considers the myriad approaches people take—and
should take—when they write computer programs. This knowledge includes journal publications
describing theoretical research, laboratory experiments, field observations, and recommended
practices, as well as industry wisdom codified in books and computer magazines.
Since a spreadsheet is nothing more than a computer programming tool, one hopes that some of
the accumulated knowledge of software engineering is relevant to spreadsheets, and [Panko
2000a] recommends we start to adapt traditional programming techniques to spreadsheets.
[Rajalingham et al 2000] take a step in this direction with design recommendations and a formal
hierarchical tree technique. However, we are unaware of any systematic consideration of how
software engineering principles could apply to spreadsheets.
The application of software engineering principles to spreadsheets—call this “spreadsheet
engineering”—has the potential to increase the productivity of spreadsheet programmers,
decrease the frequency and severity of spreadsheet errors, enhance spreadsheet maintainability
over time, and actually be implemented by spreadsheet users. "
from a paper that's well worth a read.
Also this one on spreadsheet QA!
How do you know your spreadsheet is right?
Principles, Techniques and Practice of Spreadsheet Style
Philip L. Bewig — July 28, 200
http://www.eusprig.org/hdykysir.pdf
now I'm convinced its best to start again!
Conclusion - don't try and programme anything complicated in Excel. I had concerns about using this environment to do the scientific calculations before we started this review exercise but now I am absolutely certain its a poor choice. The problem is its easy to get something going - and therein lies the mainissue. Unless your are very very very structured, particularly when writing VBA and using Excel sheets to feed and record results, it is too easy to implement bad practice into the coding. Cutting and pasting data (was that to the right cell), macros (must have seemed like a good idea at the time), sheets for storing mass data (is there a limit in Excel?) are all inappropriate functionality for producing robust, verified and validated (in the proper sense) code.
We are simply going to have to rewrite the whole lot if we want to take these codes forward.
Just come across this quote from a 2002 paper on 'Spreadsheet Engineering' by
Thomas A. Grossman
School of Business and Management, University of San Francisco,
San Francisco, California, USA 94117-1045
tagrossman@usfca.edu
referenced from;
http://www.eusprig.org/best-practice.htm
which kind of sums up what should be done - ten years on!
"People have programmed computers for at least five decades. Over this time there has emerged a
field called “software engineering” that considers the myriad approaches people take—and
should take—when they write computer programs. This knowledge includes journal publications
describing theoretical research, laboratory experiments, field observations, and recommended
practices, as well as industry wisdom codified in books and computer magazines.
Since a spreadsheet is nothing more than a computer programming tool, one hopes that some of
the accumulated knowledge of software engineering is relevant to spreadsheets, and [Panko
2000a] recommends we start to adapt traditional programming techniques to spreadsheets.
[Rajalingham et al 2000] take a step in this direction with design recommendations and a formal
hierarchical tree technique. However, we are unaware of any systematic consideration of how
software engineering principles could apply to spreadsheets.
The application of software engineering principles to spreadsheets—call this “spreadsheet
engineering”—has the potential to increase the productivity of spreadsheet programmers,
decrease the frequency and severity of spreadsheet errors, enhance spreadsheet maintainability
over time, and actually be implemented by spreadsheet users. "
from a paper that's well worth a read.
Also this one on spreadsheet QA!
How do you know your spreadsheet is right?
Principles, Techniques and Practice of Spreadsheet Style
Philip L. Bewig — July 28, 200
http://www.eusprig.org/hdykysir.pdf
now I'm convinced its best to start again!
Friday, 23 March 2012
2 down 1 to go........
Second code review completed and documented.
On to the third code which is well structured much better documented!
A sample of the data input sheets for this code;
- Button Title Datasheet Title
- Parts Count Data Parts Count
- Process Release Freq. Data
- Riser Release Frequencies
- Blowout Frequencies
- Special Frequencies
- Events Events
- (Ignition Probabilities)
- (Escalation) n/a
- Fire and Explosion Frequencies
- (Immediate Fatality Fractions)
- Population Population
- Immediate Hydrocarbon Risk
- Travel Risk
- Non-Hydrocarbon Risk
- Button Title Datasheet Title
- Hydrocarbon QRA Results
- Summary QRA Results
Just got to figure out how it all links together now!
Labels:
blowout,
event tree,
fire,
hydrocarbon,
QRA,
riser,
risk,
software
Saturday, 17 March 2012
More progress - the overview.
Now started to look into the 'onshore' QRA model - which is a little better structured. For each fire scenario the code undertakes the following calculation flow;
The initiating
event sheet provides the event list to be processed by the application. The
naming convention for initiating events is: Area/Unit_Inventory
Where:
- · area is the primary area designator (eg site),
- · unit specifies the location of the release (eg a fire zone, module/unit or equipment name)
- · inventory is the inventory name which can result in a hazardous scenario, e.g. valves, flanges
- The initiating events (hazardous release scenarios) are based on releases from inventories. A number of hole sizes are defined (typically small, medium, large and full bore) that relate to the event such that the hole size determines the release frequency.
- Release frequencies are defined on a separate sheet and referenced via lookup during calculations.
- For each event the model walks through each release (hole) size required for both Impinged and Unimpinged states.
- Within this nested loop structure the program calculates the branch probability and outcome frequencies for the event tree and copied the results to the Event Tree sheet. The calculations use a combination of the pre-loaded data acquired during program start plus lookup data from worksheets using offsets dependant on the event.
- The risk assessment methodology analyses each of the identified initiating hazardous events (hydrocarbon releases) that can lead to potential jet fires, pool fires, flash fires, explosions or (unignited) toxic dispersion.
- When the QRA is run, the program fills in the data for each event and calculates the branch probabilities and outcome frequencies.
- The branch probabilities are calculated by a user defined maco (function) embedded in the event tree sheet. Once the main process loop has copied data to the tree sheet an Excel re-calculate is invoked to display the results.
Voila....
Subscribe to:
Posts (Atom)