File: Restraint.pm

package info (click to toggle)
libdemeter-perl 0.9.27%2Bds6-9
  • links: PTS, VCS
  • area: contrib
  • in suites: forky, sid, trixie
  • size: 74,028 kB
  • sloc: perl: 73,233; python: 2,196; makefile: 1,999; ansic: 1,368; lisp: 454; sh: 74
file content (126 lines) | stat: -rw-r--r-- 3,765 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
package  Demeter::UI::Artemis::GDS::Restraint;

=for Copyright
 .
 Copyright (c) 2006-2019 Bruce Ravel (http://bruceravel.github.io/home).
 All rights reserved.
 .
 This file is free software; you can redistribute it and/or
 modify it under the same terms as Perl itself. See The Perl
 Artistic License.
 .
 This program is distributed in the hope that it will be useful,
 but WITHOUT ANY WARRANTY; without even the implied warranty of
 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.

=cut

use strict;
use warnings;

use Wx qw( :everything );
use base qw(Wx::Dialog);
use Wx::Event qw(EVT_LISTBOX EVT_BUTTON EVT_RADIOBOX);

use Demeter::Constants qw($NUMBER);

sub new {
  my ($class, $parent, $name) = @_;

  my $this = $class->SUPER::new($parent, -1, "Artemis: Build a restraint",
				wxDefaultPosition, wxDefaultSize,
				wxMINIMIZE_BOX|wxCAPTION|wxSYSTEM_MENU|wxSTAY_ON_TOP
			       );
  my $vbox  = Wx::BoxSizer->new( wxVERTICAL );
  $vbox -> Add(Wx::StaticText->new($this, -1, "Create a restraint for the parameter $name"), 0, wxALL, 5);

  my $hbox = Wx::BoxSizer->new( wxHORIZONTAL );
  $vbox -> Add($hbox, 1, wxGROW|wxALL, 5);
  $hbox -> Add(Wx::StaticText->new($this, -1, "Scale by"), 0, wxALL, 5);
  $this->{scale} = Wx::TextCtrl->new($this, -1, 1000);
  $hbox->Add($this->{scale}, 1, wxGROW|wxALL, 2);

  $hbox = Wx::BoxSizer->new( wxHORIZONTAL );
  $vbox -> Add($hbox, 1, wxGROW|wxALL, 5);
  $hbox -> Add(Wx::StaticText->new($this, -1, "Lower bound"), 0, wxALL, 5);
  $this->{low} = Wx::TextCtrl->new($this, -1, 0);
  $hbox->Add($this->{low}, 1, wxGROW|wxALL, 2);

  $hbox = Wx::BoxSizer->new( wxHORIZONTAL );
  $vbox -> Add($hbox, 1, wxGROW|wxALL, 5);
  $hbox -> Add(Wx::StaticText->new($this, -1, "Upper bound"), 0, wxALL, 5);
  $this->{high} = Wx::TextCtrl->new($this, -1, 4);
  $hbox->Add($this->{high}, 1, wxGROW|wxALL, 2);


  $this->{ok} = Wx::Button->new($this, wxID_OK, "Make restraint", wxDefaultPosition, wxDefaultSize, 0, );
  $vbox -> Add($this->{ok}, 0, wxGROW|wxALL, 5);

  $this->{cancel} = Wx::Button->new($this, wxID_CANCEL, "Cancel", wxDefaultPosition, wxDefaultSize);
  $vbox -> Add($this->{cancel}, 0, wxGROW|wxALL, 5);


  my $gds = $parent->{grid}->{$name};
  if (ref($gds) =~ m{GDS}) {
    my $bestfit = $gds->bestfit || $gds->mathexp;
    ($bestfit = 1) if ($bestfit !~ m{\A$NUMBER\z});
    my ($lo, $hi) = sort {$a <=> $b} ($bestfit/2, $bestfit*2);
    $lo = (abs($lo) < 0.01) ? sprintf("%.6f", $lo) : sprintf("%.3f", $lo);
    $hi = (abs($hi) < 0.01) ? sprintf("%.6f", $hi) : sprintf("%.3f", $hi);
    $this->{low} ->SetValue($lo);
    $this->{high}->SetValue($hi);
  };


  $this -> SetSizerAndFit( $vbox );
  return $this;
};

sub ShouldPreventAppExit {
  0
};

1;

=head1 NAME

Demeter::UI::Artemis::GDS::Restraint - a restraint creation dialog

=head1 VERSION

This documentation refers to Demeter version 0.9.26.

=head1 SYNOPSIS

This module provides a dialog for creating a restraint based on an
existing GDS parameter in Artemis

=head1 DEPENDENCIES

Demeter's dependencies are in the F<Build.PL> file.

=head1 BUGS AND LIMITATIONS

Please report problems to the Ifeffit Mailing List
(L<http://cars9.uchicago.edu/mailman/listinfo/ifeffit/>)

Patches are welcome.

=head1 AUTHOR

Bruce Ravel (L<http://bruceravel.github.io/home>)

L<http://bruceravel.github.io/demeter/>

=head1 LICENCE AND COPYRIGHT

Copyright (c) 2006-2019 Bruce Ravel (L<http://bruceravel.github.io/home>). All rights reserved.

This module is free software; you can redistribute it and/or
modify it under the same terms as Perl itself. See L<perlgpl>.

This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.

=cut