Summary

This document describes the control protocol for NEC projectors (BDT140013 Rev 7.1). The projector supports both serial (RS-232C) and TCP/IP network control interfaces. Commands are sent in hexadecimal format with checksum validation. During power-on or power-off sequences (including cooling time), the projector does not accept other commands.

Transport

protocols:
  - tcp
  - serial
addressing:
  port: 7142  # TCP port for LAN command communication
serial:
  baud_rate: [115200, 38400, 19200, 9600, 4800]  # stated as supported rates
  data_bits: 8
  parity: none
  stop_bits: 1
  flow_control: none
auth:
  type: none  # inferred: no auth procedure in source

Traits

# Add only traits supported by evidence from source:
- powerable       # POWER ON/OFF commands present
- routable        # INPUT SW CHANGE command present
- queryable      # multiple status/information request commands present
- levelable      # VOLUME ADJUST, PICTURE ADJUST, GAIN PARAMETER REQUEST present

Actions

# One entry per command found in source.
- id: error_status_request
  label: Error Status Request
  kind: action
  params: []

- id: power_on
  label: Power On
  kind: action
  params: []

- id: power_off
  label: Power Off
  kind: action
  params: []

- id: input_sw_change
  label: Input SW Change
  kind: action
  params:
    - name: input_terminal
      type: integer
      description: Input terminal value (hex)

- id: picture_mute_on
  label: Picture Mute On
  kind: action
  params: []

- id: picture_mute_off
  label: Picture Mute Off
  kind: action
  params: []

- id: sound_mute_on
  label: Sound Mute On
  kind: action
  params: []

- id: sound_mute_off
  label: Sound Mute Off
  kind: action
  params: []

- id: onscreen_mute_on
  label: Onscreen Mute On
  kind: action
  params: []

- id: onscreen_mute_off
  label: Onscreen Mute Off
  kind: action
  params: []

- id: picture_adjust
  label: Picture Adjust
  kind: action
  params:
    - name: adjustment_target
      type: integer
      description: "00h=Brightness, 01h=Contrast, 02h=Color, 03h=Hue, 04h=Sharpness"
    - name: adjustment_mode
      type: integer
      description: "00h=Absolute value, 01h=Relative value"
    - name: adjustment_value
      type: integer
      description: 16-bit signed value (low-order 8 bits in DATA03, high-order in DATA04)

- id: volume_adjust
  label: Volume Adjust
  kind: action
  params:
    - name: adjustment_mode
      type: integer
      description: "00h=Absolute value, 01h=Relative value"
    - name: adjustment_value
      type: integer
      description: 16-bit signed value

- id: aspect_adjust
  label: Aspect Adjust
  kind: action
  params:
    - name: aspect_value
      type: integer
      description: Aspect ratio value (see Appendix)

- id: other_adjust
  label: Other Adjust
  kind: action
  params:
    - name: adjustment_target
      type: integer
      description: "96h=LAMP ADJUST / LIGHT ADJUST"
    - name: adjustment_mode
      type: integer
      description: "00h=Absolute value, 01h=Relative value"
    - name: adjustment_value
      type: integer
      description: 16-bit signed value

- id: information_request
  label: Information Request
  kind: action
  params: []

- id: filter_usage_information_request
  label: Filter Usage Information Request
  kind: action
  params: []

- id: lamp_information_request_3
  label: Lamp Information Request 3
  kind: action
  params:
    - name: lamp_number
      type: integer
      description: "00h=Lamp 1, 01h=Lamp 2"
    - name: content
      type: integer
      description: "01h=Lamp usage time, 04h=Lamp remaining life"

- id: carbon_savings_information_request
  label: Carbon Savings Information Request
  kind: action
  params:
    - name: savings_type
      type: integer
      description: "00h=Total Carbon Savings, 01h=Carbon Savings during operation"

- id: remote_key_code
  label: Remote Key Code
  kind: action
  params:
    - name: key_code
      type: integer
      description: Key code from remote control key code list

- id: shutter_close
  label: Shutter Close
  kind: action
  params: []

- id: shutter_open
  label: Shutter Open
  kind: action
  params: []

- id: lens_control
  label: Lens Control
  kind: action
  params:
    - name: content
      type: integer
      description: "06h=Periphery Focus"
    - name: direction
      type: integer
      description: "00h=Stop, 01h/02h/03h=Drive plus 1/0.5/0.25s, 7Fh=Drive plus, 81h=Drive minus, FDh/FEh/FFh=Drive minus 0.25/0.5/1s"

- id: lens_control_request
  label: Lens Control Request
  kind: action
  params:
    - name: content
      type: integer
      description: Content type

- id: lens_control_2
  label: Lens Control 2
  kind: action
  params:
    - name: stop
      type: integer
      description: "FFh=Stop"
    - name: adjustment_mode
      type: integer
      description: "00h=Absolute value, 02h=Relative value"
    - name: adjustment_value
      type: integer
      description: 16-bit value

- id: lens_memory_control
  label: Lens Memory Control
  kind: action
  params:
    - name: operation
      type: integer
      description: "00h=MOVE, 01h=STORE, 02h=RESET"

- id: reference_lens_memory_control
  label: Reference Lens Memory Control
  kind: action
  params:
    - name: operation
      type: integer
      description: "00h=MOVE, 01h=STORE, 02h=RESET"

- id: lens_memory_option_request
  label: Lens Memory Option Request
  kind: action
  params:
    - name: target
      type: integer
      description: "00h=LOAD BY SIGNAL, 01h=FORCED MUTE"

- id: lens_memory_option_set
  label: Lens Memory Option Set
  kind: action
  params:
    - name: target
      type: integer
      description: "00h=LOAD BY SIGNAL, 01h=FORCED MUTE"
    - name: setting_value
      type: integer
      description: "00h=OFF, 01h=ON"

- id: lens_information_request
  label: Lens Information Request
  kind: action
  params:
    - name: target
      type: integer
      description: Lens information target

- id: lens_profile_set
  label: Lens Profile Set
  kind: action
  params:
    - name: profile_number
      type: integer
      description: "00h=Profile 1, 01h=Profile 2"

- id: lens_profile_request
  label: Lens Profile Request
  kind: action
  params: []

- id: gain_parameter_request_3
  label: Gain Parameter Request 3
  kind: action
  params:
    - name: adjusted_value_name
      type: integer
      description: "00h=PICTURE/BRIGHTNESS, 01h=CONTRAST, 02h=COLOR, 03h=HUE, 04h=SHARPNESS, 05h=VOLUME, 96h=LAMP ADJUST"

- id: setting_request
  label: Setting Request
  kind: action
  params: []

- id: running_status_request
  label: Running Status Request
  kind: action
  params: []

- id: input_status_request
  label: Input Status Request
  kind: action
  params: []

- id: mute_status_request
  label: Mute Status Request
  kind: action
  params: []

- id: model_name_request
  label: Model Name Request
  kind: action
  params: []

- id: cover_status_request
  label: Cover Status Request
  kind: action
  params: []

- id: freeze_control
  label: Freeze Control
  kind: action
  params:
    - name: freeze_state
      type: integer
      description: "01h=Turn freeze on, 02h=Turn freeze off"

- id: information_string_request
  label: Information String Request
  kind: action
  params:
    - name: information_type
      type: integer
      description: "03h=Horizontal sync frequency, 04h=Vertical sync frequency"

- id: eco_mode_request
  label: Eco Mode Request
  kind: action
  params: []

- id: lan_projector_name_request
  label: LAN Projector Name Request
  kind: action
  params: []

- id: lan_mac_address_status_request2
  label: LAN MAC Address Status Request 2
  kind: action
  params: []

- id: pip_picture_by_picture_request
  label: PIP/Picture By Picture Request
  kind: action
  params:
    - name: content_type
      type: integer
      description: "00h=MODE, 01h=START POSITION, 02h=SUB INPUT, 09h=SUB INPUT 2, 0Ah=SUB INPUT 3"

- id: edge_blending_mode_request
  label: Edge Blending Mode Request
  kind: action
  params: []

- id: eco_mode_set
  label: Eco Mode Set
  kind: action
  params:
    - name: eco_mode_value
      type: integer
      description: Eco mode value (see Appendix)

- id: lan_projector_name_set
  label: LAN Projector Name Set
  kind: action
  params:
    - name: projector_name
      type: string
      description: Projector name (up to 16 bytes, NUL terminated)

- id: pip_picture_by_picture_set
  label: PIP/Picture By Picture Set
  kind: action
  params:
    - name: content_type
      type: integer
      description: "00h=MODE, 01h=START POSITION, 02h=SUB INPUT, 09h=SUB INPUT 2, 0Ah=SUB INPUT 3"
    - name: setting_value
      type: integer
      description: Setting value dependent on content_type

- id: edge_blending_mode_set
  label: Edge Blending Mode Set
  kind: action
  params:
    - name: setting_value
      type: integer
      description: "00h=OFF, 01h=ON"

- id: base_model_type_request
  label: Base Model Type Request
  kind: action
  params: []

- id: serial_number_request
  label: Serial Number Request
  kind: action
  params: []

- id: basic_information_request
  label: Basic Information Request
  kind: action
  params: []

- id: audio_select_set
  label: Audio Select Set
  kind: action
  params:
    - name: input_terminal
      type: integer
      description: Input terminal value
    - name: setting_value
      type: integer
      description: "00h=Terminal in DATA01, 02h=COMPUTER"

# UNRESOLVED: full input terminal value tables referenced in Appendix not included in source

Feedbacks

# Responses defined in source include:
# - Success responses with execution result codes (0000h=success, other=error)
# - Error responses with ERR1/ERR2 codes (see error code list)
# - Data responses returning structured information

- id: error_status_response
  label: Error Status Response
  type: object
  properties:
    - name: error_information
      type: string
      description: Bit-coded error status (DATA01-DATA12)

- id: power_on_response
  label: Power On Response
  type: enum
  values: [success, error]

- id: power_off_response
  label: Power Off Response
  type: enum
  values: [success, error]

- id: information_response
  label: Information Response
  type: object
  properties:
    - name: projector_name
      type: string
    - name: lamp_usage_time
      type: integer
    - name: filter_usage_time
      type: integer

- id: running_status_response
  label: Running Status Response
  type: object
  properties:
    - name: power_status
      type: enum
      values: [standby, power_on, cooling]
    - name: cooling_process
      type: enum
      values: [not_executed, during_execution]
    - name: operation_status
      type: enum
      values: [standby_sleep, power_on, cooling, standby_power_saving, network_standby, standby_error]

- id: input_status_response
  label: Input Status Response
  type: object
  properties:
    - name: signal_list_number
      type: integer
    - name: selection_signal_type
      type: enum
      values: [computer, video, s_video, component, reserved, viewer_1_5, dvi_d, hdmi, displayport, viewer_6_10]

- id: mute_status_response
  label: Mute Status Response
  type: object
  properties:
    - name: picture_mute
      type: enum
      values: [off, on]
    - name: sound_mute
      type: enum
      values: [off, on]
    - name: onscreen_mute
      type: enum
      values: [off, on]
    - name: forced_onscreen_mute
      type: enum
      values: [off, on]

# UNRESOLVED: complete feedback definitions for all query commands

Variables

# Queryable state parameters:
- id: eco_mode
  label: Eco Mode
  type: integer
  values: []  # UNRESOLVED: values defined in Appendix not in source

- id: projector_name
  label: Projector Name
  type: string

- id: lamp_usage_time
  label: Lamp Usage Time
  type: integer
  unit: seconds

- id: lamp_remaining_life
  label: Lamp Remaining Life
  type: integer
  unit: percent

- id: filter_usage_time
  label: Filter Usage Time
  type: integer
  unit: seconds

- id: brightness
  label: Brightness
  type: integer
  range: [0, 255]

- id: contrast
  label: Contrast
  type: integer
  range: [0, 255]

- id: volume
  label: Volume
  type: integer
  range: [0, 255]

- id: pip_mode
  label: PIP/Picture By Picture Mode
  type: enum
  values: [off, pip, picture_by_picture]

- id: edge_blending_mode
  label: Edge Blending Mode
  type: enum
  values: [off, on]

Events

# UNRESOLVED: unsolicited notification events not explicitly documented in source.
# The protocol is query-based; no explicit event subscription mechanism described.

Macros

# UNRESOLVED: no explicit multi-step macros described in source.

Safety

confirmation_required_for: []
interlocks:
  - "While POWER ON command is executing (during power-on sequence), no other command can be accepted."
  - "While POWER OFF command is executing (including cooling time), no other command can be accepted."
# UNRESOLVED: no explicit safety warnings for lamp replacement, cover opening, or dust-related procedures in source

Notes

The projector uses a binary hexadecimal command format with checksum validation. Command structure: [header] [model] [ID1] [ID2] [data length] [data...] [checksum]. The checksum is the low-order byte of the sum of all preceding bytes. Responses use similar structure with acknowledge header (A2h for actions, A0h/A1h/A3h for queries).

Baud rate is configurable (115200/38400/19200/9600/4800 bps) but defaults are not stated. TCP port 7142 is used for LAN communication. No authentication is required for command access.

Provenance

source_domains:
  - sharpdisplays.eu
source_urls:
  - https://www.sharpdisplays.eu/p/download/cp/Products/Projectors/Shared/CommandLists/NEC-ExternalControlManual-english.pdf
retrieved_at: 2026-04-29T13:52:05.060Z
last_checked_at: 2026-06-02T22:10:41.004Z

Verification Summary

verdict: verified
checked_at: 2026-06-02T22:10:41.004Z
matched_actions: 53
action_count: 53
confidence: medium
summary: "All 53 spec actions traced to source (dip-safe re-verify). (11 unresolved item(s) noted in Known Gaps.)"

Known Gaps

- "lamp model numbers not stated in source"
- "full input terminal value tables referenced in Appendix not included in source"
- "complete feedback definitions for all query commands"
- "values defined in Appendix not in source"
- "unsolicited notification events not explicitly documented in source."
- "no explicit multi-step macros described in source."
- "no explicit safety warnings for lamp replacement, cover opening, or dust-related procedures in source"
- "full input terminal value tables not included (referenced in Appendix)"
- "eco mode and aspect ratio value tables not included (referenced in Appendix)"
- "firmware compatibility range not stated in source"
- "port number for serial CONTROL on projector side not explicitly stated (D-SUB 9P described)"

From the AI4AV catalog (https://ai4av.net) · ODbL-1.0