Estoy haciendo mi propia etiqueta láser y estaba revisando las soluciones de código abierto existentes.
El protocolo MilesTag utiliza 600us como longitud de pulso básica. Sin embargo, esto limita las rondas máximas por minuto a menos de 2000 RPM, mientras que las ametralladoras alcanzan las 6000 RPM (100 rondas por segundo). ¿Hay alguna razón que desconozco para el pulso de 600us?
¿Mi propia solución será menos confiable si elijo, digamos, pulsos de 300us? Más bajo no funcionará con el receptor IR con el que estoy trabajando, porque necesita al menos 10 ciclos en una ráfaga con una frecuencia de modulación de 40kHz, pero un pulso de 300us me permitiría duplicar mis RPM.
Lo siguiente se menciona en la página del protocolo de datos de MilesTag (la versión original del protocolo) que también usa el mismo tiempo:
El paquete de datos MilesTag consta de un pulso de encabezado seguido de 16 bits de datos (dos bytes de datos de 8 bits) y 1 bit de paridad. El pulso de encabezado y los bits de datos se codifican en una señal portadora infrarroja de 40 kHz usando modulación de longitud de pulso. Esta modulación es idéntica al formato utilizado en los controles remotos IR de Sony y otros.
Así que sospecho que la decisión de diseño original fue elegir un método de codificación de bajo nivel conocido por ser compatible con una amplia gama de receptores IR. Parece que ha determinado que el receptor que está utilizando puede demodular una señal en diez ciclos, por lo que no veo una razón, en principio, la velocidad de datos más alta no funcionará, pero podría aplicarse lo siguiente:
Puede ser una de esas cosas que tienes que probar y ver qué diferencia hace en la práctica. Si fuera yo, para empezar, escribiría un código para que la duración del pulso del transmisor pudiera cambiarse fácilmente usando unos pocos botones y una pantalla LCD, y en el extremo del receptor haría lo mismo. Luego, también podría usar la pantalla LCD para mostrar la cantidad de paquetes recibidos durante un período de tiempo conocido para determinar el porcentaje de pérdida de paquetes a varias velocidades de datos y en diferentes condiciones.
Otra idea algo "fuera de la caja" es que si está codificando su propio protocolo, entonces podría agregar un número de secuencia móvil al paquete. Si recibió dos paquetes con números de secuencia consecutivos, podría suponer cuando estaba en modo "minigun" que representaba, digamos, tres hits. Por supuesto, dependiendo de la longitud del número de secuencia, tendría una cierta probabilidad de acertar el siguiente número de secuencia por casualidad en un punto posterior en lugar de que sea un acierto consecutivo.
KL
Andy alias
JSON
JSON
tomas krejci