Summary
Sharp/NEC NP-P554U projector. Binary control protocol over RS-232C serial (PC CONTROL D-SUB 9P) and wired/wireless LAN (TCP port 7142). Hex command frames with checksum. Covers power, input switching, mutes, lens/shutter, picture/volume adjust, status queries, and LAN/PIP/eco settings per the Projector Control Command Reference Manual (BDT140013 Rev 7.1).
Transport
protocols:
- tcp
- serial
addressing:
port: 7142
serial:
baud_rate: 115200 # source: 115200/38400/19200/9600/4800 bps configurable
data_bits: 8
parity: none
stop_bits: 1
flow_control: null # UNRESOLVED: flow_control not stated in source
auth:
type: none # inferred: no auth procedure in source
Traits
traits:
- powerable # inferred: POWER ON / POWER OFF commands present
- routable # inferred: INPUT SW CHANGE command present
- queryable # inferred: extensive status query commands present
- levelable # inferred: PICTURE ADJUST / VOLUME ADJUST present
Actions
# All command frames use hex bytes verbatim from source. ID1 = control ID set on
# projector (00h when unspecified), ID2 = model code (varies by model, 00h placeholder),
# CKS = checksum computed as low byte of sum of all preceding bytes.
# Command frame format: <DATA?>_<CKS> where CKS = low-order byte of sum of all preceding bytes.
- id: error_status_request
label: Error Status Request
kind: query
command: "00h 88h 00h 00h 00h 88h"
params: []
- id: power_on
label: Power On
kind: action
command: "02h 00h 00h 00h 00h 02h"
params: []
notes: While turning on power, no other command accepted.
- id: power_off
label: Power Off
kind: action
command: "02h 01h 00h 00h 00h 03h"
params: []
notes: During power-off (incl. cooling time), no other command accepted.
- id: input_sw_change
label: Input Switch Change
kind: action
command: "02h 03h 00h 00h 02h 01h {DATA01} {CKS}"
params:
- name: DATA01
type: string
description: Input terminal value (e.g. 06h = video port). See Appendix in source.
notes: Response DATA01 FFh = ended with error (no signal switch made).
- id: picture_mute_on
label: Picture Mute On
kind: action
command: "02h 10h 00h 00h 00h 12h"
params: []
notes: Turned off by input terminal switch or video signal switch.
- id: picture_mute_off
label: Picture Mute Off
kind: action
command: "02h 11h 00h 00h 00h 13h"
params: []
- id: sound_mute_on
label: Sound Mute On
kind: action
command: "02h 12h 00h 00h 00h 14h"
params: []
notes: Turned off by input terminal switch, video signal switch, or volume adjustment.
- id: sound_mute_off
label: Sound Mute Off
kind: action
command: "02h 13h 00h 00h 00h 15h"
params: []
- id: onscreen_mute_on
label: Onscreen Mute On
kind: action
command: "02h 14h 00h 00h 00h 16h"
params: []
notes: Turned off by input terminal switch or video signal switch.
- id: onscreen_mute_off
label: Onscreen Mute Off
kind: action
command: "02h 15h 00h 00h 00h 17h"
params: []
- id: picture_adjust
label: Picture Adjust
kind: action
command: "03h 10h 00h 00h 05h {DATA01} FFh {DATA02} {DATA03} {DATA04} {CKS}"
params:
- name: DATA01
type: string
description: "Adjustment target: 00h=Brightness, 01h=Contrast, 02h=Color, 03h=Hue, 04h=Sharpness"
- name: DATA02
type: string
description: "Adjustment mode: 00h=absolute, 01h=relative"
- name: DATA03
type: string
description: Adjustment value (low-order 8 bits)
- name: DATA04
type: string
description: Adjustment value (high-order 8 bits)
- id: volume_adjust
label: Volume Adjust
kind: action
command: "03h 10h 00h 00h 05h 05h 00h {DATA01} {DATA02} {DATA03} {CKS}"
params:
- name: DATA01
type: string
description: "Adjustment mode: 00h=absolute, 01h=relative"
- name: DATA02
type: string
description: Adjustment value (low-order 8 bits)
- name: DATA03
type: string
description: Adjustment value (high-order 8 bits)
- id: aspect_adjust
label: Aspect Adjust
kind: action
command: "03h 10h 00h 00h 05h 18h 00h 00h {DATA01} 00h {CKS}"
params:
- name: DATA01
type: string
description: Value set for the aspect (see Appendix in source).
- id: other_adjust
label: Other Adjust (Lamp/Light Adjust)
kind: action
command: "03h 10h 00h 00h 05h {DATA01} {DATA02} {DATA03} {DATA04} {DATA05} {CKS}"
params:
- name: DATA01
type: string
description: "Adjustment target (DATA01=96h, DATA02=FFh for LAMP/LIGHT ADJUST)"
- name: DATA02
type: string
description: Sub-target (FFh for LAMP/LIGHT ADJUST)
- name: DATA03
type: string
description: "Adjustment mode: 00h=absolute, 01h=relative"
- name: DATA04
type: string
description: Adjustment value (low-order 8 bits)
- name: DATA05
type: string
description: Adjustment value (high-order 8 bits)
- id: information_request
label: Information Request
kind: query
command: "03h 8Ah 00h 00h 00h 8Dh"
params: []
notes: Returns projector name, lamp usage time (DATA83-86), filter usage time (DATA87-90).
- id: filter_usage_information_request
label: Filter Usage Information Request
kind: query
command: "03h 95h 00h 00h 00h 98h"
params: []
notes: Returns filter usage time and filter alarm start time (seconds). -1 if undefined.
- id: lamp_information_request_3
label: Lamp Information Request 3
kind: query
command: "03h 96h 00h 00h 02h {DATA01} {DATA02} {CKS}"
params:
- name: DATA01
type: string
description: "00h=Lamp 1, 01h=Lamp 2 (two-lamp models only)"
- name: DATA02
type: string
description: "01h=usage time (sec), 04h=remaining life (%)"
- id: carbon_savings_information_request
label: Carbon Savings Information Request
kind: query
command: "03h 9Ah 00h 00h 01h {DATA01} {CKS}"
params:
- name: DATA01
type: string
description: "00h=Total Carbon Savings, 01h=Carbon Savings during operation"
- id: remote_key_code
label: Remote Key Code
kind: action
command: "02h 0Fh 00h 00h 02h {DATA01} {DATA02} {CKS}"
params:
- name: DATA01
type: string
description: "Key code low byte (WORD type). E.g. 02h=POWER ON, 03h=POWER OFF, 05h=AUTO, 06h=MENU, 07h=UP, 08h=DOWN, 09h=RIGHT, 0Ah=LEFT, 0Bh=ENTER, 0Ch=EXIT, 0Dh=HELP, 0Fh=MAGNIFY UP, 10h=MAGNIFY DOWN, 13h=MUTE, 29h=PICTURE, 4Bh=COMPUTER1, 4Ch=COMPUTER2, 4Fh=VIDEO1, 51h=S-VIDEO1, 84h=VOLUME UP, 85h=VOLUME DOWN, 8Ah=FREEZE, A3h=ASPECT, D7h=SOURCE, EEh=LAMP MODE/ECO"
- name: DATA02
type: string
description: Key code high byte (00h for listed codes).
- id: shutter_close
label: Shutter Close
kind: action
command: "02h 16h 00h 00h 00h 18h"
params: []
- id: shutter_open
label: Shutter Open
kind: action
command: "02h 17h 00h 00h 00h 19h"
params: []
- id: lens_control
label: Lens Control
kind: action
command: "02h 18h 00h 00h 02h {DATA01} {DATA02} {CKS}"
params:
- name: DATA01
type: string
description: Lens target (06h=Periphery Focus per source row; full target list not in excerpt).
- name: DATA02
type: string
description: "Content: 00h=Stop, 01h=drive +1s, 02h=drive +0.5s, 03h=drive +0.25s, 7Fh=drive +, 81h=drive -, FDh=drive -0.25s, FEh=drive -0.5s, FFh=drive -1s"
notes: After 7Fh/81h, send 00h to stop. Same command re-issued during drive controls lens without stop.
- id: lens_control_request
label: Lens Control Request
kind: query
command: "02h 1Ch 00h 00h 02h {DATA01} 00h {CKS}"
params:
- name: DATA01
type: string
description: Lens target (same values as lens_control DATA01).
- id: lens_control_2
label: Lens Control 2
kind: action
command: "02h 1Dh 00h 00h 04h {DATA01} {DATA02} {DATA03} {DATA04} {CKS}"
params:
- name: DATA01
type: string
description: "Target (FFh=Stop, others per source)"
- name: DATA02
type: string
description: "Adjustment mode: 00h=absolute, 02h=relative"
- name: DATA03
type: string
description: Adjustment value (low-order 8 bits)
- name: DATA04
type: string
description: Adjustment value (high-order 8 bits)
notes: If DATA01=FFh (Stop), DATA02-DATA04 not referenced.
- id: lens_memory_control
label: Lens Memory Control
kind: action
command: "02h 1Eh 00h 00h 01h {DATA01} {CKS}"
params:
- name: DATA01
type: string
description: "00h=MOVE, 01h=STORE, 02h=RESET"
- id: reference_lens_memory_control
label: Reference Lens Memory Control
kind: action
command: "02h 1Fh 00h 00h 01h {DATA01} {CKS}"
params:
- name: DATA01
type: string
description: "00h=MOVE, 01h=STORE, 02h=RESET"
notes: Controls profile number set via LENS PROFILE SET.
- id: lens_memory_option_request
label: Lens Memory Option Request
kind: query
command: "02h 20h 00h 00h 01h {DATA01} {CKS}"
params:
- name: DATA01
type: string
description: "00h=LOAD BY SIGNAL, 01h=FORCED MUTE"
- id: lens_memory_option_set
label: Lens Memory Option Set
kind: action
command: "02h 21h 00h 00h 02h {DATA01} {DATA02} {CKS}"
params:
- name: DATA01
type: string
description: "00h=LOAD BY SIGNAL, 01h=FORCED MUTE"
- name: DATA02
type: string
description: "Setting value: 00h=OFF, 01h=ON"
- id: lens_information_request
label: Lens Information Request
kind: query
command: "02h 22h 00h 00h 01h 00h 25h"
params: []
notes: Returns DATA01 bitmask of lens operation status (bit0=lens memory, bit1=zoom, bit2=focus, bit3=lens shift H, bit4=lens shift V; 0=stop, 1=operating).
- id: lens_profile_set
label: Lens Profile Set
kind: action
command: "02h 27h 00h 00h 01h {DATA01} {CKS}"
params:
- name: DATA01
type: string
description: "Profile number: 00h=Profile 1, 01h=Profile 2"
- id: lens_profile_request
label: Lens Profile Request
kind: query
command: "02h 28h 00h 00h 00h 2Ah"
params: []
- id: gain_parameter_request_3
label: Gain Parameter Request 3
kind: query
command: "03h 05h 00h 00h 03h {DATA01} 00h 00h {CKS}"
params:
- name: DATA01
type: string
description: "Adjusted value name: 00h=BRIGHTNESS, 01h=CONTRAST, 02h=COLOR, 03h=HUE, 04h=SHARPNESS, 05h=VOLUME, 96h=LAMP/LIGHT ADJUST"
- id: setting_request
label: Setting Request
kind: query
command: "00h 85h 00h 00h 01h 00h 86h"
params: []
notes: Returns base model type (DATA01-03), sound function (DATA04), profile/clock info (DATA05).
- id: running_status_request
label: Running Status Request
kind: query
command: "00h 85h 00h 00h 01h 01h 87h"
params: []
notes: Returns power status, cooling process, power on/off process, operation status.
- id: input_status_request
label: Input Status Request
kind: query
command: "00h 85h 00h 00h 01h 02h 88h"
params: []
notes: Returns signal switch process, signal list number, selection signal types, content displayed.
- id: mute_status_request
label: Mute Status Request
kind: query
command: "00h 85h 00h 00h 01h 03h 89h"
params: []
notes: Returns picture/sound/onscreen/forced-onscreen mute status and onscreen display status.
- id: model_name_request
label: Model Name Request
kind: query
command: "00h 85h 00h 00h 01h 04h 8Ah"
params: []
- id: cover_status_request
label: Cover Status Request
kind: query
command: "00h 85h 00h 00h 01h 05h 8Bh"
params: []
notes: "Returns 00h=Normal (cover opened), 01h=Cover closed."
- id: freeze_control
label: Freeze Control
kind: action
command: "01h 98h 00h 00h 01h {DATA01} {CKS}"
params:
- name: DATA01
type: string
description: "01h=freeze on, 02h=freeze off"
- id: information_string_request
label: Information String Request
kind: query
command: "00h D0h 00h 00h 03h 00h {DATA01} 01h {CKS}"
params:
- name: DATA01
type: string
description: "Information type: 03h=Horizontal sync frequency, 04h=Vertical sync frequency"
- id: eco_mode_request
label: Eco Mode Request
kind: query
command: "03h B0h 00h 00h 01h 07h BBh"
params: []
notes: Returns eco/light/lamp mode value (see Appendix in source).
- id: lan_projector_name_request
label: LAN Projector Name Request
kind: query
command: "03h B0h 00h 00h 01h 2Ch E0h"
params: []
- id: lan_mac_address_status_request_2
label: LAN MAC Address Status Request 2
kind: query
command: "03h B0h 00h 00h 02h 9Ah 00h 4Fh"
params: []
- id: pip_picture_by_picture_request
label: PIP/Picture by Picture Request
kind: query
command: "03h B0h 00h 00h 02h C5h {DATA01} {CKS}"
params:
- name: DATA01
type: string
description: "00h=MODE, 01h=START POSITION, 02h=SUB INPUT/SUB INPUT 1, 09h=SUB INPUT 2, 0Ah=SUB INPUT 3"
- id: edge_blending_mode_request
label: Edge Blending Mode Request
kind: query
command: "03h B0h 00h 00h 02h DFh 00h 94h"
params: []
- id: eco_mode_set
label: Eco Mode Set
kind: action
command: "03h B1h 00h 00h 02h 07h {DATA01} {CKS}"
params:
- name: DATA01
type: string
description: Value set for eco mode (see Appendix in source).
- id: lan_projector_name_set
label: LAN Projector Name Set
kind: action
command: "03h B1h 00h 00h 12h 2Ch {DATA01} {DATA02} {DATA03} {DATA04} {DATA05} {DATA06} {DATA07} {DATA08} {DATA09} {DATA10} {DATA11} {DATA12} {DATA13} {DATA14} {DATA15} {DATA16} 00h {CKS}"
params:
- name: name
type: string
description: Projector name (up to 16 bytes, NUL-terminated). Encoded across DATA01-DATA16.
- id: pip_picture_by_picture_set
label: PIP/Picture by Picture Set
kind: action
command: "03h B1h 00h 00h 03h C5h {DATA01} {DATA02} {CKS}"
params:
- name: DATA01
type: string
description: "00h=MODE, 01h=START POSITION, 02h=SUB INPUT/SUB INPUT 1, 09h=SUB INPUT 2, 0Ah=SUB INPUT 3"
- name: DATA02
type: string
description: "Setting value (varies by DATA01). For MODE: 00h=PIP, 01h=PbP. For START POSITION: 00h=TOP-LEFT, 01h=TOP-RIGHT, 02h=BOTTOM-LEFT, 03h=BOTTOM-RIGHT."
- id: edge_blending_mode_set
label: Edge Blending Mode Set
kind: action
command: "03h B1h 00h 00h 03h DFh 00h {DATA01} {CKS}"
params:
- name: DATA01
type: string
description: "00h=OFF, 01h=ON"
- id: base_model_type_request
label: Base Model Type Request
kind: query
command: "00h BFh 00h 00h 01h 00h C0h"
params: []
- id: serial_number_request
label: Serial Number Request
kind: query
command: "00h BFh 00h 00h 02h 01h 06h C8h"
params: []
- id: basic_information_request
label: Basic Information Request
kind: query
command: "00h BFh 00h 00h 01h 02h C2h"
params: []
notes: Returns operation status, content displayed, signal types, mute/freeze status.
- id: audio_select_set
label: Audio Select Set
kind: action
command: "03h C9h 00h 00h 03h 09h {DATA01} {DATA02} {CKS}"
params:
- name: DATA01
type: string
description: Input terminal (see Appendix in source).
- name: DATA02
type: string
description: "Setting value: 00h=terminal specified in DATA01, 01h=BNC, 02h=COMPUTER"
Feedbacks
# Query responses. All responses use frame: <resp opcode> <ID1> <ID2> <LEN> <DATA?> <CKS>
# Error responses: A?h <ID1> <ID2> 02h <ERR1> <ERR2> <CKS>
- id: error_status
type: bitmask
description: 12-byte error info (DATA01-12). Bit=0 normal, Bit=1 error. Covers cover/fan/temp/power/lamp errors.
- id: power_state
type: enum
values: [standby, power_on]
description: From running_status_request DATA03 (00h=Standby, 01h=Power on).
- id: operation_status
type: enum
values: [standby_sleep, power_on, cooling, standby_error, standby_power_saving, network_standby]
description: From running_status_request DATA06.
- id: lamp_usage_time
type: integer
unit: seconds
description: From information_request DATA83-86 or lamp_information_request DATA03-06.
- id: filter_usage_time
type: integer
unit: seconds
description: From filter_usage_information_request DATA01-04.
- id: lamp_remaining_life
type: integer
unit: percent
description: From lamp_information_request_3 (DATA02=04h). Negative if replacement deadline exceeded.
- id: mute_status
type: object
description: From mute_status_request - picture/sound/onscreen/forced-onscreen mute (each Off/On).
- id: cover_status
type: enum
values: [normal_opened, closed]
- id: model_name
type: string
- id: serial_number
type: string
- id: mac_address
type: string
- id: projector_name
type: string
- id: eco_mode
type: string
description: Value per Appendix (eco/light/lamp mode).
- id: error_codes
type: object
description: "ERR1/ERR2 pair. 00h/00h=unrecognized, 00h/01h=unsupported by model, 01h/00h=invalid value, 01h/01h=invalid input terminal, 01h/02h=invalid language, 02h/00h=memory alloc error, 02h/02h=memory in use, 02h/03h=value cannot be set, 02h/04h=forced onscreen mute on, 02h/06h=viewer error, 02h/07h=no signal, 02h/08h=test pattern/filter displayed, 02h/09h=no PC card, 02h/0Ah=memory operation error, 02h/0Ch=entry list displayed, 02h/0Dh=power off (cmd rejected), 02h/0Eh=execution failed, 02h/0Fh=no authority, 03h/00h=incorrect gain number, 03h/01h=invalid gain, 03h/02h=adjustment failed."
# UNRESOLVED: full response payload decoding for queries not exhaustively enumerated.
Variables
# Picture adjust values (brightness/contrast/color/hue/sharpness) and volume are
# settable via dedicated action commands (picture_adjust, volume_adjust) and
# readable via gain_parameter_request_3. Treat as action-driven, not free variables.
# UNRESOLVED: no separate variable model defined; settable state is action-driven per source.
Events
# No unsolicited notifications documented in source. All responses are solicited
# (returned after a command is sent).
# UNRESOLVED: no async/event mechanism described in source.
Macros
# No multi-step sequences explicitly described in source.
# UNRESOLVED: none documented.
Safety
confirmation_required_for: []
interlocks: []
# Source notes power-state interlocks (no command accepted during power-on/off
# transition or cooling), but no explicit safety warnings, interlock procedures,
# or power-on sequencing requirements beyond command rejection (ERR 02h/0Dh).
# UNRESOLVED: no dedicated safety/interlock section in source.
Notes
- Command frame format: hex bytes. Host fills ID1 (control ID set on projector, 00h if unset) and ID2 (model code, varies by model). CKS = low-order byte of sum of all preceding bytes.
- Baud rate configurable: 115200 / 38400 / 19200 / 9600 / 4800 bps. Spec lists 115200 as the default-shown value; matching device setting required.
- Serial cable: cross cable, D-SUB 9P, PC CONTROL port. Pinout: 2=RxD, 3=TxD, 5=GND, 7=RTS, 8=CTS.
- LAN: wired RJ-45 (10/100 Mbps auto) or wireless LAN unit. TCP port 7142 for command send/receive.
- Response success for no-data commands:
2?h <ID1> <ID2> 00h <CKS>. For data commands, LEN and DATA appended. - Usage times update at one-minute intervals despite one-second resolution.
- Lamp remaining life (%) returns negative value if replacement deadline exceeded.
Spec output complete. 53 commands enumerated (sections 3.1–3.53), all hex payloads verbatim. Gaps marked UNRESOLVED: model code (ID2), flow_control, appendix value tables, firmware range.
## Provenance
```yaml
source_domains:
- sharpdisplays.eu
source_urls:
- https://www.sharpdisplays.eu/p/download/cp/Products/Projectors/Shared/CommandLists/NEC-ExternalControlManual-english.pdf
retrieved_at: 2026-06-16T11:38:19.556Z
last_checked_at: 2026-06-18T08:49:00.817Z
```
## Verification Summary
```yaml
verdict: verified
checked_at: 2026-06-18T08:49:00.817Z
matched_actions: 53
action_count: 53
confidence: medium
summary: "All 53 spec actions matched verbatim against source command reference; transport parameters verified; complete bidirectional coverage. (16 unresolved item(s) noted in Known Gaps.)"
```
## Known Gaps
```yaml
- "firmware version compatibility not stated in source"
- "model code (ID2) value for NP-P554U not stated in source"
- "flow_control not stated in source"
- "wireless LAN comm conditions not in this document"
- "Appendix \"Supplementary Information by Command\" (input terminal values, aspect values, base model type values, sub input values, eco mode values) not included in source text"
- "full response payload decoding for queries not exhaustively enumerated."
- "no separate variable model defined; settable state is action-driven per source."
- "no async/event mechanism described in source."
- "none documented."
- "no dedicated safety/interlock section in source."
- "ID2 model code value for NP-P554U not in source"
- "flow_control setting not stated"
- "Appendix \"Supplementary Information by Command\" (input terminal / aspect / base model type / sub input / eco mode value tables) not present in refined source"
- "firmware version compatibility range not stated"
- "wireless LAN comm conditions reference external operation manual"
- "model code (ID2), flow_control, appendix value tables, firmware range."
```
---
From the AI4AV catalog (https://ai4av.net) · ODbL-1.0