#
# mncyclib.pm
# library module for monocyclic compounds
#
print "module mncyclib version 1.1 2000-01-17\n";

# Zyklobutan
# parameter: "cb", , , startpos, bliste, radius
sub cb_default_
{
   my ($iAnz, $p1, $iAngle, $iStart, $BT, $bAromat, $rRadius) = @_;
   $$iAnz = 4;
   $$iStart = $$p1 = $$iAngle = 0;
   $$rRadius = $rLenN;
   $$bAromat = $false;
   @$BT = (9, 9, 0, 0);
}

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

   $$rRadius_bak = $$rRadius = abs($$rRadius);
   $$XYa[0] = loc->new(0,0);
   $$XYa[1] = getpos($$XYa[0], -130, $$rRadius);
   $$XYa[2] = getpos($$XYa[1], 140, $$rRadius);
   $$XYa[3] = getpos($$XYa[2], -30, $$rRadius*1.5);
   @$rThetaa = (-130, 140, -30, getangle($$XYa[3], $$XYa[0]));
   @$rLena = ($$rRadius, $$rRadius, $$rRadius*1.5,
       getlength($$XYa[3], $$XYa[0]));

   grep(($_->rotate($iAngle) && 0), @$XYa);
   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);   # start atom
   @$r = (60, -100, 150, -60);
   @$t = (120, 170, 90,   30);
   @$b = (30,  -90, -150, -90);
   grep((($_ += $iAngle) && 0), @$r, @$t, @$b, @$rThetaa);
}



# Zyklopentan envelope-Konformation
# parameter: "cp", conformertyp, , startpos, bliste, radius
sub cp_default_
{
   my ($iAnz, $conf, $iAngle, $iStart, $BT, $bAromat, $rRadius) = @_;
   $$iAnz = 5;
   $$iStart = $$conf = $$iAngle = 0;
   $$rRadius = $rLenN;
   $$bAromat = $false;
   @$BT = (9, 9, 0, 0, 0);
}

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

   $$rRadius_bak = $$rRadius = abs($$rRadius);
   $$XYa[0] = loc->new(0,0);
   if ($conf == 0)
   {
       $$XYa[1] = getpos($$XYa[0], -120, $$rRadius*1.5);
       $$XYa[2] = getpos($$XYa[1], 170, $$rRadius);
       $$XYa[3] = getpos($$XYa[2], 20, $$rRadius);
       $$XYa[4] = getpos($$XYa[3], -10, $$rRadius);
       @$rThetaa = (-120, 170, 20, -10, getangle($$XYa[4], $$XYa[0]));
       @$rLena = ($$rRadius*1.5, $$rRadius, $$rRadius, $$rRadius,
               getlength($$XYa[4], $$XYa[0]));
       @$r = (80, -60, -170, 110, -50);
       @$t = (150, 30,  150, 150, 30);
       @$b = (30,  -90, -90, -90, -90);
   }
   elsif ($conf == 1)
   {
       $$XYa[1] = getpos($$XYa[0], -160, $$rRadius);
       $$XYa[2] = getpos($$XYa[1], 170, $$rRadius);
       $$XYa[3] = getpos($$XYa[2], 100, $$rRadius);
       $$XYa[4] = getpos($$XYa[0], 170, $$rRadius);
       @$rThetaa = (-160, 170, 100, getangle($$XYa[3], $$XYa[4]), -10);
       @$rLena = ($$rRadius, $$rRadius, $$rRadius,
               getlength($$XYa[3], $$XYa[4]), $$rRadius);
       @$r = (0, -60, -150, 120, 60);
       @$t = (90,  90,  150,  90,   90);
       @$b = (-30, -60, -90, -150, -150);
   }
   elsif ($conf == 2)
   {
       $$XYa[1] = getpos($$XYa[0], -160, $$rRadius);
       $$XYa[2] = getpos($$XYa[1], 140, $$rRadius*1.5);
       $$XYa[4] = getpos($$XYa[0], 170, $$rRadius);
       $$XYa[3] = getpos($$XYa[4], -160, $$rRadius);
       @$rThetaa = (-160, 140, getangle($$XYa[2], $$XYa[3]), 20, -10);
       @$rLena = ($$rRadius, $$rRadius*1.5,
               getlength($$XYa[2], $$XYa[3]), $$rRadius, $$rRadius);
       @$r = (0, -90, 120, -120, 90);
       @$t = (90,  0,   60,  150, 90);
       @$b = (-30, -90, 180, -90, -60);
   }
   elsif ($conf == 3)
   {
       $$XYa[1] = getpos($$XYa[0], -160, $$rRadius);
       $$XYa[2] = getpos($$XYa[1], 140, $$rRadius);
       $$XYa[3] = getpos($$XYa[2], 20, $$rRadius);
       $$XYa[4] = getpos($$XYa[0], 100, $$rRadius*1.5);
       @$rThetaa = (-160, 140, 20, getangle($$XYa[3], $$XYa[4]), -80);
       @$rLena = ($$rRadius, $$rRadius, $$rRadius,
               getlength($$XYa[3], $$XYa[4]), $$rRadius*1.5);
       @$r = (-30, -90, 180, -60, 80);
       @$t = (30,  -10,  90,  120,   150);
       @$b = (-90, -90, -150, -90, 30);
   }

   grep(($_->rotate($iAngle) && 0), @$XYa);
   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);   # start atom
   grep((($_ += $iAngle) && 0), @$r, @$t, @$b, @$rThetaa);
}



# Furanosering
# parameter: "furanose", , , startpos, bliste, radius
sub furanose_default_
{
   my ($iAnz, $conf, $iAngle, $iStart, $BT, $bAromat, $rRadius) = @_;
   $$iAnz = 5;
   $$iStart = $$conf = $$iAngle = 0;
   $$rRadius = $rLenN;
   $$bAromat = $false;
   @$BT = (0, 9, 9, 9, 0);
}

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

   $$rRadius_bak = $$rRadius = abs($$rRadius);
   $$XYa[0] = loc->new(0,0);
   $$XYa[1] = getpos($$XYa[0], -30, $$rRadius*2/sqrt(3));
   $$XYa[2] = getpos($$XYa[1], -120, $$rRadius);
   $$XYa[3] = getpos($$XYa[2], 180, $$rRadius);
   $$XYa[4] = getpos($$XYa[3], 120, $$rRadius);
   @$rThetaa = (-30, -120, 180, 120,30);
   @$rLena = ($$rRadius*2/sqrt(3), $$rRadius, $$rRadius, $$rRadius, $$rRadius*2/sqrt(3));
   @$r = (90, 30, -60, -120, 150);
   @$t = (150, 60,  0, -60, -150);
   @$b = (30,  -30, -120, 180, 120);

   grep(($_->rotate($iAngle) && 0), @$XYa);
   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);   # start atom
   grep((($_ += $iAngle) && 0), @$r, @$t, @$b, @$rThetaa);
}