xdco

Capsim Block Documentation

Short Description

This star produces samples of the outputs every 1/fs seconds. The dco behaves just like an FM modulator. The phase is updated as theta=theta+lambda (integrates the input) *

Top
Input Connections
Port Type Name
0 float lambda
Top
Output Connections
Port Type Name
0 float cout
1 float sout
Top
Parameters
Num Description Type Name Default Value
0 Sampling Rate float fs 1.
1 Center Frequency float fo 1.
2 Amplitude float A 1.
Top
States
Num Type Name Initial Value Description
0 float t 0.
1 float theta 0.
Top

Declarations


 




Top

Initialization Code



 





Top

Main Code



 


	if(AVAIL(0)>0)
	{
		IT_IN(0);
		if(IT_OUT(0)) {
			KrnOverflow("xdco",0);
			return(99);
		}
		if(IT_OUT(1)) {
			KrnOverflow("xdco",1);
			return(99);
		}
		theta=theta+lambda(0);
		cout(0)=A*(float)cos((double)(2.*PI*fo*t+theta));
		sout(0)=A*(float)sin((double)(2.*PI*fo*t+theta));
		t=t+1/fs;
	}




Top

Wrapup Code



 





Top

License



/*  Capsim (r) Text Mode Kernel (TMK) Star Library (Blocks)
    Copyright (C) 1989-2017  Silicon DSP Corporation

    This library is free software; you can redistribute it and/or
    modify it under the terms of the GNU Lesser General Public
    License as published by the Free Software Foundation; either
    version 2.1 of the License, or (at your option) any later version.

    This library 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.  See the GNU
    Lesser General Public License for more details.

    You should have received a copy of the GNU Lesser General Public
    License along with this library; if not, write to the Free Software
    Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA

    http://www.silicondsp.com
    Silicon DSP  Corporation
    Las Vegas, Nevada
*/


Top

Description



 

/************************************************************************
 *                                                                      *
 *	xdco.s	:	digitally controlled oscillator 		*
 *									*
 *	parameters:	fs, sampling frequency				*
 *			fo, center frequency				*
 *			A, amplitude					*
 *									*
 *	inputs:		lambda, phase update term			*
 *									*
 *	outputs:	A*cos(2*PI*fo*t+theta)				*
 *			A*sin(2*PI*fo*t+theta)				*
 *									*
 *	description:	This star produces samples of the outputs	*
 *			every 1/fs seconds.  The dco behaves just	*
 *			like an FM modulator.  The phase is updated	*
 *			as theta=theta+lambda (integrates the input)	*
 *									*
 *									*
 *			written by John T. Stonick			*
 *									*

xdco


digitally controlled oscillator 		*
 *									*
 *	parameters:	fs, sampling frequency				*
 *			fo, center frequency				*
 *			A, amplitude					*
 *									*
 *	inputs:		lambda, phase update term			*
 *									*
 *	outputs:	A*cos(2*PI*fo*t+theta)				*
 *			A*sin(2*PI*fo*t+theta)				*
 *									*
 *	description:	This star produces samples of the outputs	*
 *			every 1/fs seconds.  The dco behaves just	*
 *			like an FM modulator.  The phase is updated	*
 *			as theta=theta+lambda (integrates the input)	*


written by John T. Stonick

 ************************************************************************/