Result - the first ROBFIT module has been loaded onto Github!
It only took me 4 hours to do that mind!
Setting up the ROBFIT repo (got to do the jargon right - that's short for repository on github) was more of a lesson in retro. All command line control once you have downloaded github,
mkdir robfit
cd robfit
git init
type stuff - not sure whether to be pleased that I still follow this stuff or not - thought there would be some slick modern version to clickety click and bob's your uncle its all done for you. But no - maybe the advanced version comes with a green screen too ;)
Anyway;
git add BKGFIT
git remote add origin https://github/grandwizz/robfit.git
git push origin master
seemed to load the background fitting programme BKGFIT onto the site.
Github - looks very very useful by-the-way once you have got over up the learning curve!
Check it out.......more to come.
All things computing, software engineering and physics related! Now also including retirement stuff.
Friday, 22 June 2012
Friday, 15 June 2012
Reading my own words.
Bit odd - I have had to resort to reading the ROBFIT book to accelerate the learning.
Feels like I'm cheating - a bit.
So I have;
BKGFIT - which fits the background alone
FSPFIT - which fits he complete spectrum
RAWDD - displays the raw`data
XCALIBER - x-axis calibration to energy
FSPDIS - display the full spectrum
STGEN - generate a standard peak
The order of events for the way the code works is as follows;
Feels like I'm cheating - a bit.
So I have;
BKGFIT - which fits the background alone
FSPFIT - which fits he complete spectrum
RAWDD - displays the raw`data
XCALIBER - x-axis calibration to energy
FSPDIS - display the full spectrum
STGEN - generate a standard peak
The order of events for the way the code works is as follows;
- Read and display the raw data (RAWDD)
- Generate a 'standard' peak from the peak data (STGEN)
- Fit the background (BKGFIT)
- Search for regions where there may be peaks (FSPFIT)
- Add a peak to the region (FSPFIT)
- Repeat 3,4,5 until there are no further peak regions identified
- Convert the x-axis channel numbers into energies (XCALIBER)
- Display the fitting results (FSPDIS)
During the fitting the user has full control over the level to which the code will identify and attempt to fit smaller and smaller peaks.
Can't believe we did this on machines available at the time!
Saturday, 9 June 2012
Back to ROBFIT and the Fortran for a while!
So have agreed with Bob that posting the code on GITHUB is a good idea. However, getting a version of the code off the floppy disc's proved to be an exercise in itself! Involving clearing the loft to try and find an old machine that could read the 3 1/4 disc's. Found the machine and a miracle occurred it fired up without any trouble - the drive worked - and I managed to copy a total or 30 discs with various versions onto a modern disc drive. Result!
On a roll I selected the most recent version - copied it onto the machine I am typing this on (a Toshiba Satellite laptop - conveniently named for analysing Supernova data I thought) - the found a 'read.me' file - another result! Can't for the life of me remember writing any of this build stuff - maybe Bob did it ;)
Tried to follow the instructions, which are;
"Welcome to Robfit
Book reference "The Theory and Operation of Spectral Analysis
Using ROBFIT". AIP 1991 ISBN 0-88318-941-0
Robert L. Coldwell and Gary J. Bamford Univ. of Fla
ROBFIT@NERVM.NERDC.UFL.EDU
The disks have a mk...hd.bat file in the root directory
First insert Essential and run MKESSHD.BAT
This creates the robfit directory and various subdirectories
with a set of test cases in them.
Next insert the appropriate coproexe or nocoproexe disk
(depending on whether you do or do not have a coprocessor)
and enter the command RUNABLE.BAT. This creates the subdirectory
runable under robfit on the hard disk. Enter this subdirectory and
enter the command ROBFIT and read the book. The test cases are labelled
ZTCASE1.SP (the data file) through ZTCASE8.SP (supernova data).
It is supposed to be obvious what to do next. (...dis for display),
(...fit to fit).
On a roll I selected the most recent version - copied it onto the machine I am typing this on (a Toshiba Satellite laptop - conveniently named for analysing Supernova data I thought) - the found a 'read.me' file - another result! Can't for the life of me remember writing any of this build stuff - maybe Bob did it ;)
Tried to follow the instructions, which are;
"Welcome to Robfit
Book reference "The Theory and Operation of Spectral Analysis
Using ROBFIT". AIP 1991 ISBN 0-88318-941-0
Robert L. Coldwell and Gary J. Bamford Univ. of Fla
ROBFIT@NERVM.NERDC.UFL.EDU
The disks have a mk...hd.bat file in the root directory
First insert Essential and run MKESSHD.BAT
This creates the robfit directory and various subdirectories
with a set of test cases in them.
Next insert the appropriate coproexe or nocoproexe disk
(depending on whether you do or do not have a coprocessor)
and enter the command RUNABLE.BAT. This creates the subdirectory
runable under robfit on the hard disk. Enter this subdirectory and
enter the command ROBFIT and read the book. The test cases are labelled
ZTCASE1.SP (the data file) through ZTCASE8.SP (supernova data).
It is supposed to be obvious what to do next. (...dis for display),
(...fit to fit).
.................."
Er - nope - that didn't happen. Guess after 20 years things have changed. I am blaming Bob for not making it future proof ;))
So the plan now is to take the Fortran files one by one and try and figure out how to re-compile them for new machines.
I am enjoying this aren't I??
Saturday, 2 June 2012
Escalation modelling.....
Back to the offshore QRA modelling...
This is what we are trying to get our heads around at the moment!
This is the code escalation modelling element of the QRA code. The intention is to extract this module so that we can reuse in future applications.
We now just need a slick way of setting this up for future use that doesn't involve some tortured sequence of ascii characters that the spreadsheet models utilise - mind bending!
This is what we are trying to get our heads around at the moment!
This is the code escalation modelling element of the QRA code. The intention is to extract this module so that we can reuse in future applications.
We now just need a slick way of setting this up for future use that doesn't involve some tortured sequence of ascii characters that the spreadsheet models utilise - mind bending!
Saturday, 26 May 2012
Thought leadership!
Twitter update.
Just started to collate information on Twitter - which is a bit of a nightmare given the volume of traffic from the 80 people and organisation I follow.
However I have discovered the beauty of 'Lists' - you can essentially allocate certain people/organisations to a List or a number of Lists that you yourself can define. So I have set up 4 Lists which I am calling my Twitter Libraries, at the moment I have the following,
Which seem to be a good grouping of my areas of interest. These are proving to be very effective at filtering the dross and not losing a post in all of the traffic. So well done Twitter!
I am also using #arctki to record all of my tweets related to technical knowledge and innovation which again is a great way of tracking and sharing information.
Everyone has visibility of the Libraries and #arctki - not sure if anyone is checking them on a regular basis but a store of information is building up.
Just started to collate information on Twitter - which is a bit of a nightmare given the volume of traffic from the 80 people and organisation I follow.
However I have discovered the beauty of 'Lists' - you can essentially allocate certain people/organisations to a List or a number of Lists that you yourself can define. So I have set up 4 Lists which I am calling my Twitter Libraries, at the moment I have the following,
- Science Library
- Computing Library
- Management Library
- Coffee Library
Which seem to be a good grouping of my areas of interest. These are proving to be very effective at filtering the dross and not losing a post in all of the traffic. So well done Twitter!
I am also using #arctki to record all of my tweets related to technical knowledge and innovation which again is a great way of tracking and sharing information.
Everyone has visibility of the Libraries and #arctki - not sure if anyone is checking them on a regular basis but a store of information is building up.
Saturday, 19 May 2012
Data abstraction.
Back to the coding.....
We have decided not to go for the big-bang approach to rewriting the QRA codes but instead pull out the key functionality from each re-structure these elements and convert them into object modules so that we can later reassemble with each of these modules fully tested. This also helps in understanding how the current version operates as we need to continue using these codes in the interim period before the new version has been assembled.
Roy is again buried in the code and in the process of extracting the fire and explosion escalation elements of one of the codes. The first step being to put the data structures into better order. Quote;
The plan is therefore to create a data abstraction layer to decouple the code from the spreasheets as illustrated below.
Lets see how we get on from here ......
We have decided not to go for the big-bang approach to rewriting the QRA codes but instead pull out the key functionality from each re-structure these elements and convert them into object modules so that we can later reassemble with each of these modules fully tested. This also helps in understanding how the current version operates as we need to continue using these codes in the interim period before the new version has been assembled.
Roy is again buried in the code and in the process of extracting the fire and explosion escalation elements of one of the codes. The first step being to put the data structures into better order. Quote;
The QRA relies on an extensive data set held
within MS Excel. The code accesses the data by explicit sheet and cell
references using a combination of global variables and conditional logic. This
makes the code very difficult to follow and tightly couples the code to the
specific spreadsheet layout, hence it could not be directly ported to a
differently structured spreadsheet (or other data source)
The model also relies heavily on conditional
logic to perform its calculations given that there are many factors that have
to be considered and evaluated. This has resulted in a large number of chained conditionals
statements together with extensive nesting of the conditionals. As with the
data issue, this makes the code extremely difficult to follow and test.
Modifying the model with the existing escalation implementation would be
impractical.
The plan is therefore to create a data abstraction layer to decouple the code from the spreasheets as illustrated below.
Lets see how we get on from here ......
Saturday, 12 May 2012
Social media side show or main event .....
Things are starting to ramp up regarding the use of Twitter and LinkedIn within the company. I think the trick for me will be to make sure that the content is kept appropriate and useful to the community. There are probably a thousand reasons why we shouldn't be using these media for company 'knowledge' sharing - privacy, IPR etc. In fact I think there will be some corporate guidelines issued 'advising' staff on how to 'use' this material - kind of defeats the object of it all but lets see where we get to.
One of the issues I am feeling my way around is how do I generate sharing of best practice related to software development - yes in spreadsheets too! I had a discussion only yesterday with someone who should know better on the liabilities of just bashing out 'calculations' on projects because quote "that's what we do" - "it will only take you a couple of days" - holy smoke - read earlier entries on this one!
There is going to have to be a major culture change to make sure we get on top of this. Fortunately senior management appreciate the risk - would you just go out grab a few bricks and build a bridge. You know what a bridge looks like and you can lift bricks but does that mean you are qualified to design a bridge?
The journey takes a few twists and turns....
One of the issues I am feeling my way around is how do I generate sharing of best practice related to software development - yes in spreadsheets too! I had a discussion only yesterday with someone who should know better on the liabilities of just bashing out 'calculations' on projects because quote "that's what we do" - "it will only take you a couple of days" - holy smoke - read earlier entries on this one!
There is going to have to be a major culture change to make sure we get on top of this. Fortunately senior management appreciate the risk - would you just go out grab a few bricks and build a bridge. You know what a bridge looks like and you can lift bricks but does that mean you are qualified to design a bridge?
The journey takes a few twists and turns....
Subscribe to:
Posts (Atom)