Библиотека Tone() вопрос.
- Войдите на сайт для отправки комментариев
Ср, 22/07/2015 - 11:15
Друзья, есть такая библиотека по работе за звуком " Tone.h + Tone.ccp "
Оная выводит сигнал на Одну назначенную ножку Arduino
Кто разбирается в библиотеках , подскажите
Как добавить еще одну ножку которая выдавала ИНВЕРСНЫЙ сигнал , назначенному выводу
т.е плучить с библиотеки ДВА взаимно инверсных сигнала
плата Arduino PRO MINI
Как прикрепить файл библиотеки не нашел , вынужден прикрепить код 2х файлов...
Tone.h
/* $Id: Tone.h 113 2010-06-16 20:16:29Z bhagman@roguerobotics.com $ A Tone Generator Library Written by Brett Hagman http://www.roguerobotics.com/ bhagman@roguerobotics.com This library is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version. This library is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with this program. If not, see <http://www.gnu.org/licenses/>. *************************************************/ #ifndef _Tone_h #define _Tone_h #include <stdint.h> /************************************************* * Public Constants *************************************************/ #define NOTE_B0 31 #define NOTE_C1 33 #define NOTE_CS1 35 #define NOTE_D1 37 #define NOTE_DS1 39 #define NOTE_E1 41 #define NOTE_F1 44 #define NOTE_FS1 46 #define NOTE_G1 49 #define NOTE_GS1 52 #define NOTE_A1 55 #define NOTE_AS1 58 #define NOTE_B1 62 #define NOTE_C2 65 #define NOTE_CS2 69 #define NOTE_D2 73 #define NOTE_DS2 78 #define NOTE_E2 82 #define NOTE_F2 87 #define NOTE_FS2 93 #define NOTE_G2 98 #define NOTE_GS2 104 #define NOTE_A2 110 #define NOTE_AS2 117 #define NOTE_B2 123 #define NOTE_C3 131 #define NOTE_CS3 139 #define NOTE_D3 147 #define NOTE_DS3 156 #define NOTE_E3 165 #define NOTE_F3 175 #define NOTE_FS3 185 #define NOTE_G3 196 #define NOTE_GS3 208 #define NOTE_A3 220 #define NOTE_AS3 233 #define NOTE_B3 247 #define NOTE_C4 262 #define NOTE_CS4 277 #define NOTE_D4 294 #define NOTE_DS4 311 #define NOTE_E4 330 #define NOTE_F4 349 #define NOTE_FS4 370 #define NOTE_G4 392 #define NOTE_GS4 415 #define NOTE_A4 440 #define NOTE_AS4 466 #define NOTE_B4 494 #define NOTE_C5 523 #define NOTE_CS5 554 #define NOTE_D5 587 #define NOTE_DS5 622 #define NOTE_E5 659 #define NOTE_F5 698 #define NOTE_FS5 740 #define NOTE_G5 784 #define NOTE_GS5 831 #define NOTE_A5 880 #define NOTE_AS5 932 #define NOTE_B5 988 #define NOTE_C6 1047 #define NOTE_CS6 1109 #define NOTE_D6 1175 #define NOTE_DS6 1245 #define NOTE_E6 1319 #define NOTE_F6 1397 #define NOTE_FS6 1480 #define NOTE_G6 1568 #define NOTE_GS6 1661 #define NOTE_A6 1760 #define NOTE_AS6 1865 #define NOTE_B6 1976 #define NOTE_C7 2093 #define NOTE_CS7 2217 #define NOTE_D7 2349 #define NOTE_DS7 2489 #define NOTE_E7 2637 #define NOTE_F7 2794 #define NOTE_FS7 2960 #define NOTE_G7 3136 #define NOTE_GS7 3322 #define NOTE_A7 3520 #define NOTE_AS7 3729 #define NOTE_B7 3951 #define NOTE_C8 4186 #define NOTE_CS8 4435 #define NOTE_D8 4699 #define NOTE_DS8 4978 /************************************************* * Definitions *************************************************/ class Tone { public: void begin(uint8_t tonePin); bool isPlaying(); void play(uint16_t frequency, uint32_t duration = 0); void stop(); private: static uint8_t _tone_pin_count; uint8_t _pin; int8_t _timer; }; #endif
//==================================================================================
Tone.ccp
/* $Id: Tone.cpp 119 2010-07-17 18:56:36Z bhagman@roguerobotics.com $ A Tone Generator Library Written by Brett Hagman http://www.roguerobotics.com/ bhagman@roguerobotics.com This library is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version. This library is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with this program. If not, see <http://www.gnu.org/licenses/>. *************************************************/ #include <avr/interrupt.h> #include <avr/pgmspace.h> #include <Arduino.h> #include "Tone.h" #if defined(__AVR_ATmega8__) #define TCCR2A TCCR2 #define TCCR2B TCCR2 #define COM2A1 COM21 #define COM2A0 COM20 #define OCR2A OCR2 #define TIMSK2 TIMSK #define OCIE2A OCIE2 #define TIMER2_COMPA_vect TIMER2_COMP_vect #define TIMSK1 TIMSK #endif // timerx_toggle_count: // > 0 - duration specified // = 0 - stopped // < 0 - infinitely (until stop() method called, or new play() called) #if !defined(__AVR_ATmega8__) volatile int32_t timer0_toggle_count; volatile uint8_t *timer0_pin_port; volatile uint8_t timer0_pin_mask; #endif volatile int32_t timer1_toggle_count; volatile uint8_t *timer1_pin_port; volatile uint8_t timer1_pin_mask; volatile int32_t timer2_toggle_count; volatile uint8_t *timer2_pin_port; volatile uint8_t timer2_pin_mask; #if defined(__AVR_ATmega1280__) volatile int32_t timer3_toggle_count; volatile uint8_t *timer3_pin_port; volatile uint8_t timer3_pin_mask; volatile int32_t timer4_toggle_count; volatile uint8_t *timer4_pin_port; volatile uint8_t timer4_pin_mask; volatile int32_t timer5_toggle_count; volatile uint8_t *timer5_pin_port; volatile uint8_t timer5_pin_mask; #endif #if defined(__AVR_ATmega1280__) #define AVAILABLE_TONE_PINS 6 // Leave timers 1, and zero to last. const uint8_t PROGMEM tone_pin_to_timer_PGM[] = { 2, 3, 4, 5, 1, 0 }; #elif defined(__AVR_ATmega8__) #define AVAILABLE_TONE_PINS 2 const uint8_t PROGMEM tone_pin_to_timer_PGM[] = { 2, 1 }; #else #define AVAILABLE_TONE_PINS 3 // Leave timer 0 to last. const uint8_t PROGMEM tone_pin_to_timer_PGM[] = { 2, 1, 0 }; #endif // Initialize our pin count uint8_t Tone::_tone_pin_count = 0; void Tone::begin(uint8_t tonePin) { if (_tone_pin_count < AVAILABLE_TONE_PINS) { _pin = tonePin; _timer = pgm_read_byte(tone_pin_to_timer_PGM + _tone_pin_count); _tone_pin_count++; // Set timer specific stuff // All timers in CTC mode // 8 bit timers will require changing prescalar values, // whereas 16 bit timers are set to either ck/1 or ck/64 prescalar switch (_timer) { #if !defined(__AVR_ATmega8__) case 0: // 8 bit timer TCCR0A = 0; TCCR0B = 0; bitWrite(TCCR0A, WGM01, 1); bitWrite(TCCR0B, CS00, 1); timer0_pin_port = portOutputRegister(digitalPinToPort(_pin)); timer0_pin_mask = digitalPinToBitMask(_pin); break; #endif case 1: // 16 bit timer TCCR1A = 0; TCCR1B = 0; bitWrite(TCCR1B, WGM12, 1); bitWrite(TCCR1B, CS10, 1); timer1_pin_port = portOutputRegister(digitalPinToPort(_pin)); timer1_pin_mask = digitalPinToBitMask(_pin); break; case 2: // 8 bit timer TCCR2A = 0; TCCR2B = 0; bitWrite(TCCR2A, WGM21, 1); bitWrite(TCCR2B, CS20, 1); timer2_pin_port = portOutputRegister(digitalPinToPort(_pin)); timer2_pin_mask = digitalPinToBitMask(_pin); break; #if defined(__AVR_ATmega1280__) case 3: // 16 bit timer TCCR3A = 0; TCCR3B = 0; bitWrite(TCCR3B, WGM32, 1); bitWrite(TCCR3B, CS30, 1); timer3_pin_port = portOutputRegister(digitalPinToPort(_pin)); timer3_pin_mask = digitalPinToBitMask(_pin); break; case 4: // 16 bit timer TCCR4A = 0; TCCR4B = 0; bitWrite(TCCR4B, WGM42, 1); bitWrite(TCCR4B, CS40, 1); timer4_pin_port = portOutputRegister(digitalPinToPort(_pin)); timer4_pin_mask = digitalPinToBitMask(_pin); break; case 5: // 16 bit timer TCCR5A = 0; TCCR5B = 0; bitWrite(TCCR5B, WGM52, 1); bitWrite(TCCR5B, CS50, 1); timer5_pin_port = portOutputRegister(digitalPinToPort(_pin)); timer5_pin_mask = digitalPinToBitMask(_pin); break; #endif } } else { // disabled _timer = -1; } } // frequency (in hertz) and duration (in milliseconds). void Tone::play(uint16_t frequency, uint32_t duration) { uint8_t prescalarbits = 0b001; int32_t toggle_count = 0; uint32_t ocr = 0; if (_timer >= 0) { // Set the pinMode as OUTPUT pinMode(_pin, OUTPUT); // if we are using an 8 bit timer, scan through prescalars to find the best fit if (_timer == 0 || _timer == 2) { ocr = F_CPU / frequency / 2 - 1; prescalarbits = 0b001; // ck/1: same for both timers if (ocr > 255) { ocr = F_CPU / frequency / 2 / 8 - 1; prescalarbits = 0b010; // ck/8: same for both timers if (_timer == 2 && ocr > 255) { ocr = F_CPU / frequency / 2 / 32 - 1; prescalarbits = 0b011; } if (ocr > 255) { ocr = F_CPU / frequency / 2 / 64 - 1; prescalarbits = _timer == 0 ? 0b011 : 0b100; if (_timer == 2 && ocr > 255) { ocr = F_CPU / frequency / 2 / 128 - 1; prescalarbits = 0b101; } if (ocr > 255) { ocr = F_CPU / frequency / 2 / 256 - 1; prescalarbits = _timer == 0 ? 0b100 : 0b110; if (ocr > 255) { // can't do any better than /1024 ocr = F_CPU / frequency / 2 / 1024 - 1; prescalarbits = _timer == 0 ? 0b101 : 0b111; } } } } #if !defined(__AVR_ATmega8__) if (_timer == 0) TCCR0B = (TCCR0B & 0b11111000) | prescalarbits; else #endif TCCR2B = (TCCR2B & 0b11111000) | prescalarbits; } else { // two choices for the 16 bit timers: ck/1 or ck/64 ocr = F_CPU / frequency / 2 - 1; prescalarbits = 0b001; if (ocr > 0xffff) { ocr = F_CPU / frequency / 2 / 64 - 1; prescalarbits = 0b011; } if (_timer == 1) TCCR1B = (TCCR1B & 0b11111000) | prescalarbits; #if defined(__AVR_ATmega1280__) else if (_timer == 3) TCCR3B = (TCCR3B & 0b11111000) | prescalarbits; else if (_timer == 4) TCCR4B = (TCCR4B & 0b11111000) | prescalarbits; else if (_timer == 5) TCCR5B = (TCCR5B & 0b11111000) | prescalarbits; #endif } // Calculate the toggle count if (duration > 0) { toggle_count = 2 * frequency * duration / 1000; } else { toggle_count = -1; } // Set the OCR for the given timer, // set the toggle count, // then turn on the interrupts switch (_timer) { #if !defined(__AVR_ATmega8__) case 0: OCR0A = ocr; timer0_toggle_count = toggle_count; bitWrite(TIMSK0, OCIE0A, 1); break; #endif case 1: OCR1A = ocr; timer1_toggle_count = toggle_count; bitWrite(TIMSK1, OCIE1A, 1); break; case 2: OCR2A = ocr; timer2_toggle_count = toggle_count; bitWrite(TIMSK2, OCIE2A, 1); break; #if defined(__AVR_ATmega1280__) case 3: OCR3A = ocr; timer3_toggle_count = toggle_count; bitWrite(TIMSK3, OCIE3A, 1); break; case 4: OCR4A = ocr; timer4_toggle_count = toggle_count; bitWrite(TIMSK4, OCIE4A, 1); break; case 5: OCR5A = ocr; timer5_toggle_count = toggle_count; bitWrite(TIMSK5, OCIE5A, 1); break; #endif } } } void Tone::stop() { switch (_timer) { #if !defined(__AVR_ATmega8__) case 0: TIMSK0 &= ~(1 << OCIE0A); break; #endif case 1: TIMSK1 &= ~(1 << OCIE1A); break; case 2: TIMSK2 &= ~(1 << OCIE2A); break; #if defined(__AVR_ATmega1280__) case 3: TIMSK3 &= ~(1 << OCIE3A); break; case 4: TIMSK4 &= ~(1 << OCIE4A); break; case 5: TIMSK5 &= ~(1 << OCIE5A); break; #endif } digitalWrite(_pin, 0); } bool Tone::isPlaying(void) { bool returnvalue = false; switch (_timer) { #if !defined(__AVR_ATmega8__) case 0: returnvalue = (TIMSK0 & (1 << OCIE0A)); break; #endif case 1: returnvalue = (TIMSK1 & (1 << OCIE1A)); break; case 2: returnvalue = (TIMSK2 & (1 << OCIE2A)); break; #if defined(__AVR_ATmega1280__) case 3: returnvalue = (TIMSK3 & (1 << OCIE3A)); break; case 4: returnvalue = (TIMSK4 & (1 << OCIE4A)); break; case 5: returnvalue = (TIMSK5 & (1 << OCIE5A)); break; #endif } return returnvalue; } #if !defined(__AVR_ATmega8__) ISR(TIMER0_COMPA_vect) { if (timer0_toggle_count != 0) { // toggle the pin *timer0_pin_port ^= timer0_pin_mask; if (timer0_toggle_count > 0) timer0_toggle_count--; } else { TIMSK0 &= ~(1 << OCIE0A); // disable the interrupt *timer0_pin_port &= ~(timer0_pin_mask); // keep pin low after stop } } #endif ISR(TIMER1_COMPA_vect) { if (timer1_toggle_count != 0) { // toggle the pin *timer1_pin_port ^= timer1_pin_mask; if (timer1_toggle_count > 0) timer1_toggle_count--; } else { TIMSK1 &= ~(1 << OCIE1A); // disable the interrupt *timer1_pin_port &= ~(timer1_pin_mask); // keep pin low after stop } } ISR(TIMER2_COMPA_vect) { int32_t temp_toggle_count = timer2_toggle_count; if (temp_toggle_count != 0) { // toggle the pin *timer2_pin_port ^= timer2_pin_mask; if (temp_toggle_count > 0) temp_toggle_count--; } else { TIMSK2 &= ~(1 << OCIE2A); // disable the interrupt *timer2_pin_port &= ~(timer2_pin_mask); // keep pin low after stop } timer2_toggle_count = temp_toggle_count; } #if defined(__AVR_ATmega1280__) ISR(TIMER3_COMPA_vect) { if (timer3_toggle_count != 0) { // toggle the pin *timer3_pin_port ^= timer3_pin_mask; if (timer3_toggle_count > 0) timer3_toggle_count--; } else { TIMSK3 &= ~(1 << OCIE3A); // disable the interrupt *timer3_pin_port &= ~(timer3_pin_mask); // keep pin low after stop } } ISR(TIMER4_COMPA_vect) { if (timer4_toggle_count != 0) { // toggle the pin *timer4_pin_port ^= timer4_pin_mask; if (timer4_toggle_count > 0) timer4_toggle_count--; } else { TIMSK4 &= ~(1 << OCIE4A); // disable the interrupt *timer4_pin_port &= ~(timer4_pin_mask); // keep pin low after stop } } ISR(TIMER5_COMPA_vect) { if (timer5_toggle_count != 0) { // toggle the pin *timer5_pin_port ^= timer5_pin_mask; if (timer5_toggle_count > 0) timer5_toggle_count--; } else { TIMSK5 &= ~(1 << OCIE5A); // disable the interrupt *timer5_pin_port &= ~(timer5_pin_mask); // keep pin low after stop } } #endif
Добавлю , Это нужно для того , чтобы на излучателе, подключенному к этим выводам, получить Удвоенный сигнал (Более сильный звук -фактически создать усилитель класса "D") и Еще, по окончании работы по выводу звука ,
"Пример: speaker1.play(tone, beep_period); вывод звука тональностью-tone , длительностью -beep_period "
обе ножки Arduino устанавливались в одно и тоже состояние "0" или "1"
какой еще "Удвоенный сигнал"?
ардуина питается же от однополярного источника питания, мах амплитуда сигнала будет 5В
wallera, знаете что нибудь о сложении фаз ? Если включить динамик к точно противофазным сигналам получите 0. Хотите громче -используйте транзистор.
ну, да - ТС попутал пороговые значения сигналов INPUT и параметры OUTPUT.
если параметры входных сигналов могут иметь некие параметры, отличные от 0 вольт и напряжения питания, то на выходе - всё честно: 0 и напряжение питания.
как ни комбинируй 0 и 1 - получим или 0 или 1, 1+1 или 0-1 - никак не получается.
Я надеюсь вы не подключаете динамик напрямую к выходу ардуины? Тем более мощный динамик:) Хотя если вам еще пиротехнические эффекты нужны...
Я надеюсь вы не подключаете динамик напрямую к выходу ардуины? Тем более мощный динамик:) Хотя если вам еще пиротехнические эффекты нужны...
P= U * I ;)
Динамики бывают не только мощьными но и высоковольтными ( например пьезо)
требуюшие высокого напряжения при достаточно низком токе.....
Динамики бывают не только мощьными но и высоковольтными ( например пьезо)
требуюшие высокого напряжения при достаточно низком токе.....
для этих нужно писать библиотеку, складывающую амплитуды всех доступных пинов.
а я вот такой использую с макеткой. Удобно, что подключается напрямую, без доп. согласований.
Очень громкий, сочный, тёплый ламповый звук :)
SD150 - динамический капсюль
один я как лох пьезоизлучателем со стиралки комаров и собак гоняю
Во первых я спрашивал про библиотеку, а не про динамик , и как его подключать
Второе: вот по схеме ниже я так подключу динамик, A , B-выходы ардуины, +U -питание arduino
V -это напряжение на динамике, подключите к точкам o1 и о2 осциллоскоп , и все встанет на свои места...
ЭТА СХЕМА ПРОВЕРЕНА И РАБОТАЕТ!
Пожалуйста про динамикм НЕ ПИШИТЕ! Пишите о Библиотеке!
Во первых я спрашивал про библиотеку, а не про динамик , и как его подключать
Второе: вот по схеме ниже я так подключу динамик, A , B-выходы ардуины, +U -питание arduino
V -это напряжение на динамике, подключите к точкам o1 и о2 осциллоскоп , и все встанет на свои места...
ЭТА СХЕМА ПРОВЕРЕНА И РАБОТАЕТ!
ок. подключи мультиметр или осциллограф и покажи нам, что у тебя напряжение V=10 вольт.
я же тебе теоретически обосновал невозможность удвоения напряжения.
по этой схеме ты просаживаешь напряжение на динамике последовательным резистором и просадку компенсируешь раскачкой динамика в противоположную сторону - смысл?
подключай один пин к усилителю звуковой частоты и качай напряжение, сколько пожелаешь.
библиотека http://playground.arduino.cc/Code/ToneAC
мультиметр покажет от-5 до +5 вольт
нет - покажет от 0 до 5 вольт.
So in effect, the speaker is getting 5 volts instead of 2.5, making it nearly twice as loud.
wallera, в ардуино есть встроенная библа tone, и подгружаемая внешняя. Речь про подгружаемую? Впрочем разницы нет, у них один автор и один принцип . Но я копался в своё время именно во встроенной. По умолчанию она использует таймер2 на уноподобных платах. Можно грязно влезть в библу и вставить свою команду. Предположим tone() настроен на 9 пин. А инверсный сигнал предположим нужно снять с 6 го пина, тогда в tone.cpp в 446 строке нужно вставить выражение: PINB&B00000010? PORTD|= (1<<6) : PORTD&=~(1<<6) ; тут читается состояние 9 пина, и записывается инверсно в 6 пин.
Что б оба выхода закончили на лог.0 нужно после 453 строки вставить: PORTD&=~(1<<6)
@2 toc - огромное спасибо, то что нужно!
2 dimax да речь про подгружаемую, спасибо за совет буду пробовать...вы првильно заметили грязно влезть- что я и хотел
Клапауций 999, при данной схеме включения действительно сигналы как-то по хитрому складываются, и реально Vpp будет 10 вольт, но не так просто извлечь из неё ток, придётся коллекторные резисторы уменьшать до минимально допустимого. Посмотрим что ТС напишет после экспериментов, стало ли громче)
Или как вариант поставить высокоомный динамик , главное условие , чтобы сопротивление резисторов было значительно меньше сопротивления динамика , или еще как вариант заменить плечо транзистор - коллекторный резистор ,на : пару p-n-p (вместо резика) n-p-n, ну и соответствующую объвязку
PS я пробовал так подключил пьезик межде 3 и 4 ногой и запустил тестовый скетч ,громкость прибавлялась,осцилл подключенный параллельно показывал полный размах +- U питания(или оч близко к этому)
вопрос из задних рядов
А на кой это нужно? если за 1 бакс можно взять чип усилителя и к нему на 20 центов горсть обвязки.
вопрос из задних рядов
А на кой это нужно? если за 1 бакс можно взять чип усилителя и к нему на 20 центов горсть обвязки.
Эй Вы, на галерке! А ну ка посоветуйте какой чип усилитель и какую объвязку - условие , чтоб эта вся штука поместилась на площади 5х5 мм
Эй Вы, на галерке! А ну ка посоветуйте какой чип усилитель и какую объвязку - условие , чтоб эта вся штука поместилась на площади 5х5 мм
ну например TS2012 И обвязку к нему размером 0402 еще даже место останеться, там обвязка пару кондеров :)
wallera, я не утерпел, сейчас попробывал свой вариант "с грязным влезанием" во встроенный tone.cpp. На прямую на спикер , без транзисторов (у меня динамик на 150 ом, ему так можно) , напрямую меж двумя выходами дуни - громкость существенно выше, чем относительно общего :)
Клапауций 999, при данной схеме включения действительно сигналы как-то по хитрому складываются, и реально Vpp будет 10 вольт, но не так просто извлечь из неё ток, придётся коллекторные резисторы уменьшать до минимально допустимого. Посмотрим что ТС напишет после экспериментов, стало ли громче)
набираю в секту Свидетелей Умножителей Напряжения.
wallera, я не утерпел, сейчас попробывал свой вариант "с грязным влезанием" во встроенный tone.cpp. На прямую на спикер , без транзисторов (у меня динамик на 150 ом, ему так можно) , напрямую меж двумя выходами дуни - громкость существенно выше, чем относительно общего :)
правильно - если без уродской схемы, то
So in effect, the speaker is getting 5 volts instead of 2.5, making it nearly twice as loud.
вопрос из задних рядов
А на кой это нужно? если за 1 бакс можно взять чип усилителя и к нему на 20 центов горсть обвязки.
нефиг тут русофобию из Канады разводить - тут импортозамещение, береста и матрёшки.
нефиг тут русофобию из Канады разводить - тут импортозамещение, береста и матрёшки.
балалайка и гусли заместо tone?
нефиг тут русофобию из Канады разводить - тут импортозамещение, береста и матрёшки.
балалайка и гусли заместо tone?
скрэпы!
скрэпы!
скрипы. нужно смазывать что бы не скрипело.
скрипы. нужно смазывать что бы не скрипело.
давно ты Родину покинул, пердатель.
http://www.wikireality.ru/wiki/%D0%94%D1%83%D1%85%D0%BE%D0%B2%D0%BD%D1%8...
Еще раз спасибо dimax . Парни хорош флудить!
Еще раз спасибо dimax . Парни хорош флудить!
ну так ты ж получил че хотел? ну все. проходи дальше!
Dimax ,хочу уточнить, а Вы встроенную библиотечку перпилили, выложите сюда код , пожалуйста!
Перепилом это сложно назвать.. :) Они могут быть разные, найдите в своём tone.cpp блок, вставьте подсвеченную строку:
Проверочный скетч был таким:
Вообще-то это называется не усилителем класса D, а усилителем, выполненным по мостовой схеме. Применяется, когда требуется обойтись низким напряжением питания усилителя, не удовлетворяющем соотношению U^2 > 8*W*R. Позволяет увеличить мощность при том же напряжении питания до 4 раз, т.е. на 6 дБ.
А усилительт класса D - это по сути усилитель с ШИМ.
Давеча был на мероприятии. Как водится, не обошлось без пропаганды. В хорошем смысле. Продекламировали Пушкина А.С.
http://feb-web.ru/feb/pushkin/texts/push17/vol03/y03-269-.htm
Актуально однако.
это все у вас в голове :) кто то там кому то грозит и шумит.. да всем давно начхать...
имхо.. но российская пропаганда напоминает крики старой девственицы на которую никто внимание не обращает... а ей так хочется..
и не говори - такую страну Хуйлу позволили просрать, кретины.
Вообще-то это называется не усилителем класса D, а усилителем, выполненным по мостовой схеме. Применяется, когда требуется обойтись низким напряжением питания усилителя, не удовлетворяющем соотношению U^2 > 8*W*R. Позволяет увеличить мощность при том же напряжении питания до 4 раз, т.е. на 6 дБ.
А усилительт класса D - это по сути усилитель с ШИМ.
Какая там пропаганда, сплошная коммерция.
это все у вас в голове...
Вот это - точно.
2 dimax чавойто вот этот код , то что Вы пhедлагали вставить не пошел у меня , не на встроенной не на внешне подключенной библиотеке
PINB&B00000010? PORTD|= (1<<6) : PORTD&=~(1<<6) ;
правда я его модифицировал для своих ног арду
PIND&B00010000? PORTD|= (1<<3) : PORTD&=~(1<<3);
c 4го пина арду считываю , на 3 пин посылаю инверсию
эту всю батву ко второму тамеру соотношу, ну куда Вы указали
не работает...(плата Arduino Pro Mini)
wallera, странно у меня же шёл.. ну попробуйте иначе, вот так: if (PIND&(1<<4)) PORTD|= (1<<3); else PORTD&=~(1<<3);
Ещё не мешало бы проверить, во второй ли таймер пищит ваш tone, сделайте такой скетчик:
Первые два регистра должны вывести нулевыми.
Пытался генерировать DTMF из библиотеки Tone -выдает ошибку Arduino\libraries\Tone\Tone.cpp:26:20: fatal error: wiring.h: No such file or directory
#include <wiring.h>
ок. подключи мультиметр или осциллограф и покажи нам, что у тебя напряжение V=10 вольт.
я же тебе теоретически обосновал невозможность удвоения напряжения.
по этой схеме ты просаживаешь напряжение на динамике последовательным резистором и просадку компенсируешь раскачкой динамика в противоположную сторону - смысл?
подключай один пин к усилителю звуковой частоты и качай напряжение, сколько пожелаешь.
Выход пин 4 и пин 5
http://arduino.ru/forum/programmirovanie/arduino-push-pull
Выход пин 4 и пин 5
http://arduino.ru/forum/programmirovanie/arduino-push-pull
ок - подскажи мне: цена деления электронного осциллографа(-2, -1, 0, 1, 2) сколько вольт?
Пожалуйста про динамикм НЕ ПИШИТЕ! Пишите о Библиотеке!
Когда-то в инете наткнулся на схему подключения пьезоизлучателя. Говорят, что в 2 раза громче пищит. Сам не пробовал. Может кому-то интересно будет. Требуется лишь 1 выход и 1 транзистор.
Слева - это типа ардуины, лень было нормально нарисовать.
Выход пин 4 и пин 5
http://arduino.ru/forum/programmirovanie/arduino-push-pull
ок - подскажи мне: цена деления электронного осциллографа(-2, -1, 0, 1, 2) сколько вольт?
Электронного не скажу т.к. использовал от безисходности звуковую карту и смотрел только форму сигнала при настройке.
ЭЛ осцилограф - 5 Вольт (на клетку), размах получается 10 Вольт... там в теме много фото и вся история скетча...
скетч рабочий я его использовал для запуска пуш-пула... https://www.youtube.com/watch?v=rQ368CWKoCU
ЭЛ осцилограф - 5 Вольт (на клетку), размах получается 10 Вольт... там в теме много фото и вся история скетча...
не занимайся самобманом - ты получил честные 5v напряжения питания схемы.
то, что ты называешь размахом, есть переполюсовка питания звукового излучателя.
ЭЛ осцилограф - 5 Вольт (на клетку), размах получается 10 Вольт... там в теме много фото и вся история скетча...
не занимайся самобманом - ты получил честные 5v напряжения питания схемы.
то, что ты называешь размахом, есть переполюсовка питания звукового излучателя.
Амплитуда волны именно десять Вольт... Но насчет переполюсовки та конечно прав !
В скетче, образно говоря, два выходных пина постоянно инвертируются поэтому и получаем две полуволны по 5 Вольт, а общая амплитуда 10 Вольт. Если мерять напряжение отдельно на каждом пине относительно GND то естественно там будет 5 Вольт (сдвинутые по фазе).
Амплитуда волны именно десять Вольт.
а, в этом моменте нужно внимательно разобраться - т.к. у тебя на аналоговом осциллографе напряжение перед переходом в + или - равно 0, т.е. отсутвует одномоментный переход из +5 в -5 вольт.