logo
Free, unlimited AI code reviews that run on commit
git-lrc git-lrc GitHub Install Now We'd appreciate a star git-lrc - Free, unlimited AI code reviews that run on commit | Product Hunt git-lrc - Free, unlimited AI code reviews that run on commit | Product Hunt

DS2450 - Quad A/D Converter

Addressing

       All 1-wire devices are factory assigned a unique 64-bit address. This address is of the form:

       FamilyCode
              8 bits

       Address
              48 bits

       CRC    8 bits

       Addressing under OWFS is in hexadecimal, of form:

              01.123456789ABC

       where 01 is an example 8-bit family code, and 12345678ABC is an example 48 bit address.

       The dot is optional, and the CRC code can included. If included, it must be correct.

Alarms

       None.

Author

       Paul Alfille (paul.alfille@gmail.com)

OWFS Manpage                                          2003                                             DS2450(3)

Availability

Co2 (Carbon Dioxide) Sensor Properties

       The CO2 sensor is a device constructed from a SenseAir K30 and a DS2450CO2/powerread-only,floatingpoint
       Supply voltage to the CO2 sensor (should be around 5V)

   CO2/ppmread-only,unsigned
       CO2 level in ppm (parts per million). Range 0-5000.

   CO2/statusread-only,yes-no
       Is the internal voltage correct (around 3.2V)?

Datasheet

       DS2450 http://pdfserv.maxim-ic.com/en/ds/DS2450.pdf

       CO2 sensor
              http://www.senseair.se/Datablad/k30%20.pdf

       CO2 device
              https://www.m.nu/co2meter-version-2-p-259.html?language=en

Description

1-Wire1-wire is a wiring protocol and series of devices designed and manufactured by Dallas Semiconductor, Inc.
       The bus is a low-power low-speed low-connector scheme where the data line can also provide power.

       Each device is uniquely and unalterably numbered during manufacture. There are a wide variety of devices,
       including memory, sensors (humidity, temperature, voltage, contact, current), switches, timers  and  data
       loggers.  More  complex  devices (like thermocouple sensors) can be built with these basic devices. There
       are also 1-wire devices that have encryption included.

       The 1-wire scheme uses a single busmaster and multiple slaves on the same wire. The bus master initiates
       all communication. The slaves can be individually discovered and addressed using their unique ID.

       Bus masters come in a variety of configurations including serial, parallel, i2c, network or USB adapters.

   OWFSdesignOWFS is a suite of programs that designed to make the 1-wire bus and its devices easily  accessible.  The
       underlying  principle  is to create a virtual filesystem, with the unique ID being the directory, and the
       individual properties of the device are represented as simple files that can be read and written.

       Details of the individual slave or master design are hidden behind a consistent interface. The goal is to
       provide an easy set of tools for a software designer to create monitoring or control applications.  There
       are  some  performance enhancements in the implementation, including data caching, parallel access to bus
       masters, and aggregation of device communication. Still the  fundamental  goal  has  been  ease  of  use,
       flexibility and correctness rather than speed.

   DS2450
       The  DS2450(3)  is  a  (supposedly)  high resolution A/D converter with 4 channels. Actual resolutin is
       reporterd to be 8 bits. The channels can also function as switches. Voltage sensing (with temperature and
       current, but sometimes restricted voltrage ranges) can also be obtained with  the  DS2436  ,  DS2438  and
       DS276x

Family Code

20

Name

DS2450 - Quad A/D Converter

See Also

Programsowfs(1)owhttpd(1)owftpd(1)owserver(1)owdir(1)owread(1)owwrite(1)owpresent(1)owtap(1)Configurationandtestingowfs(5)owtap(1)owmon(1)Languagebindingsowtcl(3)owperl(3)owcapi(3)ClocksDS1427(3)DS1904(3)DS1994(3)DS2404(3)DS2404S(3)DS2415(3)DS2417(3)IDDS2401(3)DS2411(3)DS1990A(3)MemoryDS1982(3)DS1985(3)DS1986(3)DS1991(3)DS1992(3)DS1993(3)DS1995(3)DS1996(3)DS2430A(3)DS2431(3)DS2433(3)DS2502(3)DS2506(3)DS28E04(3)DS28EC20(3)SwitchesDS2405(3)DS2406(3)DS2408(3)DS2409(3)DS2413(3)DS28EA00(3)InfernoEmbedded(3)TemperatureDS1822(3)DS1825(3)DS1820(3)DS18B20(3)DS18S20(3)DS1920(3)DS1921(3)DS1821(3)DS28EA00(3)DS28E04(3)EDS0064(3)EDS0065(3)EDS0066(3)EDS0067(3)EDS0068(3)EDS0071(3)EDS0072(3)MAX31826(3)HumidityDS1922(3)DS2438(3)EDS0065(3)EDS0068(3)VoltageDS2450(3)ResistanceDS2890(3)Multifunction(current,voltage,temperature)DS2436(3)DS2437(3)DS2438(3)DS2751(3)DS2755(3)DS2756(3)DS2760(3)DS2770(3)DS2780(3)DS2781(3)DS2788(3)DS2784(3)CounterDS2423(3)LCDScreenLCD(3)DS2408(3)CryptoDS1977(3)PressureDS2406(3)TAI8570(3)EDS0066(3)EDS0068(3)MoistureEEEF(3)DS2438(3)

Special Properties

alarm/high.A...alarm/high.Dalarm.high.ALLalarm/high.A...alarm/high.Dalarm.high.ALLread-write,binary
       The alarm state of the voltage channel. The alarm state is set one of two ways:

       voltage conversion
              Whenever  the DS2450 measures a voltage on a channel, that voltage is compared to the high and low
              limits set_alarm/volthigh and/or set_alarm/voltlow and if  the  alarm  is  enabled  set_alarm/high
              and/or set_alarm/low the corresponding flag is set in alarm/high and/or alarm/low

       manual set
              The flag can be set by a direct write to alarm/high or alarm/lowmemoryread-write,binary
       32 bytes of data. Much has special implications. See the datasheet.

   pages/page.0...pages/page.3pages/page.ALLread-write,binary
       Memory  is  split into 4 pages of 8 bytes each. Mostly for reading and setting device properties. See the
       datasheet for details.
       ALL is an aggregate of the pages. Each page is accessed sequentially.

   PIO.A...PIO.DPIO.ALLread-write,yes-no
       Pins used for digital control. 1 turns  the  switch  on  (conducting).  0  turns  the  switch  off  (non-
       conducting).
       Control is specifically enabled. Reading volt will turn off this control.
       ALL is an aggregate of the voltages. Readings are made separately.

   powerread-write,yes-no
       Configure  whether  the  DS2450  is externally powered (as opposed to parasitically powered from the data
       line).
       If configured as powered, the A/D coverter will be set to  continuous  sampling,  and  the  bus  will  be
       released during a single conversion allowing other devices to communicate.
       Setting  this  to  1  when  no  power is applied to the chip's Vcc will result in wrong voltage readouts.
       Setting this to 0 when power is applied to the chip's Vcc allows a simultaneous conversion trigger on all
       DS2450 on a bus. The (always safe) default is 0.

   set_alarm/high.A...set_alarm/high.Dset_alarm/high.ALLset_alarm/low.A...set_alarm/low.Dset_alarm/low.ALLread-write,yes-no
       Enabled status of the voltage threshold. 1 is on. 0 is off.

   set_alarm/volthigh.A...set_alarm/volthigh.Dset_alarm/volthigh.ALLset_alarm/volt2high.A...set_alarm/volt2high.Dset_alarm/volt2high.ALLset_alarm/voltlow.A...set_alarm/voltlow.Dset_alarm/voltlow.ALLset_alarm/volt2low.A...set_alarm/volt2low.Dset_alarm/volt2low.ALLread-write,floatingpoint
       The upper or lower limit for the voltage measured before triggering an alarm.
       Note that the alarm must be enabled alarm/high or alarm.low and an actual reading must be requested  volt
       for the alarm state to actually be set. The alarm state can be sensed at alarm/high and alarm/lowset_alarm/unsetread-write,yes-no
       Status of the power-on-reset (POR) flag.
       The  POR  is  set  when  the  DS2450 is first powered up, and will match the alarm state until explicitly
       cleared. (By writing 0 to it).
       The purpose of the POR is to alert the user that the chip is not yet fully configured,  especially  alarm
       thresholds and enabling.

   volt.A...volt.Dvolt.ALLvolt2.A...volt2.Dvolt2.ALL8bit/volt.A...8bit/volt.D8bit/volt.ALL8bit/volt2.A...8bit/volt2.D8bit/volt2.ALLread-only,floatingpoint
       Reading  one  of  these  nodes  triggers a conversion on the specified voltage input(s) with the selected
       resolution (16 or 8 bit) and returns the sampled voltage(s) with the selected scaling (0 - 5.10V or  0  -
       2.55V).   The  conversion  time  is  about 1.4ms per input for 16-bit and 0.8ms per input for 8-bit.  The
       output feature ( PIO ) is disabled by reading the corresponding node.
       ALL is an aggregate of the voltages. Sampling is controlled by the chip and done in the order A, B, C, D,
       one after another.

   latestvolt.A...latestvolt.Dlatestvolt.ALLlatestvolt2.A...latestvolt2.Dlatestvolt2.ALL8bit/latestvolt.A...8bit/latestvolt.D8bit/latestvolt.ALL8bit/latestvolt2.A...8bit/latestvolt2.D8bit/latestvolt2.ALLread-only,floatingpoint
       Returns previously measured voltage on the specified input(s) with the selected scaling (0 - 5.10V or 0 -
       2.55V).  Resolution and scaling are set by sampling a voltage, not here;  the  correct  latestvolt  nodes
       have to be read to make the result meaningful.
       ALL is an aggregate of the voltages and returns all voltage values from the chip.
       Reading  these  nodes  will  never  trigger  a  voltage  conversion. Intended for use in conjunction with
       /simultaneous/voltage.

Standard Properties

addressr_addressread-only,ascii
       The entire 64-bit unique ID. Given as upper case hexadecimal digits (0-9A-F).
       address starts with the family code
       raddress is the address in reverse order, which is often used in other applications and labeling.

   crc8read-only,ascii
       The 8-bit error correction portion. Uses cyclic redundancy check. Computed from the preceding 56 bits  of
       the unique ID number. Given as upper case hexadecimal digits (0-9A-F).

   familyread-only,ascii
       The 8-bit family code. Unique to each type of device. Given as upper case hexadecimal digits (0-9A-F).

   idr_idread-only,ascii
       The  48-bit  middle  portion  of  the unique ID number. Does not include the family code or CRC. Given as
       upper case hexadecimal digits (0-9A-F).
       rid is the id in reverse order, which is often used in other applications and labeling.

   locatorr_locatorread-only,ascii
       Uses an extension of  the  1-wire  design  from  iButtonLink  company  that  associated  1-wire  physical
       connections with a unique 1-wire code. If the connection is behind a LinkLocator the locatorwillshowaunique8-bytenumber(16characterhexadecimal)startingwithfamilycodeFE.
       If no LinkLocator is between the device and the master, the locator field will be all FF.
       rlocator is the locator in reverse order.

   present(DEPRECATED)read-only,yes-no
       Is the device currently present on the 1-wire bus?

   typeread-only,ascii
       Part  name  assigned  by  Dallas  Semi.  E.g.  DS2401 Alternative packaging (iButton vs chip) will not be
       distiguished.

Synopsis

Voltage*4andMemory.20  [.]XXXXXXXXXXXX[XX][/[  PIO.[A-D|ALL]  |  volt.[A-D|ALL]  |  volt2.[A-D|ALL] | latestvolt.[A-D|ALL] |
       latestvolt2.[A-D|ALL] ]]

       20  [.]XXXXXXXXXXXX[XX][/[  8bit/volt.[A-D|ALL]  |  8bit/volt2.[A-D|ALL]  |  8bit/latestvolt.[A-D|ALL]  |
       8bit/latestvolt2.[A-D|ALL] ]]

       20 [.]XXXXXXXXXXXX[XX][/[ memory | pages/page.[0-3|ALL] | power ]

       20   [.]XXXXXXXXXXXX[XX][/[  alarm/high.[A-D|ALL]  |  alarm/low.[A-D|ALL]  |  set_alarm/high.[A-D|ALL]  |
       set_alarm/low.[A-D|ALL] | set_alarm/unset | set_alarm/volthigh.[A-D|ALL] |  set_alarm/volt2high.[A-D|ALL]
       | set_alarm/voltlow.[A-D|ALL] | set_alarm/volt2low.[A-D|ALL] ]

       20 [.]XXXXXXXXXXXX[XX][/[ address | crc8 | id | locator | r_address | r_id | r_locator | type ]]

   CO2sensor20 [.]XXXXXXXXXXXX[XX][/[ CO2/ppm | CO2/power | CO2/status ]

See Also