1   
2   
3   
4   
5   
6   
7   
8   
9   
10  
11  
12  
13  
14  
15  
16  
17  package org.apache.commons.statistics.examples.distribution;
18  
19  import java.util.ArrayList;
20  import java.util.List;
21  import org.apache.commons.statistics.distribution.ContinuousDistribution;
22  import org.apache.commons.statistics.distribution.WeibullDistribution;
23  import picocli.CommandLine.ArgGroup;
24  import picocli.CommandLine.Command;
25  import picocli.CommandLine.Option;
26  
27  
28  
29  
30  @Command(name = "weibull",
31           aliases = {"wbl"},
32           description = "Weibull distribution.",
33           subcommands = {
34               WeibullCommand.Check.class,
35               WeibullCommand.PDF.class,
36               WeibullCommand.LPDF.class,
37               WeibullCommand.CDF.class,
38               WeibullCommand.SF.class,
39               WeibullCommand.ICDF.class,
40               WeibullCommand.ISF.class,
41           })
42  class WeibullCommand extends AbstractDistributionCommand {
43  
44      
45      private abstract static class BaseCommand extends AbstractContinuousDistributionCommand {
46          
47          @ArgGroup(validate = false, heading = "Distribution parameters:%n", order = 1)
48          private Params params = new Params();
49  
50          
51          static class Params {
52              
53              @Option(names = {"-k", "--alpha", "--shape"},
54                      arity = "1..*",
55                      split = ",",
56                      description = {"alpha shape (default: ${DEFAULT-VALUE})."})
57              private double[] alpha = {0.5, 1, 1.5, 5};
58  
59              
60              @Option(names = {"-l", "--beta", "--scale"},
61                      arity = "1..*",
62                      split = ",",
63                      description = {"beta scale (default: ${DEFAULT-VALUE})."})
64              private double[] beta = {1};
65          }
66  
67          
68          static final class Options extends ContinuousDistributionOptions {
69              
70              private Options() {
71                  min = 0;
72                  max = 2.5;
73              }
74          }
75  
76          @Override
77          protected List<Distribution<ContinuousDistribution>> getDistributions() {
78              double[] alpha = params.alpha;
79              double[] beta = params.beta;
80              final int n = DistributionUtils.validateLengths(alpha.length, beta.length);
81  
82              alpha = DistributionUtils.expandToLength(alpha, n);
83              beta = DistributionUtils.expandToLength(beta, n);
84  
85              
86              final ArrayList<Distribution<ContinuousDistribution>> list = new ArrayList<>();
87              for (int i = 0; i < n; i++) {
88                  final ContinuousDistribution d = WeibullDistribution.of(alpha[i], beta[i]);
89                  list.add(new Distribution<>(d, "alpha=" + alpha[i] + ",beta=" + beta[i]));
90              }
91              return list;
92          }
93      }
94  
95      
96      private abstract static class ProbabilityCommand extends BaseCommand {
97          
98          @ArgGroup(validate = false, heading = "Evaluation options:%n", order = 2)
99          private Options distributionOptions = new Options();
100 
101         @Override
102         protected DistributionOptions getDistributionOptions() {
103             return distributionOptions;
104         }
105     }
106 
107     
108     private abstract static class InverseProbabilityCommand extends BaseCommand {
109         
110         @ArgGroup(validate = false, heading = "Evaluation options:%n", order = 2)
111         private InverseContinuousDistributionOptions distributionOptions = new InverseContinuousDistributionOptions();
112 
113         @Override
114         protected DistributionOptions getDistributionOptions() {
115             return distributionOptions;
116         }
117     }
118 
119     
120     @Command(name = "check",
121              hidden = true,
122              description = "Weibull distribution verification checks.")
123     static class Check extends ProbabilityCommand {}
124 
125     
126     @Command(name = "pdf",
127              description = "Weibull distribution PDF.")
128     static class PDF extends ProbabilityCommand {}
129 
130     
131     @Command(name = "lpdf",
132              description = "Weibull distribution natural logarithm of the PDF.")
133     static class LPDF extends ProbabilityCommand {}
134 
135     
136     @Command(name = "cdf",
137              description = "Weibull distribution CDF.")
138     static class CDF extends ProbabilityCommand {}
139 
140     
141     @Command(name = "sf",
142              description = "Weibull distribution survival probability.")
143     static class SF extends ProbabilityCommand {}
144 
145     
146     @Command(name = "icdf",
147              description = "Weibull distribution inverse CDF.")
148     static class ICDF extends InverseProbabilityCommand {}
149 
150     
151     @Command(name = "isf",
152              description = "Weibull distribution inverse SF.")
153     static class ISF extends InverseProbabilityCommand {}
154 }