Index


Using recursion to scan for directories
and insert each one into a binary tree structure


     The source code below scans for directories and subdirectories from a given starting point and stores all the paths in a binary tree structure. You will need to drop two buttons onto a form, name one Filesearch, and the other tree print. Then use selectall and delete to remove the code for the unit and replace it with the code below to run the program. After you have pasted the replacement code into the unit, remember to click on the form and then choose the events tab on the properties list, and then double click on 'form create' and also remember to double click on the 'onclick' events for both buttons to get the code to run. You can also modify the code to scan for directories in whatever folder you wish (the AssignFile statement defaults to 'c:\windows\*.*' for the directory scan and outputs to 'c:\treeprint.txt'). You will notice a variable named Flcount which is incremented during the TreePrint routine. You can right click on the folder you choose to scan and then make a note of how many directory and subdirectory folders are in the chosen starting folder by choosing properties from the pop up menu (the treeprint routine prints out one 'blank' which represents the empty root of the tree, so the variable is initialized to zero).

You can download the code as a textfile by right clicking on the following link ->directory_search_recursive.txt


A related page scans subdirectories and puts them onto a Delphi TreeView.

unit Unit1;
interface
uses
 Windows, Messages, SysUtils, Classes, Graphics, Controls, Forms, Dialogs,
 StdCtrls, FileCtrl;
type
 link=^node;
 node=record filename:string;  l, r:link end;  {tree node to store directories}
 TForm1 = class(TForm)
   FileSearch: TButton;
   TreePrint: TButton;
   procedure FormCreate(Sender: TObject);
   procedure FileSearchClick(Sender: TObject);
   function FileLook(Filespec:string):boolean;
   Function TreeInsert(Fname:string; q:link):link;
   procedure TreePrintClick(Sender: TObject);
   Procedure PrintTree(q:link);
 private
   { Private declarations }
 public
   { Public declarations }
 end;
var
 Form1: TForm1;
 t, head, z: link;
 fs:textfile; {*********************************}
 flcount:integer;
implementation
{$R *.DFM}
procedure TForm1.FormCreate(Sender: TObject);
begin
new(z); new(head);  {initialize binary tree head}
head^.filename:=''; head^.r:=z;  head^.l:=z;  {set key to nothing, lowest value on sorted tree}
             & nbsp;            &nb sp;                      {z is a dummy node, similar to setting to 'nil'}
    flcount:=0;  {count the number of folders during the print routine}
end;
procedure TForm1.FileSearchClick(Sender: TObject);
var
found:boolean;
begin
Found:=FileLook('c:\windows\*.*'); {**************scan this folder for sub dirs}
If found then MessageDlg('DUN!', mtInformation, [mbOk], 0)
  else MessageDlg('Directory does not exist', mtError, [mbOk], 0);
end;

Function TForm1.FileLook(Filespec:string):boolean; {scan for subdirs code}
var
 x:link; {tree link, only needed if you had additional fields in the record to fill}
 validres:integer; {SearchRec routines return 0 if successful}
 SearchRec  : TSearchRec;
 DirPath, DirName, Flname : string; {search for subdirs flname will be *.*}
begin
    DirPath:=ExtractFilePath(FileSpec);
    Result:= DirectoryExists(DirPath);
    If not Result then exit; {some error checking code}
    Flname:=ExtractFileName(FileSpec); {save the wild cards in the filespec}
    validres := FindFirst(FileSpec, faDirectory, SearchRec);
    while validres=0 do begin
         If (SearchRec.Attr and faDirectory>0) and (SearchRec.Name[1]<>'.') then   begin
             & nbsp;  {ignore the two dotted directories, do an and on the attributes to confirm
             & nbsp;  that the current searchrec is a directory}
             dir name:=SearchRec.Name; {extract the directory name}
             x: =TreeInsert(dirpath + dirname, head); {add the dirname to the current path
             & nbsp;            &nb sp;                           & nbsp;  and insert onto tree}
             Fil eLook(Dirpath+ dirname + '\' + Flname); {now check this new dir for subdirs
             & nbsp;            &nb sp;                           & nbsp;  using a recursive call to the function}
         end;
         validres:=FindNext(SearchRec) ;  {if it was not a directory or function returned
             & nbsp;            &nb sp;                from recursive search for subdirectories keep looking
             & nbsp;            &nb sp;                      in current path}
    end;
end;
Function TForm1.TreeInsert(Fname:string; q:link):link;
var st:link;  {st ­ the previous link, search until insertion value is less than current tree val}
begin
repeat
     st:=q;
     if fname<q^.filename then q:=q^.l else q:=q^.r;
until q=z;  {dummy node indicates search end, similar to nil pointer, easier to code}
new(q); q^.filename:=fname;  {create a new leaf node, insert value}
q^.l:=z; q^.r:=z;  {set leaf node pointers to dummy value}
if fname<st^.filename then st^.l:=q else st^.r:=q;  {use st to attach leaf to tree}
Result:=q;  {result only needed if you had additional record fields to fill in}
end;
procedure TForm1.TreePrintClick(Sender: TObject);
begin
assignfile(fs, 'c:\treeprint.txt');  {******************}
rewrite(fs);
PrintTree(head);  {pass the head pointer of the tree}
CloseFile(fs);
MessageDlg('TREE DUN!', mtInformation, [mbOk], 0);
end;
Procedure Tform1.PrintTree(q:link);  
{recursively search tree to left (less than) nodes and then search to the right (greater than nodes) to get an alphabetically sorted printout to file}
begin
    if q<>z then begin
       PrintTree(q^.l);
       Writeln(fs, inttostr(flcount) + ' : ' + q^.filename);  
        flcount:=flcount+1;  {compare count to property menu directory count}
       PrintTree(q^.r);
    end;
end;
end.

Index       Home




A Unified Field Theory

failed_gravity_theory.gif - 10361 Bytes



The Unified Field Theory
is also available as a zip file ->
unified.zip

Introduction :The Pioneer Effect and the New Physics. A brief description of the new physics required to explain the 'Pioneer Effect', which is the constant deceleration of space craft as they fly through space.




Principles of Evolution: A Study in the Evolution of Bedbugs



A couple of years ago my bedroom was invaded by bedbugs. There were two variant genetic lines. One type of bedbug was an enlongated, thin, tubular insect, and the second genetic line was a flat, perfectly circular insect. The result of the cross breeding of these two genetically distinct variants was the production of a bedbug with charcteristics of both, an enlongated, flat bedbug with a central bulge (such that the shape of the bedbug was somewhere between 'long' and 'circular'). The long skinny bedbugs were such strange and unfamiliar looking insects that at first I did not recognize them as being bedbugs, and considered them to be a seperate species of insect. However, as the photographs of bedbugs above indicate, enlongated and skinny bedbugs are not uncommon, and the photographs also show the variants that are produced by genetic combinations that result in an insect somewhere in between 'circular' and 'enlongated'.

Therefore it is my hypothesis that evolution occurs by means of the transfer of dominate genes, with the production of such dominant genes being the product of 'biological algorithms', a genetic software program that brings physical characteristics into harmony with behavior, such that when behavior changes, and a conflict then exists, this acts as a trigger and causes the release of dominant genes. The result is rapid evolution of species. The bedbug is a relatively new insect, not the product of millions of years of evolution but rather an insect that is evolving in real time. The newly emerging dominant form of the insect is the flat, round ciruclar insect, well adapted to living in human bedrooms (it is flat, rather than tubular, thus allowing it to hide in the smallest cracks, living a stealthy lifestyle, and it is round, which gives the insect a maximum storage capacity such that it must endanger itself only a few times a month by emerging to feed.

Other examples of rapid evolution include the development of long legs in an invasive species of toad in Australia. As the toads move into the mountainous regions of Australia, and their behvaior changes, making them 'climbing toads', over the course of just a couple of decades the toads in the highlands have grown long legs specially adapted to climbing. It is worth noting here that the toads are poisonous, and are a successful invasive species because they have no natural predators in Australia, and so it would not be the case that the toads with long legs were 'the fittest survivors', because all the toads are survivors, and therefore predation does not explain the rapid emergence and spread of such well adapted, long legged toads. Once again we see evidence for the existence of biological algorithms and the rapid spread of dominant genes through a population, which once introduced proceed to overwhelm the older genes which are being replaced (making toad long legged and a bed bug round and flat).


A Theological Experiment

My interest in pursuing the Unified Field Theory is spurred on by my need to discover the theoretical explanation of a new form of propulsion (as explained on this page: Why the Unified Field Theory?). The experiment involving the bedbugs came out of nowhere.

I also believe that it is possible to justify theological propositions using experimental methods. If a thing is an objective truth then it can be verified and proven true by means of experimentation. Such a theological proposition is of more value than a ‘divine revelation’, since such revelations depend upon nothing more than establishing authority figures which requires the creation of artificial hierarchies, for the only reason why I might be encouraged to believe an authority figure who orders me to believe unsubstantiated opinions is if I could somehow be convinced that this authority possessed a mind that was somehow superior to mine, and thus was fit to express opinions as though opinions were unquestionable facts and thus worthy of being elevated to the status of absolute dogma.

There is a self evident human inequality which is visibly apparent. Some people are ‘beautiful’ and thus are the true elite on this planet, and some people are not. It is this sexual inequality and the degeneration that follows upon beauty that is the true driving force behind all the evil that happens on earth. The need for ruthless oppression and the pursuit of wealth and the consequent creation of suffering and poverty which must follow upon this practice is for the purpose of creating an artificial alpha elite.

The true elites are the young and the beautiful. The artificial elite are the rich and the wealthy. The elite aging rich artificial alpha male has no good looks, for he is physically degenerate, but he will be found escorting beauty because he has a beautiful wallet. If he loses his wallet he will be found at home with all the other unattractive aged beta males sitting in a rocking chair watching reruns of Bonanza. No money, no sex. It is for this reason that the alpha males are found to be so ruthless and so violent in pursuit of their goal. The alpha male has fallen. The beta male has arisen and now the whole planet is full of ruinous destruction for it.

We see in religion a confused and contradictory reaction to this reality. On the one hand religion preaches a sexless heaven where castration and the clitorectomy create ‘pure spirits’. Muslims throw women under sacks. On the other hand religion supports hierarchy and is the prop of the elite alpha male. It is for this reason that religion is incoherent when it comes to speaking about sex.

Now we see this same principle at work in all of nature. Guppies dance and show off their colorful tails and the guppy who dances with the most colorful tail is the sexually successful guppy. Therefore it is the doctrine of the ruthless oppressor which teaches that the solution to human sexual violence is to be found in castration and the creation of pure ghosts. This would be equivalent to damning an aardvark for having the ‘sinful aardvark nature’ or prosecuting an anteater for the high crime of ‘ant genocide’.

Therefore it was my theological hypothesis that the correct solution to this problem is to give every guppy a beautiful colorful tail. I compare this solution to the classic religious solution which is to cut off every tail since having a tail is ‘sinful’. If having a tail is sinful then God must be sinful for no human being has any choice in deciding whether or not they would be born with a colorful tail, or whether they would not.

When I was young I was a beautiful guppy with a lovely tail. So everyone seemed to think. I am older now. My nose became very badly sunburned and destroyed. It seemed good to me to test my hypothesis by using these ‘biological algorithms’ to correct this problem. I healed half my nose as you can see by the line separating the still very dark patch on the side in the photograph below.





I documented my experiment on these pages. one two t hree four fi ve six


I have confirmed to my own satisfaction that my theological proposition is correct and that religious dogma is erroneous, being based as it was upon nothing more than ‘divine revelation’ which is just a form of opinionated speculation. For the time being I am not continuing this experiment, for I must wait until the weather on this planet improves, and the dark clouds of ruthless oppression break letting a little sun shine come through so that I can show the world the truth about God, by showing people how God goes about giving an old guppy back his beautiful colorful tail.


Until then I will have to sit on the sidelines, while all my scientific breakthroughs are deliberately ignored, while I wonder to myself what ever in the world could be wrong with the human race, because what this all will prove at the end of it all is that there definitely was something wrong with the people on this planet.