Jump to content

Виталик1705

Members
  • Content Count

    101
  • Joined

  • Last visited

Community Reputation

0 Обычный

About Виталик1705

  • Rank
    Осваивающийся

Информация

  • Пол
    Мужчина
  • Город
    Киев

Электроника

  • Стаж в электронике
    1-2 года

Recent Profile Visitors

The recent visitors block is disabled and is not being shown to other users.

  1. Она сегодня еще и протекать стала. Под машинкой лужа воды. Представители фирмы Zanussi, если вы это читаете, то подавитесь своей жлобской техникой.
  2. Ну как же сказочник? Вот например, у родителей стоит Самсунг. Так она как только начинает сильно болтаться, так сразу останавливается, еще минуту его распределяет, потом начинает отжимать и все нормально. Электроника не позволяет ей скакать как бешеной (как моя Zanussi, например).
  3. Вы вообще понимаете о чем я говорю? При чем здесь все это? Нормальные машины не продолжают отжимать, если белье не распределилось в достаточной степени. Они его болтают пока не распределится, а если нет, то выдают ошибку. А эта хрень фигачит на полных оборотах, даже если белье сбилось в комок. Лишь бы написать. По делу есть чё, блин??? Прошу прощения за мой франсузкий, но эти советы читай инструкцию наталкивают на нехорошие мысли по поводу этого форума.
  4. Транспортировочные болты снял. По уровню установил. Пол нормальный (плитка). Мастер, который приходил, сказал что установлена правильно.
  5. Всем привет. Купил недавно стиралку zanussi zws 7100 v. Все работает, всем доволен, но есть но. Для начала, опишу как я представляю нормальную работу любой машинки, а конкретно отжим. Вот такой алгоритм. 1. Машина постирала белье. 2. Начала отжимать. 3. Если белье нормально распределилось и нет сильной тряски, то переход к (4). Если нет, то переход на (3). 4. Повышаем обороты и полностью отжимаем. Что я получил, купив эту стиралку: Если белье не распределилось, то она все-равно по полной отжимает, скачет по всей комнате, ломает шланги, бьет вищи, ломает душевую кабину и вообще такое ощущение, как будто из нее изгоняют дьявола! Теперь я не могу ее оставлять без присмотра. Приходил мастер из сервис цента, заменил камень (зачем?), сказал что проблема в нем. Ничего не изменилось. Вызвал опять, они говорят сними на видео как прыгает и мы тебе заменим на такую же (опять с этой недоработкой, да?). Скачет она только когда белье плохо распределилось, и мне тяжело при каждом отжиме стоять с камерой и ждать. Я же ее купил что бы жизнь облегчить, а не затруднять ее. Или в программе ошибка, или там нет датчика, который реагирует на сильную тряску. Что посоветуете сделать? Сбросить с 5 этажа или с 9-го? Или может монтировкой ее того?) А если серьезно, что делать? Я думаю, эта проблема во всех аппаратах этой модели.
  6. Спасибо. Лучше сделать на одной ПП и усилитель и блок питания или БП лучше отдельно? Может ли в таком случае БП вносить ощутимые на слух искажения или помехи?
  7. Поставить ресторный делитель или увеличить глубину обратной связи? Не могу решить что лучше
  8. Всем добрый вечер. Подскажите пожалуйста, как ограничить выходную мощность усилителя на TDA2030? У меня уже есть купленные микросхемы, но мощность усилителя превысит мощность моей акустической системы. Как быть?
  9. Разобрался в программе. Вот код: #include <avr/pgmspace.h> #include <avr/io.h> #include <avr/sleep.h> #include <avr/interrupt.h> // таблица длительностей интервалов (в тиках) //const uint8_t intervals []__attribute__ ((progmem)) = const uint8_t intervals [] PROGMEM = { 0x01, 0x05, 0x04, 0x04, 0x05, 0x09, 0x04, 0x02, 0x09, 0x02, 0x02, 0x07, 0x02, 0x03, 0x03, 0x03, 0x03, 0x05, 0x05, 0x07, 0x04, 0x06, 0x07, 0x01, 0x02, 0x01, 0x05, 0x02, 0x03, 0x03, 0x0C, 0x04, 0x06, 0x02, 0x01, 0x0D, 0x02, 0x03, 0x04, 0x03, 0x01, 0x01, 0x06, 0x04, 0x06, 0x04, 0x02, 0x06, 0x02, 0x04, 0x06, 0x01, 0x07, 0x04, 0x02, 0x02, 0x01, 0x05, 0x03, 0x04 }; ISR (TIM0_COMPA_vect) // Прерывание по таймеру { static uint8_t polarity =0; static uint8_t tick_no =0; static uint8_t next_tick_no =0; static uint8_t interval_no =0; if (tick_no == next_tick_no) { if (polarity) { // положительный импульс PORTB |= (1 << 2)|(1 << 4); } else { // отрицательный импульс PORTB |= (1 << 0)|(1 << 1); } polarity ^= 0x01; if (interval_no < 59) { //next_tick_no += intervals[interval_no]; next_tick_no += pgm_read_byte(&intervals[interval_no]); interval_no++; } else { // началась новая минута next_tick_no = 0; interval_no = 0; } } if (tick_no < 239) { tick_no ++; } else { tick_no = 0; } } ISR (TIM0_COMPB_vect) // Второе прерывание, через 100 мс после первого { // отключаем двигатель PORTB &= ~((1 << 0)|(1 << 1)|(1 << 2)|(1 << 4)); } int main(void) __attribute__((noreturn)); int main(void) { DDRB |= (1 << 0)|(1 << 1)|(1 << 2)|(1 << 4); TCCR0A = (1 << WGM01); // режим работы таймера "сброс по совпадению" TCCR0B =(1 << CS02); // предделитель таймера 1/256 OCR0A = 0x1f; // Верхняя граница счета 1f // 32768 / 256 / 0x20 = 4 Hz - частота следования прерываний OCR0B = 0x0C; // примерно 100 мс от сброса счетчика до второго прерывания TIMSK0 = (1 << OCIE0A)|(1 << OCIE0B); // разрешить прерывания по таймеру set_sleep_mode (SLEEP_MODE_IDLE); sei (); // глобальное разрешение прерываний for (; sleep_enable (); // в спячку! }
  10. Интересно, этот сайт http://dxportal.ru/drugie-novosti-radiolyubitelya/23231-34neravnomerno34-iduschie-chasy-problema-s-kontrollerom.html имеет какое-либо отношение к сайту cxem.net? Там мой вопрос с этого форума, но я его задавал только на этом форуме.
  11. Расписал сегодня алгоритм обработчика прерывания на бумаге. Все нормально работает. Почему он может не выполнятся в контроллере и симуляторе?
  12. Еще я заметил что интервал между 1 и вторым прерыванием ровно 100 миллисекунд, как и полагается. Но первое прерывание возникает очень редко.
  13. Не знаю, но я компилировал в Code::Blocks и в AVR Studio, на выходе hex-файлы одинаковые. Это от компилятора зависит. Возможно в этом причина?
  14. Добрый день! Собрал часы по инструкции из статьи http://habrahabr.ru/post/130594/. К проекту прилагается только исходный код, поэтому откомпилировал в Code::Blocks, прошил с помощью USBasp. Но вот беда, часы идут очень медленно (приблизительно раз в 10 медленнее реального времени). Сначала думал кварц не тот, проверил в Протеусе - то же самое. Думаю ошибка в программе, но мои знания в AVR весьма поверхностны, что бы ее найти. Смотрю на код - вроде все нормально, а на деле - не работает. Помогите, кто чем может. Заранее спасибо. #include <avr/io.h> #include <avr/sleep.h> #include <avr/interrupt.h> // таблица длительностей интервалов (в тиках) const uint8_t intervals [] __attribute__ ((progmem)) = { 0x01, 0x05, 0x04, 0x04, 0x05, 0x09, 0x04, 0x02, 0x09, 0x02, 0x02, 0x07, 0x02, 0x03, 0x03, 0x03, 0x03, 0x05, 0x05, 0x07, 0x04, 0x06, 0x07, 0x01, 0x02, 0x01, 0x05, 0x02, 0x03, 0x03, 0x0C, 0x04, 0x06, 0x02, 0x01, 0x0D, 0x02, 0x03, 0x04, 0x03, 0x01, 0x01, 0x06, 0x04, 0x06, 0x04, 0x02, 0x06, 0x02, 0x04, 0x06, 0x01, 0x07, 0x04, 0x02, 0x02, 0x01, 0x05, 0x03, 0x04 }; ISR (TIM0_COMPA_vect) // Прерывание по таймеру { static uint8_t polarity =0; static uint8_t tick_no =0; static uint8_t next_tick_no =0; static uint8_t interval_no =0; if (tick_no == next_tick_no) { if (polarity) { // положительный импульс PORTB |= (1 << 2)|(1 << 4); } else { // отрицательный импульс PORTB |= (1 << 0)|(1 << 1); } polarity ^= 0x01; if (interval_no < 59) { next_tick_no += intervals [interval_no]; interval_no++; } else { // началась новая минута next_tick_no = 0; interval_no = 0; } } if (tick_no < 239) tick_no ++; else tick_no = 0; } ISR (TIM0_COMPB_vect) // Второе прерывание, через 100 мс после первого { // отключаем двигатель PORTB &= ~((1 << 0)|(1 << 1)|(1 << 2)|(1 << 4)); } void main(void) __attribute__((noreturn)); void main(void) { DDRB |= (1 << 0)|(1 << 1)|(1 << 2)|(1 << 4); TCCR0A = (1 << WGM01); // режим работы таймера "сброс по совпадению" TCCR0B = (1 << CS02); // предделитель таймера 1/256 OCR0A = 0x1F; // Верхняя граница счета // 32768 / 256 / 0x20 = 4 Hz - частота следования прерываний OCR0B = 0x0С; // примерно 100 мс от сброса счетчика до второго прерывания TIMSK0 = (1 << OCIE0A)|(1 << OCIE0B); // разрешить прерывания по таймеру set_sleep_mode (SLEEP_MODE_IDLE); sei (); // глобальное разрешение прерываний for (; sleep_enable (); // в спячку! }
×
×
  • Create New...