<?xml version="1.0" encoding="utf-8" standalone="yes"?>

<?xml-stylesheet href="./_c74_ref.xsl" type="text/xsl"?>

<!--This is an automatically generated file. DO NOT EDIT THIS FILE DIRECTLY. Rather, use the _ref.xml files found in the 'edits' folder.-->
<c74object name="mc.generate~" module="" category="">
	<digest>
		Generate Values for a Range of Channels
	</digest>
	<description>
		The <o>mc.generate~</o> object allows signal-rate updating of MC Wrapper features such as <m>deviate</m>, <m>spread</m>, and <m>harmonic</m> as a trigger signal or parameter inputs change. One wrapper message is assigned as an operator.
	</description>
	<!--METADATA-->
	<metadatalist>
		<metadata name="author">
			Cycling '74
		</metadata>
		<metadata name="tag">
			MSP
		</metadata>
		<metadata name="tag">
			MC
		</metadata>
	</metadatalist>
	<!--INLETS-->
	<inletlist>
		<inlet id="0" type="multi-channel signal">
			<digest>
				Trigger Input
			</digest>
			<description>
				A connected input signal triggers a new calculation of the current operator when the value goes from zero to non-zero.
			</description>
		</inlet>
		<inlet id="1" type="multi-channel signal, float">
			<digest>
				Parameter 1 Value
			</digest>
			<description>
				A signal or float supplies the first parameter of the current operator.
			</description>
		</inlet>
		<inlet id="2" type="multi-channel signal, float">
			<digest>
				Parameter 2 Value
			</digest>
			<description>
				A signal or float supplies the second parameter of the current operator.
			</description>
		</inlet>
		<inlet id="3" type="multi-channel signal, float">
			<digest>
				Parameter 3 Value
			</digest>
			<description>
				A signal or float supplies the third (optional) parameter of the current operator.
			</description>
		</inlet>
	</inletlist>
	<!--OUTLETS-->
	<outletlist>
		<outlet id="0" type="multi-channel signal">
			<digest>
				Output
			</digest>
			<description>
				The signals containing the values of the current operator's calculation.
			</description>
		</outlet>
	</outletlist>
	<!--ARGUMENTS-->
	<objarglist>
		<objarg id="0" name="initial-parameter-1" type="float" optional="1">
			<digest>
				Initial value for parameter 1
			</digest>
		</objarg>
		<objarg id="0" name="initial-parameter-2" type="float" optional="1">
			<digest>
				Initial value for parameter 2
			</digest>
		</objarg>
		<objarg id="0" name="initial-parameter-3" type="float" optional="1">
			<digest>
				Initial value for parameter 3
			</digest>
		</objarg>
	</objarglist>
	<!--MESSAGES-->
	<methodlist>
		<method name="int">
			<arglist>
				<arg name="ARG_NAME_0" type="int" optional="0" />
			</arglist>
			<digest>
				Set parameter values
			</digest>
			<description>
				Converted to float
			</description>
		</method>
		<method name="float">
			<arglist>
				<arg name="ARG_NAME_0" type="float" optional="0" />
			</arglist>
			<digest>
				Set parameter values
			</digest>
			<description>
				A number in the second inlet sets value of the first parameter. A number in the third inlet sets the value of the second parameter. A number in the right inlet sets the third parameter.
			</description>
		</method>
		<method name="signal">
			<arglist />
			<digest>
				Inputs
			</digest>
			<description>
				A signal in the left inlet triggers a calculation of the current operator. Signals in the other three inlets set parameter values.
			</description>
		</method>
	</methodlist>
	<!--ATTRIBUTES-->
	<attributelist>
		<attribute name="chans" get="1" set="1" type="int" size="1">
			<digest>
				Output Channels
			</digest>
			<description>
				The <at>chans</at> attribute sets the number of channels in the output multi-channel signal. If the <at>chans</at> attribute is changed while the audio is on, the number of channels will change when the audio is restarted.
			</description>
			<attributelist>
				<attribute name="label" get="1" set="1" type="symbol" size="1" value="Output Channels" />
			</attributelist>
		</attribute>
		<attribute name="op" get="1" set="1" type="symbol" size="1">
			<digest>
				Generator Operator
			</digest>
			<description>
				Use <at>op</at> to select the operator used to generate values. Possible values are <m>deviate</m>, <m>increment</m>, <m>spread</m>, <m>spreadinclusive</m>, <m>spreadexclusive</m>, <m>spreadincludesecond</m>, <m>spreadincludefirst</m>, <m>harmonic</m>, <m>subharmonic</m>, <m>exponential</m>, <m>scaledexponential</m>, and <m>decide</m>. For information on these operators, see the <link module="core" name="mc_messages_to_wrapper" type="vignette">MC Wrapper Messages</link> guide.
			</description>
			<attributelist>
				<attribute name="enumvals" get="1" set="1" type="symbol" size="44">
					<enumlist>
						<enum name="decide">
							<digest>
								TEXT_HERE
							</digest>
							<description>
								TEXT_HERE
							</description>
						</enum>
						<enum name="deviate">
							<digest>
								TEXT_HERE
							</digest>
							<description>
								TEXT_HERE
							</description>
						</enum>
						<enum name="ease.in_back">
							<digest>
								TEXT_HERE
							</digest>
							<description>
								TEXT_HERE
							</description>
						</enum>
						<enum name="ease.in_bounce">
							<digest>
								TEXT_HERE
							</digest>
							<description>
								TEXT_HERE
							</description>
						</enum>
						<enum name="ease.in_circular">
							<digest>
								TEXT_HERE
							</digest>
							<description>
								TEXT_HERE
							</description>
						</enum>
						<enum name="ease.in_cubic">
							<digest>
								TEXT_HERE
							</digest>
							<description>
								TEXT_HERE
							</description>
						</enum>
						<enum name="ease.in_elastic">
							<digest>
								TEXT_HERE
							</digest>
							<description>
								TEXT_HERE
							</description>
						</enum>
						<enum name="ease.in_exponential">
							<digest>
								TEXT_HERE
							</digest>
							<description>
								TEXT_HERE
							</description>
						</enum>
						<enum name="ease.in_out_back">
							<digest>
								TEXT_HERE
							</digest>
							<description>
								TEXT_HERE
							</description>
						</enum>
						<enum name="ease.in_out_bounce">
							<digest>
								TEXT_HERE
							</digest>
							<description>
								TEXT_HERE
							</description>
						</enum>
						<enum name="ease.in_out_circular">
							<digest>
								TEXT_HERE
							</digest>
							<description>
								TEXT_HERE
							</description>
						</enum>
						<enum name="ease.in_out_cubic">
							<digest>
								TEXT_HERE
							</digest>
							<description>
								TEXT_HERE
							</description>
						</enum>
						<enum name="ease.in_out_elastic">
							<digest>
								TEXT_HERE
							</digest>
							<description>
								TEXT_HERE
							</description>
						</enum>
						<enum name="ease.in_out_exponential">
							<digest>
								TEXT_HERE
							</digest>
							<description>
								TEXT_HERE
							</description>
						</enum>
						<enum name="ease.in_out_quadratic">
							<digest>
								TEXT_HERE
							</digest>
							<description>
								TEXT_HERE
							</description>
						</enum>
						<enum name="ease.in_out_quartic">
							<digest>
								TEXT_HERE
							</digest>
							<description>
								TEXT_HERE
							</description>
						</enum>
						<enum name="ease.in_out_quintic">
							<digest>
								TEXT_HERE
							</digest>
							<description>
								TEXT_HERE
							</description>
						</enum>
						<enum name="ease.in_out_sine">
							<digest>
								TEXT_HERE
							</digest>
							<description>
								TEXT_HERE
							</description>
						</enum>
						<enum name="ease.in_quadratic">
							<digest>
								TEXT_HERE
							</digest>
							<description>
								TEXT_HERE
							</description>
						</enum>
						<enum name="ease.in_quartic">
							<digest>
								TEXT_HERE
							</digest>
							<description>
								TEXT_HERE
							</description>
						</enum>
						<enum name="ease.in_quintic">
							<digest>
								TEXT_HERE
							</digest>
							<description>
								TEXT_HERE
							</description>
						</enum>
						<enum name="ease.in_sine">
							<digest>
								TEXT_HERE
							</digest>
							<description>
								TEXT_HERE
							</description>
						</enum>
						<enum name="ease.linear">
							<digest>
								TEXT_HERE
							</digest>
							<description>
								TEXT_HERE
							</description>
						</enum>
						<enum name="ease.out_back">
							<digest>
								TEXT_HERE
							</digest>
							<description>
								TEXT_HERE
							</description>
						</enum>
						<enum name="ease.out_bounce">
							<digest>
								TEXT_HERE
							</digest>
							<description>
								TEXT_HERE
							</description>
						</enum>
						<enum name="ease.out_circular">
							<digest>
								TEXT_HERE
							</digest>
							<description>
								TEXT_HERE
							</description>
						</enum>
						<enum name="ease.out_cubic">
							<digest>
								TEXT_HERE
							</digest>
							<description>
								TEXT_HERE
							</description>
						</enum>
						<enum name="ease.out_elastic">
							<digest>
								TEXT_HERE
							</digest>
							<description>
								TEXT_HERE
							</description>
						</enum>
						<enum name="ease.out_quadratic">
							<digest>
								TEXT_HERE
							</digest>
							<description>
								TEXT_HERE
							</description>
						</enum>
						<enum name="ease.out_quartic">
							<digest>
								TEXT_HERE
							</digest>
							<description>
								TEXT_HERE
							</description>
						</enum>
						<enum name="ease.out_quintic">
							<digest>
								TEXT_HERE
							</digest>
							<description>
								TEXT_HERE
							</description>
						</enum>
						<enum name="ease.out_sine">
							<digest>
								TEXT_HERE
							</digest>
							<description>
								TEXT_HERE
							</description>
						</enum>
						<enum name="exponential">
							<digest>
								TEXT_HERE
							</digest>
							<description>
								TEXT_HERE
							</description>
						</enum>
						<enum name="harmonic">
							<digest>
								TEXT_HERE
							</digest>
							<description>
								TEXT_HERE
							</description>
						</enum>
						<enum name="increment">
							<digest>
								TEXT_HERE
							</digest>
							<description>
								TEXT_HERE
							</description>
						</enum>
						<enum name="randomrange">
							<digest>
								TEXT_HERE
							</digest>
							<description>
								TEXT_HERE
							</description>
						</enum>
						<enum name="scaledexponential">
							<digest>
								TEXT_HERE
							</digest>
							<description>
								TEXT_HERE
							</description>
						</enum>
						<enum name="smoothstep">
							<digest>
								TEXT_HERE
							</digest>
							<description>
								TEXT_HERE
							</description>
						</enum>
						<enum name="spread">
							<digest>
								TEXT_HERE
							</digest>
							<description>
								TEXT_HERE
							</description>
						</enum>
						<enum name="spreadexclusive">
							<digest>
								TEXT_HERE
							</digest>
							<description>
								TEXT_HERE
							</description>
						</enum>
						<enum name="spreadincludefirst">
							<digest>
								TEXT_HERE
							</digest>
							<description>
								TEXT_HERE
							</description>
						</enum>
						<enum name="spreadincludesecond">
							<digest>
								TEXT_HERE
							</digest>
							<description>
								TEXT_HERE
							</description>
						</enum>
						<enum name="spreadinclusive">
							<digest>
								TEXT_HERE
							</digest>
							<description>
								TEXT_HERE
							</description>
						</enum>
						<enum name="subharmonic">
							<digest>
								TEXT_HERE
							</digest>
							<description>
								TEXT_HERE
							</description>
						</enum>
					</enumlist>
				</attribute>
				<attribute name="label" get="1" set="1" type="symbol" size="1" value="Generator Operator" />
				<attribute name="style" get="1" set="1" type="symbol" size="1" value="enum" />
			</attributelist>
		</attribute>
		<attribute name="p1" get="1" set="1" type="float" size="1">
			<digest>
				Parameter 1 Value
			</digest>
			<description>
				Sets the value of the first operator parameter
			</description>
			<attributelist>
				<attribute name="label" get="1" set="1" type="symbol" size="1" value="Parameter 1 Value" />
			</attributelist>
		</attribute>
		<attribute name="p2" get="1" set="1" type="float" size="1">
			<digest>
				Parameter 2 Value
			</digest>
			<description>
				Sets the value of the second operator parameter
			</description>
			<attributelist>
				<attribute name="label" get="1" set="1" type="symbol" size="1" value="Parameter 2 Value" />
			</attributelist>
		</attribute>
		<attribute name="p3" get="1" set="1" type="float" size="1">
			<digest>
				Parameter 3 Value
			</digest>
			<description>
				Sets the value of the third operator parameter
			</description>
			<attributelist>
				<attribute name="label" get="1" set="1" type="symbol" size="1" value="Parameter 3 Value" />
			</attributelist>
		</attribute>
		<attribute name="ramptime" get="1" set="1" type="float" size="1">
			<digest>
				Ramp Time in Milliseconds
			</digest>
			<description>
				If the <at>ramptime</at> attribute is zero, the values of new operator calculations are output immediately and will be discontinuous with previous values. A non-zero <at>ramptime</at> specifies the number of milliseconds for the output signals to ramp to the newly calculated values.	The new values are effectively delayed	by the ramp time.
			</description>
			<attributelist>
				<attribute name="label" get="1" set="1" type="symbol" size="1" value="Ramp Time in Milliseconds" />
			</attributelist>
		</attribute>
	</attributelist>
	<!--EXAMPLE-->
	<examplelist>
		<example caption="" img="" />
	</examplelist>
	<!--SEEALSO-->
	<seealsolist>
		<seealso name="mc_messages_to_wrapper" module="core" type="vignette" />
	</seealsolist>
</c74object>
