• Skip to main content
  • Skip to header right navigation
  • Skip to site footer
CDP Studio logo

CDP Studio

The no-code and full-code software development tool for distributed control systems and HMI

  • Doc
  • Why CDP
    • Software developers
    • Automation engineers
    • Managers
  • Products
    • Automation Designer
    • HMI Designer
    • Maritime HMIs
  • Services
  • Use cases
  • Pricing
  • Try CDP

CDP Studio Documentation

  • Framework - Automation
  • WatchdogTimer
  • 5.0.0

WatchdogTimer Class

(Automation::WatchdogTimer)

The WatchdogTimer More...

Header: #include <WatchdogTimer>
Inherits: CDPOperator<T>
  • List of all members, including inherited members

Public Functions

WatchdogTimer(const CDPPropertyBase &in)

Reimplemented Public Functions

virtual void Configure(XMLPrimitive *operatorXML) override
virtual unsigned int Process() override
  • 18 public functions inherited from CDPOperator
  • 17 public functions inherited from CDPOperatorBase
  • 49 public functions inherited from CDPBaseObject
  • 27 public functions inherited from CDP::StudioAPI::CDPNode
  • 22 public functions inherited from CDP::StudioAPI::ICDPNode

Additional Inherited Members

  • 1 public variable inherited from CDPOperatorBase
  • 1 static public member inherited from CDPBaseObject
  • 1 protected function inherited from CDP::StudioAPI::CDPNode
  • 8 protected variables inherited from CDPOperator
  • 5 protected variables inherited from CDPOperatorBase
  • 10 protected variables inherited from CDPBaseObject

Detailed Description

The WatchdogTimer

WatchdogTimer is an operator to detect Reset input inactivity. When Reset is inactive for more than set by Delay input, Timeout output will go high until Reset becomes active again. On application startup, WatchdogTimer remains in a timed out state until it receives the first Reset value change at its input.

Arguments

NameDescription
ResetChange on Reset value restarts internal delay timer to postpone Timeout going high.
DelayDelay sets the amount of time in seconds allowed between Reset input changes.
TimeoutTimeout becomes high after Reset is inactive for at least the time set by Delay.

Example

Below is an example plot with Reset input becoming inactive and Timeout going high in response to the inactivity.

Actual Processing Code of the WatchdogTimer

unsigned int WatchdogTimer<T>::Process()
{
  m_output = Timer.TimedOut();
  if (LastResetValue != m_input)
  {
    Timer.Reset(static_cast<double>(*Delay));
    Timer.Start();
    LastResetValue = static_cast<double>(m_input);
  }
  return STATUS_OK;
}

See also Argument.

Member Function Documentation

WatchdogTimer::WatchdogTimer(const CDPPropertyBase &in)

Default constructs an instance of WatchdogTimer.

[override virtual] void WatchdogTimer::Configure(XMLPrimitive *operatorXML)

[override virtual] unsigned int WatchdogTimer::Process()

The content of this document is confidential information not to be published without the consent of CDP Technologies AS.

CDP Technologies AS, www.cdpstudio.com

Get started with CDP Studio today

Let us help you take your great ideas and turn them into the products your customer will love.

Try CDP Studio for free
Why CDP Studio?

CDP Technologies AS
Hundsværgata 8,
P.O. Box 144
6001 Ålesund, Norway

Tel: +47 990 80 900
E-mail: info@cdptech.com

Company

About CDP

Contact us

Services

Partners

Blog

Developers

Get started

User manuals

Support

Document download

Release notes

My account

Follow CDP

  • LinkedIn
  • YouTube
  • GitHub

© Copyright 2025 CDP Technologies. Privacy and cookie policy.

Return to top