LINE Solver
MATLAB API documentation
Loading...
Searching...
No Matches
Source.m
1classdef Source < Station
2 % Source External job arrival node for open queueing networks
3 %
4 % Source represents an external arrival node that generates jobs for open
5 % classes according to specified arrival processes. It serves as the entry
6 % point for jobs entering the network from the external environment, with
7 % configurable arrival rates and distributions for each job class.
8 %
9 % @brief External arrival node generating jobs for open queueing networks
10 %
11 % Key characteristics:
12 % - External job generation for open classes
13 % - Class-dependent arrival processes
14 % - Infinite capacity job source
15 % - Configurable inter-arrival time distributions
16 % - Integration with network routing
17 %
18 % Source node features:
19 % - Multiple job class support
20 % - Flexible arrival process specification
21 % - Poisson, MAP, and general arrival processes
22 % - Arrival rate configuration per class
23 % - Disabled arrival capability for specific classes
24 %
25 % Source is used for:
26 % - Web server client arrivals
27 % - Manufacturing job arrivals
28 % - Call center customer generation
29 % - Network packet injection
30 % - Open system workload modeling
31 %
32 % Example:
33 % @code
34 % model = Network('WebServer');
35 % source = Source(model, 'ClientArrivals');
36 % webClass = OpenClass(model, 'WebRequests', 1);
37 % source.setArrival(webClass, Exp(2.0)); % Poisson arrivals, rate 2
38 % @endcode
39 %
40 % Copyright (c) 2012-2026, Imperial College London
41 % All rights reserved.
42
43 properties
44 schedStrategy;
45 arrivalProcess;
46 end
47
48 methods
49 %Constructor
50 function self = Source(model, name)
51 % SOURCE Create an external arrival source node
52 %
53 % @brief Creates a Source node for external job generation
54 % @param model Network model to add the source node to
55 % @param name String identifier for the source node
56 % @return self Source instance ready for arrival process configuration
57 self@Station(name);
58 if model.isMatlabNative()
59 self.numberOfServers = 1;
60 if(model ~= 0)
61 classes = model.getClasses();
62 self.classCap = Inf*ones(1,length(classes));
63 self.output = Dispatcher(classes);
64 self.server = ServiceTunnel();
65 self.input = RandomSource(classes);
66 self.schedStrategy = SchedStrategy.EXT;
67 self.setModel(model);
68 model.addNode(self);
69 end
70 elseif model.isJavaNative()
71 self.setModel(model);
72 self.obj=jline.lang.nodes.Source(model.obj, name);
73 end
74 end
75
76 function setArrival(self, class, distribution)
77 % SETARRIVAL(CLASS, DISTRIBUTION)
78 if isempty(self.obj)
79 self.input.sourceClasses{1, class.index}{2} = ServiceStrategy.LI;
80 self.input.sourceClasses{1, class.index}{3} = distribution;
81 self.arrivalProcess{1,class.index} = distribution;
82 if distribution.isDisabled()
83 self.classCap(class.index) = 0;
84 else
85 self.classCap(class.index) = Inf;
86 end
87 else
88 self.obj.setArrival(class.obj, distribution.obj);
89 end
90 end
91
92 function distrib = getArrivalProcess(self, oclass)
93 distrib = self.arrivalProcess{oclass};
94 end
95
96 end
97
98end