#
# bicyclib.pm
# library module for bicyclic compounds
#
print "module bicyclib version 1.0 1999-04-12\n";

# Norbornan
# parameter: "bc221h", , , startpos, bliste, radius
sub bc221h_default_
{
    my ($iAnz, $p1, $p2, $iStart, $BT, $bAromat, $rRadius) = @_;
    $$iAnz = 7;
    $$iStart = $$p1 = $$p2 = 0;
    $$rRadius = $rLenN;
    $$bAromat = $false;
    @$BT = (9, 9, 9, 0, 0, 0, 9, 0);
}

sub bc221h_
{
    my ($XYstart, $rRadius, $rRadius_bak, $iAnz, $p1, $p2, $iStart, 
			$M, $rLena, $rThetaa, $XYa, $BLa, $t, $b, $r) = @_;

    $$rRadius_bak = $$rRadius = abs($$rRadius);
    my ($dx, $dy) = (cos(30*$pi/180)*$$rRadius, sin(30*$pi/180)*$$rRadius);
    my ($sx, $sy) = (0.6*$$rRadius, 0.7*$$rRadius);
    my $l1 = sqrt($sx*$sx+$sy*$sy);
    @$XYa = (loc->new(0,0), loc->new($dx,$dy), loc->new(2*$dx,0), 
	     loc->new($sx+2*$dx,$sy), loc->new($sx+$dx,$sy+$dy), loc->new($sx,$sy),
	     loc->new($dx*1.5,$sy*3));
    my $XYshift = loc->new($$XYa[$iStart]);
    grep(($_->translate(- $XYshift->{"x"},
			- $XYshift->{"y"}) && 0), @$XYa);
    grep(($_->translate($XYstart) && 0), @$XYa);
    $M->eq(0,0);
    $M->translate($XYstart);
    @$rThetaa = (30, -30, getangle($$XYa[2], $$XYa[3]), 150, -150,
		getangle($$XYa[5], $$XYa[0]),  
		getangle($$XYa[1], $$XYa[6]), getangle($$XYa[4], $$XYa[6]));
    @$rLena = ($$rRadius, $$rRadius, $l1, $$rRadius, $$rRadius, $l1,
		getlength($$XYa[1], $$XYa[6]), getlength($$XYa[4], $$XYa[6]));
    @$BLa = (0, 1, 2, 3, 4, 5, 1, 4);   # start atom
    @$r = (-140, -120, -80, 10, 30, 150, 90);
    @$t = (150, 30, 30, 30, 150, 150, 150);
    @$b = (-90, 150, -90, -90, 30, -90, 30);
}


# Norpinan-Geruest
# parameter: "bc311h", , , startpos, bliste, radius
sub bc311h_default_
{
    my ($iAnz, $p1, $p2, $iStart, $BT, $bAromat, $rRadius) = @_;
    $$iAnz = 7;
    $$iStart = $$p1 = $$p2 = 0;
    $$rRadius = $rLenN;
    $$bAromat = $false;
    @$BT = (0, 0, 0, 9, 9, 9, 9, 0);
}

sub bc311h_
{
    my ($XYstart, $rRadius, $rRadius_bak, $iAnz, $p1, $p2, $iStart, 
			$M, $rLena, $rThetaa, $XYa, $BLa, $t, $b, $r) = @_;

    $$rRadius_bak = $$rRadius = abs($$rRadius);
    my ($dx, $dy) = (cos(30*$pi/180)*$$rRadius, sin(30*$pi/180)*$$rRadius);
    my ($sx, $sy) = ($$rRadius, sin(30*$pi/180)*(2*$$rRadius));
    my $l1 = sqrt($sx*$sx+$sy*$sy);
    @$XYa = (loc->new(0,0), loc->new($dx,-$dy), loc->new(2*$dx,0), 
	    loc->new($sx+2*$dx,-$sy), loc->new($sx+$dx,$dy-$sy), loc->new($sx,-$sy),
	    0);
    $$XYa[6] = getpos($$XYa[5], -120,$$rRadius);
    @$rThetaa = (-30, +30, getangle($$XYa[2], $$XYa[3]), 
	    150, -150, getangle($$XYa[5], $$XYa[0]),
	    -120,  getangle($$XYa[1], $$XYa[6]));
    @$rLena = ($$rRadius, $$rRadius, $l1, $$rRadius, $$rRadius, $l1,
	    $$rRadius, getlength($$XYa[1], $$XYa[6]));
    my $XYshift = loc->new($$XYa[$iStart]);
    grep(($_->translate(- $XYshift->{"x"},
			- $XYshift->{"y"}) && 0), @$XYa);
    grep(($_->translate($XYstart) && 0), @$XYa);
    $M->eq(0,0);
    $M->translate($XYstart);
    @$BLa = (0, 1, 2, 3, 4, 5, 5, 1);   # start atom
    @$r = (142, -60, 82, -37, 90, -60, -120);
    @$t = (90, -30, 90, 30, 90, 10, 180);
    @$b = (-150, -150, -20, -90, -120, -90, -60);
}

# Bizyklo[2.2.2]oktan
# parameter: "bc222o", , , startpos, bliste, radius
sub bc222o_default_
{
    my ($iAnz, $p1, $p2, $iStart, $BT, $bAromat, $rRadius) = @_;
    $$iAnz = 8;
    $$iStart = $$p1 = $$p2 = 0;
    $$rRadius = $rLenN;
    $$bAromat = $false;
    @$BT = (0, 0, 9, 9, 9, 0, 9, 9, 0);
}

sub bc222o_
{
    my ($XYstart, $rRadius, $rRadius_bak, $iAnz, $p1, $p2, $iStart, 
			$M, $rLena, $rThetaa, $XYa, $BLa, $t, $b, $r) = @_;

    $$rRadius_bak = $$rRadius = abs($$rRadius);
    my ($dx, $dy) = (cos(30*$pi/180)*$$rRadius, sin(30*$pi/180)*$$rRadius);
    my ($sx, $sy) = (0.6*$$rRadius, 0.7*$$rRadius);
    my $l1 = sqrt($sx*$sx+$sy*$sy);
    @$XYa = (loc->new(0,0), loc->new($dx,$dy), loc->new(2*$dx,0), 
	     loc->new(2*$dx-$sx,-$sy), loc->new($dx-$sx,$dy-$sy), loc->new(-$sx,-$sy),
	     0,0);
    $$XYa[6] = getpos($$XYa[4], 90, $$rRadius);
    $$XYa[7] = getpos($$XYa[1], 90, $$rRadius);
    my $XYshift = loc->new($$XYa[$iStart]);
    grep(($_->translate(- $XYshift->{"x"},
			- $XYshift->{"y"}) && 0), @$XYa);
    grep(($_->translate($XYstart) && 0), @$XYa);
    $M->eq(0,0);
    $M->translate($XYstart);
    @$rThetaa = (30, -30, getangle($$XYa[2], $$XYa[3]), 150, -150,
		getangle($$XYa[5], $$XYa[0]),  
		90, getangle($$XYa[6], $$XYa[7]), 90);
    @$rLena = ($$rRadius, $$rRadius, $l1, $$rRadius, $$rRadius, $l1,
		$$rRadius, $l1, $$rRadius);
    @$BLa = (0, 1, 2, 3, 4, 5, 4, 6, 1);   # start atom
    @$r = (135, 45, 30, -80, -120, -138, 140, 70);
    @$t = (150, 30, 30, 30, 150, 150, 150, 150);
    @$b = (-90, 150, -90, -90, -90, -90, 20, 30);
}


# Tropin-Geruest
# parameter: "bc321o", , , startpos, bliste, radius
sub bc321o_default_
{
    my ($iAnz, $p1, $p2, $iStart, $BT, $bAromat, $rRadius) = @_;
    $$iAnz = 8;
    $$iStart = $$p1 = $$p2 = 0;
    $$rRadius = $rLenN;
    $$bAromat = $false;
    @$BT = (0, 0, 0, 9, 9, 9, 9, 0, 0);
}

sub bc321o_
{
    my ($XYstart, $rRadius, $rRadius_bak, $iAnz, $p1, $p2, $iStart, 
			$M, $rLena, $rThetaa, $XYa, $BLa, $t, $b, $r) = @_;

    $$rRadius_bak = $$rRadius = abs($$rRadius);
    my ($dx, $dy) = (cos(30*$pi/180)*$$rRadius, sin(30*$pi/180)*$$rRadius);
    my ($sx, $sy) = ($$rRadius, sin(30*$pi/180)*(2*$$rRadius));
    my $l1 = sqrt($sx*$sx+$sy*$sy);
    @$XYa = (loc->new(0,0), loc->new($dx,-$dy), loc->new(2*$dx,0), 
	    loc->new($sx+2*$dx,-$sy), loc->new($sx+$dx,$dy-$sy), 
	    loc->new($sx,-$sy), 0, 0);
    $$XYa[6] = getpos($$XYa[5],-100,$$rRadius);
    $$XYa[7] = getpos($$XYa[1],-100,$$rRadius);
    @$rThetaa = (-30, +30, getangle($$XYa[2], $$XYa[3]), 
	    150, -150, getangle($$XYa[5], $$XYa[0]),
	    -100, getangle($$XYa[6], $$XYa[7]), -100);
    @$rLena = ($$rRadius, $$rRadius, $l1, $$rRadius, $$rRadius, $l1,
	    $$rRadius, getlength($$XYa[6], $$XYa[7]), $$rRadius);
    my $XYshift = loc->new($$XYa[$iStart]);
    grep(($_->translate(- $XYshift->{"x"},
			- $XYshift->{"y"}) && 0), @$XYa);
    grep(($_->translate($XYstart) && 0), @$XYa);
    $M->eq(0,0);
    $M->translate($XYstart);
    @$BLa = (0, 1, 2, 3, 4, 5, 5, 6, 1);   # start atom
    @$r = (143, 100, 82, -37, 90, -60, -100, -120);
    @$t = (90, -30, 90, 30, 90, -150, -30, -20);
    @$b = (-150, -150, -20, -90, -60, -45, -150, -160);
}